{
  "version": 3,
  "sources": ["../../dayjs/dayjs.min.js", "../../dayjs/plugin/customParseFormat.js", "../../dayjs/plugin/localeData.js", "../../dayjs/plugin/advancedFormat.js", "../../dayjs/plugin/weekOfYear.js", "../../dayjs/plugin/weekYear.js", "../../dayjs/plugin/dayOfYear.js", "../../dayjs/plugin/isSameOrAfter.js", "../../dayjs/plugin/isSameOrBefore.js", "../../../packages/utils/dom/aria.ts", "../../../packages/utils/dom/event.ts", "../../@vueuse/shared/index.mjs", "../../@vueuse/core/node_modules/vue-demi/lib/index.mjs", "../../@vueuse/core/index.mjs", "../../../packages/utils/browser.ts", "../../../packages/utils/dom/position.ts", "../../../packages/utils/easings.ts", "../../lodash-es/_freeGlobal.js", "../../lodash-es/_root.js", "../../lodash-es/_Symbol.js", "../../lodash-es/_getRawTag.js", "../../lodash-es/_objectToString.js", "../../lodash-es/_baseGetTag.js", "../../lodash-es/isObjectLike.js", "../../lodash-es/isSymbol.js", "../../lodash-es/_baseToNumber.js", "../../lodash-es/_arrayMap.js", "../../lodash-es/isArray.js", "../../lodash-es/_baseToString.js", "../../lodash-es/_createMathOperation.js", "../../lodash-es/add.js", "../../lodash-es/_trimmedEndIndex.js", "../../lodash-es/_baseTrim.js", "../../lodash-es/isObject.js", "../../lodash-es/toNumber.js", "../../lodash-es/toFinite.js", "../../lodash-es/toInteger.js", "../../lodash-es/after.js", "../../lodash-es/identity.js", "../../lodash-es/isFunction.js", "../../lodash-es/_coreJsData.js", "../../lodash-es/_isMasked.js", "../../lodash-es/_toSource.js", "../../lodash-es/_baseIsNative.js", "../../lodash-es/_getValue.js", "../../lodash-es/_getNative.js", "../../lodash-es/_WeakMap.js", "../../lodash-es/_metaMap.js", "../../lodash-es/_baseSetData.js", "../../lodash-es/_baseCreate.js", "../../lodash-es/_createCtor.js", "../../lodash-es/_createBind.js", "../../lodash-es/_apply.js", "../../lodash-es/_composeArgs.js", "../../lodash-es/_composeArgsRight.js", "../../lodash-es/_countHolders.js", "../../lodash-es/_baseLodash.js", "../../lodash-es/_LazyWrapper.js", "../../lodash-es/noop.js", "../../lodash-es/_getData.js", "../../lodash-es/_realNames.js", "../../lodash-es/_getFuncName.js", "../../lodash-es/_LodashWrapper.js", "../../lodash-es/_copyArray.js", "../../lodash-es/_wrapperClone.js", "../../lodash-es/wrapperLodash.js", "../../lodash-es/_isLaziable.js", "../../lodash-es/_shortOut.js", "../../lodash-es/_setData.js", "../../lodash-es/_getWrapDetails.js", "../../lodash-es/_insertWrapDetails.js", "../../lodash-es/constant.js", "../../lodash-es/_defineProperty.js", "../../lodash-es/_baseSetToString.js", "../../lodash-es/_setToString.js", "../../lodash-es/_arrayEach.js", "../../lodash-es/_baseFindIndex.js", "../../lodash-es/_baseIsNaN.js", "../../lodash-es/_strictIndexOf.js", "../../lodash-es/_baseIndexOf.js", "../../lodash-es/_arrayIncludes.js", "../../lodash-es/_updateWrapDetails.js", "../../lodash-es/_setWrapToString.js", "../../lodash-es/_createRecurry.js", "../../lodash-es/_getHolder.js", "../../lodash-es/_isIndex.js", "../../lodash-es/_reorder.js", "../../lodash-es/_replaceHolders.js", "../../lodash-es/_createHybrid.js", "../../lodash-es/_createCurry.js", "../../lodash-es/_createPartial.js", "../../lodash-es/_mergeData.js", "../../lodash-es/_createWrap.js", "../../lodash-es/ary.js", "../../lodash-es/_baseAssignValue.js", "../../lodash-es/eq.js", "../../lodash-es/_assignValue.js", "../../lodash-es/_copyObject.js", "../../lodash-es/_overRest.js", "../../lodash-es/_baseRest.js", "../../lodash-es/isLength.js", "../../lodash-es/isArrayLike.js", "../../lodash-es/_isIterateeCall.js", "../../lodash-es/_createAssigner.js", "../../lodash-es/_isPrototype.js", "../../lodash-es/_baseTimes.js", "../../lodash-es/_baseIsArguments.js", "../../lodash-es/isArguments.js", "../../lodash-es/stubFalse.js", "../../lodash-es/isBuffer.js", "../../lodash-es/_baseIsTypedArray.js", "../../lodash-es/_baseUnary.js", "../../lodash-es/_nodeUtil.js", "../../lodash-es/isTypedArray.js", "../../lodash-es/_arrayLikeKeys.js", "../../lodash-es/_overArg.js", "../../lodash-es/_nativeKeys.js", "../../lodash-es/_baseKeys.js", "../../lodash-es/keys.js", "../../lodash-es/assign.js", "../../lodash-es/_nativeKeysIn.js", "../../lodash-es/_baseKeysIn.js", "../../lodash-es/keysIn.js", "../../lodash-es/assignIn.js", "../../lodash-es/assignInWith.js", "../../lodash-es/assignWith.js", "../../lodash-es/_isKey.js", "../../lodash-es/_nativeCreate.js", "../../lodash-es/_hashClear.js", "../../lodash-es/_hashDelete.js", "../../lodash-es/_hashGet.js", "../../lodash-es/_hashHas.js", "../../lodash-es/_hashSet.js", "../../lodash-es/_Hash.js", "../../lodash-es/_listCacheClear.js", "../../lodash-es/_assocIndexOf.js", "../../lodash-es/_listCacheDelete.js", "../../lodash-es/_listCacheGet.js", "../../lodash-es/_listCacheHas.js", "../../lodash-es/_listCacheSet.js", "../../lodash-es/_ListCache.js", "../../lodash-es/_Map.js", "../../lodash-es/_mapCacheClear.js", "../../lodash-es/_isKeyable.js", "../../lodash-es/_getMapData.js", "../../lodash-es/_mapCacheDelete.js", "../../lodash-es/_mapCacheGet.js", "../../lodash-es/_mapCacheHas.js", "../../lodash-es/_mapCacheSet.js", "../../lodash-es/_MapCache.js", "../../lodash-es/memoize.js", "../../lodash-es/_memoizeCapped.js", "../../lodash-es/_stringToPath.js", "../../lodash-es/toString.js", "../../lodash-es/_castPath.js", "../../lodash-es/_toKey.js", "../../lodash-es/_baseGet.js", "../../lodash-es/get.js", "../../lodash-es/_baseAt.js", "../../lodash-es/_arrayPush.js", "../../lodash-es/_isFlattenable.js", "../../lodash-es/_baseFlatten.js", "../../lodash-es/flatten.js", "../../lodash-es/_flatRest.js", "../../lodash-es/at.js", "../../lodash-es/_getPrototype.js", "../../lodash-es/isPlainObject.js", "../../lodash-es/isError.js", "../../lodash-es/attempt.js", "../../lodash-es/before.js", "../../lodash-es/bind.js", "../../lodash-es/bindAll.js", "../../lodash-es/bindKey.js", "../../lodash-es/_baseSlice.js", "../../lodash-es/_castSlice.js", "../../lodash-es/_hasUnicode.js", "../../lodash-es/_asciiToArray.js", "../../lodash-es/_unicodeToArray.js", "../../lodash-es/_stringToArray.js", "../../lodash-es/_createCaseFirst.js", "../../lodash-es/upperFirst.js", "../../lodash-es/capitalize.js", "../../lodash-es/_arrayReduce.js", "../../lodash-es/_basePropertyOf.js", "../../lodash-es/_deburrLetter.js", "../../lodash-es/deburr.js", "../../lodash-es/_asciiWords.js", "../../lodash-es/_hasUnicodeWord.js", "../../lodash-es/_unicodeWords.js", "../../lodash-es/words.js", "../../lodash-es/_createCompounder.js", "../../lodash-es/camelCase.js", "../../lodash-es/castArray.js", "../../lodash-es/_createRound.js", "../../lodash-es/ceil.js", "../../lodash-es/chain.js", "../../lodash-es/chunk.js", "../../lodash-es/_baseClamp.js", "../../lodash-es/clamp.js", "../../lodash-es/_stackClear.js", "../../lodash-es/_stackDelete.js", "../../lodash-es/_stackGet.js", "../../lodash-es/_stackHas.js", "../../lodash-es/_stackSet.js", "../../lodash-es/_Stack.js", "../../lodash-es/_baseAssign.js", "../../lodash-es/_baseAssignIn.js", "../../lodash-es/_cloneBuffer.js", "../../lodash-es/_arrayFilter.js", "../../lodash-es/stubArray.js", "../../lodash-es/_getSymbols.js", "../../lodash-es/_copySymbols.js", "../../lodash-es/_getSymbolsIn.js", "../../lodash-es/_copySymbolsIn.js", "../../lodash-es/_baseGetAllKeys.js", "../../lodash-es/_getAllKeys.js", "../../lodash-es/_getAllKeysIn.js", "../../lodash-es/_DataView.js", "../../lodash-es/_Promise.js", "../../lodash-es/_Set.js", "../../lodash-es/_getTag.js", "../../lodash-es/_initCloneArray.js", "../../lodash-es/_Uint8Array.js", "../../lodash-es/_cloneArrayBuffer.js", "../../lodash-es/_cloneDataView.js", "../../lodash-es/_cloneRegExp.js", "../../lodash-es/_cloneSymbol.js", "../../lodash-es/_cloneTypedArray.js", "../../lodash-es/_initCloneByTag.js", "../../lodash-es/_initCloneObject.js", "../../lodash-es/_baseIsMap.js", "../../lodash-es/isMap.js", "../../lodash-es/_baseIsSet.js", "../../lodash-es/isSet.js", "../../lodash-es/_baseClone.js", "../../lodash-es/clone.js", "../../lodash-es/cloneDeep.js", "../../lodash-es/cloneDeepWith.js", "../../lodash-es/cloneWith.js", "../../lodash-es/commit.js", "../../lodash-es/compact.js", "../../lodash-es/concat.js", "../../lodash-es/_setCacheAdd.js", "../../lodash-es/_setCacheHas.js", "../../lodash-es/_SetCache.js", "../../lodash-es/_arraySome.js", "../../lodash-es/_cacheHas.js", "../../lodash-es/_equalArrays.js", "../../lodash-es/_mapToArray.js", "../../lodash-es/_setToArray.js", "../../lodash-es/_equalByTag.js", "../../lodash-es/_equalObjects.js", "../../lodash-es/_baseIsEqualDeep.js", "../../lodash-es/_baseIsEqual.js", "../../lodash-es/_baseIsMatch.js", "../../lodash-es/_isStrictComparable.js", "../../lodash-es/_getMatchData.js", "../../lodash-es/_matchesStrictComparable.js", "../../lodash-es/_baseMatches.js", "../../lodash-es/_baseHasIn.js", "../../lodash-es/_hasPath.js", "../../lodash-es/hasIn.js", "../../lodash-es/_baseMatchesProperty.js", "../../lodash-es/_baseProperty.js", "../../lodash-es/_basePropertyDeep.js", "../../lodash-es/property.js", "../../lodash-es/_baseIteratee.js", "../../lodash-es/cond.js", "../../lodash-es/_baseConformsTo.js", "../../lodash-es/_baseConforms.js", "../../lodash-es/conforms.js", "../../lodash-es/conformsTo.js", "../../lodash-es/_arrayAggregator.js", "../../lodash-es/_createBaseFor.js", "../../lodash-es/_baseFor.js", "../../lodash-es/_baseForOwn.js", "../../lodash-es/_createBaseEach.js", "../../lodash-es/_baseEach.js", "../../lodash-es/_baseAggregator.js", "../../lodash-es/_createAggregator.js", "../../lodash-es/countBy.js", "../../lodash-es/create.js", "../../lodash-es/curry.js", "../../lodash-es/curryRight.js", "../../lodash-es/now.js", "../../lodash-es/debounce.js", "../../lodash-es/defaultTo.js", "../../lodash-es/defaults.js", "../../lodash-es/_assignMergeValue.js", "../../lodash-es/isArrayLikeObject.js", "../../lodash-es/_safeGet.js", "../../lodash-es/toPlainObject.js", "../../lodash-es/_baseMergeDeep.js", "../../lodash-es/_baseMerge.js", "../../lodash-es/_customDefaultsMerge.js", "../../lodash-es/mergeWith.js", "../../lodash-es/defaultsDeep.js", "../../lodash-es/_baseDelay.js", "../../lodash-es/defer.js", "../../lodash-es/delay.js", "../../lodash-es/_arrayIncludesWith.js", "../../lodash-es/_baseDifference.js", "../../lodash-es/difference.js", "../../lodash-es/last.js", "../../lodash-es/differenceBy.js", "../../lodash-es/differenceWith.js", "../../lodash-es/divide.js", "../../lodash-es/drop.js", "../../lodash-es/dropRight.js", "../../lodash-es/_baseWhile.js", "../../lodash-es/dropRightWhile.js", "../../lodash-es/dropWhile.js", "../../lodash-es/_castFunction.js", "../../lodash-es/forEach.js", "../../lodash-es/_arrayEachRight.js", "../../lodash-es/_baseForRight.js", "../../lodash-es/_baseForOwnRight.js", "../../lodash-es/_baseEachRight.js", "../../lodash-es/forEachRight.js", "../../lodash-es/endsWith.js", "../../lodash-es/_baseToPairs.js", "../../lodash-es/_setToPairs.js", "../../lodash-es/_createToPairs.js", "../../lodash-es/toPairs.js", "../../lodash-es/toPairsIn.js", "../../lodash-es/_escapeHtmlChar.js", "../../lodash-es/escape.js", "../../lodash-es/escapeRegExp.js", "../../lodash-es/_arrayEvery.js", "../../lodash-es/_baseEvery.js", "../../lodash-es/every.js", "../../lodash-es/toLength.js", "../../lodash-es/_baseFill.js", "../../lodash-es/fill.js", "../../lodash-es/_baseFilter.js", "../../lodash-es/filter.js", "../../lodash-es/_createFind.js", "../../lodash-es/findIndex.js", "../../lodash-es/find.js", "../../lodash-es/_baseFindKey.js", "../../lodash-es/findKey.js", "../../lodash-es/findLastIndex.js", "../../lodash-es/findLast.js", "../../lodash-es/findLastKey.js", "../../lodash-es/head.js", "../../lodash-es/_baseMap.js", "../../lodash-es/map.js", "../../lodash-es/flatMap.js", "../../lodash-es/flatMapDeep.js", "../../lodash-es/flatMapDepth.js", "../../lodash-es/flattenDeep.js", "../../lodash-es/flattenDepth.js", "../../lodash-es/flip.js", "../../lodash-es/floor.js", "../../lodash-es/_createFlow.js", "../../lodash-es/flow.js", "../../lodash-es/flowRight.js", "../../lodash-es/forIn.js", "../../lodash-es/forInRight.js", "../../lodash-es/forOwn.js", "../../lodash-es/forOwnRight.js", "../../lodash-es/fromPairs.js", "../../lodash-es/_baseFunctions.js", "../../lodash-es/functions.js", "../../lodash-es/functionsIn.js", "../../lodash-es/groupBy.js", "../../lodash-es/_baseGt.js", "../../lodash-es/_createRelationalOperation.js", "../../lodash-es/gt.js", "../../lodash-es/gte.js", "../../lodash-es/_baseHas.js", "../../lodash-es/has.js", "../../lodash-es/_baseInRange.js", "../../lodash-es/inRange.js", "../../lodash-es/isString.js", "../../lodash-es/_baseValues.js", "../../lodash-es/values.js", "../../lodash-es/includes.js", "../../lodash-es/indexOf.js", "../../lodash-es/initial.js", "../../lodash-es/_baseIntersection.js", "../../lodash-es/_castArrayLikeObject.js", "../../lodash-es/intersection.js", "../../lodash-es/intersectionBy.js", "../../lodash-es/intersectionWith.js", "../../lodash-es/_baseInverter.js", "../../lodash-es/_createInverter.js", "../../lodash-es/invert.js", "../../lodash-es/invertBy.js", "../../lodash-es/_parent.js", "../../lodash-es/_baseInvoke.js", "../../lodash-es/invoke.js", "../../lodash-es/invokeMap.js", "../../lodash-es/_baseIsArrayBuffer.js", "../../lodash-es/isArrayBuffer.js", "../../lodash-es/isBoolean.js", "../../lodash-es/_baseIsDate.js", "../../lodash-es/isDate.js", "../../lodash-es/isElement.js", "../../lodash-es/isEmpty.js", "../../lodash-es/isEqual.js", "../../lodash-es/isEqualWith.js", "../../lodash-es/isFinite.js", "../../lodash-es/isInteger.js", "../../lodash-es/isMatch.js", "../../lodash-es/isMatchWith.js", "../../lodash-es/isNumber.js", "../../lodash-es/isNaN.js", "../../lodash-es/_isMaskable.js", "../../lodash-es/isNative.js", "../../lodash-es/isNil.js", "../../lodash-es/isNull.js", "../../lodash-es/_baseIsRegExp.js", "../../lodash-es/isRegExp.js", "../../lodash-es/isSafeInteger.js", "../../lodash-es/isUndefined.js", "../../lodash-es/isWeakMap.js", "../../lodash-es/isWeakSet.js", "../../lodash-es/iteratee.js", "../../lodash-es/join.js", "../../lodash-es/kebabCase.js", "../../lodash-es/keyBy.js", "../../lodash-es/_strictLastIndexOf.js", "../../lodash-es/lastIndexOf.js", "../../lodash-es/lowerCase.js", "../../lodash-es/lowerFirst.js", "../../lodash-es/_baseLt.js", "../../lodash-es/lt.js", "../../lodash-es/lte.js", "../../lodash-es/mapKeys.js", "../../lodash-es/mapValues.js", "../../lodash-es/matches.js", "../../lodash-es/matchesProperty.js", "../../lodash-es/_baseExtremum.js", "../../lodash-es/max.js", "../../lodash-es/maxBy.js", "../../lodash-es/_baseSum.js", "../../lodash-es/_baseMean.js", "../../lodash-es/mean.js", "../../lodash-es/meanBy.js", "../../lodash-es/merge.js", "../../lodash-es/method.js", "../../lodash-es/methodOf.js", "../../lodash-es/min.js", "../../lodash-es/minBy.js", "../../lodash-es/mixin.js", "../../lodash-es/multiply.js", "../../lodash-es/negate.js", "../../lodash-es/_iteratorToArray.js", "../../lodash-es/toArray.js", "../../lodash-es/next.js", "../../lodash-es/_baseNth.js", "../../lodash-es/nth.js", "../../lodash-es/nthArg.js", "../../lodash-es/_baseUnset.js", "../../lodash-es/_customOmitClone.js", "../../lodash-es/omit.js", "../../lodash-es/_baseSet.js", "../../lodash-es/_basePickBy.js", "../../lodash-es/pickBy.js", "../../lodash-es/omitBy.js", "../../lodash-es/once.js", "../../lodash-es/_baseSortBy.js", "../../lodash-es/_compareAscending.js", "../../lodash-es/_compareMultiple.js", "../../lodash-es/_baseOrderBy.js", "../../lodash-es/orderBy.js", "../../lodash-es/_createOver.js", "../../lodash-es/over.js", "../../lodash-es/_castRest.js", "../../lodash-es/overArgs.js", "../../lodash-es/overEvery.js", "../../lodash-es/overSome.js", "../../lodash-es/_baseRepeat.js", "../../lodash-es/_asciiSize.js", "../../lodash-es/_unicodeSize.js", "../../lodash-es/_stringSize.js", "../../lodash-es/_createPadding.js", "../../lodash-es/pad.js", "../../lodash-es/padEnd.js", "../../lodash-es/padStart.js", "../../lodash-es/parseInt.js", "../../lodash-es/partial.js", "../../lodash-es/partialRight.js", "../../lodash-es/partition.js", "../../lodash-es/_basePick.js", "../../lodash-es/pick.js", "../../lodash-es/plant.js", "../../lodash-es/propertyOf.js", "../../lodash-es/_baseIndexOfWith.js", "../../lodash-es/_basePullAll.js", "../../lodash-es/pullAll.js", "../../lodash-es/pull.js", "../../lodash-es/pullAllBy.js", "../../lodash-es/pullAllWith.js", "../../lodash-es/_basePullAt.js", "../../lodash-es/pullAt.js", "../../lodash-es/_baseRandom.js", "../../lodash-es/random.js", "../../lodash-es/_baseRange.js", "../../lodash-es/_createRange.js", "../../lodash-es/range.js", "../../lodash-es/rangeRight.js", "../../lodash-es/rearg.js", "../../lodash-es/_baseReduce.js", "../../lodash-es/reduce.js", "../../lodash-es/_arrayReduceRight.js", "../../lodash-es/reduceRight.js", "../../lodash-es/reject.js", "../../lodash-es/remove.js", "../../lodash-es/repeat.js", "../../lodash-es/replace.js", "../../lodash-es/rest.js", "../../lodash-es/result.js", "../../lodash-es/reverse.js", "../../lodash-es/round.js", "../../lodash-es/_arraySample.js", "../../lodash-es/_baseSample.js", "../../lodash-es/sample.js", "../../lodash-es/_shuffleSelf.js", "../../lodash-es/_arraySampleSize.js", "../../lodash-es/_baseSampleSize.js", "../../lodash-es/sampleSize.js", "../../lodash-es/set.js", "../../lodash-es/setWith.js", "../../lodash-es/_arrayShuffle.js", "../../lodash-es/_baseShuffle.js", "../../lodash-es/shuffle.js", "../../lodash-es/size.js", "../../lodash-es/slice.js", "../../lodash-es/snakeCase.js", "../../lodash-es/_baseSome.js", "../../lodash-es/some.js", "../../lodash-es/sortBy.js", "../../lodash-es/_baseSortedIndexBy.js", "../../lodash-es/_baseSortedIndex.js", "../../lodash-es/sortedIndex.js", "../../lodash-es/sortedIndexBy.js", "../../lodash-es/sortedIndexOf.js", "../../lodash-es/sortedLastIndex.js", "../../lodash-es/sortedLastIndexBy.js", "../../lodash-es/sortedLastIndexOf.js", "../../lodash-es/_baseSortedUniq.js", "../../lodash-es/sortedUniq.js", "../../lodash-es/sortedUniqBy.js", "../../lodash-es/split.js", "../../lodash-es/spread.js", "../../lodash-es/startCase.js", "../../lodash-es/startsWith.js", "../../lodash-es/stubObject.js", "../../lodash-es/stubString.js", "../../lodash-es/stubTrue.js", "../../lodash-es/subtract.js", "../../lodash-es/sum.js", "../../lodash-es/sumBy.js", "../../lodash-es/tail.js", "../../lodash-es/take.js", "../../lodash-es/takeRight.js", "../../lodash-es/takeRightWhile.js", "../../lodash-es/takeWhile.js", "../../lodash-es/tap.js", "../../lodash-es/_customDefaultsAssignIn.js", "../../lodash-es/_escapeStringChar.js", "../../lodash-es/_reInterpolate.js", "../../lodash-es/_reEscape.js", "../../lodash-es/_reEvaluate.js", "../../lodash-es/templateSettings.js", "../../lodash-es/template.js", "../../lodash-es/throttle.js", "../../lodash-es/thru.js", "../../lodash-es/times.js", "../../lodash-es/toIterator.js", "../../lodash-es/_baseWrapperValue.js", "../../lodash-es/wrapperValue.js", "../../lodash-es/toLower.js", "../../lodash-es/toPath.js", "../../lodash-es/toSafeInteger.js", "../../lodash-es/toUpper.js", "../../lodash-es/transform.js", "../../lodash-es/_charsEndIndex.js", "../../lodash-es/_charsStartIndex.js", "../../lodash-es/trim.js", "../../lodash-es/trimEnd.js", "../../lodash-es/trimStart.js", "../../lodash-es/truncate.js", "../../lodash-es/unary.js", "../../lodash-es/_unescapeHtmlChar.js", "../../lodash-es/unescape.js", "../../lodash-es/_createSet.js", "../../lodash-es/_baseUniq.js", "../../lodash-es/union.js", "../../lodash-es/unionBy.js", "../../lodash-es/unionWith.js", "../../lodash-es/uniq.js", "../../lodash-es/uniqBy.js", "../../lodash-es/uniqWith.js", "../../lodash-es/uniqueId.js", "../../lodash-es/unset.js", "../../lodash-es/unzip.js", "../../lodash-es/unzipWith.js", "../../lodash-es/_baseUpdate.js", "../../lodash-es/update.js", "../../lodash-es/updateWith.js", "../../lodash-es/upperCase.js", "../../lodash-es/valuesIn.js", "../../lodash-es/without.js", "../../lodash-es/wrap.js", "../../lodash-es/wrapperAt.js", "../../lodash-es/wrapperChain.js", "../../lodash-es/wrapperReverse.js", "../../lodash-es/_baseXor.js", "../../lodash-es/xor.js", "../../lodash-es/xorBy.js", "../../lodash-es/xorWith.js", "../../lodash-es/zip.js", "../../lodash-es/_baseZipObject.js", "../../lodash-es/zipObject.js", "../../lodash-es/zipObjectDeep.js", "../../lodash-es/zipWith.js", "../../lodash-es/array.default.js", "../../lodash-es/collection.default.js", "../../lodash-es/date.default.js", "../../lodash-es/function.default.js", "../../lodash-es/lang.default.js", "../../lodash-es/math.default.js", "../../lodash-es/number.default.js", "../../lodash-es/object.default.js", "../../lodash-es/seq.default.js", "../../lodash-es/string.default.js", "../../lodash-es/util.default.js", "../../lodash-es/_lazyClone.js", "../../lodash-es/_lazyReverse.js", "../../lodash-es/_getView.js", "../../lodash-es/_lazyValue.js", "../../lodash-es/lodash.default.js", "../../../packages/utils/types.ts", "../../../packages/utils/raf.ts", "../../../packages/utils/strings.ts", "../../../packages/utils/objects.ts", "../../../packages/utils/error.ts", "../../../packages/utils/dom/style.ts", "../../../packages/utils/dom/scroll.ts", "../../../packages/utils/dom/element.ts", "../../../packages/utils/vue/global-node.ts", "../../../packages/utils/vue/props/runtime.ts", "../../../packages/utils/vue/icon.ts", "../../../packages/utils/vue/install.ts", "../../../packages/utils/vue/refs.ts", "../../../packages/constants/aria.ts", "../../../packages/constants/date.ts", "../../../packages/constants/event.ts", "../../../packages/constants/key.ts", "../../../packages/constants/size.ts", "../../../packages/utils/vue/validator.ts", "../../../packages/utils/vue/vnode.ts", "../../../packages/utils/arrays.ts", "../../../packages/utils/i18n.ts", "../../../packages/utils/typescript.ts", "../../../packages/utils/throttleByRaf.ts", "../../../packages/hooks/use-attrs/index.ts", "../../../packages/hooks/use-deprecated/index.ts", "../../../packages/hooks/use-draggable/index.ts", "../../../packages/hooks/use-focus/index.ts", "../../../packages/locale/lang/en.ts", "../../../packages/hooks/use-locale/index.ts", "../../../packages/hooks/use-namespace/index.ts", "../../../packages/hooks/use-lockscreen/index.ts", "../../../packages/hooks/use-modal/index.ts", "../../../packages/hooks/use-model-toggle/index.ts", "../../../packages/hooks/use-prevent-global/index.ts", "../../../packages/hooks/use-prop/index.ts", "../../@popperjs/core/dist/index.mjs", "../../../packages/hooks/use-popper/index.ts", "../../../packages/hooks/use-same-target/index.ts", "../../../packages/hooks/use-teleport/index.ts", "../../../packages/hooks/use-throttle-render/index.ts", "../../../packages/hooks/use-timeout/index.ts", "../../../packages/hooks/use-transition-fallthrough/index.ts", "../../../packages/hooks/use-id/index.ts", "../../../packages/hooks/use-escape-keydown/index.ts", "../../../packages/hooks/use-popper-container/index.ts", "../../../packages/hooks/use-intermediate-render/index.ts", "../../../packages/hooks/use-delayed-toggle/index.ts", "../../../packages/hooks/use-forward-ref/index.ts", "../../../packages/hooks/use-z-index/index.ts", "../../@floating-ui/utils/dist/floating-ui.utils.mjs", "../../@floating-ui/core/dist/floating-ui.core.mjs", "../../@floating-ui/utils/dist/floating-ui.utils.dom.mjs", "../../@floating-ui/dom/dist/floating-ui.dom.mjs", "../../../packages/hooks/use-floating/index.ts", "../../../packages/hooks/use-cursor/index.ts", "../../../packages/hooks/use-ordered-children/index.ts", "../../../packages/hooks/use-size/index.ts", "../../../packages/hooks/use-focus-controller/index.ts", "../../../packages/hooks/use-composition/index.ts", "../../../packages/hooks/use-empty-values/index.ts", "../../../packages/hooks/use-aria/index.ts", "../../../packages/components/config-provider/src/constants.ts", "../../../packages/components/config-provider/src/hooks/use-global-config.ts", "../../../packages/components/config-provider/src/config-provider-props.ts", "../../../packages/components/config-provider/src/config-provider.ts", "../../../packages/components/config-provider/index.ts", "../../../packages/element-plus/version.ts", "../../../packages/element-plus/make-installer.ts", "../../../packages/components/affix/src/affix.ts", "../../../internal/build/plugin-vue:export-helper", "../../../packages/components/affix/src/affix.vue", "../../../packages/components/affix/index.ts", "../../../packages/components/icon/src/icon.ts", "../../../packages/components/icon/src/icon.vue", "../../../packages/components/icon/index.ts", "../../../packages/components/alert/src/alert.ts", "../../../packages/components/alert/src/alert.vue", "../../../packages/components/alert/index.ts", "../../../packages/components/form/src/constants.ts", "../../../packages/components/form/src/hooks/use-form-common-props.ts", "../../../packages/components/form/src/hooks/use-form-item.ts", "../../../packages/components/form/src/form.ts", "../../../packages/components/form/src/utils.ts", "../../../packages/components/form/src/form.vue", "../../src/util.ts", "../../src/rule/required.ts", "../../src/rule/whitespace.ts", "../../src/rule/url.ts", "../../src/rule/type.ts", "../../src/rule/range.ts", "../../src/rule/enum.ts", "../../src/rule/pattern.ts", "../../src/rule/index.ts", "../../src/validator/string.ts", "../../src/validator/method.ts", "../../src/validator/number.ts", "../../src/validator/boolean.ts", "../../src/validator/regexp.ts", "../../src/validator/integer.ts", "../../src/validator/float.ts", "../../src/validator/array.ts", "../../src/validator/object.ts", "../../src/validator/enum.ts", "../../src/validator/pattern.ts", "../../src/validator/date.ts", "../../src/validator/required.ts", "../../src/validator/type.ts", "../../src/validator/any.ts", "../../src/validator/index.ts", "../../src/messages.ts", "../../src/index.ts", "../../../packages/components/form/src/form-item.ts", "../../../packages/components/form/src/form-label-wrap.tsx", "../../../packages/components/form/src/form-item.vue", "../../../packages/components/form/index.ts", "../../../packages/components/input/src/utils.ts", "../../../packages/components/input/src/input.ts", "../../../packages/components/input/src/input.vue", "../../../packages/components/input/index.ts", "../../../packages/components/scrollbar/src/util.ts", "../../../packages/components/scrollbar/src/constants.ts", "../../../packages/components/scrollbar/src/thumb.ts", "../../../packages/components/scrollbar/src/thumb.vue", "../../../packages/components/scrollbar/src/bar.ts", "../../../packages/components/scrollbar/src/bar.vue", "../../../packages/components/scrollbar/src/scrollbar.ts", "../../../packages/components/scrollbar/src/scrollbar.vue", "../../../packages/components/scrollbar/index.ts", "../../../packages/components/popper/src/constants.ts", "../../../packages/components/popper/src/popper.ts", "../../../packages/components/popper/src/popper.vue", "../../../packages/components/popper/src/arrow.ts", "../../../packages/components/popper/src/arrow.vue", "../../../packages/components/slot/src/only-child.tsx", "../../../packages/components/popper/src/trigger.ts", "../../../packages/components/popper/src/trigger.vue", "../../../packages/components/focus-trap/src/tokens.ts", "../../../packages/components/focus-trap/src/utils.ts", "../../../packages/components/focus-trap/src/focus-trap.vue", "../../../packages/components/popper/src/content.ts", "../../../packages/components/popper/src/utils.ts", "../../../packages/components/popper/src/composables/use-content.ts", "../../../packages/components/popper/src/composables/use-content-dom.ts", "../../../packages/components/popper/src/composables/use-focus-trap.ts", "../../../packages/components/popper/src/content.vue", "../../../packages/components/popper/index.ts", "../../../packages/components/tooltip/src/constants.ts", "../../../packages/components/tooltip/src/content.ts", "../../../packages/components/tooltip/src/trigger.ts", "../../../packages/components/tooltip/src/tooltip.ts", "../../../packages/components/tooltip/src/utils.ts", "../../../packages/components/tooltip/src/trigger.vue", "../../../packages/components/teleport/src/teleport.ts", "../../element-plus/es/components/teleport/src/teleport.mjs", "../../../packages/components/teleport/index.ts", "../../../packages/components/tooltip/src/content.vue", "../../../packages/components/tooltip/src/tooltip.vue", "../../../packages/components/tooltip/index.ts", "../../../packages/components/autocomplete/src/autocomplete.ts", "../../../packages/components/autocomplete/src/autocomplete.vue", "../../../packages/components/autocomplete/index.ts", "../../../packages/components/avatar/src/avatar.ts", "../../../packages/components/avatar/src/avatar.vue", "../../../packages/components/avatar/index.ts", "../../../packages/components/backtop/src/backtop.ts", "../../../packages/components/backtop/src/use-backtop.ts", "../../../packages/components/backtop/src/backtop.vue", "../../../packages/components/backtop/index.ts", "../../../packages/components/badge/src/badge.ts", "../../../packages/components/badge/src/badge.vue", "../../../packages/components/badge/index.ts", "../../../packages/components/breadcrumb/src/constants.ts", "../../../packages/components/breadcrumb/src/breadcrumb.ts", "../../../packages/components/breadcrumb/src/breadcrumb.vue", "../../../packages/components/breadcrumb/src/breadcrumb-item.ts", "../../../packages/components/breadcrumb/src/breadcrumb-item.vue", "../../../packages/components/breadcrumb/index.ts", "../../../packages/components/button/src/constants.ts", "../../../packages/components/button/src/use-button.ts", "../../../packages/components/button/src/button.ts", "../../@ctrl/tinycolor/dist/module/util.js", "../../@ctrl/tinycolor/dist/module/conversion.js", "../../@ctrl/tinycolor/dist/module/css-color-names.js", "../../@ctrl/tinycolor/dist/module/format-input.js", "../../@ctrl/tinycolor/dist/module/index.js", "../../../packages/components/button/src/button-custom.ts", "../../../packages/components/button/src/button.vue", "../../../packages/components/button/src/button-group.ts", "../../../packages/components/button/src/button-group.vue", "../../../packages/components/button/index.ts", "../../../packages/components/time-picker/src/constants.ts", "../../../packages/components/time-picker/src/utils.ts", "../../../packages/components/time-picker/src/props/shared.ts", "../../../packages/components/time-picker/src/common/props.ts", "../../../packages/components/time-picker/src/common/picker.vue", "../../../packages/components/time-picker/src/props/panel-time-picker.ts", "../../../packages/components/time-picker/src/composables/use-time-panel.ts", "../../../packages/components/time-picker/src/composables/use-time-picker.ts", "../../../packages/directives/click-outside/index.ts", "../../../packages/directives/repeat-click/index.ts", "../../../packages/directives/trap-focus/index.ts", "../../normalize-wheel-es/src/UserAgent_DEPRECATED.js", "../../normalize-wheel-es/src/ExecutionEnvironment.js", "../../normalize-wheel-es/src/isEventSupported.js", "../../normalize-wheel-es/src/normalizeWheel.js", "../../../packages/directives/mousewheel/index.ts", "../../../packages/components/time-picker/src/props/basic-time-spinner.ts", "../../../packages/components/time-picker/src/time-picker-com/basic-time-spinner.vue", "../../../packages/components/time-picker/src/time-picker-com/panel-time-pick.vue", "../../../packages/components/time-picker/src/props/panel-time-range.ts", "../../../packages/components/time-picker/src/time-picker-com/panel-time-range.vue", "../../../packages/components/time-picker/src/time-picker.tsx", "../../../packages/components/time-picker/index.ts", "../../../packages/components/calendar/src/date-table.ts", "../../../packages/components/calendar/src/use-date-table.ts", "../../../packages/components/calendar/src/date-table.vue", "../../../packages/components/calendar/src/use-calendar.ts", "../../../packages/components/calendar/src/calendar.ts", "../../../packages/components/calendar/src/calendar.vue", "../../../packages/components/calendar/index.ts", "../../../packages/components/card/src/card.ts", "../../../packages/components/card/src/card.vue", "../../../packages/components/card/index.ts", "../../../packages/components/carousel/src/carousel.ts", "../../../packages/components/carousel/src/constants.ts", "../../../packages/components/carousel/src/use-carousel.ts", "../../../packages/components/carousel/src/carousel.vue", "../../../packages/components/carousel/src/carousel-item.ts", "../../../packages/components/carousel/src/use-carousel-item.ts", "../../../packages/components/carousel/src/carousel-item.vue", "../../../packages/components/carousel/index.ts", "../../../packages/components/checkbox/src/checkbox.ts", "../../../packages/components/checkbox/src/constants.ts", "../../../packages/components/checkbox/src/composables/use-checkbox-disabled.ts", "../../../packages/components/checkbox/src/composables/use-checkbox-event.ts", "../../../packages/components/checkbox/src/composables/use-checkbox-model.ts", "../../../packages/components/checkbox/src/composables/use-checkbox-status.ts", "../../../packages/components/checkbox/src/composables/use-checkbox.ts", "../../../packages/components/checkbox/src/checkbox.vue", "../../../packages/components/checkbox/src/checkbox-button.vue", "../../../packages/components/checkbox/src/checkbox-group.ts", "../../../packages/components/checkbox/src/checkbox-group.vue", "../../../packages/components/checkbox/index.ts", "../../../packages/components/radio/src/radio.ts", "../../../packages/components/radio/src/constants.ts", "../../../packages/components/radio/src/use-radio.ts", "../../../packages/components/radio/src/radio.vue", "../../../packages/components/radio/src/radio-button.ts", "../../../packages/components/radio/src/radio-button.vue", "../../../packages/components/radio/src/radio-group.ts", "../../../packages/components/radio/src/radio-group.vue", "../../../packages/components/radio/index.ts", "../../../packages/components/cascader-panel/src/node-content.ts", "../../../packages/components/cascader-panel/src/types.ts", "../../../packages/components/cascader-panel/src/node.vue", "../../../packages/components/cascader-panel/src/menu.vue", "../../../packages/components/cascader-panel/src/node.ts", "../../../packages/components/cascader-panel/src/store.ts", "../../../packages/components/cascader-panel/src/config.ts", "../../../packages/components/cascader-panel/src/utils.ts", "../../../packages/components/cascader-panel/src/index.vue", "../../../packages/components/cascader-panel/index.ts", "../../../packages/components/tag/src/tag.ts", "../../../packages/components/tag/src/tag.vue", "../../../packages/components/tag/index.ts", "../../../packages/components/cascader/src/cascader.ts", "../../../packages/components/cascader/src/cascader.vue", "../../../packages/components/cascader/index.ts", "../../../packages/components/check-tag/src/check-tag.ts", "../../../packages/components/check-tag/src/check-tag.vue", "../../../packages/components/check-tag/index.ts", "../../../packages/components/row/src/constants.ts", "../../../packages/components/row/src/row.ts", "../../../packages/components/row/src/row.vue", "../../../packages/components/row/index.ts", "../../../packages/components/col/src/col.ts", "../../../packages/components/col/src/col.vue", "../../../packages/components/col/index.ts", "../../../packages/components/collapse/src/collapse.ts", "../../../packages/components/collapse/src/constants.ts", "../../../packages/components/collapse/src/use-collapse.ts", "../../../packages/components/collapse/src/collapse.vue", "../../../packages/components/collapse-transition/src/collapse-transition.vue", "../../../packages/components/collapse-transition/index.ts", "../../../packages/components/collapse/src/collapse-item.ts", "../../../packages/components/collapse/src/use-collapse-item.ts", "../../../packages/components/collapse/src/collapse-item.vue", "../../../packages/components/collapse/index.ts", "../../../packages/components/color-picker/src/props/alpha-slider.ts", "../../../packages/components/color-picker/src/utils/draggable.ts", "../../../packages/components/color-picker/src/composables/use-alpha-slider.ts", "../../../packages/components/color-picker/src/components/alpha-slider.vue", "../../../packages/components/color-picker/src/components/hue-slider.vue", "../../../packages/components/color-picker/src/color-picker.ts", "../../../packages/components/color-picker/src/utils/color.ts", "../../../packages/components/color-picker/src/components/predefine.vue", "../../../packages/components/color-picker/src/components/sv-panel.vue", "../../../packages/components/color-picker/src/color-picker.vue", "../../../packages/components/color-picker/index.ts", "../../../packages/components/container/src/container.vue", "../../../packages/components/container/src/aside.vue", "../../../packages/components/container/src/footer.vue", "../../../packages/components/container/src/header.vue", "../../../packages/components/container/src/main.vue", "../../../packages/components/container/index.ts", "../../../packages/components/date-picker/src/constants.ts", "../../../packages/components/date-picker/src/props/date-picker.ts", "../../../packages/components/date-picker/src/props/shared.ts", "../../../packages/components/date-picker/src/props/panel-date-pick.ts", "../../../packages/components/date-picker/src/utils.ts", "../../../packages/components/date-picker/src/props/basic-date-table.ts", "../../../packages/components/date-picker/src/composables/use-basic-date-table.ts", "../../../packages/components/date-picker/src/props/basic-cell.ts", "../../../packages/components/date-picker/src/date-picker-com/basic-cell-render.tsx", "../../../packages/components/date-picker/src/date-picker-com/basic-date-table.vue", "../../../packages/components/date-picker/src/props/basic-month-table.ts", "../../../packages/components/date-picker/src/date-picker-com/basic-month-table.vue", "../../../packages/components/date-picker/src/props/basic-year-table.ts", "../../../packages/components/date-picker/src/date-picker-com/basic-year-table.vue", "../../../packages/components/date-picker/src/date-picker-com/panel-date-pick.vue", "../../../packages/components/date-picker/src/props/panel-date-range.ts", "../../../packages/components/date-picker/src/composables/use-shortcut.ts", "../../../packages/components/date-picker/src/composables/use-range-picker.ts", "../../../packages/components/date-picker/src/date-picker-com/panel-date-range.vue", "../../../packages/components/date-picker/src/props/panel-month-range.ts", "../../../packages/components/date-picker/src/composables/use-month-range-header.ts", "../../../packages/components/date-picker/src/date-picker-com/panel-month-range.vue", "../../../packages/components/date-picker/src/props/panel-year-range.ts", "../../../packages/components/date-picker/src/composables/use-year-range-header.ts", "../../../packages/components/date-picker/src/date-picker-com/panel-year-range.vue", "../../../packages/components/date-picker/src/panel-utils.ts", "../../../packages/components/date-picker/src/date-picker.tsx", "../../../packages/components/date-picker/index.ts", "../../../packages/components/descriptions/src/token.ts", "../../../packages/components/descriptions/src/descriptions-cell.ts", "../../../packages/components/descriptions/src/descriptions-row.ts", "../../../packages/components/descriptions/src/descriptions-row.vue", "../../../packages/components/descriptions/src/description.ts", "../../../packages/components/descriptions/src/description.vue", "../../../packages/components/descriptions/src/description-item.ts", "../../../packages/components/descriptions/index.ts", "../../../packages/components/overlay/src/overlay.ts", "../../../packages/components/overlay/index.ts", "../../../packages/components/dialog/src/constants.ts", "../../../packages/components/dialog/src/dialog-content.ts", "../../../packages/components/dialog/src/dialog-content.vue", "../../../packages/components/dialog/src/dialog.ts", "../../../packages/components/dialog/src/use-dialog.ts", "../../../packages/components/dialog/src/dialog.vue", "../../../packages/components/dialog/index.ts", "../../../packages/components/divider/src/divider.ts", "../../../packages/components/divider/src/divider.vue", "../../../packages/components/divider/index.ts", "../../../packages/components/drawer/src/drawer.ts", "../../../packages/components/drawer/src/drawer.vue", "../../../packages/components/drawer/index.ts", "../../../packages/components/collection/src/collection.vue", "../../../packages/components/collection/src/collection-item.vue", "../../../packages/components/collection/src/collection.ts", "../../../packages/components/roving-focus-group/src/roving-focus-group.ts", "../../../packages/components/roving-focus-group/src/tokens.ts", "../../../packages/components/roving-focus-group/src/utils.ts", "../../../packages/components/roving-focus-group/src/roving-focus-group-impl.vue", "../../../packages/components/roving-focus-group/src/roving-focus-group.vue", "../../../packages/components/roving-focus-group/src/roving-focus-item.vue", "../../../packages/components/dropdown/src/dropdown.ts", "../../../packages/components/dropdown/src/tokens.ts", "../../../packages/components/dropdown/src/dropdown.vue", "../../../packages/components/dropdown/src/dropdown-item-impl.vue", "../../../packages/components/dropdown/src/useDropdown.ts", "../../../packages/components/dropdown/src/dropdown-item.vue", "../../../packages/components/dropdown/src/dropdown-menu.vue", "../../../packages/components/dropdown/index.ts", "../../../packages/components/empty/src/img-empty.vue", "../../../packages/components/empty/src/empty.ts", "../../../packages/components/empty/src/empty.vue", "../../../packages/components/empty/index.ts", "../../../packages/components/image-viewer/src/image-viewer.ts", "../../../packages/components/image-viewer/src/image-viewer.vue", "../../../packages/components/image-viewer/index.ts", "../../../packages/components/image/src/image.ts", "../../../packages/components/image/src/image.vue", "../../../packages/components/image/index.ts", "../../../packages/components/input-number/src/input-number.ts", "../../../packages/components/input-number/src/input-number.vue", "../../../packages/components/input-number/index.ts", "../../../packages/components/link/src/link.ts", "../../../packages/components/link/src/link.vue", "../../../packages/components/link/index.ts", "../../../packages/components/menu/src/utils/submenu.ts", "../../../packages/components/menu/src/utils/menu-item.ts", "../../../packages/components/menu/src/utils/menu-bar.ts", "../../../packages/components/menu/src/menu-collapse-transition.vue", "../../../packages/components/menu/src/use-menu.ts", "../../../packages/components/menu/src/use-menu-color.ts", "../../../packages/components/menu/src/use-menu-css-var.ts", "../../../packages/components/menu/src/sub-menu.ts", "../../../packages/components/menu/src/menu.ts", "../../../packages/components/menu/src/menu-item.ts", "../../../packages/components/menu/src/menu-item.vue", "../../../packages/components/menu/src/menu-item-group.ts", "../../../packages/components/menu/src/menu-item-group.vue", "../../../packages/components/menu/index.ts", "../../../packages/components/page-header/src/page-header.ts", "../../../packages/components/page-header/src/page-header.vue", "../../../packages/components/page-header/index.ts", "../../../packages/components/pagination/src/constants.ts", "../../../packages/components/pagination/src/components/prev.ts", "../../../packages/components/pagination/src/components/prev.vue", "../../../packages/components/pagination/src/components/next.ts", "../../../packages/components/pagination/src/components/next.vue", "../../../packages/components/select/src/token.ts", "../../../packages/components/select/src/useOption.ts", "../../../packages/components/select/src/option.vue", "../../../packages/components/select/src/select-dropdown.vue", "../../../packages/components/select/src/useSelect.ts", "../../../packages/components/select/src/options.ts", "../../../packages/components/select/src/select.ts", "../../../packages/components/select/src/select.vue", "../../../packages/components/select/src/option-group.vue", "../../../packages/components/select/index.ts", "../../../packages/components/pagination/src/usePagination.ts", "../../../packages/components/pagination/src/components/sizes.ts", "../../../packages/components/pagination/src/components/sizes.vue", "../../../packages/components/pagination/src/components/jumper.ts", "../../../packages/components/pagination/src/components/jumper.vue", "../../../packages/components/pagination/src/components/total.ts", "../../../packages/components/pagination/src/components/total.vue", "../../../packages/components/pagination/src/components/pager.ts", "../../../packages/components/pagination/src/components/pager.vue", "../../../packages/components/pagination/src/pagination.ts", "../../../packages/components/pagination/index.ts", "../../../packages/components/popconfirm/src/popconfirm.ts", "../../../packages/components/popconfirm/src/popconfirm.vue", "../../../packages/components/popconfirm/index.ts", "../../../packages/components/popover/src/popover.ts", "../../../packages/components/popover/src/popover.vue", "../../../packages/components/popover/src/directive.ts", "../../../packages/components/popover/index.ts", "../../../packages/components/progress/src/progress.ts", "../../../packages/components/progress/src/progress.vue", "../../../packages/components/progress/index.ts", "../../../packages/components/rate/src/rate.ts", "../../../packages/components/rate/src/rate.vue", "../../../packages/components/rate/index.ts", "../../../packages/components/result/src/result.ts", "../../../packages/components/result/src/result.vue", "../../../packages/components/result/index.ts", "../../memoize-one/dist/memoize-one.esm.js", "../../../packages/components/virtual-list/src/hooks/use-cache.ts", "../../../packages/components/virtual-list/src/defaults.ts", "../../../packages/components/virtual-list/src/hooks/use-wheel.ts", "../../../packages/components/virtual-list/src/props.ts", "../../../packages/components/virtual-list/src/utils.ts", "../../../packages/components/virtual-list/src/components/scrollbar.ts", "../../../packages/components/virtual-list/src/builders/build-list.ts", "../../../packages/components/virtual-list/src/components/fixed-size-list.ts", "../../../packages/components/virtual-list/src/components/dynamic-size-list.ts", "../../../packages/components/virtual-list/src/hooks/use-grid-wheel.ts", "../../../packages/components/virtual-list/src/builders/build-grid.ts", "../../../packages/components/virtual-list/src/components/fixed-size-grid.ts", "../../../packages/components/virtual-list/src/components/dynamic-size-grid.ts", "../../../packages/components/select-v2/src/group-item.vue", "../../../packages/components/select-v2/src/useOption.ts", "../../../packages/components/select-v2/src/useProps.ts", "../../../packages/components/select-v2/src/defaults.ts", "../../../packages/components/select-v2/src/token.ts", "../../../packages/components/select-v2/src/option-item.vue", "../../../packages/components/select-v2/src/select-dropdown.tsx", "../../../packages/components/select-v2/src/useAllowCreate.ts", "../../../packages/components/select-v2/src/useSelect.ts", "../../../packages/components/select-v2/src/select.vue", "../../../packages/components/select-v2/index.ts", "../../../packages/components/skeleton/src/skeleton.ts", "../../../packages/components/skeleton/src/skeleton-item.ts", "../../../packages/components/skeleton/src/skeleton-item.vue", "../../../packages/components/skeleton/src/skeleton.vue", "../../../packages/components/skeleton/index.ts", "../../../packages/components/slider/src/constants.ts", "../../../packages/components/slider/src/slider.ts", "../../../packages/components/slider/src/composables/use-lifecycle.ts", "../../../packages/components/slider/src/composables/use-marks.ts", "../../../packages/components/slider/src/composables/use-slide.ts", "../../../packages/components/slider/src/composables/use-slider-button.ts", "../../../packages/components/slider/src/composables/use-stops.ts", "../../../packages/components/slider/src/composables/use-watch.ts", "../../../packages/components/slider/src/button.ts", "../../../packages/components/slider/src/button.vue", "../../../packages/components/slider/src/marker.ts", "../../../packages/components/slider/src/slider.vue", "../../../packages/components/slider/index.ts", "../../../packages/components/space/src/item.ts", "../../../packages/components/space/src/use-space.ts", "../../../packages/components/space/src/space.ts", "../../../packages/components/space/index.ts", "../../../packages/components/statistic/src/statistic.ts", "../../../packages/components/statistic/src/statistic.vue", "../../../packages/components/statistic/index.ts", "../../../packages/components/countdown/src/countdown.ts", "../../../packages/components/countdown/src/utils.ts", "../../../packages/components/countdown/src/countdown.vue", "../../../packages/components/countdown/index.ts", "../../../packages/components/steps/src/steps.ts", "../../../packages/components/steps/src/steps.vue", "../../../packages/components/steps/src/item.ts", "../../../packages/components/steps/src/item.vue", "../../../packages/components/steps/index.ts", "../../../packages/components/switch/src/switch.ts", "../../../packages/components/switch/src/switch.vue", "../../../packages/components/switch/index.ts", "../../../packages/components/table/src/util.ts", "../../../packages/components/table/src/store/expand.ts", "../../../packages/components/table/src/store/current.ts", "../../../packages/components/table/src/store/tree.ts", "../../../packages/components/table/src/store/watcher.ts", "../../../packages/components/table/src/store/index.ts", "../../../packages/components/table/src/store/helper.ts", "../../../packages/components/table/src/table-layout.ts", "../../../packages/components/table/src/filter-panel.vue", "../../../packages/components/table/src/layout-observer.ts", "../../../packages/components/table/src/tokens.ts", "../../../packages/components/table/src/table-header/event-helper.ts", "../../../packages/components/table/src/table-header/style.helper.ts", "../../../packages/components/table/src/table-header/utils-helper.ts", "../../../packages/components/table/src/table-header/index.ts", "../../../packages/components/table/src/table-body/events-helper.ts", "../../../packages/components/table/src/table-body/styles-helper.ts", "../../../packages/components/table/src/table-body/render-helper.ts", "../../../packages/components/table/src/table-body/defaults.ts", "../../../packages/components/table/src/table-body/index.ts", "../../../packages/components/table/src/table-footer/mapState-helper.ts", "../../../packages/components/table/src/table-footer/style-helper.ts", "../../../packages/components/table/src/table-footer/index.ts", "../../../packages/components/table/src/table/utils-helper.ts", "../../../packages/components/table/src/table/style-helper.ts", "../../../packages/components/table/src/table/key-render-helper.ts", "../../../packages/components/table/src/table/defaults.ts", "../../../packages/components/table/src/h-helper.ts", "../../../packages/components/table/src/composables/use-scrollbar.ts", "../../../packages/components/table/src/table.vue", "../../../packages/components/table/src/config.ts", "../../../packages/components/table/src/table-column/watcher-helper.ts", "../../../packages/components/table/src/table-column/render-helper.ts", "../../../packages/components/table/src/table-column/defaults.ts", "../../../packages/components/table/src/table-column/index.ts", "../../../packages/components/table/index.ts", "../../../packages/components/table-v2/src/constants.ts", "../../../packages/components/table-v2/src/private.ts", "../../../packages/components/table-v2/src/composables/utils.ts", "../../../packages/components/table-v2/src/composables/use-columns.ts", "../../../packages/components/table-v2/src/composables/use-scrollbar.ts", "../../../packages/components/table-v2/src/composables/use-row.ts", "../../../packages/components/table-v2/src/composables/use-data.ts", "../../../packages/components/table-v2/src/utils.ts", "../../../packages/components/table-v2/src/composables/use-styles.ts", "../../../packages/components/table-v2/src/composables/use-auto-resize.ts", "../../../packages/components/table-v2/src/use-table.ts", "../../../packages/components/table-v2/src/tokens.ts", "../../../packages/components/table-v2/src/common.ts", "../../../packages/components/table-v2/src/row.ts", "../../../packages/components/table-v2/src/header.ts", "../../../packages/components/table-v2/src/grid.ts", "../../../packages/components/table-v2/src/table.ts", "../../../packages/components/table-v2/src/components/cell.tsx", "../../../packages/components/table-v2/src/components/header-cell.tsx", "../../../packages/components/table-v2/src/header-row.ts", "../../../packages/components/table-v2/src/components/header-row.tsx", "../../../packages/components/table-v2/src/components/header.tsx", "../../../packages/components/table-v2/src/components/row.tsx", "../../../packages/components/table-v2/src/components/sort-icon.tsx", "../../../packages/components/table-v2/src/components/expand-icon.tsx", "../../../packages/components/table-v2/src/table-grid.tsx", "../../../packages/components/table-v2/src/renderers/main-table.tsx", "../../../packages/components/table-v2/src/renderers/left-table.tsx", "../../../packages/components/table-v2/src/renderers/right-table.tsx", "../../../packages/components/table-v2/src/renderers/row.tsx", "../../../packages/components/table-v2/src/renderers/cell.tsx", "../../../packages/components/table-v2/src/renderers/header.tsx", "../../../packages/components/table-v2/src/renderers/header-cell.tsx", "../../../packages/components/table-v2/src/renderers/footer.tsx", "../../../packages/components/table-v2/src/renderers/empty.tsx", "../../../packages/components/table-v2/src/renderers/overlay.tsx", "../../../packages/components/table-v2/src/table-v2.tsx", "../../../packages/components/table-v2/src/auto-resizer.ts", "../../../packages/components/table-v2/src/components/auto-resizer.tsx", "../../../packages/components/table-v2/index.ts", "../../../packages/components/tabs/src/constants.ts", "../../../packages/components/tabs/src/tab-bar.ts", "../../../packages/components/tabs/src/tab-bar.vue", "../../../packages/components/tabs/src/tab-nav.tsx", "../../../packages/components/tabs/src/tabs.tsx", "../../../packages/components/tabs/src/tab-pane.ts", "../../../packages/components/tabs/src/tab-pane.vue", "../../../packages/components/tabs/index.ts", "../../../packages/components/text/src/text.ts", "../../../packages/components/text/src/text.vue", "../../../packages/components/text/index.ts", "../../../packages/components/time-select/src/time-select.ts", "../../../packages/components/time-select/src/utils.ts", "../../../packages/components/time-select/src/time-select.vue", "../../../packages/components/time-select/index.ts", "../../../packages/components/timeline/src/timeline.ts", "../../../packages/components/timeline/src/timeline-item.ts", "../../../packages/components/timeline/src/timeline-item.vue", "../../../packages/components/timeline/index.ts", "../../../packages/components/tooltip-v2/src/common.ts", "../../../packages/components/tooltip-v2/src/arrow.ts", "../../../packages/components/tooltip-v2/src/content.ts", "../../../packages/components/tooltip-v2/src/root.ts", "../../../packages/components/tooltip-v2/src/trigger.ts", "../../../packages/components/tooltip-v2/src/tooltip.ts", "../../../packages/components/tooltip-v2/src/constants.ts", "../../../packages/components/tooltip-v2/src/root.vue", "../../../packages/components/tooltip-v2/src/arrow.vue", "../../../packages/components/visual-hidden/src/visual-hidden.ts", "../../../packages/components/visual-hidden/src/visual-hidden.vue", "../../../packages/components/tooltip-v2/src/content.vue", "../../../packages/components/tooltip-v2/src/forward-ref.tsx", "../../../packages/components/tooltip-v2/src/trigger.vue", "../../../packages/components/tooltip-v2/src/tooltip.vue", "../../../packages/components/tooltip-v2/index.ts", "../../../packages/components/transfer/src/transfer.ts", "../../../packages/components/transfer/src/transfer-panel.ts", "../../../packages/components/transfer/src/composables/use-props-alias.ts", "../../../packages/components/transfer/src/composables/use-check.ts", "../../../packages/components/transfer/src/composables/use-checked-change.ts", "../../../packages/components/transfer/src/composables/use-computed-data.ts", "../../../packages/components/transfer/src/composables/use-move.ts", "../../../packages/components/transfer/src/transfer-panel.vue", "../../../packages/components/transfer/src/transfer.vue", "../../../packages/components/transfer/index.ts", "../../../packages/components/tree/src/model/util.ts", "../../../packages/components/tree/src/model/node.ts", "../../../packages/components/tree/src/model/tree-store.ts", "../../../packages/components/tree/src/tree-node-content.vue", "../../../packages/components/tree/src/model/useNodeExpandEventBroadcast.ts", "../../../packages/components/tree/src/model/useDragNode.ts", "../../../packages/components/tree/src/tree-node.vue", "../../../packages/components/tree/src/model/useKeydown.ts", "../../../packages/components/tree/src/tree.vue", "../../../packages/components/tree/index.ts", "../../../packages/components/tree-select/src/select.ts", "../../../packages/components/tree-select/src/tree-select-option.ts", "../../../packages/components/tree-select/src/utils.ts", "../../../packages/components/tree-select/src/tree.ts", "../../../packages/components/tree-select/src/cache-options.ts", "../../../packages/components/tree-select/src/tree-select.vue", "../../../packages/components/tree-select/index.ts", "../../../packages/components/tree-v2/src/virtual-tree.ts", "../../../packages/components/tree-v2/src/composables/useCheck.ts", "../../../packages/components/tree-v2/src/composables/useFilter.ts", "../../../packages/components/tree-v2/src/composables/useTree.ts", "../../../packages/components/tree-v2/src/tree-node-content.ts", "../../../packages/components/tree-v2/src/tree-node.vue", "../../../packages/components/tree-v2/src/tree.vue", "../../../packages/components/tree-v2/index.ts", "../../../packages/components/upload/src/constants.ts", "../../../packages/components/upload/src/ajax.ts", "../../../packages/components/upload/src/upload.ts", "../../../packages/components/upload/src/upload-list.ts", "../../../packages/components/upload/src/upload-list.vue", "../../../packages/components/upload/src/upload-dragger.ts", "../../../packages/components/upload/src/upload-dragger.vue", "../../../packages/components/upload/src/upload-content.ts", "../../../packages/components/upload/src/upload-content.vue", "../../../packages/components/upload/src/use-handlers.ts", "../../../packages/components/upload/src/upload.vue", "../../../packages/components/upload/index.ts", "../../../packages/components/watermark/src/watermark.ts", "../../../packages/components/watermark/src/utils.ts", "../../../packages/components/watermark/src/useClips.ts", "../../../packages/components/watermark/src/watermark.vue", "../../../packages/components/watermark/index.ts", "../../../packages/components/tour/src/mask.ts", "../../../packages/components/tour/src/helper.ts", "../../../packages/components/tour/src/mask.vue", "../../../packages/components/tour/src/content.ts", "../../../packages/components/tour/src/content.vue", "../../../packages/components/tour/src/steps.ts", "../../../packages/components/tour/src/tour.ts", "../../../packages/components/tour/src/tour.vue", "../../../packages/components/tour/src/step.ts", "../../../packages/components/tour/src/step.vue", "../../../packages/components/tour/index.ts", "../../../packages/components/anchor/src/anchor.ts", "../../../packages/components/anchor/src/constants.ts", "../../../packages/components/anchor/src/anchor.vue", "../../../packages/components/anchor/src/anchor-link.ts", "../../../packages/components/anchor/src/anchor-link.vue", "../../../packages/components/anchor/index.ts", "../../../packages/components/segmented/src/segmented.ts", "../../../packages/components/segmented/src/segmented.vue", "../../../packages/components/segmented/index.ts", "../../../packages/components/mention/src/helper.ts", "../../../packages/components/mention/src/mention.ts", "../../../packages/components/mention/src/mention-dropdown.ts", "../../../packages/components/mention/src/mention-dropdown.vue", "../../../packages/components/mention/src/mention.vue", "../../../packages/components/mention/index.ts", "../../../packages/element-plus/component.ts", "../../../packages/components/infinite-scroll/src/index.ts", "../../../packages/components/infinite-scroll/index.ts", "../../../packages/components/loading/src/loading.ts", "../../../packages/components/loading/src/service.ts", "../../../packages/components/loading/src/directive.ts", "../../../packages/components/loading/index.ts", "../../../packages/components/message/src/message.ts", "../../../packages/components/message/src/instance.ts", "../../../packages/components/message/src/message.vue", "../../../packages/components/message/src/method.ts", "../../../packages/components/message/index.ts", "../../../packages/components/message-box/src/index.vue", "../../../packages/components/message-box/src/messageBox.ts", "../../../packages/components/message-box/index.ts", "../../../packages/components/notification/src/notification.ts", "../../../packages/components/notification/src/notification.vue", "../../../packages/components/notification/src/notify.ts", "../../../packages/components/notification/index.ts", "../../../packages/element-plus/plugin.ts", "../../../packages/element-plus/defaults.ts", "../../../packages/element-plus/index.ts"],
  "sourcesContent": ["!function(t,e){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=e():\"function\"==typeof define&&define.amd?define(e):(t=\"undefined\"!=typeof globalThis?globalThis:t||self).dayjs=e()}(this,(function(){\"use strict\";var t=1e3,e=6e4,n=36e5,r=\"millisecond\",i=\"second\",s=\"minute\",u=\"hour\",a=\"day\",o=\"week\",c=\"month\",f=\"quarter\",h=\"year\",d=\"date\",l=\"Invalid Date\",$=/^(\\d{4})[-/]?(\\d{1,2})?[-/]?(\\d{0,2})[Tt\\s]*(\\d{1,2})?:?(\\d{1,2})?:?(\\d{1,2})?[.:]?(\\d+)?$/,y=/\\[([^\\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g,M={name:\"en\",weekdays:\"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday\".split(\"_\"),months:\"January_February_March_April_May_June_July_August_September_October_November_December\".split(\"_\"),ordinal:function(t){var e=[\"th\",\"st\",\"nd\",\"rd\"],n=t%100;return\"[\"+t+(e[(n-20)%10]||e[n]||e[0])+\"]\"}},m=function(t,e,n){var r=String(t);return!r||r.length>=e?t:\"\"+Array(e+1-r.length).join(n)+t},v={s:m,z:function(t){var e=-t.utcOffset(),n=Math.abs(e),r=Math.floor(n/60),i=n%60;return(e<=0?\"+\":\"-\")+m(r,2,\"0\")+\":\"+m(i,2,\"0\")},m:function t(e,n){if(e.date()<n.date())return-t(n,e);var r=12*(n.year()-e.year())+(n.month()-e.month()),i=e.clone().add(r,c),s=n-i<0,u=e.clone().add(r+(s?-1:1),c);return+(-(r+(n-i)/(s?i-u:u-i))||0)},a:function(t){return t<0?Math.ceil(t)||0:Math.floor(t)},p:function(t){return{M:c,y:h,w:o,d:a,D:d,h:u,m:s,s:i,ms:r,Q:f}[t]||String(t||\"\").toLowerCase().replace(/s$/,\"\")},u:function(t){return void 0===t}},g=\"en\",D={};D[g]=M;var p=\"$isDayjsObject\",S=function(t){return t instanceof _||!(!t||!t[p])},w=function t(e,n,r){var i;if(!e)return g;if(\"string\"==typeof e){var s=e.toLowerCase();D[s]&&(i=s),n&&(D[s]=n,i=s);var u=e.split(\"-\");if(!i&&u.length>1)return t(u[0])}else{var a=e.name;D[a]=e,i=a}return!r&&i&&(g=i),i||!r&&g},O=function(t,e){if(S(t))return t.clone();var n=\"object\"==typeof e?e:{};return n.date=t,n.args=arguments,new _(n)},b=v;b.l=w,b.i=S,b.w=function(t,e){return O(t,{locale:e.$L,utc:e.$u,x:e.$x,$offset:e.$offset})};var _=function(){function M(t){this.$L=w(t.locale,null,!0),this.parse(t),this.$x=this.$x||t.x||{},this[p]=!0}var m=M.prototype;return m.parse=function(t){this.$d=function(t){var e=t.date,n=t.utc;if(null===e)return new Date(NaN);if(b.u(e))return new Date;if(e instanceof Date)return new Date(e);if(\"string\"==typeof e&&!/Z$/i.test(e)){var r=e.match($);if(r){var i=r[2]-1||0,s=(r[7]||\"0\").substring(0,3);return n?new Date(Date.UTC(r[1],i,r[3]||1,r[4]||0,r[5]||0,r[6]||0,s)):new Date(r[1],i,r[3]||1,r[4]||0,r[5]||0,r[6]||0,s)}}return new Date(e)}(t),this.init()},m.init=function(){var t=this.$d;this.$y=t.getFullYear(),this.$M=t.getMonth(),this.$D=t.getDate(),this.$W=t.getDay(),this.$H=t.getHours(),this.$m=t.getMinutes(),this.$s=t.getSeconds(),this.$ms=t.getMilliseconds()},m.$utils=function(){return b},m.isValid=function(){return!(this.$d.toString()===l)},m.isSame=function(t,e){var n=O(t);return this.startOf(e)<=n&&n<=this.endOf(e)},m.isAfter=function(t,e){return O(t)<this.startOf(e)},m.isBefore=function(t,e){return this.endOf(e)<O(t)},m.$g=function(t,e,n){return b.u(t)?this[e]:this.set(n,t)},m.unix=function(){return Math.floor(this.valueOf()/1e3)},m.valueOf=function(){return this.$d.getTime()},m.startOf=function(t,e){var n=this,r=!!b.u(e)||e,f=b.p(t),l=function(t,e){var i=b.w(n.$u?Date.UTC(n.$y,e,t):new Date(n.$y,e,t),n);return r?i:i.endOf(a)},$=function(t,e){return b.w(n.toDate()[t].apply(n.toDate(\"s\"),(r?[0,0,0,0]:[23,59,59,999]).slice(e)),n)},y=this.$W,M=this.$M,m=this.$D,v=\"set\"+(this.$u?\"UTC\":\"\");switch(f){case h:return r?l(1,0):l(31,11);case c:return r?l(1,M):l(0,M+1);case o:var g=this.$locale().weekStart||0,D=(y<g?y+7:y)-g;return l(r?m-D:m+(6-D),M);case a:case d:return $(v+\"Hours\",0);case u:return $(v+\"Minutes\",1);case s:return $(v+\"Seconds\",2);case i:return $(v+\"Milliseconds\",3);default:return this.clone()}},m.endOf=function(t){return this.startOf(t,!1)},m.$set=function(t,e){var n,o=b.p(t),f=\"set\"+(this.$u?\"UTC\":\"\"),l=(n={},n[a]=f+\"Date\",n[d]=f+\"Date\",n[c]=f+\"Month\",n[h]=f+\"FullYear\",n[u]=f+\"Hours\",n[s]=f+\"Minutes\",n[i]=f+\"Seconds\",n[r]=f+\"Milliseconds\",n)[o],$=o===a?this.$D+(e-this.$W):e;if(o===c||o===h){var y=this.clone().set(d,1);y.$d[l]($),y.init(),this.$d=y.set(d,Math.min(this.$D,y.daysInMonth())).$d}else l&&this.$d[l]($);return this.init(),this},m.set=function(t,e){return this.clone().$set(t,e)},m.get=function(t){return this[b.p(t)]()},m.add=function(r,f){var d,l=this;r=Number(r);var $=b.p(f),y=function(t){var e=O(l);return b.w(e.date(e.date()+Math.round(t*r)),l)};if($===c)return this.set(c,this.$M+r);if($===h)return this.set(h,this.$y+r);if($===a)return y(1);if($===o)return y(7);var M=(d={},d[s]=e,d[u]=n,d[i]=t,d)[$]||1,m=this.$d.getTime()+r*M;return b.w(m,this)},m.subtract=function(t,e){return this.add(-1*t,e)},m.format=function(t){var e=this,n=this.$locale();if(!this.isValid())return n.invalidDate||l;var r=t||\"YYYY-MM-DDTHH:mm:ssZ\",i=b.z(this),s=this.$H,u=this.$m,a=this.$M,o=n.weekdays,c=n.months,f=n.meridiem,h=function(t,n,i,s){return t&&(t[n]||t(e,r))||i[n].slice(0,s)},d=function(t){return b.s(s%12||12,t,\"0\")},$=f||function(t,e,n){var r=t<12?\"AM\":\"PM\";return n?r.toLowerCase():r};return r.replace(y,(function(t,r){return r||function(t){switch(t){case\"YY\":return String(e.$y).slice(-2);case\"YYYY\":return b.s(e.$y,4,\"0\");case\"M\":return a+1;case\"MM\":return b.s(a+1,2,\"0\");case\"MMM\":return h(n.monthsShort,a,c,3);case\"MMMM\":return h(c,a);case\"D\":return e.$D;case\"DD\":return b.s(e.$D,2,\"0\");case\"d\":return String(e.$W);case\"dd\":return h(n.weekdaysMin,e.$W,o,2);case\"ddd\":return h(n.weekdaysShort,e.$W,o,3);case\"dddd\":return o[e.$W];case\"H\":return String(s);case\"HH\":return b.s(s,2,\"0\");case\"h\":return d(1);case\"hh\":return d(2);case\"a\":return $(s,u,!0);case\"A\":return $(s,u,!1);case\"m\":return String(u);case\"mm\":return b.s(u,2,\"0\");case\"s\":return String(e.$s);case\"ss\":return b.s(e.$s,2,\"0\");case\"SSS\":return b.s(e.$ms,3,\"0\");case\"Z\":return i}return null}(t)||i.replace(\":\",\"\")}))},m.utcOffset=function(){return 15*-Math.round(this.$d.getTimezoneOffset()/15)},m.diff=function(r,d,l){var $,y=this,M=b.p(d),m=O(r),v=(m.utcOffset()-this.utcOffset())*e,g=this-m,D=function(){return b.m(y,m)};switch(M){case h:$=D()/12;break;case c:$=D();break;case f:$=D()/3;break;case o:$=(g-v)/6048e5;break;case a:$=(g-v)/864e5;break;case u:$=g/n;break;case s:$=g/e;break;case i:$=g/t;break;default:$=g}return l?$:b.a($)},m.daysInMonth=function(){return this.endOf(c).$D},m.$locale=function(){return D[this.$L]},m.locale=function(t,e){if(!t)return this.$L;var n=this.clone(),r=w(t,e,!0);return r&&(n.$L=r),n},m.clone=function(){return b.w(this.$d,this)},m.toDate=function(){return new Date(this.valueOf())},m.toJSON=function(){return this.isValid()?this.toISOString():null},m.toISOString=function(){return this.$d.toISOString()},m.toString=function(){return this.$d.toUTCString()},M}(),k=_.prototype;return O.prototype=k,[[\"$ms\",r],[\"$s\",i],[\"$m\",s],[\"$H\",u],[\"$W\",a],[\"$M\",c],[\"$y\",h],[\"$D\",d]].forEach((function(t){k[t[1]]=function(e){return this.$g(e,t[0],t[1])}})),O.extend=function(t,e){return t.$i||(t(e,_,O),t.$i=!0),O},O.locale=w,O.isDayjs=S,O.unix=function(t){return O(1e3*t)},O.en=D[g],O.Ls=D,O.p={},O}));", "!function(e,t){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define(t):(e=\"undefined\"!=typeof globalThis?globalThis:e||self).dayjs_plugin_customParseFormat=t()}(this,(function(){\"use strict\";var e={LTS:\"h:mm:ss A\",LT:\"h:mm A\",L:\"MM/DD/YYYY\",LL:\"MMMM D, YYYY\",LLL:\"MMMM D, YYYY h:mm A\",LLLL:\"dddd, MMMM D, YYYY h:mm A\"},t=/(\\[[^[]*\\])|([-_:/.,()\\s]+)|(A|a|YYYY|YY?|MM?M?M?|Do|DD?|hh?|HH?|mm?|ss?|S{1,3}|z|ZZ?)/g,n=/\\d\\d/,r=/\\d\\d?/,i=/\\d*[^-_:/,()\\s\\d]+/,o={},s=function(e){return(e=+e)+(e>68?1900:2e3)};var a=function(e){return function(t){this[e]=+t}},f=[/[+-]\\d\\d:?(\\d\\d)?|Z/,function(e){(this.zone||(this.zone={})).offset=function(e){if(!e)return 0;if(\"Z\"===e)return 0;var t=e.match(/([+-]|\\d\\d)/g),n=60*t[1]+(+t[2]||0);return 0===n?0:\"+\"===t[0]?-n:n}(e)}],h=function(e){var t=o[e];return t&&(t.indexOf?t:t.s.concat(t.f))},u=function(e,t){var n,r=o.meridiem;if(r){for(var i=1;i<=24;i+=1)if(e.indexOf(r(i,0,t))>-1){n=i>12;break}}else n=e===(t?\"pm\":\"PM\");return n},d={A:[i,function(e){this.afternoon=u(e,!1)}],a:[i,function(e){this.afternoon=u(e,!0)}],S:[/\\d/,function(e){this.milliseconds=100*+e}],SS:[n,function(e){this.milliseconds=10*+e}],SSS:[/\\d{3}/,function(e){this.milliseconds=+e}],s:[r,a(\"seconds\")],ss:[r,a(\"seconds\")],m:[r,a(\"minutes\")],mm:[r,a(\"minutes\")],H:[r,a(\"hours\")],h:[r,a(\"hours\")],HH:[r,a(\"hours\")],hh:[r,a(\"hours\")],D:[r,a(\"day\")],DD:[n,a(\"day\")],Do:[i,function(e){var t=o.ordinal,n=e.match(/\\d+/);if(this.day=n[0],t)for(var r=1;r<=31;r+=1)t(r).replace(/\\[|\\]/g,\"\")===e&&(this.day=r)}],M:[r,a(\"month\")],MM:[n,a(\"month\")],MMM:[i,function(e){var t=h(\"months\"),n=(h(\"monthsShort\")||t.map((function(e){return e.slice(0,3)}))).indexOf(e)+1;if(n<1)throw new Error;this.month=n%12||n}],MMMM:[i,function(e){var t=h(\"months\").indexOf(e)+1;if(t<1)throw new Error;this.month=t%12||t}],Y:[/[+-]?\\d+/,a(\"year\")],YY:[n,function(e){this.year=s(e)}],YYYY:[/\\d{4}/,a(\"year\")],Z:f,ZZ:f};function c(n){var r,i;r=n,i=o&&o.formats;for(var s=(n=r.replace(/(\\[[^\\]]+])|(LTS?|l{1,4}|L{1,4})/g,(function(t,n,r){var o=r&&r.toUpperCase();return n||i[r]||e[r]||i[o].replace(/(\\[[^\\]]+])|(MMMM|MM|DD|dddd)/g,(function(e,t,n){return t||n.slice(1)}))}))).match(t),a=s.length,f=0;f<a;f+=1){var h=s[f],u=d[h],c=u&&u[0],l=u&&u[1];s[f]=l?{regex:c,parser:l}:h.replace(/^\\[|\\]$/g,\"\")}return function(e){for(var t={},n=0,r=0;n<a;n+=1){var i=s[n];if(\"string\"==typeof i)r+=i.length;else{var o=i.regex,f=i.parser,h=e.slice(r),u=o.exec(h)[0];f.call(t,u),e=e.replace(u,\"\")}}return function(e){var t=e.afternoon;if(void 0!==t){var n=e.hours;t?n<12&&(e.hours+=12):12===n&&(e.hours=0),delete e.afternoon}}(t),t}}return function(e,t,n){n.p.customParseFormat=!0,e&&e.parseTwoDigitYear&&(s=e.parseTwoDigitYear);var r=t.prototype,i=r.parse;r.parse=function(e){var t=e.date,r=e.utc,s=e.args;this.$u=r;var a=s[1];if(\"string\"==typeof a){var f=!0===s[2],h=!0===s[3],u=f||h,d=s[2];h&&(d=s[2]),o=this.$locale(),!f&&d&&(o=n.Ls[d]),this.$d=function(e,t,n){try{if([\"x\",\"X\"].indexOf(t)>-1)return new Date((\"X\"===t?1e3:1)*e);var r=c(t)(e),i=r.year,o=r.month,s=r.day,a=r.hours,f=r.minutes,h=r.seconds,u=r.milliseconds,d=r.zone,l=new Date,m=s||(i||o?1:l.getDate()),M=i||l.getFullYear(),Y=0;i&&!o||(Y=o>0?o-1:l.getMonth());var p=a||0,v=f||0,D=h||0,g=u||0;return d?new Date(Date.UTC(M,Y,m,p,v,D,g+60*d.offset*1e3)):n?new Date(Date.UTC(M,Y,m,p,v,D,g)):new Date(M,Y,m,p,v,D,g)}catch(e){return new Date(\"\")}}(t,a,r),this.init(),d&&!0!==d&&(this.$L=this.locale(d).$L),u&&t!=this.format(a)&&(this.$d=new Date(\"\")),o={}}else if(a instanceof Array)for(var l=a.length,m=1;m<=l;m+=1){s[1]=a[m-1];var M=n.apply(this,s);if(M.isValid()){this.$d=M.$d,this.$L=M.$L,this.init();break}m===l&&(this.$d=new Date(\"\"))}else i.call(this,e)}}}));", "!function(n,e){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=e():\"function\"==typeof define&&define.amd?define(e):(n=\"undefined\"!=typeof globalThis?globalThis:n||self).dayjs_plugin_localeData=e()}(this,(function(){\"use strict\";return function(n,e,t){var r=e.prototype,o=function(n){return n&&(n.indexOf?n:n.s)},u=function(n,e,t,r,u){var i=n.name?n:n.$locale(),a=o(i[e]),s=o(i[t]),f=a||s.map((function(n){return n.slice(0,r)}));if(!u)return f;var d=i.weekStart;return f.map((function(n,e){return f[(e+(d||0))%7]}))},i=function(){return t.Ls[t.locale()]},a=function(n,e){return n.formats[e]||function(n){return n.replace(/(\\[[^\\]]+])|(MMMM|MM|DD|dddd)/g,(function(n,e,t){return e||t.slice(1)}))}(n.formats[e.toUpperCase()])},s=function(){var n=this;return{months:function(e){return e?e.format(\"MMMM\"):u(n,\"months\")},monthsShort:function(e){return e?e.format(\"MMM\"):u(n,\"monthsShort\",\"months\",3)},firstDayOfWeek:function(){return n.$locale().weekStart||0},weekdays:function(e){return e?e.format(\"dddd\"):u(n,\"weekdays\")},weekdaysMin:function(e){return e?e.format(\"dd\"):u(n,\"weekdaysMin\",\"weekdays\",2)},weekdaysShort:function(e){return e?e.format(\"ddd\"):u(n,\"weekdaysShort\",\"weekdays\",3)},longDateFormat:function(e){return a(n.$locale(),e)},meridiem:this.$locale().meridiem,ordinal:this.$locale().ordinal}};r.localeData=function(){return s.bind(this)()},t.localeData=function(){var n=i();return{firstDayOfWeek:function(){return n.weekStart||0},weekdays:function(){return t.weekdays()},weekdaysShort:function(){return t.weekdaysShort()},weekdaysMin:function(){return t.weekdaysMin()},months:function(){return t.months()},monthsShort:function(){return t.monthsShort()},longDateFormat:function(e){return a(n,e)},meridiem:n.meridiem,ordinal:n.ordinal}},t.months=function(){return u(i(),\"months\")},t.monthsShort=function(){return u(i(),\"monthsShort\",\"months\",3)},t.weekdays=function(n){return u(i(),\"weekdays\",null,null,n)},t.weekdaysShort=function(n){return u(i(),\"weekdaysShort\",\"weekdays\",3,n)},t.weekdaysMin=function(n){return u(i(),\"weekdaysMin\",\"weekdays\",2,n)}}}));", "!function(e,t){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define(t):(e=\"undefined\"!=typeof globalThis?globalThis:e||self).dayjs_plugin_advancedFormat=t()}(this,(function(){\"use strict\";return function(e,t){var r=t.prototype,n=r.format;r.format=function(e){var t=this,r=this.$locale();if(!this.isValid())return n.bind(this)(e);var s=this.$utils(),a=(e||\"YYYY-MM-DDTHH:mm:ssZ\").replace(/\\[([^\\]]+)]|Q|wo|ww|w|WW|W|zzz|z|gggg|GGGG|Do|X|x|k{1,2}|S/g,(function(e){switch(e){case\"Q\":return Math.ceil((t.$M+1)/3);case\"Do\":return r.ordinal(t.$D);case\"gggg\":return t.weekYear();case\"GGGG\":return t.isoWeekYear();case\"wo\":return r.ordinal(t.week(),\"W\");case\"w\":case\"ww\":return s.s(t.week(),\"w\"===e?1:2,\"0\");case\"W\":case\"WW\":return s.s(t.isoWeek(),\"W\"===e?1:2,\"0\");case\"k\":case\"kk\":return s.s(String(0===t.$H?24:t.$H),\"k\"===e?1:2,\"0\");case\"X\":return Math.floor(t.$d.getTime()/1e3);case\"x\":return t.$d.getTime();case\"z\":return\"[\"+t.offsetName()+\"]\";case\"zzz\":return\"[\"+t.offsetName(\"long\")+\"]\";default:return e}}));return n.bind(this)(a)}}}));", "!function(e,t){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define(t):(e=\"undefined\"!=typeof globalThis?globalThis:e||self).dayjs_plugin_weekOfYear=t()}(this,(function(){\"use strict\";var e=\"week\",t=\"year\";return function(i,n,r){var f=n.prototype;f.week=function(i){if(void 0===i&&(i=null),null!==i)return this.add(7*(i-this.week()),\"day\");var n=this.$locale().yearStart||1;if(11===this.month()&&this.date()>25){var f=r(this).startOf(t).add(1,t).date(n),s=r(this).endOf(e);if(f.isBefore(s))return 1}var a=r(this).startOf(t).date(n).startOf(e).subtract(1,\"millisecond\"),o=this.diff(a,e,!0);return o<0?r(this).startOf(\"week\").week():Math.ceil(o)},f.weeks=function(e){return void 0===e&&(e=null),this.week(e)}}}));", "!function(e,t){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define(t):(e=\"undefined\"!=typeof globalThis?globalThis:e||self).dayjs_plugin_weekYear=t()}(this,(function(){\"use strict\";return function(e,t){t.prototype.weekYear=function(){var e=this.month(),t=this.week(),n=this.year();return 1===t&&11===e?n+1:0===e&&t>=52?n-1:n}}}));", "!function(e,t){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define(t):(e=\"undefined\"!=typeof globalThis?globalThis:e||self).dayjs_plugin_dayOfYear=t()}(this,(function(){\"use strict\";return function(e,t,n){t.prototype.dayOfYear=function(e){var t=Math.round((n(this).startOf(\"day\")-n(this).startOf(\"year\"))/864e5)+1;return null==e?t:this.add(e-t,\"day\")}}}));", "!function(e,t){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define(t):(e=\"undefined\"!=typeof globalThis?globalThis:e||self).dayjs_plugin_isSameOrAfter=t()}(this,(function(){\"use strict\";return function(e,t){t.prototype.isSameOrAfter=function(e,t){return this.isSame(e,t)||this.isAfter(e,t)}}}));", "!function(e,i){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=i():\"function\"==typeof define&&define.amd?define(i):(e=\"undefined\"!=typeof globalThis?globalThis:e||self).dayjs_plugin_isSameOrBefore=i()}(this,(function(){\"use strict\";return function(e,i){i.prototype.isSameOrBefore=function(e,i){return this.isSame(e,i)||this.isBefore(e,i)}}}));", "const FOCUSABLE_ELEMENT_SELECTORS = `a[href],button:not([disabled]),button:not([hidden]),:not([tabindex=\"-1\"]),input:not([disabled]),input:not([type=\"hidden\"]),select:not([disabled]),textarea:not([disabled])`\n\n/**\n * Determine if the testing element is visible on screen no matter if its on the viewport or not\n */\nexport const isVisible = (element: HTMLElement) => {\n  if (process.env.NODE_ENV === 'test') return true\n  const computed = getComputedStyle(element)\n  // element.offsetParent won't work on fix positioned\n  // WARNING: potential issue here, going to need some expert advices on this issue\n  return computed.position === 'fixed' ? false : element.offsetParent !== null\n}\n\nexport const obtainAllFocusableElements = (\n  element: HTMLElement\n): HTMLElement[] => {\n  return Array.from(\n    element.querySelectorAll<HTMLElement>(FOCUSABLE_ELEMENT_SELECTORS)\n  ).filter((item: HTMLElement) => isFocusable(item) && isVisible(item))\n}\n\n/**\n * @desc Determine if target element is focusable\n * @param element {HTMLElement}\n * @returns {Boolean} true if it is focusable\n */\nexport const isFocusable = (element: HTMLElement): boolean => {\n  if (\n    element.tabIndex > 0 ||\n    (element.tabIndex === 0 && element.getAttribute('tabIndex') !== null)\n  ) {\n    return true\n  }\n  // HTMLButtonElement has disabled\n  if ((element as HTMLButtonElement).disabled) {\n    return false\n  }\n\n  switch (element.nodeName) {\n    case 'A': {\n      // casting current element to Specific HTMLElement in order to be more type precise\n      return (\n        !!(element as HTMLAnchorElement).href &&\n        (element as HTMLAnchorElement).rel !== 'ignore'\n      )\n    }\n    case 'INPUT': {\n      return !(\n        (element as HTMLInputElement).type === 'hidden' ||\n        (element as HTMLInputElement).type === 'file'\n      )\n    }\n    case 'BUTTON':\n    case 'SELECT':\n    case 'TEXTAREA': {\n      return true\n    }\n    default: {\n      return false\n    }\n  }\n}\n\n/**\n * @desc Set Attempt to set focus on the current node.\n * @param element\n *          The node to attempt to focus on.\n * @returns\n *  true if element is focused.\n */\nexport const attemptFocus = (element: HTMLElement): boolean => {\n  if (!isFocusable(element)) {\n    return false\n  }\n  // Remove the old try catch block since there will be no error to be thrown\n  element.focus?.()\n  return document.activeElement === element\n}\n\n/**\n * Trigger an event\n * mouseenter, mouseleave, mouseover, keyup, change, click, etc.\n * @param  {HTMLElement} elm\n * @param  {String} name\n * @param  {*} opts\n */\nexport const triggerEvent = function (\n  elm: HTMLElement,\n  name: string,\n  ...opts: Array<boolean>\n): HTMLElement {\n  let eventName: string\n\n  if (name.includes('mouse') || name.includes('click')) {\n    eventName = 'MouseEvents'\n  } else if (name.includes('key')) {\n    eventName = 'KeyboardEvent'\n  } else {\n    eventName = 'HTMLEvents'\n  }\n  const evt = document.createEvent(eventName)\n\n  evt.initEvent(name, ...opts)\n  elm.dispatchEvent(evt)\n  return elm\n}\n\nexport const isLeaf = (el: HTMLElement) => !el.getAttribute('aria-owns')\n\nexport const getSibling = (\n  el: HTMLElement,\n  distance: number,\n  elClass: string\n) => {\n  const { parentNode } = el\n  if (!parentNode) return null\n  const siblings = parentNode.querySelectorAll(elClass)\n  const index = Array.prototype.indexOf.call(siblings, el)\n  return siblings[index + distance] || null\n}\n\nexport const focusNode = (el: HTMLElement) => {\n  if (!el) return\n  el.focus()\n  !isLeaf(el) && el.click()\n}\n", "export const composeEventHandlers = <E>(\n  theirsHandler?: (event: E) => boolean | void,\n  oursHandler?: (event: E) => void,\n  { checkForDefaultPrevented = true } = {}\n) => {\n  const handleEvent = (event: E) => {\n    const shouldPrevent = theirsHandler?.(event)\n\n    if (checkForDefaultPrevented === false || !shouldPrevent) {\n      return oursHandler?.(event)\n    }\n  }\n  return handleEvent\n}\n\ntype WhenMouseHandler = (e: PointerEvent) => any\nexport const whenMouse = (handler: WhenMouseHandler): WhenMouseHandler => {\n  return (e: PointerEvent) =>\n    e.pointerType === 'mouse' ? handler(e) : undefined\n}\n", "import { shallowRef, watchEffect, readonly, unref, ref, isVue3, version, watch, customRef, getCurrentScope, onScopeDispose, effectScope, provide, inject, isRef, computed, reactive, toRefs as toRefs$1, toRef, isVue2, set as set$1, getCurrentInstance, onBeforeMount, nextTick, onBeforeUnmount, onMounted, onUnmounted, isReactive } from 'vue-demi';\n\nvar __defProp$9 = Object.defineProperty;\nvar __defProps$6 = Object.defineProperties;\nvar __getOwnPropDescs$6 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$b = Object.getOwnPropertySymbols;\nvar __hasOwnProp$b = Object.prototype.hasOwnProperty;\nvar __propIsEnum$b = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$9 = (obj, key, value) => key in obj ? __defProp$9(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$9 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$b.call(b, prop))\n      __defNormalProp$9(a, prop, b[prop]);\n  if (__getOwnPropSymbols$b)\n    for (var prop of __getOwnPropSymbols$b(b)) {\n      if (__propIsEnum$b.call(b, prop))\n        __defNormalProp$9(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$6 = (a, b) => __defProps$6(a, __getOwnPropDescs$6(b));\nfunction computedEager(fn, options) {\n  var _a;\n  const result = shallowRef();\n  watchEffect(() => {\n    result.value = fn();\n  }, __spreadProps$6(__spreadValues$9({}, options), {\n    flush: (_a = options == null ? void 0 : options.flush) != null ? _a : \"sync\"\n  }));\n  return readonly(result);\n}\n\nvar _a;\nconst isClient = typeof window !== \"undefined\";\nconst isDef = (val) => typeof val !== \"undefined\";\nconst assert = (condition, ...infos) => {\n  if (!condition)\n    console.warn(...infos);\n};\nconst toString = Object.prototype.toString;\nconst isBoolean = (val) => typeof val === \"boolean\";\nconst isFunction = (val) => typeof val === \"function\";\nconst isNumber = (val) => typeof val === \"number\";\nconst isString = (val) => typeof val === \"string\";\nconst isObject = (val) => toString.call(val) === \"[object Object]\";\nconst isWindow = (val) => typeof window !== \"undefined\" && toString.call(val) === \"[object Window]\";\nconst now = () => Date.now();\nconst timestamp = () => +Date.now();\nconst clamp = (n, min, max) => Math.min(max, Math.max(min, n));\nconst noop = () => {\n};\nconst rand = (min, max) => {\n  min = Math.ceil(min);\n  max = Math.floor(max);\n  return Math.floor(Math.random() * (max - min + 1)) + min;\n};\nconst isIOS = isClient && ((_a = window == null ? void 0 : window.navigator) == null ? void 0 : _a.userAgent) && /iP(ad|hone|od)/.test(window.navigator.userAgent);\nconst hasOwn = (val, key) => Object.prototype.hasOwnProperty.call(val, key);\n\nfunction resolveUnref(r) {\n  return typeof r === \"function\" ? r() : unref(r);\n}\n\nfunction createFilterWrapper(filter, fn) {\n  function wrapper(...args) {\n    return new Promise((resolve, reject) => {\n      Promise.resolve(filter(() => fn.apply(this, args), { fn, thisArg: this, args })).then(resolve).catch(reject);\n    });\n  }\n  return wrapper;\n}\nconst bypassFilter = (invoke) => {\n  return invoke();\n};\nfunction debounceFilter(ms, options = {}) {\n  let timer;\n  let maxTimer;\n  let lastRejector = noop;\n  const _clearTimeout = (timer2) => {\n    clearTimeout(timer2);\n    lastRejector();\n    lastRejector = noop;\n  };\n  const filter = (invoke) => {\n    const duration = resolveUnref(ms);\n    const maxDuration = resolveUnref(options.maxWait);\n    if (timer)\n      _clearTimeout(timer);\n    if (duration <= 0 || maxDuration !== void 0 && maxDuration <= 0) {\n      if (maxTimer) {\n        _clearTimeout(maxTimer);\n        maxTimer = null;\n      }\n      return Promise.resolve(invoke());\n    }\n    return new Promise((resolve, reject) => {\n      lastRejector = options.rejectOnCancel ? reject : resolve;\n      if (maxDuration && !maxTimer) {\n        maxTimer = setTimeout(() => {\n          if (timer)\n            _clearTimeout(timer);\n          maxTimer = null;\n          resolve(invoke());\n        }, maxDuration);\n      }\n      timer = setTimeout(() => {\n        if (maxTimer)\n          _clearTimeout(maxTimer);\n        maxTimer = null;\n        resolve(invoke());\n      }, duration);\n    });\n  };\n  return filter;\n}\nfunction throttleFilter(ms, trailing = true, leading = true, rejectOnCancel = false) {\n  let lastExec = 0;\n  let timer;\n  let isLeading = true;\n  let lastRejector = noop;\n  let lastValue;\n  const clear = () => {\n    if (timer) {\n      clearTimeout(timer);\n      timer = void 0;\n      lastRejector();\n      lastRejector = noop;\n    }\n  };\n  const filter = (_invoke) => {\n    const duration = resolveUnref(ms);\n    const elapsed = Date.now() - lastExec;\n    const invoke = () => {\n      return lastValue = _invoke();\n    };\n    clear();\n    if (duration <= 0) {\n      lastExec = Date.now();\n      return invoke();\n    }\n    if (elapsed > duration && (leading || !isLeading)) {\n      lastExec = Date.now();\n      invoke();\n    } else if (trailing) {\n      lastValue = new Promise((resolve, reject) => {\n        lastRejector = rejectOnCancel ? reject : resolve;\n        timer = setTimeout(() => {\n          lastExec = Date.now();\n          isLeading = true;\n          resolve(invoke());\n          clear();\n        }, Math.max(0, duration - elapsed));\n      });\n    }\n    if (!leading && !timer)\n      timer = setTimeout(() => isLeading = true, duration);\n    isLeading = false;\n    return lastValue;\n  };\n  return filter;\n}\nfunction pausableFilter(extendFilter = bypassFilter) {\n  const isActive = ref(true);\n  function pause() {\n    isActive.value = false;\n  }\n  function resume() {\n    isActive.value = true;\n  }\n  const eventFilter = (...args) => {\n    if (isActive.value)\n      extendFilter(...args);\n  };\n  return { isActive: readonly(isActive), pause, resume, eventFilter };\n}\n\nfunction __onlyVue3(name = \"this function\") {\n  if (isVue3)\n    return;\n  throw new Error(`[VueUse] ${name} is only works on Vue 3.`);\n}\nfunction __onlyVue27Plus(name = \"this function\") {\n  if (isVue3 || version.startsWith(\"2.7.\"))\n    return;\n  throw new Error(`[VueUse] ${name} is only works on Vue 2.7 or above.`);\n}\nconst directiveHooks = {\n  mounted: isVue3 ? \"mounted\" : \"inserted\",\n  updated: isVue3 ? \"updated\" : \"componentUpdated\",\n  unmounted: isVue3 ? \"unmounted\" : \"unbind\"\n};\n\nfunction promiseTimeout(ms, throwOnTimeout = false, reason = \"Timeout\") {\n  return new Promise((resolve, reject) => {\n    if (throwOnTimeout)\n      setTimeout(() => reject(reason), ms);\n    else\n      setTimeout(resolve, ms);\n  });\n}\nfunction identity(arg) {\n  return arg;\n}\nfunction createSingletonPromise(fn) {\n  let _promise;\n  function wrapper() {\n    if (!_promise)\n      _promise = fn();\n    return _promise;\n  }\n  wrapper.reset = async () => {\n    const _prev = _promise;\n    _promise = void 0;\n    if (_prev)\n      await _prev;\n  };\n  return wrapper;\n}\nfunction invoke(fn) {\n  return fn();\n}\nfunction containsProp(obj, ...props) {\n  return props.some((k) => k in obj);\n}\nfunction increaseWithUnit(target, delta) {\n  var _a;\n  if (typeof target === \"number\")\n    return target + delta;\n  const value = ((_a = target.match(/^-?[0-9]+\\.?[0-9]*/)) == null ? void 0 : _a[0]) || \"\";\n  const unit = target.slice(value.length);\n  const result = parseFloat(value) + delta;\n  if (Number.isNaN(result))\n    return target;\n  return result + unit;\n}\nfunction objectPick(obj, keys, omitUndefined = false) {\n  return keys.reduce((n, k) => {\n    if (k in obj) {\n      if (!omitUndefined || obj[k] !== void 0)\n        n[k] = obj[k];\n    }\n    return n;\n  }, {});\n}\n\nfunction computedWithControl(source, fn) {\n  let v = void 0;\n  let track;\n  let trigger;\n  const dirty = ref(true);\n  const update = () => {\n    dirty.value = true;\n    trigger();\n  };\n  watch(source, update, { flush: \"sync\" });\n  const get = isFunction(fn) ? fn : fn.get;\n  const set = isFunction(fn) ? void 0 : fn.set;\n  const result = customRef((_track, _trigger) => {\n    track = _track;\n    trigger = _trigger;\n    return {\n      get() {\n        if (dirty.value) {\n          v = get();\n          dirty.value = false;\n        }\n        track();\n        return v;\n      },\n      set(v2) {\n        set == null ? void 0 : set(v2);\n      }\n    };\n  });\n  if (Object.isExtensible(result))\n    result.trigger = update;\n  return result;\n}\n\nfunction tryOnScopeDispose(fn) {\n  if (getCurrentScope()) {\n    onScopeDispose(fn);\n    return true;\n  }\n  return false;\n}\n\nfunction createEventHook() {\n  const fns = [];\n  const off = (fn) => {\n    const index = fns.indexOf(fn);\n    if (index !== -1)\n      fns.splice(index, 1);\n  };\n  const on = (fn) => {\n    fns.push(fn);\n    const offFn = () => off(fn);\n    tryOnScopeDispose(offFn);\n    return {\n      off: offFn\n    };\n  };\n  const trigger = (param) => {\n    fns.forEach((fn) => fn(param));\n  };\n  return {\n    on,\n    off,\n    trigger\n  };\n}\n\nfunction createGlobalState(stateFactory) {\n  let initialized = false;\n  let state;\n  const scope = effectScope(true);\n  return () => {\n    if (!initialized) {\n      state = scope.run(stateFactory);\n      initialized = true;\n    }\n    return state;\n  };\n}\n\nfunction createInjectionState(composable) {\n  const key = Symbol(\"InjectionState\");\n  const useProvidingState = (...args) => {\n    const state = composable(...args);\n    provide(key, state);\n    return state;\n  };\n  const useInjectedState = () => inject(key);\n  return [useProvidingState, useInjectedState];\n}\n\nfunction createSharedComposable(composable) {\n  let subscribers = 0;\n  let state;\n  let scope;\n  const dispose = () => {\n    subscribers -= 1;\n    if (scope && subscribers <= 0) {\n      scope.stop();\n      state = void 0;\n      scope = void 0;\n    }\n  };\n  return (...args) => {\n    subscribers += 1;\n    if (!state) {\n      scope = effectScope(true);\n      state = scope.run(() => composable(...args));\n    }\n    tryOnScopeDispose(dispose);\n    return state;\n  };\n}\n\nfunction extendRef(ref, extend, { enumerable = false, unwrap = true } = {}) {\n  __onlyVue27Plus();\n  for (const [key, value] of Object.entries(extend)) {\n    if (key === \"value\")\n      continue;\n    if (isRef(value) && unwrap) {\n      Object.defineProperty(ref, key, {\n        get() {\n          return value.value;\n        },\n        set(v) {\n          value.value = v;\n        },\n        enumerable\n      });\n    } else {\n      Object.defineProperty(ref, key, { value, enumerable });\n    }\n  }\n  return ref;\n}\n\nfunction get(obj, key) {\n  if (key == null)\n    return unref(obj);\n  return unref(obj)[key];\n}\n\nfunction isDefined(v) {\n  return unref(v) != null;\n}\n\nvar __defProp$8 = Object.defineProperty;\nvar __getOwnPropSymbols$a = Object.getOwnPropertySymbols;\nvar __hasOwnProp$a = Object.prototype.hasOwnProperty;\nvar __propIsEnum$a = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$8 = (obj, key, value) => key in obj ? __defProp$8(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$8 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$a.call(b, prop))\n      __defNormalProp$8(a, prop, b[prop]);\n  if (__getOwnPropSymbols$a)\n    for (var prop of __getOwnPropSymbols$a(b)) {\n      if (__propIsEnum$a.call(b, prop))\n        __defNormalProp$8(a, prop, b[prop]);\n    }\n  return a;\n};\nfunction makeDestructurable(obj, arr) {\n  if (typeof Symbol !== \"undefined\") {\n    const clone = __spreadValues$8({}, obj);\n    Object.defineProperty(clone, Symbol.iterator, {\n      enumerable: false,\n      value() {\n        let index = 0;\n        return {\n          next: () => ({\n            value: arr[index++],\n            done: index > arr.length\n          })\n        };\n      }\n    });\n    return clone;\n  } else {\n    return Object.assign([...arr], obj);\n  }\n}\n\nfunction reactify(fn, options) {\n  const unrefFn = (options == null ? void 0 : options.computedGetter) === false ? unref : resolveUnref;\n  return function(...args) {\n    return computed(() => fn.apply(this, args.map((i) => unrefFn(i))));\n  };\n}\n\nfunction reactifyObject(obj, optionsOrKeys = {}) {\n  let keys = [];\n  let options;\n  if (Array.isArray(optionsOrKeys)) {\n    keys = optionsOrKeys;\n  } else {\n    options = optionsOrKeys;\n    const { includeOwnProperties = true } = optionsOrKeys;\n    keys.push(...Object.keys(obj));\n    if (includeOwnProperties)\n      keys.push(...Object.getOwnPropertyNames(obj));\n  }\n  return Object.fromEntries(keys.map((key) => {\n    const value = obj[key];\n    return [\n      key,\n      typeof value === \"function\" ? reactify(value.bind(obj), options) : value\n    ];\n  }));\n}\n\nfunction toReactive(objectRef) {\n  if (!isRef(objectRef))\n    return reactive(objectRef);\n  const proxy = new Proxy({}, {\n    get(_, p, receiver) {\n      return unref(Reflect.get(objectRef.value, p, receiver));\n    },\n    set(_, p, value) {\n      if (isRef(objectRef.value[p]) && !isRef(value))\n        objectRef.value[p].value = value;\n      else\n        objectRef.value[p] = value;\n      return true;\n    },\n    deleteProperty(_, p) {\n      return Reflect.deleteProperty(objectRef.value, p);\n    },\n    has(_, p) {\n      return Reflect.has(objectRef.value, p);\n    },\n    ownKeys() {\n      return Object.keys(objectRef.value);\n    },\n    getOwnPropertyDescriptor() {\n      return {\n        enumerable: true,\n        configurable: true\n      };\n    }\n  });\n  return reactive(proxy);\n}\n\nfunction reactiveComputed(fn) {\n  return toReactive(computed(fn));\n}\n\nfunction reactiveOmit(obj, ...keys) {\n  const flatKeys = keys.flat();\n  return reactiveComputed(() => Object.fromEntries(Object.entries(toRefs$1(obj)).filter((e) => !flatKeys.includes(e[0]))));\n}\n\nfunction reactivePick(obj, ...keys) {\n  const flatKeys = keys.flat();\n  return reactive(Object.fromEntries(flatKeys.map((k) => [k, toRef(obj, k)])));\n}\n\nfunction refAutoReset(defaultValue, afterMs = 1e4) {\n  return customRef((track, trigger) => {\n    let value = defaultValue;\n    let timer;\n    const resetAfter = () => setTimeout(() => {\n      value = defaultValue;\n      trigger();\n    }, resolveUnref(afterMs));\n    tryOnScopeDispose(() => {\n      clearTimeout(timer);\n    });\n    return {\n      get() {\n        track();\n        return value;\n      },\n      set(newValue) {\n        value = newValue;\n        trigger();\n        clearTimeout(timer);\n        timer = resetAfter();\n      }\n    };\n  });\n}\n\nfunction useDebounceFn(fn, ms = 200, options = {}) {\n  return createFilterWrapper(debounceFilter(ms, options), fn);\n}\n\nfunction refDebounced(value, ms = 200, options = {}) {\n  const debounced = ref(value.value);\n  const updater = useDebounceFn(() => {\n    debounced.value = value.value;\n  }, ms, options);\n  watch(value, () => updater());\n  return debounced;\n}\n\nfunction refDefault(source, defaultValue) {\n  return computed({\n    get() {\n      var _a;\n      return (_a = source.value) != null ? _a : defaultValue;\n    },\n    set(value) {\n      source.value = value;\n    }\n  });\n}\n\nfunction useThrottleFn(fn, ms = 200, trailing = false, leading = true, rejectOnCancel = false) {\n  return createFilterWrapper(throttleFilter(ms, trailing, leading, rejectOnCancel), fn);\n}\n\nfunction refThrottled(value, delay = 200, trailing = true, leading = true) {\n  if (delay <= 0)\n    return value;\n  const throttled = ref(value.value);\n  const updater = useThrottleFn(() => {\n    throttled.value = value.value;\n  }, delay, trailing, leading);\n  watch(value, () => updater());\n  return throttled;\n}\n\nfunction refWithControl(initial, options = {}) {\n  let source = initial;\n  let track;\n  let trigger;\n  const ref = customRef((_track, _trigger) => {\n    track = _track;\n    trigger = _trigger;\n    return {\n      get() {\n        return get();\n      },\n      set(v) {\n        set(v);\n      }\n    };\n  });\n  function get(tracking = true) {\n    if (tracking)\n      track();\n    return source;\n  }\n  function set(value, triggering = true) {\n    var _a, _b;\n    if (value === source)\n      return;\n    const old = source;\n    if (((_a = options.onBeforeChange) == null ? void 0 : _a.call(options, value, old)) === false)\n      return;\n    source = value;\n    (_b = options.onChanged) == null ? void 0 : _b.call(options, value, old);\n    if (triggering)\n      trigger();\n  }\n  const untrackedGet = () => get(false);\n  const silentSet = (v) => set(v, false);\n  const peek = () => get(false);\n  const lay = (v) => set(v, false);\n  return extendRef(ref, {\n    get,\n    set,\n    untrackedGet,\n    silentSet,\n    peek,\n    lay\n  }, { enumerable: true });\n}\nconst controlledRef = refWithControl;\n\nfunction resolveRef(r) {\n  return typeof r === \"function\" ? computed(r) : ref(r);\n}\n\nfunction set(...args) {\n  if (args.length === 2) {\n    const [ref, value] = args;\n    ref.value = value;\n  }\n  if (args.length === 3) {\n    if (isVue2) {\n      set$1(...args);\n    } else {\n      const [target, key, value] = args;\n      target[key] = value;\n    }\n  }\n}\n\nfunction syncRef(left, right, options = {}) {\n  var _a, _b;\n  const {\n    flush = \"sync\",\n    deep = false,\n    immediate = true,\n    direction = \"both\",\n    transform = {}\n  } = options;\n  let watchLeft;\n  let watchRight;\n  const transformLTR = (_a = transform.ltr) != null ? _a : (v) => v;\n  const transformRTL = (_b = transform.rtl) != null ? _b : (v) => v;\n  if (direction === \"both\" || direction === \"ltr\") {\n    watchLeft = watch(left, (newValue) => right.value = transformLTR(newValue), { flush, deep, immediate });\n  }\n  if (direction === \"both\" || direction === \"rtl\") {\n    watchRight = watch(right, (newValue) => left.value = transformRTL(newValue), { flush, deep, immediate });\n  }\n  return () => {\n    watchLeft == null ? void 0 : watchLeft();\n    watchRight == null ? void 0 : watchRight();\n  };\n}\n\nfunction syncRefs(source, targets, options = {}) {\n  const {\n    flush = \"sync\",\n    deep = false,\n    immediate = true\n  } = options;\n  if (!Array.isArray(targets))\n    targets = [targets];\n  return watch(source, (newValue) => targets.forEach((target) => target.value = newValue), { flush, deep, immediate });\n}\n\nvar __defProp$7 = Object.defineProperty;\nvar __defProps$5 = Object.defineProperties;\nvar __getOwnPropDescs$5 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$9 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$9 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$9 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$7 = (obj, key, value) => key in obj ? __defProp$7(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$7 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$9.call(b, prop))\n      __defNormalProp$7(a, prop, b[prop]);\n  if (__getOwnPropSymbols$9)\n    for (var prop of __getOwnPropSymbols$9(b)) {\n      if (__propIsEnum$9.call(b, prop))\n        __defNormalProp$7(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$5 = (a, b) => __defProps$5(a, __getOwnPropDescs$5(b));\nfunction toRefs(objectRef) {\n  if (!isRef(objectRef))\n    return toRefs$1(objectRef);\n  const result = Array.isArray(objectRef.value) ? new Array(objectRef.value.length) : {};\n  for (const key in objectRef.value) {\n    result[key] = customRef(() => ({\n      get() {\n        return objectRef.value[key];\n      },\n      set(v) {\n        if (Array.isArray(objectRef.value)) {\n          const copy = [...objectRef.value];\n          copy[key] = v;\n          objectRef.value = copy;\n        } else {\n          const newObject = __spreadProps$5(__spreadValues$7({}, objectRef.value), { [key]: v });\n          Object.setPrototypeOf(newObject, objectRef.value);\n          objectRef.value = newObject;\n        }\n      }\n    }));\n  }\n  return result;\n}\n\nfunction tryOnBeforeMount(fn, sync = true) {\n  if (getCurrentInstance())\n    onBeforeMount(fn);\n  else if (sync)\n    fn();\n  else\n    nextTick(fn);\n}\n\nfunction tryOnBeforeUnmount(fn) {\n  if (getCurrentInstance())\n    onBeforeUnmount(fn);\n}\n\nfunction tryOnMounted(fn, sync = true) {\n  if (getCurrentInstance())\n    onMounted(fn);\n  else if (sync)\n    fn();\n  else\n    nextTick(fn);\n}\n\nfunction tryOnUnmounted(fn) {\n  if (getCurrentInstance())\n    onUnmounted(fn);\n}\n\nfunction createUntil(r, isNot = false) {\n  function toMatch(condition, { flush = \"sync\", deep = false, timeout, throwOnTimeout } = {}) {\n    let stop = null;\n    const watcher = new Promise((resolve) => {\n      stop = watch(r, (v) => {\n        if (condition(v) !== isNot) {\n          stop == null ? void 0 : stop();\n          resolve(v);\n        }\n      }, {\n        flush,\n        deep,\n        immediate: true\n      });\n    });\n    const promises = [watcher];\n    if (timeout != null) {\n      promises.push(promiseTimeout(timeout, throwOnTimeout).then(() => resolveUnref(r)).finally(() => stop == null ? void 0 : stop()));\n    }\n    return Promise.race(promises);\n  }\n  function toBe(value, options) {\n    if (!isRef(value))\n      return toMatch((v) => v === value, options);\n    const { flush = \"sync\", deep = false, timeout, throwOnTimeout } = options != null ? options : {};\n    let stop = null;\n    const watcher = new Promise((resolve) => {\n      stop = watch([r, value], ([v1, v2]) => {\n        if (isNot !== (v1 === v2)) {\n          stop == null ? void 0 : stop();\n          resolve(v1);\n        }\n      }, {\n        flush,\n        deep,\n        immediate: true\n      });\n    });\n    const promises = [watcher];\n    if (timeout != null) {\n      promises.push(promiseTimeout(timeout, throwOnTimeout).then(() => resolveUnref(r)).finally(() => {\n        stop == null ? void 0 : stop();\n        return resolveUnref(r);\n      }));\n    }\n    return Promise.race(promises);\n  }\n  function toBeTruthy(options) {\n    return toMatch((v) => Boolean(v), options);\n  }\n  function toBeNull(options) {\n    return toBe(null, options);\n  }\n  function toBeUndefined(options) {\n    return toBe(void 0, options);\n  }\n  function toBeNaN(options) {\n    return toMatch(Number.isNaN, options);\n  }\n  function toContains(value, options) {\n    return toMatch((v) => {\n      const array = Array.from(v);\n      return array.includes(value) || array.includes(resolveUnref(value));\n    }, options);\n  }\n  function changed(options) {\n    return changedTimes(1, options);\n  }\n  function changedTimes(n = 1, options) {\n    let count = -1;\n    return toMatch(() => {\n      count += 1;\n      return count >= n;\n    }, options);\n  }\n  if (Array.isArray(resolveUnref(r))) {\n    const instance = {\n      toMatch,\n      toContains,\n      changed,\n      changedTimes,\n      get not() {\n        return createUntil(r, !isNot);\n      }\n    };\n    return instance;\n  } else {\n    const instance = {\n      toMatch,\n      toBe,\n      toBeTruthy,\n      toBeNull,\n      toBeNaN,\n      toBeUndefined,\n      changed,\n      changedTimes,\n      get not() {\n        return createUntil(r, !isNot);\n      }\n    };\n    return instance;\n  }\n}\nfunction until(r) {\n  return createUntil(r);\n}\n\nfunction useArrayEvery(list, fn) {\n  return computed(() => resolveUnref(list).every((element, index, array) => fn(resolveUnref(element), index, array)));\n}\n\nfunction useArrayFilter(list, fn) {\n  return computed(() => resolveUnref(list).map((i) => resolveUnref(i)).filter(fn));\n}\n\nfunction useArrayFind(list, fn) {\n  return computed(() => resolveUnref(resolveUnref(list).find((element, index, array) => fn(resolveUnref(element), index, array))));\n}\n\nfunction useArrayFindIndex(list, fn) {\n  return computed(() => resolveUnref(list).findIndex((element, index, array) => fn(resolveUnref(element), index, array)));\n}\n\nfunction findLast(arr, cb) {\n  let index = arr.length;\n  while (index-- > 0) {\n    if (cb(arr[index], index, arr))\n      return arr[index];\n  }\n  return void 0;\n}\nfunction useArrayFindLast(list, fn) {\n  return computed(() => resolveUnref(!Array.prototype.findLast ? findLast(resolveUnref(list), (element, index, array) => fn(resolveUnref(element), index, array)) : resolveUnref(list).findLast((element, index, array) => fn(resolveUnref(element), index, array))));\n}\n\nfunction useArrayJoin(list, separator) {\n  return computed(() => resolveUnref(list).map((i) => resolveUnref(i)).join(resolveUnref(separator)));\n}\n\nfunction useArrayMap(list, fn) {\n  return computed(() => resolveUnref(list).map((i) => resolveUnref(i)).map(fn));\n}\n\nfunction useArrayReduce(list, reducer, ...args) {\n  const reduceCallback = (sum, value, index) => reducer(resolveUnref(sum), resolveUnref(value), index);\n  return computed(() => {\n    const resolved = resolveUnref(list);\n    return args.length ? resolved.reduce(reduceCallback, resolveUnref(args[0])) : resolved.reduce(reduceCallback);\n  });\n}\n\nfunction useArraySome(list, fn) {\n  return computed(() => resolveUnref(list).some((element, index, array) => fn(resolveUnref(element), index, array)));\n}\n\nfunction useArrayUnique(list) {\n  return computed(() => [...new Set(resolveUnref(list).map((element) => resolveUnref(element)))]);\n}\n\nfunction useCounter(initialValue = 0, options = {}) {\n  const count = ref(initialValue);\n  const {\n    max = Infinity,\n    min = -Infinity\n  } = options;\n  const inc = (delta = 1) => count.value = Math.min(max, count.value + delta);\n  const dec = (delta = 1) => count.value = Math.max(min, count.value - delta);\n  const get = () => count.value;\n  const set = (val) => count.value = Math.max(min, Math.min(max, val));\n  const reset = (val = initialValue) => {\n    initialValue = val;\n    return set(val);\n  };\n  return { count, inc, dec, get, set, reset };\n}\n\nconst REGEX_PARSE = /^(\\d{4})[-/]?(\\d{1,2})?[-/]?(\\d{0,2})[Tt\\s]*(\\d{1,2})?:?(\\d{1,2})?:?(\\d{1,2})?[.:]?(\\d+)?$/;\nconst REGEX_FORMAT = /\\[([^\\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a{1,2}|A{1,2}|m{1,2}|s{1,2}|Z{1,2}|SSS/g;\nconst defaultMeridiem = (hours, minutes, isLowercase, hasPeriod) => {\n  let m = hours < 12 ? \"AM\" : \"PM\";\n  if (hasPeriod)\n    m = m.split(\"\").reduce((acc, curr) => acc += `${curr}.`, \"\");\n  return isLowercase ? m.toLowerCase() : m;\n};\nconst formatDate = (date, formatStr, options = {}) => {\n  var _a;\n  const years = date.getFullYear();\n  const month = date.getMonth();\n  const days = date.getDate();\n  const hours = date.getHours();\n  const minutes = date.getMinutes();\n  const seconds = date.getSeconds();\n  const milliseconds = date.getMilliseconds();\n  const day = date.getDay();\n  const meridiem = (_a = options.customMeridiem) != null ? _a : defaultMeridiem;\n  const matches = {\n    YY: () => String(years).slice(-2),\n    YYYY: () => years,\n    M: () => month + 1,\n    MM: () => `${month + 1}`.padStart(2, \"0\"),\n    MMM: () => date.toLocaleDateString(options.locales, { month: \"short\" }),\n    MMMM: () => date.toLocaleDateString(options.locales, { month: \"long\" }),\n    D: () => String(days),\n    DD: () => `${days}`.padStart(2, \"0\"),\n    H: () => String(hours),\n    HH: () => `${hours}`.padStart(2, \"0\"),\n    h: () => `${hours % 12 || 12}`.padStart(1, \"0\"),\n    hh: () => `${hours % 12 || 12}`.padStart(2, \"0\"),\n    m: () => String(minutes),\n    mm: () => `${minutes}`.padStart(2, \"0\"),\n    s: () => String(seconds),\n    ss: () => `${seconds}`.padStart(2, \"0\"),\n    SSS: () => `${milliseconds}`.padStart(3, \"0\"),\n    d: () => day,\n    dd: () => date.toLocaleDateString(options.locales, { weekday: \"narrow\" }),\n    ddd: () => date.toLocaleDateString(options.locales, { weekday: \"short\" }),\n    dddd: () => date.toLocaleDateString(options.locales, { weekday: \"long\" }),\n    A: () => meridiem(hours, minutes),\n    AA: () => meridiem(hours, minutes, false, true),\n    a: () => meridiem(hours, minutes, true),\n    aa: () => meridiem(hours, minutes, true, true)\n  };\n  return formatStr.replace(REGEX_FORMAT, (match, $1) => $1 || matches[match]());\n};\nconst normalizeDate = (date) => {\n  if (date === null)\n    return new Date(NaN);\n  if (date === void 0)\n    return new Date();\n  if (date instanceof Date)\n    return new Date(date);\n  if (typeof date === \"string\" && !/Z$/i.test(date)) {\n    const d = date.match(REGEX_PARSE);\n    if (d) {\n      const m = d[2] - 1 || 0;\n      const ms = (d[7] || \"0\").substring(0, 3);\n      return new Date(d[1], m, d[3] || 1, d[4] || 0, d[5] || 0, d[6] || 0, ms);\n    }\n  }\n  return new Date(date);\n};\nfunction useDateFormat(date, formatStr = \"HH:mm:ss\", options = {}) {\n  return computed(() => formatDate(normalizeDate(resolveUnref(date)), resolveUnref(formatStr), options));\n}\n\nfunction useIntervalFn(cb, interval = 1e3, options = {}) {\n  const {\n    immediate = true,\n    immediateCallback = false\n  } = options;\n  let timer = null;\n  const isActive = ref(false);\n  function clean() {\n    if (timer) {\n      clearInterval(timer);\n      timer = null;\n    }\n  }\n  function pause() {\n    isActive.value = false;\n    clean();\n  }\n  function resume() {\n    const intervalValue = resolveUnref(interval);\n    if (intervalValue <= 0)\n      return;\n    isActive.value = true;\n    if (immediateCallback)\n      cb();\n    clean();\n    timer = setInterval(cb, intervalValue);\n  }\n  if (immediate && isClient)\n    resume();\n  if (isRef(interval) || isFunction(interval)) {\n    const stopWatch = watch(interval, () => {\n      if (isActive.value && isClient)\n        resume();\n    });\n    tryOnScopeDispose(stopWatch);\n  }\n  tryOnScopeDispose(pause);\n  return {\n    isActive,\n    pause,\n    resume\n  };\n}\n\nvar __defProp$6 = Object.defineProperty;\nvar __getOwnPropSymbols$8 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$8 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$8 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$6 = (obj, key, value) => key in obj ? __defProp$6(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$6 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$8.call(b, prop))\n      __defNormalProp$6(a, prop, b[prop]);\n  if (__getOwnPropSymbols$8)\n    for (var prop of __getOwnPropSymbols$8(b)) {\n      if (__propIsEnum$8.call(b, prop))\n        __defNormalProp$6(a, prop, b[prop]);\n    }\n  return a;\n};\nfunction useInterval(interval = 1e3, options = {}) {\n  const {\n    controls: exposeControls = false,\n    immediate = true,\n    callback\n  } = options;\n  const counter = ref(0);\n  const update = () => counter.value += 1;\n  const reset = () => {\n    counter.value = 0;\n  };\n  const controls = useIntervalFn(callback ? () => {\n    update();\n    callback(counter.value);\n  } : update, interval, { immediate });\n  if (exposeControls) {\n    return __spreadValues$6({\n      counter,\n      reset\n    }, controls);\n  } else {\n    return counter;\n  }\n}\n\nfunction useLastChanged(source, options = {}) {\n  var _a;\n  const ms = ref((_a = options.initialValue) != null ? _a : null);\n  watch(source, () => ms.value = timestamp(), options);\n  return ms;\n}\n\nfunction useTimeoutFn(cb, interval, options = {}) {\n  const {\n    immediate = true\n  } = options;\n  const isPending = ref(false);\n  let timer = null;\n  function clear() {\n    if (timer) {\n      clearTimeout(timer);\n      timer = null;\n    }\n  }\n  function stop() {\n    isPending.value = false;\n    clear();\n  }\n  function start(...args) {\n    clear();\n    isPending.value = true;\n    timer = setTimeout(() => {\n      isPending.value = false;\n      timer = null;\n      cb(...args);\n    }, resolveUnref(interval));\n  }\n  if (immediate) {\n    isPending.value = true;\n    if (isClient)\n      start();\n  }\n  tryOnScopeDispose(stop);\n  return {\n    isPending: readonly(isPending),\n    start,\n    stop\n  };\n}\n\nvar __defProp$5 = Object.defineProperty;\nvar __getOwnPropSymbols$7 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$7 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$7 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$5 = (obj, key, value) => key in obj ? __defProp$5(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$5 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$7.call(b, prop))\n      __defNormalProp$5(a, prop, b[prop]);\n  if (__getOwnPropSymbols$7)\n    for (var prop of __getOwnPropSymbols$7(b)) {\n      if (__propIsEnum$7.call(b, prop))\n        __defNormalProp$5(a, prop, b[prop]);\n    }\n  return a;\n};\nfunction useTimeout(interval = 1e3, options = {}) {\n  const {\n    controls: exposeControls = false,\n    callback\n  } = options;\n  const controls = useTimeoutFn(callback != null ? callback : noop, interval, options);\n  const ready = computed(() => !controls.isPending.value);\n  if (exposeControls) {\n    return __spreadValues$5({\n      ready\n    }, controls);\n  } else {\n    return ready;\n  }\n}\n\nfunction useToNumber(value, options = {}) {\n  const {\n    method = \"parseFloat\",\n    radix,\n    nanToZero\n  } = options;\n  return computed(() => {\n    let resolved = resolveUnref(value);\n    if (typeof resolved === \"string\")\n      resolved = Number[method](resolved, radix);\n    if (nanToZero && isNaN(resolved))\n      resolved = 0;\n    return resolved;\n  });\n}\n\nfunction useToString(value) {\n  return computed(() => `${resolveUnref(value)}`);\n}\n\nfunction useToggle(initialValue = false, options = {}) {\n  const {\n    truthyValue = true,\n    falsyValue = false\n  } = options;\n  const valueIsRef = isRef(initialValue);\n  const _value = ref(initialValue);\n  function toggle(value) {\n    if (arguments.length) {\n      _value.value = value;\n      return _value.value;\n    } else {\n      const truthy = resolveUnref(truthyValue);\n      _value.value = _value.value === truthy ? resolveUnref(falsyValue) : truthy;\n      return _value.value;\n    }\n  }\n  if (valueIsRef)\n    return toggle;\n  else\n    return [_value, toggle];\n}\n\nfunction watchArray(source, cb, options) {\n  let oldList = (options == null ? void 0 : options.immediate) ? [] : [\n    ...source instanceof Function ? source() : Array.isArray(source) ? source : unref(source)\n  ];\n  return watch(source, (newList, _, onCleanup) => {\n    const oldListRemains = new Array(oldList.length);\n    const added = [];\n    for (const obj of newList) {\n      let found = false;\n      for (let i = 0; i < oldList.length; i++) {\n        if (!oldListRemains[i] && obj === oldList[i]) {\n          oldListRemains[i] = true;\n          found = true;\n          break;\n        }\n      }\n      if (!found)\n        added.push(obj);\n    }\n    const removed = oldList.filter((_2, i) => !oldListRemains[i]);\n    cb(newList, oldList, added, removed, onCleanup);\n    oldList = [...newList];\n  }, options);\n}\n\nvar __getOwnPropSymbols$6 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$6 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$6 = Object.prototype.propertyIsEnumerable;\nvar __objRest$5 = (source, exclude) => {\n  var target = {};\n  for (var prop in source)\n    if (__hasOwnProp$6.call(source, prop) && exclude.indexOf(prop) < 0)\n      target[prop] = source[prop];\n  if (source != null && __getOwnPropSymbols$6)\n    for (var prop of __getOwnPropSymbols$6(source)) {\n      if (exclude.indexOf(prop) < 0 && __propIsEnum$6.call(source, prop))\n        target[prop] = source[prop];\n    }\n  return target;\n};\nfunction watchWithFilter(source, cb, options = {}) {\n  const _a = options, {\n    eventFilter = bypassFilter\n  } = _a, watchOptions = __objRest$5(_a, [\n    \"eventFilter\"\n  ]);\n  return watch(source, createFilterWrapper(eventFilter, cb), watchOptions);\n}\n\nvar __getOwnPropSymbols$5 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$5 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$5 = Object.prototype.propertyIsEnumerable;\nvar __objRest$4 = (source, exclude) => {\n  var target = {};\n  for (var prop in source)\n    if (__hasOwnProp$5.call(source, prop) && exclude.indexOf(prop) < 0)\n      target[prop] = source[prop];\n  if (source != null && __getOwnPropSymbols$5)\n    for (var prop of __getOwnPropSymbols$5(source)) {\n      if (exclude.indexOf(prop) < 0 && __propIsEnum$5.call(source, prop))\n        target[prop] = source[prop];\n    }\n  return target;\n};\nfunction watchAtMost(source, cb, options) {\n  const _a = options, {\n    count\n  } = _a, watchOptions = __objRest$4(_a, [\n    \"count\"\n  ]);\n  const current = ref(0);\n  const stop = watchWithFilter(source, (...args) => {\n    current.value += 1;\n    if (current.value >= resolveUnref(count))\n      nextTick(() => stop());\n    cb(...args);\n  }, watchOptions);\n  return { count: current, stop };\n}\n\nvar __defProp$4 = Object.defineProperty;\nvar __defProps$4 = Object.defineProperties;\nvar __getOwnPropDescs$4 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$4 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$4 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$4 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$4 = (obj, key, value) => key in obj ? __defProp$4(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$4 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$4.call(b, prop))\n      __defNormalProp$4(a, prop, b[prop]);\n  if (__getOwnPropSymbols$4)\n    for (var prop of __getOwnPropSymbols$4(b)) {\n      if (__propIsEnum$4.call(b, prop))\n        __defNormalProp$4(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$4 = (a, b) => __defProps$4(a, __getOwnPropDescs$4(b));\nvar __objRest$3 = (source, exclude) => {\n  var target = {};\n  for (var prop in source)\n    if (__hasOwnProp$4.call(source, prop) && exclude.indexOf(prop) < 0)\n      target[prop] = source[prop];\n  if (source != null && __getOwnPropSymbols$4)\n    for (var prop of __getOwnPropSymbols$4(source)) {\n      if (exclude.indexOf(prop) < 0 && __propIsEnum$4.call(source, prop))\n        target[prop] = source[prop];\n    }\n  return target;\n};\nfunction watchDebounced(source, cb, options = {}) {\n  const _a = options, {\n    debounce = 0,\n    maxWait = void 0\n  } = _a, watchOptions = __objRest$3(_a, [\n    \"debounce\",\n    \"maxWait\"\n  ]);\n  return watchWithFilter(source, cb, __spreadProps$4(__spreadValues$4({}, watchOptions), {\n    eventFilter: debounceFilter(debounce, { maxWait })\n  }));\n}\n\nvar __defProp$3 = Object.defineProperty;\nvar __defProps$3 = Object.defineProperties;\nvar __getOwnPropDescs$3 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$3 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$3 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$3 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$3 = (obj, key, value) => key in obj ? __defProp$3(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$3 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$3.call(b, prop))\n      __defNormalProp$3(a, prop, b[prop]);\n  if (__getOwnPropSymbols$3)\n    for (var prop of __getOwnPropSymbols$3(b)) {\n      if (__propIsEnum$3.call(b, prop))\n        __defNormalProp$3(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$3 = (a, b) => __defProps$3(a, __getOwnPropDescs$3(b));\nvar __objRest$2 = (source, exclude) => {\n  var target = {};\n  for (var prop in source)\n    if (__hasOwnProp$3.call(source, prop) && exclude.indexOf(prop) < 0)\n      target[prop] = source[prop];\n  if (source != null && __getOwnPropSymbols$3)\n    for (var prop of __getOwnPropSymbols$3(source)) {\n      if (exclude.indexOf(prop) < 0 && __propIsEnum$3.call(source, prop))\n        target[prop] = source[prop];\n    }\n  return target;\n};\nfunction watchIgnorable(source, cb, options = {}) {\n  const _a = options, {\n    eventFilter = bypassFilter\n  } = _a, watchOptions = __objRest$2(_a, [\n    \"eventFilter\"\n  ]);\n  const filteredCb = createFilterWrapper(eventFilter, cb);\n  let ignoreUpdates;\n  let ignorePrevAsyncUpdates;\n  let stop;\n  if (watchOptions.flush === \"sync\") {\n    const ignore = ref(false);\n    ignorePrevAsyncUpdates = () => {\n    };\n    ignoreUpdates = (updater) => {\n      ignore.value = true;\n      updater();\n      ignore.value = false;\n    };\n    stop = watch(source, (...args) => {\n      if (!ignore.value)\n        filteredCb(...args);\n    }, watchOptions);\n  } else {\n    const disposables = [];\n    const ignoreCounter = ref(0);\n    const syncCounter = ref(0);\n    ignorePrevAsyncUpdates = () => {\n      ignoreCounter.value = syncCounter.value;\n    };\n    disposables.push(watch(source, () => {\n      syncCounter.value++;\n    }, __spreadProps$3(__spreadValues$3({}, watchOptions), { flush: \"sync\" })));\n    ignoreUpdates = (updater) => {\n      const syncCounterPrev = syncCounter.value;\n      updater();\n      ignoreCounter.value += syncCounter.value - syncCounterPrev;\n    };\n    disposables.push(watch(source, (...args) => {\n      const ignore = ignoreCounter.value > 0 && ignoreCounter.value === syncCounter.value;\n      ignoreCounter.value = 0;\n      syncCounter.value = 0;\n      if (ignore)\n        return;\n      filteredCb(...args);\n    }, watchOptions));\n    stop = () => {\n      disposables.forEach((fn) => fn());\n    };\n  }\n  return { stop, ignoreUpdates, ignorePrevAsyncUpdates };\n}\n\nfunction watchOnce(source, cb, options) {\n  const stop = watch(source, (...args) => {\n    nextTick(() => stop());\n    return cb(...args);\n  }, options);\n}\n\nvar __defProp$2 = Object.defineProperty;\nvar __defProps$2 = Object.defineProperties;\nvar __getOwnPropDescs$2 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$2 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$2 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$2 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$2 = (obj, key, value) => key in obj ? __defProp$2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$2 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$2.call(b, prop))\n      __defNormalProp$2(a, prop, b[prop]);\n  if (__getOwnPropSymbols$2)\n    for (var prop of __getOwnPropSymbols$2(b)) {\n      if (__propIsEnum$2.call(b, prop))\n        __defNormalProp$2(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$2 = (a, b) => __defProps$2(a, __getOwnPropDescs$2(b));\nvar __objRest$1 = (source, exclude) => {\n  var target = {};\n  for (var prop in source)\n    if (__hasOwnProp$2.call(source, prop) && exclude.indexOf(prop) < 0)\n      target[prop] = source[prop];\n  if (source != null && __getOwnPropSymbols$2)\n    for (var prop of __getOwnPropSymbols$2(source)) {\n      if (exclude.indexOf(prop) < 0 && __propIsEnum$2.call(source, prop))\n        target[prop] = source[prop];\n    }\n  return target;\n};\nfunction watchPausable(source, cb, options = {}) {\n  const _a = options, {\n    eventFilter: filter\n  } = _a, watchOptions = __objRest$1(_a, [\n    \"eventFilter\"\n  ]);\n  const { eventFilter, pause, resume, isActive } = pausableFilter(filter);\n  const stop = watchWithFilter(source, cb, __spreadProps$2(__spreadValues$2({}, watchOptions), {\n    eventFilter\n  }));\n  return { stop, pause, resume, isActive };\n}\n\nvar __defProp$1 = Object.defineProperty;\nvar __defProps$1 = Object.defineProperties;\nvar __getOwnPropDescs$1 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$1 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$1 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$1 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$1 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$1.call(b, prop))\n      __defNormalProp$1(a, prop, b[prop]);\n  if (__getOwnPropSymbols$1)\n    for (var prop of __getOwnPropSymbols$1(b)) {\n      if (__propIsEnum$1.call(b, prop))\n        __defNormalProp$1(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$1 = (a, b) => __defProps$1(a, __getOwnPropDescs$1(b));\nvar __objRest = (source, exclude) => {\n  var target = {};\n  for (var prop in source)\n    if (__hasOwnProp$1.call(source, prop) && exclude.indexOf(prop) < 0)\n      target[prop] = source[prop];\n  if (source != null && __getOwnPropSymbols$1)\n    for (var prop of __getOwnPropSymbols$1(source)) {\n      if (exclude.indexOf(prop) < 0 && __propIsEnum$1.call(source, prop))\n        target[prop] = source[prop];\n    }\n  return target;\n};\nfunction watchThrottled(source, cb, options = {}) {\n  const _a = options, {\n    throttle = 0,\n    trailing = true,\n    leading = true\n  } = _a, watchOptions = __objRest(_a, [\n    \"throttle\",\n    \"trailing\",\n    \"leading\"\n  ]);\n  return watchWithFilter(source, cb, __spreadProps$1(__spreadValues$1({}, watchOptions), {\n    eventFilter: throttleFilter(throttle, trailing, leading)\n  }));\n}\n\nvar __defProp = Object.defineProperty;\nvar __defProps = Object.defineProperties;\nvar __getOwnPropDescs = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp.call(b, prop))\n      __defNormalProp(a, prop, b[prop]);\n  if (__getOwnPropSymbols)\n    for (var prop of __getOwnPropSymbols(b)) {\n      if (__propIsEnum.call(b, prop))\n        __defNormalProp(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));\nfunction watchTriggerable(source, cb, options = {}) {\n  let cleanupFn;\n  function onEffect() {\n    if (!cleanupFn)\n      return;\n    const fn = cleanupFn;\n    cleanupFn = void 0;\n    fn();\n  }\n  function onCleanup(callback) {\n    cleanupFn = callback;\n  }\n  const _cb = (value, oldValue) => {\n    onEffect();\n    return cb(value, oldValue, onCleanup);\n  };\n  const res = watchIgnorable(source, _cb, options);\n  const { ignoreUpdates } = res;\n  const trigger = () => {\n    let res2;\n    ignoreUpdates(() => {\n      res2 = _cb(getWatchSources(source), getOldValue(source));\n    });\n    return res2;\n  };\n  return __spreadProps(__spreadValues({}, res), {\n    trigger\n  });\n}\nfunction getWatchSources(sources) {\n  if (isReactive(sources))\n    return sources;\n  if (Array.isArray(sources))\n    return sources.map((item) => getOneWatchSource(item));\n  return getOneWatchSource(sources);\n}\nfunction getOneWatchSource(source) {\n  return typeof source === \"function\" ? source() : unref(source);\n}\nfunction getOldValue(source) {\n  return Array.isArray(source) ? source.map(() => void 0) : void 0;\n}\n\nfunction whenever(source, cb, options) {\n  return watch(source, (v, ov, onInvalidate) => {\n    if (v)\n      cb(v, ov, onInvalidate);\n  }, options);\n}\n\nexport { __onlyVue27Plus, __onlyVue3, assert, refAutoReset as autoResetRef, bypassFilter, clamp, computedEager, computedWithControl, containsProp, computedWithControl as controlledComputed, controlledRef, createEventHook, createFilterWrapper, createGlobalState, createInjectionState, reactify as createReactiveFn, createSharedComposable, createSingletonPromise, debounceFilter, refDebounced as debouncedRef, watchDebounced as debouncedWatch, directiveHooks, computedEager as eagerComputed, extendRef, formatDate, get, hasOwn, identity, watchIgnorable as ignorableWatch, increaseWithUnit, invoke, isBoolean, isClient, isDef, isDefined, isFunction, isIOS, isNumber, isObject, isString, isWindow, makeDestructurable, noop, normalizeDate, now, objectPick, pausableFilter, watchPausable as pausableWatch, promiseTimeout, rand, reactify, reactifyObject, reactiveComputed, reactiveOmit, reactivePick, refAutoReset, refDebounced, refDefault, refThrottled, refWithControl, resolveRef, resolveUnref, set, syncRef, syncRefs, throttleFilter, refThrottled as throttledRef, watchThrottled as throttledWatch, timestamp, toReactive, toRefs, tryOnBeforeMount, tryOnBeforeUnmount, tryOnMounted, tryOnScopeDispose, tryOnUnmounted, until, useArrayEvery, useArrayFilter, useArrayFind, useArrayFindIndex, useArrayFindLast, useArrayJoin, useArrayMap, useArrayReduce, useArraySome, useArrayUnique, useCounter, useDateFormat, refDebounced as useDebounce, useDebounceFn, useInterval, useIntervalFn, useLastChanged, refThrottled as useThrottle, useThrottleFn, useTimeout, useTimeoutFn, useToNumber, useToString, useToggle, watchArray, watchAtMost, watchDebounced, watchIgnorable, watchOnce, watchPausable, watchThrottled, watchTriggerable, watchWithFilter, whenever };\n", "import * as Vue from 'vue'\n\nvar isVue2 = false\nvar isVue3 = true\nvar Vue2 = undefined\n\nfunction install() {}\n\nexport function set(target, key, val) {\n  if (Array.isArray(target)) {\n    target.length = Math.max(target.length, key)\n    target.splice(key, 1, val)\n    return val\n  }\n  target[key] = val\n  return val\n}\n\nexport function del(target, key) {\n  if (Array.isArray(target)) {\n    target.splice(key, 1)\n    return\n  }\n  delete target[key]\n}\n\nexport * from 'vue'\nexport {\n  Vue,\n  Vue2,\n  isVue2,\n  isVue3,\n  install,\n}\n", "import { noop, resolveUnref, isClient, isString, tryOnScopeDispose, isIOS, tryOnMounted, computedWithControl, promiseTimeout, isFunction, resolveRef, increaseWithUnit, useTimeoutFn, pausableWatch, createEventHook, timestamp, pausableFilter, watchIgnorable, debounceFilter, createFilterWrapper, bypassFilter, createSingletonPromise, toRefs, containsProp, until, hasOwn, throttleFilter, useDebounceFn, useThrottleFn, isObject, isNumber, useIntervalFn, clamp, syncRef, objectPick, tryOnUnmounted, watchWithFilter, identity, isDef } from '@vueuse/shared';\nexport * from '@vueuse/shared';\nimport { isRef, ref, shallowRef, watchEffect, computed, inject, unref, watch, getCurrentInstance, customRef, onUpdated, reactive, nextTick, onMounted, markRaw, readonly, getCurrentScope, isVue2, set, del, isReadonly, onBeforeUpdate } from 'vue-demi';\n\nfunction computedAsync(evaluationCallback, initialState, optionsOrRef) {\n  let options;\n  if (isRef(optionsOrRef)) {\n    options = {\n      evaluating: optionsOrRef\n    };\n  } else {\n    options = optionsOrRef || {};\n  }\n  const {\n    lazy = false,\n    evaluating = void 0,\n    shallow = false,\n    onError = noop\n  } = options;\n  const started = ref(!lazy);\n  const current = shallow ? shallowRef(initialState) : ref(initialState);\n  let counter = 0;\n  watchEffect(async (onInvalidate) => {\n    if (!started.value)\n      return;\n    counter++;\n    const counterAtBeginning = counter;\n    let hasFinished = false;\n    if (evaluating) {\n      Promise.resolve().then(() => {\n        evaluating.value = true;\n      });\n    }\n    try {\n      const result = await evaluationCallback((cancelCallback) => {\n        onInvalidate(() => {\n          if (evaluating)\n            evaluating.value = false;\n          if (!hasFinished)\n            cancelCallback();\n        });\n      });\n      if (counterAtBeginning === counter)\n        current.value = result;\n    } catch (e) {\n      onError(e);\n    } finally {\n      if (evaluating && counterAtBeginning === counter)\n        evaluating.value = false;\n      hasFinished = true;\n    }\n  });\n  if (lazy) {\n    return computed(() => {\n      started.value = true;\n      return current.value;\n    });\n  } else {\n    return current;\n  }\n}\n\nfunction computedInject(key, options, defaultSource, treatDefaultAsFactory) {\n  let source = inject(key);\n  if (defaultSource)\n    source = inject(key, defaultSource);\n  if (treatDefaultAsFactory)\n    source = inject(key, defaultSource, treatDefaultAsFactory);\n  if (typeof options === \"function\") {\n    return computed((ctx) => options(source, ctx));\n  } else {\n    return computed({\n      get: (ctx) => options.get(source, ctx),\n      set: options.set\n    });\n  }\n}\n\nconst createUnrefFn = (fn) => {\n  return function(...args) {\n    return fn.apply(this, args.map((i) => unref(i)));\n  };\n};\n\nfunction unrefElement(elRef) {\n  var _a;\n  const plain = resolveUnref(elRef);\n  return (_a = plain == null ? void 0 : plain.$el) != null ? _a : plain;\n}\n\nconst defaultWindow = isClient ? window : void 0;\nconst defaultDocument = isClient ? window.document : void 0;\nconst defaultNavigator = isClient ? window.navigator : void 0;\nconst defaultLocation = isClient ? window.location : void 0;\n\nfunction useEventListener(...args) {\n  let target;\n  let events;\n  let listeners;\n  let options;\n  if (isString(args[0]) || Array.isArray(args[0])) {\n    [events, listeners, options] = args;\n    target = defaultWindow;\n  } else {\n    [target, events, listeners, options] = args;\n  }\n  if (!target)\n    return noop;\n  if (!Array.isArray(events))\n    events = [events];\n  if (!Array.isArray(listeners))\n    listeners = [listeners];\n  const cleanups = [];\n  const cleanup = () => {\n    cleanups.forEach((fn) => fn());\n    cleanups.length = 0;\n  };\n  const register = (el, event, listener, options2) => {\n    el.addEventListener(event, listener, options2);\n    return () => el.removeEventListener(event, listener, options2);\n  };\n  const stopWatch = watch(() => [unrefElement(target), resolveUnref(options)], ([el, options2]) => {\n    cleanup();\n    if (!el)\n      return;\n    cleanups.push(...events.flatMap((event) => {\n      return listeners.map((listener) => register(el, event, listener, options2));\n    }));\n  }, { immediate: true, flush: \"post\" });\n  const stop = () => {\n    stopWatch();\n    cleanup();\n  };\n  tryOnScopeDispose(stop);\n  return stop;\n}\n\nlet _iOSWorkaround = false;\nfunction onClickOutside(target, handler, options = {}) {\n  const { window = defaultWindow, ignore = [], capture = true, detectIframe = false } = options;\n  if (!window)\n    return;\n  if (isIOS && !_iOSWorkaround) {\n    _iOSWorkaround = true;\n    Array.from(window.document.body.children).forEach((el) => el.addEventListener(\"click\", noop));\n  }\n  let shouldListen = true;\n  const shouldIgnore = (event) => {\n    return ignore.some((target2) => {\n      if (typeof target2 === \"string\") {\n        return Array.from(window.document.querySelectorAll(target2)).some((el) => el === event.target || event.composedPath().includes(el));\n      } else {\n        const el = unrefElement(target2);\n        return el && (event.target === el || event.composedPath().includes(el));\n      }\n    });\n  };\n  const listener = (event) => {\n    const el = unrefElement(target);\n    if (!el || el === event.target || event.composedPath().includes(el))\n      return;\n    if (event.detail === 0)\n      shouldListen = !shouldIgnore(event);\n    if (!shouldListen) {\n      shouldListen = true;\n      return;\n    }\n    handler(event);\n  };\n  const cleanup = [\n    useEventListener(window, \"click\", listener, { passive: true, capture }),\n    useEventListener(window, \"pointerdown\", (e) => {\n      const el = unrefElement(target);\n      if (el)\n        shouldListen = !e.composedPath().includes(el) && !shouldIgnore(e);\n    }, { passive: true }),\n    detectIframe && useEventListener(window, \"blur\", (event) => {\n      var _a;\n      const el = unrefElement(target);\n      if (((_a = window.document.activeElement) == null ? void 0 : _a.tagName) === \"IFRAME\" && !(el == null ? void 0 : el.contains(window.document.activeElement)))\n        handler(event);\n    })\n  ].filter(Boolean);\n  const stop = () => cleanup.forEach((fn) => fn());\n  return stop;\n}\n\nvar __defProp$n = Object.defineProperty;\nvar __defProps$9 = Object.defineProperties;\nvar __getOwnPropDescs$9 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$p = Object.getOwnPropertySymbols;\nvar __hasOwnProp$p = Object.prototype.hasOwnProperty;\nvar __propIsEnum$p = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$n = (obj, key, value) => key in obj ? __defProp$n(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$n = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$p.call(b, prop))\n      __defNormalProp$n(a, prop, b[prop]);\n  if (__getOwnPropSymbols$p)\n    for (var prop of __getOwnPropSymbols$p(b)) {\n      if (__propIsEnum$p.call(b, prop))\n        __defNormalProp$n(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$9 = (a, b) => __defProps$9(a, __getOwnPropDescs$9(b));\nconst createKeyPredicate = (keyFilter) => {\n  if (typeof keyFilter === \"function\")\n    return keyFilter;\n  else if (typeof keyFilter === \"string\")\n    return (event) => event.key === keyFilter;\n  else if (Array.isArray(keyFilter))\n    return (event) => keyFilter.includes(event.key);\n  return () => true;\n};\nfunction onKeyStroke(...args) {\n  let key;\n  let handler;\n  let options = {};\n  if (args.length === 3) {\n    key = args[0];\n    handler = args[1];\n    options = args[2];\n  } else if (args.length === 2) {\n    if (typeof args[1] === \"object\") {\n      key = true;\n      handler = args[0];\n      options = args[1];\n    } else {\n      key = args[0];\n      handler = args[1];\n    }\n  } else {\n    key = true;\n    handler = args[0];\n  }\n  const { target = defaultWindow, eventName = \"keydown\", passive = false } = options;\n  const predicate = createKeyPredicate(key);\n  const listener = (e) => {\n    if (predicate(e))\n      handler(e);\n  };\n  return useEventListener(target, eventName, listener, passive);\n}\nfunction onKeyDown(key, handler, options = {}) {\n  return onKeyStroke(key, handler, __spreadProps$9(__spreadValues$n({}, options), { eventName: \"keydown\" }));\n}\nfunction onKeyPressed(key, handler, options = {}) {\n  return onKeyStroke(key, handler, __spreadProps$9(__spreadValues$n({}, options), { eventName: \"keypress\" }));\n}\nfunction onKeyUp(key, handler, options = {}) {\n  return onKeyStroke(key, handler, __spreadProps$9(__spreadValues$n({}, options), { eventName: \"keyup\" }));\n}\n\nconst DEFAULT_DELAY = 500;\nfunction onLongPress(target, handler, options) {\n  var _a, _b;\n  const elementRef = computed(() => unrefElement(target));\n  let timeout;\n  function clear() {\n    if (timeout) {\n      clearTimeout(timeout);\n      timeout = void 0;\n    }\n  }\n  function onDown(ev) {\n    var _a2, _b2, _c, _d;\n    if (((_a2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _a2.self) && ev.target !== elementRef.value)\n      return;\n    clear();\n    if ((_b2 = options == null ? void 0 : options.modifiers) == null ? void 0 : _b2.prevent)\n      ev.preventDefault();\n    if ((_c = options == null ? void 0 : options.modifiers) == null ? void 0 : _c.stop)\n      ev.stopPropagation();\n    timeout = setTimeout(() => handler(ev), (_d = options == null ? void 0 : options.delay) != null ? _d : DEFAULT_DELAY);\n  }\n  const listenerOptions = {\n    capture: (_a = options == null ? void 0 : options.modifiers) == null ? void 0 : _a.capture,\n    once: (_b = options == null ? void 0 : options.modifiers) == null ? void 0 : _b.once\n  };\n  useEventListener(elementRef, \"pointerdown\", onDown, listenerOptions);\n  useEventListener(elementRef, \"pointerup\", clear, listenerOptions);\n  useEventListener(elementRef, \"pointerleave\", clear, listenerOptions);\n}\n\nconst isFocusedElementEditable = () => {\n  const { activeElement, body } = document;\n  if (!activeElement)\n    return false;\n  if (activeElement === body)\n    return false;\n  switch (activeElement.tagName) {\n    case \"INPUT\":\n    case \"TEXTAREA\":\n      return true;\n  }\n  return activeElement.hasAttribute(\"contenteditable\");\n};\nconst isTypedCharValid = ({\n  keyCode,\n  metaKey,\n  ctrlKey,\n  altKey\n}) => {\n  if (metaKey || ctrlKey || altKey)\n    return false;\n  if (keyCode >= 48 && keyCode <= 57 || keyCode >= 96 && keyCode <= 105)\n    return true;\n  if (keyCode >= 65 && keyCode <= 90)\n    return true;\n  return false;\n};\nfunction onStartTyping(callback, options = {}) {\n  const { document: document2 = defaultDocument } = options;\n  const keydown = (event) => {\n    !isFocusedElementEditable() && isTypedCharValid(event) && callback(event);\n  };\n  if (document2)\n    useEventListener(document2, \"keydown\", keydown, { passive: true });\n}\n\nfunction templateRef(key, initialValue = null) {\n  const instance = getCurrentInstance();\n  let _trigger = () => {\n  };\n  const element = customRef((track, trigger) => {\n    _trigger = trigger;\n    return {\n      get() {\n        var _a, _b;\n        track();\n        return (_b = (_a = instance == null ? void 0 : instance.proxy) == null ? void 0 : _a.$refs[key]) != null ? _b : initialValue;\n      },\n      set() {\n      }\n    };\n  });\n  tryOnMounted(_trigger);\n  onUpdated(_trigger);\n  return element;\n}\n\nfunction useActiveElement(options = {}) {\n  var _a;\n  const { window = defaultWindow } = options;\n  const document = (_a = options.document) != null ? _a : window == null ? void 0 : window.document;\n  const activeElement = computedWithControl(() => null, () => document == null ? void 0 : document.activeElement);\n  if (window) {\n    useEventListener(window, \"blur\", (event) => {\n      if (event.relatedTarget !== null)\n        return;\n      activeElement.trigger();\n    }, true);\n    useEventListener(window, \"focus\", activeElement.trigger, true);\n  }\n  return activeElement;\n}\n\nfunction useAsyncQueue(tasks, options = {}) {\n  const {\n    interrupt = true,\n    onError = noop,\n    onFinished = noop\n  } = options;\n  const promiseState = {\n    pending: \"pending\",\n    rejected: \"rejected\",\n    fulfilled: \"fulfilled\"\n  };\n  const initialResult = Array.from(new Array(tasks.length), () => ({ state: promiseState.pending, data: null }));\n  const result = reactive(initialResult);\n  const activeIndex = ref(-1);\n  if (!tasks || tasks.length === 0) {\n    onFinished();\n    return {\n      activeIndex,\n      result\n    };\n  }\n  function updateResult(state, res) {\n    activeIndex.value++;\n    result[activeIndex.value].data = res;\n    result[activeIndex.value].state = state;\n  }\n  tasks.reduce((prev, curr) => {\n    return prev.then((prevRes) => {\n      var _a;\n      if (((_a = result[activeIndex.value]) == null ? void 0 : _a.state) === promiseState.rejected && interrupt) {\n        onFinished();\n        return;\n      }\n      return curr(prevRes).then((currentRes) => {\n        updateResult(promiseState.fulfilled, currentRes);\n        activeIndex.value === tasks.length - 1 && onFinished();\n        return currentRes;\n      });\n    }).catch((e) => {\n      updateResult(promiseState.rejected, e);\n      onError();\n      return e;\n    });\n  }, Promise.resolve());\n  return {\n    activeIndex,\n    result\n  };\n}\n\nfunction useAsyncState(promise, initialState, options) {\n  const {\n    immediate = true,\n    delay = 0,\n    onError = noop,\n    onSuccess = noop,\n    resetOnExecute = true,\n    shallow = true,\n    throwError\n  } = options != null ? options : {};\n  const state = shallow ? shallowRef(initialState) : ref(initialState);\n  const isReady = ref(false);\n  const isLoading = ref(false);\n  const error = ref(void 0);\n  async function execute(delay2 = 0, ...args) {\n    if (resetOnExecute)\n      state.value = initialState;\n    error.value = void 0;\n    isReady.value = false;\n    isLoading.value = true;\n    if (delay2 > 0)\n      await promiseTimeout(delay2);\n    const _promise = typeof promise === \"function\" ? promise(...args) : promise;\n    try {\n      const data = await _promise;\n      state.value = data;\n      isReady.value = true;\n      onSuccess(data);\n    } catch (e) {\n      error.value = e;\n      onError(e);\n      if (throwError)\n        throw error;\n    } finally {\n      isLoading.value = false;\n    }\n    return state.value;\n  }\n  if (immediate)\n    execute(delay);\n  return {\n    state,\n    isReady,\n    isLoading,\n    error,\n    execute\n  };\n}\n\nconst defaults = {\n  array: (v) => JSON.stringify(v),\n  object: (v) => JSON.stringify(v),\n  set: (v) => JSON.stringify(Array.from(v)),\n  map: (v) => JSON.stringify(Object.fromEntries(v)),\n  null: () => \"\"\n};\nfunction getDefaultSerialization(target) {\n  if (!target)\n    return defaults.null;\n  if (target instanceof Map)\n    return defaults.map;\n  else if (target instanceof Set)\n    return defaults.set;\n  else if (Array.isArray(target))\n    return defaults.array;\n  else\n    return defaults.object;\n}\n\nfunction useBase64(target, options) {\n  const base64 = ref(\"\");\n  const promise = ref();\n  function execute() {\n    if (!isClient)\n      return;\n    promise.value = new Promise((resolve, reject) => {\n      try {\n        const _target = resolveUnref(target);\n        if (_target == null) {\n          resolve(\"\");\n        } else if (typeof _target === \"string\") {\n          resolve(blobToBase64(new Blob([_target], { type: \"text/plain\" })));\n        } else if (_target instanceof Blob) {\n          resolve(blobToBase64(_target));\n        } else if (_target instanceof ArrayBuffer) {\n          resolve(window.btoa(String.fromCharCode(...new Uint8Array(_target))));\n        } else if (_target instanceof HTMLCanvasElement) {\n          resolve(_target.toDataURL(options == null ? void 0 : options.type, options == null ? void 0 : options.quality));\n        } else if (_target instanceof HTMLImageElement) {\n          const img = _target.cloneNode(false);\n          img.crossOrigin = \"Anonymous\";\n          imgLoaded(img).then(() => {\n            const canvas = document.createElement(\"canvas\");\n            const ctx = canvas.getContext(\"2d\");\n            canvas.width = img.width;\n            canvas.height = img.height;\n            ctx.drawImage(img, 0, 0, canvas.width, canvas.height);\n            resolve(canvas.toDataURL(options == null ? void 0 : options.type, options == null ? void 0 : options.quality));\n          }).catch(reject);\n        } else if (typeof _target === \"object\") {\n          const _serializeFn = (options == null ? void 0 : options.serializer) || getDefaultSerialization(_target);\n          const serialized = _serializeFn(_target);\n          return resolve(blobToBase64(new Blob([serialized], { type: \"application/json\" })));\n        } else {\n          reject(new Error(\"target is unsupported types\"));\n        }\n      } catch (error) {\n        reject(error);\n      }\n    });\n    promise.value.then((res) => base64.value = res);\n    return promise.value;\n  }\n  if (isRef(target) || isFunction(target))\n    watch(target, execute, { immediate: true });\n  else\n    execute();\n  return {\n    base64,\n    promise,\n    execute\n  };\n}\nfunction imgLoaded(img) {\n  return new Promise((resolve, reject) => {\n    if (!img.complete) {\n      img.onload = () => {\n        resolve();\n      };\n      img.onerror = reject;\n    } else {\n      resolve();\n    }\n  });\n}\nfunction blobToBase64(blob) {\n  return new Promise((resolve, reject) => {\n    const fr = new FileReader();\n    fr.onload = (e) => {\n      resolve(e.target.result);\n    };\n    fr.onerror = reject;\n    fr.readAsDataURL(blob);\n  });\n}\n\nfunction useSupported(callback, sync = false) {\n  const isSupported = ref();\n  const update = () => isSupported.value = Boolean(callback());\n  update();\n  tryOnMounted(update, sync);\n  return isSupported;\n}\n\nfunction useBattery({ navigator = defaultNavigator } = {}) {\n  const events = [\"chargingchange\", \"chargingtimechange\", \"dischargingtimechange\", \"levelchange\"];\n  const isSupported = useSupported(() => navigator && \"getBattery\" in navigator);\n  const charging = ref(false);\n  const chargingTime = ref(0);\n  const dischargingTime = ref(0);\n  const level = ref(1);\n  let battery;\n  function updateBatteryInfo() {\n    charging.value = this.charging;\n    chargingTime.value = this.chargingTime || 0;\n    dischargingTime.value = this.dischargingTime || 0;\n    level.value = this.level;\n  }\n  if (isSupported.value) {\n    navigator.getBattery().then((_battery) => {\n      battery = _battery;\n      updateBatteryInfo.call(battery);\n      for (const event of events)\n        useEventListener(battery, event, updateBatteryInfo, { passive: true });\n    });\n  }\n  return {\n    isSupported,\n    charging,\n    chargingTime,\n    dischargingTime,\n    level\n  };\n}\n\nfunction useBluetooth(options) {\n  let {\n    acceptAllDevices = false\n  } = options || {};\n  const {\n    filters = void 0,\n    optionalServices = void 0,\n    navigator = defaultNavigator\n  } = options || {};\n  const isSupported = useSupported(() => navigator && \"bluetooth\" in navigator);\n  const device = shallowRef(void 0);\n  const error = shallowRef(null);\n  watch(device, () => {\n    connectToBluetoothGATTServer();\n  });\n  async function requestDevice() {\n    if (!isSupported.value)\n      return;\n    error.value = null;\n    if (filters && filters.length > 0)\n      acceptAllDevices = false;\n    try {\n      device.value = await (navigator == null ? void 0 : navigator.bluetooth.requestDevice({\n        acceptAllDevices,\n        filters,\n        optionalServices\n      }));\n    } catch (err) {\n      error.value = err;\n    }\n  }\n  const server = ref();\n  const isConnected = computed(() => {\n    var _a;\n    return ((_a = server.value) == null ? void 0 : _a.connected) || false;\n  });\n  async function connectToBluetoothGATTServer() {\n    error.value = null;\n    if (device.value && device.value.gatt) {\n      device.value.addEventListener(\"gattserverdisconnected\", () => {\n      });\n      try {\n        server.value = await device.value.gatt.connect();\n      } catch (err) {\n        error.value = err;\n      }\n    }\n  }\n  tryOnMounted(() => {\n    var _a;\n    if (device.value)\n      (_a = device.value.gatt) == null ? void 0 : _a.connect();\n  });\n  tryOnScopeDispose(() => {\n    var _a;\n    if (device.value)\n      (_a = device.value.gatt) == null ? void 0 : _a.disconnect();\n  });\n  return {\n    isSupported,\n    isConnected,\n    device,\n    requestDevice,\n    server,\n    error\n  };\n}\n\nfunction useMediaQuery(query, options = {}) {\n  const { window = defaultWindow } = options;\n  const isSupported = useSupported(() => window && \"matchMedia\" in window && typeof window.matchMedia === \"function\");\n  let mediaQuery;\n  const matches = ref(false);\n  const cleanup = () => {\n    if (!mediaQuery)\n      return;\n    if (\"removeEventListener\" in mediaQuery)\n      mediaQuery.removeEventListener(\"change\", update);\n    else\n      mediaQuery.removeListener(update);\n  };\n  const update = () => {\n    if (!isSupported.value)\n      return;\n    cleanup();\n    mediaQuery = window.matchMedia(resolveRef(query).value);\n    matches.value = mediaQuery.matches;\n    if (\"addEventListener\" in mediaQuery)\n      mediaQuery.addEventListener(\"change\", update);\n    else\n      mediaQuery.addListener(update);\n  };\n  watchEffect(update);\n  tryOnScopeDispose(() => cleanup());\n  return matches;\n}\n\nconst breakpointsTailwind = {\n  \"sm\": 640,\n  \"md\": 768,\n  \"lg\": 1024,\n  \"xl\": 1280,\n  \"2xl\": 1536\n};\nconst breakpointsBootstrapV5 = {\n  sm: 576,\n  md: 768,\n  lg: 992,\n  xl: 1200,\n  xxl: 1400\n};\nconst breakpointsVuetify = {\n  xs: 600,\n  sm: 960,\n  md: 1264,\n  lg: 1904\n};\nconst breakpointsAntDesign = {\n  xs: 480,\n  sm: 576,\n  md: 768,\n  lg: 992,\n  xl: 1200,\n  xxl: 1600\n};\nconst breakpointsQuasar = {\n  xs: 600,\n  sm: 1024,\n  md: 1440,\n  lg: 1920\n};\nconst breakpointsSematic = {\n  mobileS: 320,\n  mobileM: 375,\n  mobileL: 425,\n  tablet: 768,\n  laptop: 1024,\n  laptopL: 1440,\n  desktop4K: 2560\n};\nconst breakpointsMasterCss = {\n  \"3xs\": 360,\n  \"2xs\": 480,\n  \"xs\": 600,\n  \"sm\": 768,\n  \"md\": 1024,\n  \"lg\": 1280,\n  \"xl\": 1440,\n  \"2xl\": 1600,\n  \"3xl\": 1920,\n  \"4xl\": 2560\n};\n\nvar __defProp$m = Object.defineProperty;\nvar __getOwnPropSymbols$o = Object.getOwnPropertySymbols;\nvar __hasOwnProp$o = Object.prototype.hasOwnProperty;\nvar __propIsEnum$o = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$m = (obj, key, value) => key in obj ? __defProp$m(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$m = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$o.call(b, prop))\n      __defNormalProp$m(a, prop, b[prop]);\n  if (__getOwnPropSymbols$o)\n    for (var prop of __getOwnPropSymbols$o(b)) {\n      if (__propIsEnum$o.call(b, prop))\n        __defNormalProp$m(a, prop, b[prop]);\n    }\n  return a;\n};\nfunction useBreakpoints(breakpoints, options = {}) {\n  function getValue(k, delta) {\n    let v = breakpoints[k];\n    if (delta != null)\n      v = increaseWithUnit(v, delta);\n    if (typeof v === \"number\")\n      v = `${v}px`;\n    return v;\n  }\n  const { window = defaultWindow } = options;\n  function match(query) {\n    if (!window)\n      return false;\n    return window.matchMedia(query).matches;\n  }\n  const greaterOrEqual = (k) => {\n    return useMediaQuery(`(min-width: ${getValue(k)})`, options);\n  };\n  const shortcutMethods = Object.keys(breakpoints).reduce((shortcuts, k) => {\n    Object.defineProperty(shortcuts, k, {\n      get: () => greaterOrEqual(k),\n      enumerable: true,\n      configurable: true\n    });\n    return shortcuts;\n  }, {});\n  return __spreadValues$m({\n    greater(k) {\n      return useMediaQuery(`(min-width: ${getValue(k, 0.1)})`, options);\n    },\n    greaterOrEqual,\n    smaller(k) {\n      return useMediaQuery(`(max-width: ${getValue(k, -0.1)})`, options);\n    },\n    smallerOrEqual(k) {\n      return useMediaQuery(`(max-width: ${getValue(k)})`, options);\n    },\n    between(a, b) {\n      return useMediaQuery(`(min-width: ${getValue(a)}) and (max-width: ${getValue(b, -0.1)})`, options);\n    },\n    isGreater(k) {\n      return match(`(min-width: ${getValue(k, 0.1)})`);\n    },\n    isGreaterOrEqual(k) {\n      return match(`(min-width: ${getValue(k)})`);\n    },\n    isSmaller(k) {\n      return match(`(max-width: ${getValue(k, -0.1)})`);\n    },\n    isSmallerOrEqual(k) {\n      return match(`(max-width: ${getValue(k)})`);\n    },\n    isInBetween(a, b) {\n      return match(`(min-width: ${getValue(a)}) and (max-width: ${getValue(b, -0.1)})`);\n    }\n  }, shortcutMethods);\n}\n\nconst useBroadcastChannel = (options) => {\n  const {\n    name,\n    window = defaultWindow\n  } = options;\n  const isSupported = useSupported(() => window && \"BroadcastChannel\" in window);\n  const isClosed = ref(false);\n  const channel = ref();\n  const data = ref();\n  const error = ref(null);\n  const post = (data2) => {\n    if (channel.value)\n      channel.value.postMessage(data2);\n  };\n  const close = () => {\n    if (channel.value)\n      channel.value.close();\n    isClosed.value = true;\n  };\n  if (isSupported.value) {\n    tryOnMounted(() => {\n      error.value = null;\n      channel.value = new BroadcastChannel(name);\n      channel.value.addEventListener(\"message\", (e) => {\n        data.value = e.data;\n      }, { passive: true });\n      channel.value.addEventListener(\"messageerror\", (e) => {\n        error.value = e;\n      }, { passive: true });\n      channel.value.addEventListener(\"close\", () => {\n        isClosed.value = true;\n      });\n    });\n  }\n  tryOnScopeDispose(() => {\n    close();\n  });\n  return {\n    isSupported,\n    channel,\n    data,\n    post,\n    close,\n    error,\n    isClosed\n  };\n};\n\nfunction useBrowserLocation({ window = defaultWindow } = {}) {\n  const buildState = (trigger) => {\n    const { state: state2, length } = (window == null ? void 0 : window.history) || {};\n    const { hash, host, hostname, href, origin, pathname, port, protocol, search } = (window == null ? void 0 : window.location) || {};\n    return {\n      trigger,\n      state: state2,\n      length,\n      hash,\n      host,\n      hostname,\n      href,\n      origin,\n      pathname,\n      port,\n      protocol,\n      search\n    };\n  };\n  const state = ref(buildState(\"load\"));\n  if (window) {\n    useEventListener(window, \"popstate\", () => state.value = buildState(\"popstate\"), { passive: true });\n    useEventListener(window, \"hashchange\", () => state.value = buildState(\"hashchange\"), { passive: true });\n  }\n  return state;\n}\n\nfunction useCached(refValue, comparator = (a, b) => a === b, watchOptions) {\n  const cachedValue = ref(refValue.value);\n  watch(() => refValue.value, (value) => {\n    if (!comparator(value, cachedValue.value))\n      cachedValue.value = value;\n  }, watchOptions);\n  return cachedValue;\n}\n\nfunction useClipboard(options = {}) {\n  const {\n    navigator = defaultNavigator,\n    read = false,\n    source,\n    copiedDuring = 1500,\n    legacy = false\n  } = options;\n  const events = [\"copy\", \"cut\"];\n  const isClipboardApiSupported = useSupported(() => navigator && \"clipboard\" in navigator);\n  const isSupported = computed(() => isClipboardApiSupported.value || legacy);\n  const text = ref(\"\");\n  const copied = ref(false);\n  const timeout = useTimeoutFn(() => copied.value = false, copiedDuring);\n  function updateText() {\n    if (isClipboardApiSupported.value) {\n      navigator.clipboard.readText().then((value) => {\n        text.value = value;\n      });\n    } else {\n      text.value = legacyRead();\n    }\n  }\n  if (isSupported.value && read) {\n    for (const event of events)\n      useEventListener(event, updateText);\n  }\n  async function copy(value = resolveUnref(source)) {\n    if (isSupported.value && value != null) {\n      if (isClipboardApiSupported.value)\n        await navigator.clipboard.writeText(value);\n      else\n        legacyCopy(value);\n      text.value = value;\n      copied.value = true;\n      timeout.start();\n    }\n  }\n  function legacyCopy(value) {\n    const ta = document.createElement(\"textarea\");\n    ta.value = value != null ? value : \"\";\n    ta.style.position = \"absolute\";\n    ta.style.opacity = \"0\";\n    document.body.appendChild(ta);\n    ta.select();\n    document.execCommand(\"copy\");\n    ta.remove();\n  }\n  function legacyRead() {\n    var _a, _b, _c;\n    return (_c = (_b = (_a = document == null ? void 0 : document.getSelection) == null ? void 0 : _a.call(document)) == null ? void 0 : _b.toString()) != null ? _c : \"\";\n  }\n  return {\n    isSupported,\n    text,\n    copied,\n    copy\n  };\n}\n\nvar __defProp$l = Object.defineProperty;\nvar __defProps$8 = Object.defineProperties;\nvar __getOwnPropDescs$8 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$n = Object.getOwnPropertySymbols;\nvar __hasOwnProp$n = Object.prototype.hasOwnProperty;\nvar __propIsEnum$n = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$l = (obj, key, value) => key in obj ? __defProp$l(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$l = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$n.call(b, prop))\n      __defNormalProp$l(a, prop, b[prop]);\n  if (__getOwnPropSymbols$n)\n    for (var prop of __getOwnPropSymbols$n(b)) {\n      if (__propIsEnum$n.call(b, prop))\n        __defNormalProp$l(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$8 = (a, b) => __defProps$8(a, __getOwnPropDescs$8(b));\nfunction cloneFnJSON(source) {\n  return JSON.parse(JSON.stringify(source));\n}\nfunction useCloned(source, options = {}) {\n  const cloned = ref({});\n  const {\n    manual,\n    clone = cloneFnJSON,\n    deep = true,\n    immediate = true\n  } = options;\n  function sync() {\n    cloned.value = clone(unref(source));\n  }\n  if (!manual && isRef(source)) {\n    watch(source, sync, __spreadProps$8(__spreadValues$l({}, options), {\n      deep,\n      immediate\n    }));\n  } else {\n    sync();\n  }\n  return { cloned, sync };\n}\n\nconst _global = typeof globalThis !== \"undefined\" ? globalThis : typeof window !== \"undefined\" ? window : typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : {};\nconst globalKey = \"__vueuse_ssr_handlers__\";\n_global[globalKey] = _global[globalKey] || {};\nconst handlers = _global[globalKey];\nfunction getSSRHandler(key, fallback) {\n  return handlers[key] || fallback;\n}\nfunction setSSRHandler(key, fn) {\n  handlers[key] = fn;\n}\n\nfunction guessSerializerType(rawInit) {\n  return rawInit == null ? \"any\" : rawInit instanceof Set ? \"set\" : rawInit instanceof Map ? \"map\" : rawInit instanceof Date ? \"date\" : typeof rawInit === \"boolean\" ? \"boolean\" : typeof rawInit === \"string\" ? \"string\" : typeof rawInit === \"object\" ? \"object\" : !Number.isNaN(rawInit) ? \"number\" : \"any\";\n}\n\nvar __defProp$k = Object.defineProperty;\nvar __getOwnPropSymbols$m = Object.getOwnPropertySymbols;\nvar __hasOwnProp$m = Object.prototype.hasOwnProperty;\nvar __propIsEnum$m = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$k = (obj, key, value) => key in obj ? __defProp$k(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$k = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$m.call(b, prop))\n      __defNormalProp$k(a, prop, b[prop]);\n  if (__getOwnPropSymbols$m)\n    for (var prop of __getOwnPropSymbols$m(b)) {\n      if (__propIsEnum$m.call(b, prop))\n        __defNormalProp$k(a, prop, b[prop]);\n    }\n  return a;\n};\nconst StorageSerializers = {\n  boolean: {\n    read: (v) => v === \"true\",\n    write: (v) => String(v)\n  },\n  object: {\n    read: (v) => JSON.parse(v),\n    write: (v) => JSON.stringify(v)\n  },\n  number: {\n    read: (v) => Number.parseFloat(v),\n    write: (v) => String(v)\n  },\n  any: {\n    read: (v) => v,\n    write: (v) => String(v)\n  },\n  string: {\n    read: (v) => v,\n    write: (v) => String(v)\n  },\n  map: {\n    read: (v) => new Map(JSON.parse(v)),\n    write: (v) => JSON.stringify(Array.from(v.entries()))\n  },\n  set: {\n    read: (v) => new Set(JSON.parse(v)),\n    write: (v) => JSON.stringify(Array.from(v))\n  },\n  date: {\n    read: (v) => new Date(v),\n    write: (v) => v.toISOString()\n  }\n};\nconst customStorageEventName = \"vueuse-storage\";\nfunction useStorage(key, defaults, storage, options = {}) {\n  var _a;\n  const {\n    flush = \"pre\",\n    deep = true,\n    listenToStorageChanges = true,\n    writeDefaults = true,\n    mergeDefaults = false,\n    shallow,\n    window = defaultWindow,\n    eventFilter,\n    onError = (e) => {\n      console.error(e);\n    }\n  } = options;\n  const data = (shallow ? shallowRef : ref)(defaults);\n  if (!storage) {\n    try {\n      storage = getSSRHandler(\"getDefaultStorage\", () => {\n        var _a2;\n        return (_a2 = defaultWindow) == null ? void 0 : _a2.localStorage;\n      })();\n    } catch (e) {\n      onError(e);\n    }\n  }\n  if (!storage)\n    return data;\n  const rawInit = resolveUnref(defaults);\n  const type = guessSerializerType(rawInit);\n  const serializer = (_a = options.serializer) != null ? _a : StorageSerializers[type];\n  const { pause: pauseWatch, resume: resumeWatch } = pausableWatch(data, () => write(data.value), { flush, deep, eventFilter });\n  if (window && listenToStorageChanges) {\n    useEventListener(window, \"storage\", update);\n    useEventListener(window, customStorageEventName, updateFromCustomEvent);\n  }\n  update();\n  return data;\n  function write(v) {\n    try {\n      if (v == null) {\n        storage.removeItem(key);\n      } else {\n        const serialized = serializer.write(v);\n        const oldValue = storage.getItem(key);\n        if (oldValue !== serialized) {\n          storage.setItem(key, serialized);\n          if (window) {\n            window.dispatchEvent(new CustomEvent(customStorageEventName, {\n              detail: {\n                key,\n                oldValue,\n                newValue: serialized,\n                storageArea: storage\n              }\n            }));\n          }\n        }\n      }\n    } catch (e) {\n      onError(e);\n    }\n  }\n  function read(event) {\n    const rawValue = event ? event.newValue : storage.getItem(key);\n    if (rawValue == null) {\n      if (writeDefaults && rawInit !== null)\n        storage.setItem(key, serializer.write(rawInit));\n      return rawInit;\n    } else if (!event && mergeDefaults) {\n      const value = serializer.read(rawValue);\n      if (isFunction(mergeDefaults))\n        return mergeDefaults(value, rawInit);\n      else if (type === \"object\" && !Array.isArray(value))\n        return __spreadValues$k(__spreadValues$k({}, rawInit), value);\n      return value;\n    } else if (typeof rawValue !== \"string\") {\n      return rawValue;\n    } else {\n      return serializer.read(rawValue);\n    }\n  }\n  function updateFromCustomEvent(event) {\n    update(event.detail);\n  }\n  function update(event) {\n    if (event && event.storageArea !== storage)\n      return;\n    if (event && event.key == null) {\n      data.value = rawInit;\n      return;\n    }\n    if (event && event.key !== key)\n      return;\n    pauseWatch();\n    try {\n      data.value = read(event);\n    } catch (e) {\n      onError(e);\n    } finally {\n      if (event)\n        nextTick(resumeWatch);\n      else\n        resumeWatch();\n    }\n  }\n}\n\nfunction usePreferredDark(options) {\n  return useMediaQuery(\"(prefers-color-scheme: dark)\", options);\n}\n\nvar __defProp$j = Object.defineProperty;\nvar __getOwnPropSymbols$l = Object.getOwnPropertySymbols;\nvar __hasOwnProp$l = Object.prototype.hasOwnProperty;\nvar __propIsEnum$l = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$j = (obj, key, value) => key in obj ? __defProp$j(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$j = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$l.call(b, prop))\n      __defNormalProp$j(a, prop, b[prop]);\n  if (__getOwnPropSymbols$l)\n    for (var prop of __getOwnPropSymbols$l(b)) {\n      if (__propIsEnum$l.call(b, prop))\n        __defNormalProp$j(a, prop, b[prop]);\n    }\n  return a;\n};\nfunction useColorMode(options = {}) {\n  const {\n    selector = \"html\",\n    attribute = \"class\",\n    initialValue = \"auto\",\n    window = defaultWindow,\n    storage,\n    storageKey = \"vueuse-color-scheme\",\n    listenToStorageChanges = true,\n    storageRef,\n    emitAuto\n  } = options;\n  const modes = __spreadValues$j({\n    auto: \"\",\n    light: \"light\",\n    dark: \"dark\"\n  }, options.modes || {});\n  const preferredDark = usePreferredDark({ window });\n  const preferredMode = computed(() => preferredDark.value ? \"dark\" : \"light\");\n  const store = storageRef || (storageKey == null ? ref(initialValue) : useStorage(storageKey, initialValue, storage, { window, listenToStorageChanges }));\n  const state = computed({\n    get() {\n      return store.value === \"auto\" && !emitAuto ? preferredMode.value : store.value;\n    },\n    set(v) {\n      store.value = v;\n    }\n  });\n  const updateHTMLAttrs = getSSRHandler(\"updateHTMLAttrs\", (selector2, attribute2, value) => {\n    const el = window == null ? void 0 : window.document.querySelector(selector2);\n    if (!el)\n      return;\n    if (attribute2 === \"class\") {\n      const current = value.split(/\\s/g);\n      Object.values(modes).flatMap((i) => (i || \"\").split(/\\s/g)).filter(Boolean).forEach((v) => {\n        if (current.includes(v))\n          el.classList.add(v);\n        else\n          el.classList.remove(v);\n      });\n    } else {\n      el.setAttribute(attribute2, value);\n    }\n  });\n  function defaultOnChanged(mode) {\n    var _a;\n    const resolvedMode = mode === \"auto\" ? preferredMode.value : mode;\n    updateHTMLAttrs(selector, attribute, (_a = modes[resolvedMode]) != null ? _a : resolvedMode);\n  }\n  function onChanged(mode) {\n    if (options.onChanged)\n      options.onChanged(mode, defaultOnChanged);\n    else\n      defaultOnChanged(mode);\n  }\n  watch(state, onChanged, { flush: \"post\", immediate: true });\n  if (emitAuto)\n    watch(preferredMode, () => onChanged(state.value), { flush: \"post\" });\n  tryOnMounted(() => onChanged(state.value));\n  return state;\n}\n\nfunction useConfirmDialog(revealed = ref(false)) {\n  const confirmHook = createEventHook();\n  const cancelHook = createEventHook();\n  const revealHook = createEventHook();\n  let _resolve = noop;\n  const reveal = (data) => {\n    revealHook.trigger(data);\n    revealed.value = true;\n    return new Promise((resolve) => {\n      _resolve = resolve;\n    });\n  };\n  const confirm = (data) => {\n    revealed.value = false;\n    confirmHook.trigger(data);\n    _resolve({ data, isCanceled: false });\n  };\n  const cancel = (data) => {\n    revealed.value = false;\n    cancelHook.trigger(data);\n    _resolve({ data, isCanceled: true });\n  };\n  return {\n    isRevealed: computed(() => revealed.value),\n    reveal,\n    confirm,\n    cancel,\n    onReveal: revealHook.on,\n    onConfirm: confirmHook.on,\n    onCancel: cancelHook.on\n  };\n}\n\nfunction useCssVar(prop, target, { window = defaultWindow, initialValue = \"\" } = {}) {\n  const variable = ref(initialValue);\n  const elRef = computed(() => {\n    var _a;\n    return unrefElement(target) || ((_a = window == null ? void 0 : window.document) == null ? void 0 : _a.documentElement);\n  });\n  watch([elRef, () => resolveUnref(prop)], ([el, prop2]) => {\n    var _a;\n    if (el && window) {\n      const value = (_a = window.getComputedStyle(el).getPropertyValue(prop2)) == null ? void 0 : _a.trim();\n      variable.value = value || initialValue;\n    }\n  }, { immediate: true });\n  watch(variable, (val) => {\n    var _a;\n    if ((_a = elRef.value) == null ? void 0 : _a.style)\n      elRef.value.style.setProperty(resolveUnref(prop), val);\n  });\n  return variable;\n}\n\nfunction useCurrentElement() {\n  const vm = getCurrentInstance();\n  const currentElement = computedWithControl(() => null, () => vm.proxy.$el);\n  onUpdated(currentElement.trigger);\n  onMounted(currentElement.trigger);\n  return currentElement;\n}\n\nfunction useCycleList(list, options) {\n  var _a;\n  const state = shallowRef((_a = options == null ? void 0 : options.initialValue) != null ? _a : list[0]);\n  const index = computed({\n    get() {\n      var _a2;\n      let index2 = (options == null ? void 0 : options.getIndexOf) ? options.getIndexOf(state.value, list) : list.indexOf(state.value);\n      if (index2 < 0)\n        index2 = (_a2 = options == null ? void 0 : options.fallbackIndex) != null ? _a2 : 0;\n      return index2;\n    },\n    set(v) {\n      set(v);\n    }\n  });\n  function set(i) {\n    const length = list.length;\n    const index2 = (i % length + length) % length;\n    const value = list[index2];\n    state.value = value;\n    return value;\n  }\n  function shift(delta = 1) {\n    return set(index.value + delta);\n  }\n  function next(n = 1) {\n    return shift(n);\n  }\n  function prev(n = 1) {\n    return shift(-n);\n  }\n  return {\n    state,\n    index,\n    next,\n    prev\n  };\n}\n\nvar __defProp$i = Object.defineProperty;\nvar __defProps$7 = Object.defineProperties;\nvar __getOwnPropDescs$7 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$k = Object.getOwnPropertySymbols;\nvar __hasOwnProp$k = Object.prototype.hasOwnProperty;\nvar __propIsEnum$k = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$i = (obj, key, value) => key in obj ? __defProp$i(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$i = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$k.call(b, prop))\n      __defNormalProp$i(a, prop, b[prop]);\n  if (__getOwnPropSymbols$k)\n    for (var prop of __getOwnPropSymbols$k(b)) {\n      if (__propIsEnum$k.call(b, prop))\n        __defNormalProp$i(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$7 = (a, b) => __defProps$7(a, __getOwnPropDescs$7(b));\nfunction useDark(options = {}) {\n  const {\n    valueDark = \"dark\",\n    valueLight = \"\",\n    window = defaultWindow\n  } = options;\n  const mode = useColorMode(__spreadProps$7(__spreadValues$i({}, options), {\n    onChanged: (mode2, defaultHandler) => {\n      var _a;\n      if (options.onChanged)\n        (_a = options.onChanged) == null ? void 0 : _a.call(options, mode2 === \"dark\");\n      else\n        defaultHandler(mode2);\n    },\n    modes: {\n      dark: valueDark,\n      light: valueLight\n    }\n  }));\n  const preferredDark = usePreferredDark({ window });\n  const isDark = computed({\n    get() {\n      return mode.value === \"dark\";\n    },\n    set(v) {\n      if (v === preferredDark.value)\n        mode.value = \"auto\";\n      else\n        mode.value = v ? \"dark\" : \"light\";\n    }\n  });\n  return isDark;\n}\n\nconst fnBypass = (v) => v;\nconst fnSetSource = (source, value) => source.value = value;\nfunction defaultDump(clone) {\n  return clone ? isFunction(clone) ? clone : cloneFnJSON : fnBypass;\n}\nfunction defaultParse(clone) {\n  return clone ? isFunction(clone) ? clone : cloneFnJSON : fnBypass;\n}\nfunction useManualRefHistory(source, options = {}) {\n  const {\n    clone = false,\n    dump = defaultDump(clone),\n    parse = defaultParse(clone),\n    setSource = fnSetSource\n  } = options;\n  function _createHistoryRecord() {\n    return markRaw({\n      snapshot: dump(source.value),\n      timestamp: timestamp()\n    });\n  }\n  const last = ref(_createHistoryRecord());\n  const undoStack = ref([]);\n  const redoStack = ref([]);\n  const _setSource = (record) => {\n    setSource(source, parse(record.snapshot));\n    last.value = record;\n  };\n  const commit = () => {\n    undoStack.value.unshift(last.value);\n    last.value = _createHistoryRecord();\n    if (options.capacity && undoStack.value.length > options.capacity)\n      undoStack.value.splice(options.capacity, Infinity);\n    if (redoStack.value.length)\n      redoStack.value.splice(0, redoStack.value.length);\n  };\n  const clear = () => {\n    undoStack.value.splice(0, undoStack.value.length);\n    redoStack.value.splice(0, redoStack.value.length);\n  };\n  const undo = () => {\n    const state = undoStack.value.shift();\n    if (state) {\n      redoStack.value.unshift(last.value);\n      _setSource(state);\n    }\n  };\n  const redo = () => {\n    const state = redoStack.value.shift();\n    if (state) {\n      undoStack.value.unshift(last.value);\n      _setSource(state);\n    }\n  };\n  const reset = () => {\n    _setSource(last.value);\n  };\n  const history = computed(() => [last.value, ...undoStack.value]);\n  const canUndo = computed(() => undoStack.value.length > 0);\n  const canRedo = computed(() => redoStack.value.length > 0);\n  return {\n    source,\n    undoStack,\n    redoStack,\n    last,\n    history,\n    canUndo,\n    canRedo,\n    clear,\n    commit,\n    reset,\n    undo,\n    redo\n  };\n}\n\nvar __defProp$h = Object.defineProperty;\nvar __defProps$6 = Object.defineProperties;\nvar __getOwnPropDescs$6 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$j = Object.getOwnPropertySymbols;\nvar __hasOwnProp$j = Object.prototype.hasOwnProperty;\nvar __propIsEnum$j = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$h = (obj, key, value) => key in obj ? __defProp$h(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$h = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$j.call(b, prop))\n      __defNormalProp$h(a, prop, b[prop]);\n  if (__getOwnPropSymbols$j)\n    for (var prop of __getOwnPropSymbols$j(b)) {\n      if (__propIsEnum$j.call(b, prop))\n        __defNormalProp$h(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$6 = (a, b) => __defProps$6(a, __getOwnPropDescs$6(b));\nfunction useRefHistory(source, options = {}) {\n  const {\n    deep = false,\n    flush = \"pre\",\n    eventFilter\n  } = options;\n  const {\n    eventFilter: composedFilter,\n    pause,\n    resume: resumeTracking,\n    isActive: isTracking\n  } = pausableFilter(eventFilter);\n  const {\n    ignoreUpdates,\n    ignorePrevAsyncUpdates,\n    stop\n  } = watchIgnorable(source, commit, { deep, flush, eventFilter: composedFilter });\n  function setSource(source2, value) {\n    ignorePrevAsyncUpdates();\n    ignoreUpdates(() => {\n      source2.value = value;\n    });\n  }\n  const manualHistory = useManualRefHistory(source, __spreadProps$6(__spreadValues$h({}, options), { clone: options.clone || deep, setSource }));\n  const { clear, commit: manualCommit } = manualHistory;\n  function commit() {\n    ignorePrevAsyncUpdates();\n    manualCommit();\n  }\n  function resume(commitNow) {\n    resumeTracking();\n    if (commitNow)\n      commit();\n  }\n  function batch(fn) {\n    let canceled = false;\n    const cancel = () => canceled = true;\n    ignoreUpdates(() => {\n      fn(cancel);\n    });\n    if (!canceled)\n      commit();\n  }\n  function dispose() {\n    stop();\n    clear();\n  }\n  return __spreadProps$6(__spreadValues$h({}, manualHistory), {\n    isTracking,\n    pause,\n    resume,\n    commit,\n    batch,\n    dispose\n  });\n}\n\nvar __defProp$g = Object.defineProperty;\nvar __defProps$5 = Object.defineProperties;\nvar __getOwnPropDescs$5 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$i = Object.getOwnPropertySymbols;\nvar __hasOwnProp$i = Object.prototype.hasOwnProperty;\nvar __propIsEnum$i = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$g = (obj, key, value) => key in obj ? __defProp$g(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$g = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$i.call(b, prop))\n      __defNormalProp$g(a, prop, b[prop]);\n  if (__getOwnPropSymbols$i)\n    for (var prop of __getOwnPropSymbols$i(b)) {\n      if (__propIsEnum$i.call(b, prop))\n        __defNormalProp$g(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$5 = (a, b) => __defProps$5(a, __getOwnPropDescs$5(b));\nfunction useDebouncedRefHistory(source, options = {}) {\n  const filter = options.debounce ? debounceFilter(options.debounce) : void 0;\n  const history = useRefHistory(source, __spreadProps$5(__spreadValues$g({}, options), { eventFilter: filter }));\n  return __spreadValues$g({}, history);\n}\n\nfunction useDeviceMotion(options = {}) {\n  const {\n    window = defaultWindow,\n    eventFilter = bypassFilter\n  } = options;\n  const acceleration = ref({ x: null, y: null, z: null });\n  const rotationRate = ref({ alpha: null, beta: null, gamma: null });\n  const interval = ref(0);\n  const accelerationIncludingGravity = ref({\n    x: null,\n    y: null,\n    z: null\n  });\n  if (window) {\n    const onDeviceMotion = createFilterWrapper(eventFilter, (event) => {\n      acceleration.value = event.acceleration;\n      accelerationIncludingGravity.value = event.accelerationIncludingGravity;\n      rotationRate.value = event.rotationRate;\n      interval.value = event.interval;\n    });\n    useEventListener(window, \"devicemotion\", onDeviceMotion);\n  }\n  return {\n    acceleration,\n    accelerationIncludingGravity,\n    rotationRate,\n    interval\n  };\n}\n\nfunction useDeviceOrientation(options = {}) {\n  const { window = defaultWindow } = options;\n  const isSupported = useSupported(() => window && \"DeviceOrientationEvent\" in window);\n  const isAbsolute = ref(false);\n  const alpha = ref(null);\n  const beta = ref(null);\n  const gamma = ref(null);\n  if (window && isSupported.value) {\n    useEventListener(window, \"deviceorientation\", (event) => {\n      isAbsolute.value = event.absolute;\n      alpha.value = event.alpha;\n      beta.value = event.beta;\n      gamma.value = event.gamma;\n    });\n  }\n  return {\n    isSupported,\n    isAbsolute,\n    alpha,\n    beta,\n    gamma\n  };\n}\n\nfunction useDevicePixelRatio({\n  window = defaultWindow\n} = {}) {\n  const pixelRatio = ref(1);\n  if (window) {\n    let observe = function() {\n      pixelRatio.value = window.devicePixelRatio;\n      cleanup();\n      media = window.matchMedia(`(resolution: ${pixelRatio.value}dppx)`);\n      media.addEventListener(\"change\", observe, { once: true });\n    }, cleanup = function() {\n      media == null ? void 0 : media.removeEventListener(\"change\", observe);\n    };\n    let media;\n    observe();\n    tryOnScopeDispose(cleanup);\n  }\n  return { pixelRatio };\n}\n\nfunction usePermission(permissionDesc, options = {}) {\n  const {\n    controls = false,\n    navigator = defaultNavigator\n  } = options;\n  const isSupported = useSupported(() => navigator && \"permissions\" in navigator);\n  let permissionStatus;\n  const desc = typeof permissionDesc === \"string\" ? { name: permissionDesc } : permissionDesc;\n  const state = ref();\n  const onChange = () => {\n    if (permissionStatus)\n      state.value = permissionStatus.state;\n  };\n  const query = createSingletonPromise(async () => {\n    if (!isSupported.value)\n      return;\n    if (!permissionStatus) {\n      try {\n        permissionStatus = await navigator.permissions.query(desc);\n        useEventListener(permissionStatus, \"change\", onChange);\n        onChange();\n      } catch (e) {\n        state.value = \"prompt\";\n      }\n    }\n    return permissionStatus;\n  });\n  query();\n  if (controls) {\n    return {\n      state,\n      isSupported,\n      query\n    };\n  } else {\n    return state;\n  }\n}\n\nfunction useDevicesList(options = {}) {\n  const {\n    navigator = defaultNavigator,\n    requestPermissions = false,\n    constraints = { audio: true, video: true },\n    onUpdated\n  } = options;\n  const devices = ref([]);\n  const videoInputs = computed(() => devices.value.filter((i) => i.kind === \"videoinput\"));\n  const audioInputs = computed(() => devices.value.filter((i) => i.kind === \"audioinput\"));\n  const audioOutputs = computed(() => devices.value.filter((i) => i.kind === \"audiooutput\"));\n  const isSupported = useSupported(() => navigator && navigator.mediaDevices && navigator.mediaDevices.enumerateDevices);\n  const permissionGranted = ref(false);\n  async function update() {\n    if (!isSupported.value)\n      return;\n    devices.value = await navigator.mediaDevices.enumerateDevices();\n    onUpdated == null ? void 0 : onUpdated(devices.value);\n  }\n  async function ensurePermissions() {\n    if (!isSupported.value)\n      return false;\n    if (permissionGranted.value)\n      return true;\n    const { state, query } = usePermission(\"camera\", { controls: true });\n    await query();\n    if (state.value !== \"granted\") {\n      const stream = await navigator.mediaDevices.getUserMedia(constraints);\n      stream.getTracks().forEach((t) => t.stop());\n      update();\n      permissionGranted.value = true;\n    } else {\n      permissionGranted.value = true;\n    }\n    return permissionGranted.value;\n  }\n  if (isSupported.value) {\n    if (requestPermissions)\n      ensurePermissions();\n    useEventListener(navigator.mediaDevices, \"devicechange\", update);\n    update();\n  }\n  return {\n    devices,\n    ensurePermissions,\n    permissionGranted,\n    videoInputs,\n    audioInputs,\n    audioOutputs,\n    isSupported\n  };\n}\n\nfunction useDisplayMedia(options = {}) {\n  var _a;\n  const enabled = ref((_a = options.enabled) != null ? _a : false);\n  const video = options.video;\n  const audio = options.audio;\n  const { navigator = defaultNavigator } = options;\n  const isSupported = useSupported(() => {\n    var _a2;\n    return (_a2 = navigator == null ? void 0 : navigator.mediaDevices) == null ? void 0 : _a2.getDisplayMedia;\n  });\n  const constraint = { audio, video };\n  const stream = shallowRef();\n  async function _start() {\n    if (!isSupported.value || stream.value)\n      return;\n    stream.value = await navigator.mediaDevices.getDisplayMedia(constraint);\n    return stream.value;\n  }\n  async function _stop() {\n    var _a2;\n    (_a2 = stream.value) == null ? void 0 : _a2.getTracks().forEach((t) => t.stop());\n    stream.value = void 0;\n  }\n  function stop() {\n    _stop();\n    enabled.value = false;\n  }\n  async function start() {\n    await _start();\n    if (stream.value)\n      enabled.value = true;\n    return stream.value;\n  }\n  watch(enabled, (v) => {\n    if (v)\n      _start();\n    else\n      _stop();\n  }, { immediate: true });\n  return {\n    isSupported,\n    stream,\n    start,\n    stop,\n    enabled\n  };\n}\n\nfunction useDocumentVisibility({ document = defaultDocument } = {}) {\n  if (!document)\n    return ref(\"visible\");\n  const visibility = ref(document.visibilityState);\n  useEventListener(document, \"visibilitychange\", () => {\n    visibility.value = document.visibilityState;\n  });\n  return visibility;\n}\n\nvar __defProp$f = Object.defineProperty;\nvar __defProps$4 = Object.defineProperties;\nvar __getOwnPropDescs$4 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$h = Object.getOwnPropertySymbols;\nvar __hasOwnProp$h = Object.prototype.hasOwnProperty;\nvar __propIsEnum$h = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$f = (obj, key, value) => key in obj ? __defProp$f(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$f = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$h.call(b, prop))\n      __defNormalProp$f(a, prop, b[prop]);\n  if (__getOwnPropSymbols$h)\n    for (var prop of __getOwnPropSymbols$h(b)) {\n      if (__propIsEnum$h.call(b, prop))\n        __defNormalProp$f(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$4 = (a, b) => __defProps$4(a, __getOwnPropDescs$4(b));\nfunction useDraggable(target, options = {}) {\n  var _a, _b, _c;\n  const draggingElement = (_a = options.draggingElement) != null ? _a : defaultWindow;\n  const draggingHandle = (_b = options.handle) != null ? _b : target;\n  const position = ref((_c = resolveUnref(options.initialValue)) != null ? _c : { x: 0, y: 0 });\n  const pressedDelta = ref();\n  const filterEvent = (e) => {\n    if (options.pointerTypes)\n      return options.pointerTypes.includes(e.pointerType);\n    return true;\n  };\n  const handleEvent = (e) => {\n    if (resolveUnref(options.preventDefault))\n      e.preventDefault();\n    if (resolveUnref(options.stopPropagation))\n      e.stopPropagation();\n  };\n  const start = (e) => {\n    var _a2;\n    if (!filterEvent(e))\n      return;\n    if (resolveUnref(options.exact) && e.target !== resolveUnref(target))\n      return;\n    const rect = resolveUnref(target).getBoundingClientRect();\n    const pos = {\n      x: e.clientX - rect.left,\n      y: e.clientY - rect.top\n    };\n    if (((_a2 = options.onStart) == null ? void 0 : _a2.call(options, pos, e)) === false)\n      return;\n    pressedDelta.value = pos;\n    handleEvent(e);\n  };\n  const move = (e) => {\n    var _a2;\n    if (!filterEvent(e))\n      return;\n    if (!pressedDelta.value)\n      return;\n    position.value = {\n      x: e.clientX - pressedDelta.value.x,\n      y: e.clientY - pressedDelta.value.y\n    };\n    (_a2 = options.onMove) == null ? void 0 : _a2.call(options, position.value, e);\n    handleEvent(e);\n  };\n  const end = (e) => {\n    var _a2;\n    if (!filterEvent(e))\n      return;\n    if (!pressedDelta.value)\n      return;\n    pressedDelta.value = void 0;\n    (_a2 = options.onEnd) == null ? void 0 : _a2.call(options, position.value, e);\n    handleEvent(e);\n  };\n  if (isClient) {\n    useEventListener(draggingHandle, \"pointerdown\", start, true);\n    useEventListener(draggingElement, \"pointermove\", move, true);\n    useEventListener(draggingElement, \"pointerup\", end, true);\n  }\n  return __spreadProps$4(__spreadValues$f({}, toRefs(position)), {\n    position,\n    isDragging: computed(() => !!pressedDelta.value),\n    style: computed(() => `left:${position.value.x}px;top:${position.value.y}px;`)\n  });\n}\n\nfunction useDropZone(target, onDrop) {\n  const isOverDropZone = ref(false);\n  let counter = 0;\n  if (isClient) {\n    useEventListener(target, \"dragenter\", (event) => {\n      event.preventDefault();\n      counter += 1;\n      isOverDropZone.value = true;\n    });\n    useEventListener(target, \"dragover\", (event) => {\n      event.preventDefault();\n    });\n    useEventListener(target, \"dragleave\", (event) => {\n      event.preventDefault();\n      counter -= 1;\n      if (counter === 0)\n        isOverDropZone.value = false;\n    });\n    useEventListener(target, \"drop\", (event) => {\n      var _a, _b;\n      event.preventDefault();\n      counter = 0;\n      isOverDropZone.value = false;\n      const files = Array.from((_b = (_a = event.dataTransfer) == null ? void 0 : _a.files) != null ? _b : []);\n      onDrop == null ? void 0 : onDrop(files.length === 0 ? null : files);\n    });\n  }\n  return {\n    isOverDropZone\n  };\n}\n\nvar __getOwnPropSymbols$g = Object.getOwnPropertySymbols;\nvar __hasOwnProp$g = Object.prototype.hasOwnProperty;\nvar __propIsEnum$g = Object.prototype.propertyIsEnumerable;\nvar __objRest$2 = (source, exclude) => {\n  var target = {};\n  for (var prop in source)\n    if (__hasOwnProp$g.call(source, prop) && exclude.indexOf(prop) < 0)\n      target[prop] = source[prop];\n  if (source != null && __getOwnPropSymbols$g)\n    for (var prop of __getOwnPropSymbols$g(source)) {\n      if (exclude.indexOf(prop) < 0 && __propIsEnum$g.call(source, prop))\n        target[prop] = source[prop];\n    }\n  return target;\n};\nfunction useResizeObserver(target, callback, options = {}) {\n  const _a = options, { window = defaultWindow } = _a, observerOptions = __objRest$2(_a, [\"window\"]);\n  let observer;\n  const isSupported = useSupported(() => window && \"ResizeObserver\" in window);\n  const cleanup = () => {\n    if (observer) {\n      observer.disconnect();\n      observer = void 0;\n    }\n  };\n  const stopWatch = watch(() => unrefElement(target), (el) => {\n    cleanup();\n    if (isSupported.value && window && el) {\n      observer = new ResizeObserver(callback);\n      observer.observe(el, observerOptions);\n    }\n  }, { immediate: true, flush: \"post\" });\n  const stop = () => {\n    cleanup();\n    stopWatch();\n  };\n  tryOnScopeDispose(stop);\n  return {\n    isSupported,\n    stop\n  };\n}\n\nfunction useElementBounding(target, options = {}) {\n  const {\n    reset = true,\n    windowResize = true,\n    windowScroll = true,\n    immediate = true\n  } = options;\n  const height = ref(0);\n  const bottom = ref(0);\n  const left = ref(0);\n  const right = ref(0);\n  const top = ref(0);\n  const width = ref(0);\n  const x = ref(0);\n  const y = ref(0);\n  function update() {\n    const el = unrefElement(target);\n    if (!el) {\n      if (reset) {\n        height.value = 0;\n        bottom.value = 0;\n        left.value = 0;\n        right.value = 0;\n        top.value = 0;\n        width.value = 0;\n        x.value = 0;\n        y.value = 0;\n      }\n      return;\n    }\n    const rect = el.getBoundingClientRect();\n    height.value = rect.height;\n    bottom.value = rect.bottom;\n    left.value = rect.left;\n    right.value = rect.right;\n    top.value = rect.top;\n    width.value = rect.width;\n    x.value = rect.x;\n    y.value = rect.y;\n  }\n  useResizeObserver(target, update);\n  watch(() => unrefElement(target), (ele) => !ele && update());\n  if (windowScroll)\n    useEventListener(\"scroll\", update, { capture: true, passive: true });\n  if (windowResize)\n    useEventListener(\"resize\", update, { passive: true });\n  tryOnMounted(() => {\n    if (immediate)\n      update();\n  });\n  return {\n    height,\n    bottom,\n    left,\n    right,\n    top,\n    width,\n    x,\n    y,\n    update\n  };\n}\n\nfunction useRafFn(fn, options = {}) {\n  const {\n    immediate = true,\n    window = defaultWindow\n  } = options;\n  const isActive = ref(false);\n  let previousFrameTimestamp = 0;\n  let rafId = null;\n  function loop(timestamp) {\n    if (!isActive.value || !window)\n      return;\n    const delta = timestamp - previousFrameTimestamp;\n    fn({ delta, timestamp });\n    previousFrameTimestamp = timestamp;\n    rafId = window.requestAnimationFrame(loop);\n  }\n  function resume() {\n    if (!isActive.value && window) {\n      isActive.value = true;\n      rafId = window.requestAnimationFrame(loop);\n    }\n  }\n  function pause() {\n    isActive.value = false;\n    if (rafId != null && window) {\n      window.cancelAnimationFrame(rafId);\n      rafId = null;\n    }\n  }\n  if (immediate)\n    resume();\n  tryOnScopeDispose(pause);\n  return {\n    isActive: readonly(isActive),\n    pause,\n    resume\n  };\n}\n\nvar __defProp$e = Object.defineProperty;\nvar __getOwnPropSymbols$f = Object.getOwnPropertySymbols;\nvar __hasOwnProp$f = Object.prototype.hasOwnProperty;\nvar __propIsEnum$f = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$e = (obj, key, value) => key in obj ? __defProp$e(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$e = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$f.call(b, prop))\n      __defNormalProp$e(a, prop, b[prop]);\n  if (__getOwnPropSymbols$f)\n    for (var prop of __getOwnPropSymbols$f(b)) {\n      if (__propIsEnum$f.call(b, prop))\n        __defNormalProp$e(a, prop, b[prop]);\n    }\n  return a;\n};\nfunction useElementByPoint(options) {\n  const element = ref(null);\n  const { x, y, document = defaultDocument } = options;\n  const controls = useRafFn(() => {\n    element.value = (document == null ? void 0 : document.elementFromPoint(resolveUnref(x), resolveUnref(y))) || null;\n  });\n  return __spreadValues$e({\n    element\n  }, controls);\n}\n\nfunction useElementHover(el, options = {}) {\n  const delayEnter = options ? options.delayEnter : 0;\n  const delayLeave = options ? options.delayLeave : 0;\n  const isHovered = ref(false);\n  let timer;\n  const toggle = (entering) => {\n    const delay = entering ? delayEnter : delayLeave;\n    if (timer) {\n      clearTimeout(timer);\n      timer = void 0;\n    }\n    if (delay)\n      timer = setTimeout(() => isHovered.value = entering, delay);\n    else\n      isHovered.value = entering;\n  };\n  if (!window)\n    return isHovered;\n  useEventListener(el, \"mouseenter\", () => toggle(true), { passive: true });\n  useEventListener(el, \"mouseleave\", () => toggle(false), { passive: true });\n  return isHovered;\n}\n\nfunction useElementSize(target, initialSize = { width: 0, height: 0 }, options = {}) {\n  const { window = defaultWindow, box = \"content-box\" } = options;\n  const isSVG = computed(() => {\n    var _a, _b;\n    return (_b = (_a = unrefElement(target)) == null ? void 0 : _a.namespaceURI) == null ? void 0 : _b.includes(\"svg\");\n  });\n  const width = ref(initialSize.width);\n  const height = ref(initialSize.height);\n  useResizeObserver(target, ([entry]) => {\n    const boxSize = box === \"border-box\" ? entry.borderBoxSize : box === \"content-box\" ? entry.contentBoxSize : entry.devicePixelContentBoxSize;\n    if (window && isSVG.value) {\n      const $elem = unrefElement(target);\n      if ($elem) {\n        const styles = window.getComputedStyle($elem);\n        width.value = parseFloat(styles.width);\n        height.value = parseFloat(styles.height);\n      }\n    } else {\n      if (boxSize) {\n        const formatBoxSize = Array.isArray(boxSize) ? boxSize : [boxSize];\n        width.value = formatBoxSize.reduce((acc, { inlineSize }) => acc + inlineSize, 0);\n        height.value = formatBoxSize.reduce((acc, { blockSize }) => acc + blockSize, 0);\n      } else {\n        width.value = entry.contentRect.width;\n        height.value = entry.contentRect.height;\n      }\n    }\n  }, options);\n  watch(() => unrefElement(target), (ele) => {\n    width.value = ele ? initialSize.width : 0;\n    height.value = ele ? initialSize.height : 0;\n  });\n  return {\n    width,\n    height\n  };\n}\n\nfunction useElementVisibility(element, { window = defaultWindow, scrollTarget } = {}) {\n  const elementIsVisible = ref(false);\n  const testBounding = () => {\n    if (!window)\n      return;\n    const document = window.document;\n    const el = unrefElement(element);\n    if (!el) {\n      elementIsVisible.value = false;\n    } else {\n      const rect = el.getBoundingClientRect();\n      elementIsVisible.value = rect.top <= (window.innerHeight || document.documentElement.clientHeight) && rect.left <= (window.innerWidth || document.documentElement.clientWidth) && rect.bottom >= 0 && rect.right >= 0;\n    }\n  };\n  watch(() => unrefElement(element), () => testBounding(), { immediate: true, flush: \"post\" });\n  if (window) {\n    useEventListener(scrollTarget || window, \"scroll\", testBounding, {\n      capture: false,\n      passive: true\n    });\n  }\n  return elementIsVisible;\n}\n\nconst events = new Map();\n\nfunction useEventBus(key) {\n  const scope = getCurrentScope();\n  function on(listener) {\n    var _a;\n    const listeners = events.get(key) || [];\n    listeners.push(listener);\n    events.set(key, listeners);\n    const _off = () => off(listener);\n    (_a = scope == null ? void 0 : scope.cleanups) == null ? void 0 : _a.push(_off);\n    return _off;\n  }\n  function once(listener) {\n    function _listener(...args) {\n      off(_listener);\n      listener(...args);\n    }\n    return on(_listener);\n  }\n  function off(listener) {\n    const listeners = events.get(key);\n    if (!listeners)\n      return;\n    const index = listeners.indexOf(listener);\n    if (index > -1)\n      listeners.splice(index, 1);\n    if (!listeners.length)\n      events.delete(key);\n  }\n  function reset() {\n    events.delete(key);\n  }\n  function emit(event, payload) {\n    var _a;\n    (_a = events.get(key)) == null ? void 0 : _a.forEach((v) => v(event, payload));\n  }\n  return { on, once, off, emit, reset };\n}\n\nfunction useEventSource(url, events = [], options = {}) {\n  const event = ref(null);\n  const data = ref(null);\n  const status = ref(\"CONNECTING\");\n  const eventSource = ref(null);\n  const error = ref(null);\n  const {\n    withCredentials = false\n  } = options;\n  const close = () => {\n    if (eventSource.value) {\n      eventSource.value.close();\n      eventSource.value = null;\n      status.value = \"CLOSED\";\n    }\n  };\n  const es = new EventSource(url, { withCredentials });\n  eventSource.value = es;\n  es.onopen = () => {\n    status.value = \"OPEN\";\n    error.value = null;\n  };\n  es.onerror = (e) => {\n    status.value = \"CLOSED\";\n    error.value = e;\n  };\n  es.onmessage = (e) => {\n    event.value = null;\n    data.value = e.data;\n  };\n  for (const event_name of events) {\n    useEventListener(es, event_name, (e) => {\n      event.value = event_name;\n      data.value = e.data || null;\n    });\n  }\n  tryOnScopeDispose(() => {\n    close();\n  });\n  return {\n    eventSource,\n    event,\n    data,\n    status,\n    error,\n    close\n  };\n}\n\nfunction useEyeDropper(options = {}) {\n  const { initialValue = \"\" } = options;\n  const isSupported = useSupported(() => typeof window !== \"undefined\" && \"EyeDropper\" in window);\n  const sRGBHex = ref(initialValue);\n  async function open(openOptions) {\n    if (!isSupported.value)\n      return;\n    const eyeDropper = new window.EyeDropper();\n    const result = await eyeDropper.open(openOptions);\n    sRGBHex.value = result.sRGBHex;\n    return result;\n  }\n  return { isSupported, sRGBHex, open };\n}\n\nfunction useFavicon(newIcon = null, options = {}) {\n  const {\n    baseUrl = \"\",\n    rel = \"icon\",\n    document = defaultDocument\n  } = options;\n  const favicon = resolveRef(newIcon);\n  const applyIcon = (icon) => {\n    document == null ? void 0 : document.head.querySelectorAll(`link[rel*=\"${rel}\"]`).forEach((el) => el.href = `${baseUrl}${icon}`);\n  };\n  watch(favicon, (i, o) => {\n    if (isString(i) && i !== o)\n      applyIcon(i);\n  }, { immediate: true });\n  return favicon;\n}\n\nvar __defProp$d = Object.defineProperty;\nvar __defProps$3 = Object.defineProperties;\nvar __getOwnPropDescs$3 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$e = Object.getOwnPropertySymbols;\nvar __hasOwnProp$e = Object.prototype.hasOwnProperty;\nvar __propIsEnum$e = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$d = (obj, key, value) => key in obj ? __defProp$d(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$d = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$e.call(b, prop))\n      __defNormalProp$d(a, prop, b[prop]);\n  if (__getOwnPropSymbols$e)\n    for (var prop of __getOwnPropSymbols$e(b)) {\n      if (__propIsEnum$e.call(b, prop))\n        __defNormalProp$d(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$3 = (a, b) => __defProps$3(a, __getOwnPropDescs$3(b));\nconst payloadMapping = {\n  json: \"application/json\",\n  text: \"text/plain\"\n};\nfunction isFetchOptions(obj) {\n  return obj && containsProp(obj, \"immediate\", \"refetch\", \"initialData\", \"timeout\", \"beforeFetch\", \"afterFetch\", \"onFetchError\", \"fetch\");\n}\nfunction isAbsoluteURL(url) {\n  return /^([a-z][a-z\\d+\\-.]*:)?\\/\\//i.test(url);\n}\nfunction headersToObject(headers) {\n  if (typeof Headers !== \"undefined\" && headers instanceof Headers)\n    return Object.fromEntries([...headers.entries()]);\n  return headers;\n}\nfunction combineCallbacks(combination, ...callbacks) {\n  if (combination === \"overwrite\") {\n    return async (ctx) => {\n      const callback = callbacks[callbacks.length - 1];\n      if (callback !== void 0)\n        await callback(ctx);\n      return ctx;\n    };\n  } else {\n    return async (ctx) => {\n      await callbacks.reduce((prevCallback, callback) => prevCallback.then(async () => {\n        if (callback)\n          ctx = __spreadValues$d(__spreadValues$d({}, ctx), await callback(ctx));\n      }), Promise.resolve());\n      return ctx;\n    };\n  }\n}\nfunction createFetch(config = {}) {\n  const _combination = config.combination || \"chain\";\n  const _options = config.options || {};\n  const _fetchOptions = config.fetchOptions || {};\n  function useFactoryFetch(url, ...args) {\n    const computedUrl = computed(() => {\n      const baseUrl = resolveUnref(config.baseUrl);\n      const targetUrl = resolveUnref(url);\n      return baseUrl && !isAbsoluteURL(targetUrl) ? joinPaths(baseUrl, targetUrl) : targetUrl;\n    });\n    let options = _options;\n    let fetchOptions = _fetchOptions;\n    if (args.length > 0) {\n      if (isFetchOptions(args[0])) {\n        options = __spreadProps$3(__spreadValues$d(__spreadValues$d({}, options), args[0]), {\n          beforeFetch: combineCallbacks(_combination, _options.beforeFetch, args[0].beforeFetch),\n          afterFetch: combineCallbacks(_combination, _options.afterFetch, args[0].afterFetch),\n          onFetchError: combineCallbacks(_combination, _options.onFetchError, args[0].onFetchError)\n        });\n      } else {\n        fetchOptions = __spreadProps$3(__spreadValues$d(__spreadValues$d({}, fetchOptions), args[0]), {\n          headers: __spreadValues$d(__spreadValues$d({}, headersToObject(fetchOptions.headers) || {}), headersToObject(args[0].headers) || {})\n        });\n      }\n    }\n    if (args.length > 1 && isFetchOptions(args[1])) {\n      options = __spreadProps$3(__spreadValues$d(__spreadValues$d({}, options), args[1]), {\n        beforeFetch: combineCallbacks(_combination, _options.beforeFetch, args[1].beforeFetch),\n        afterFetch: combineCallbacks(_combination, _options.afterFetch, args[1].afterFetch),\n        onFetchError: combineCallbacks(_combination, _options.onFetchError, args[1].onFetchError)\n      });\n    }\n    return useFetch(computedUrl, fetchOptions, options);\n  }\n  return useFactoryFetch;\n}\nfunction useFetch(url, ...args) {\n  var _a;\n  const supportsAbort = typeof AbortController === \"function\";\n  let fetchOptions = {};\n  let options = { immediate: true, refetch: false, timeout: 0 };\n  const config = {\n    method: \"GET\",\n    type: \"text\",\n    payload: void 0\n  };\n  if (args.length > 0) {\n    if (isFetchOptions(args[0]))\n      options = __spreadValues$d(__spreadValues$d({}, options), args[0]);\n    else\n      fetchOptions = args[0];\n  }\n  if (args.length > 1) {\n    if (isFetchOptions(args[1]))\n      options = __spreadValues$d(__spreadValues$d({}, options), args[1]);\n  }\n  const {\n    fetch = (_a = defaultWindow) == null ? void 0 : _a.fetch,\n    initialData,\n    timeout\n  } = options;\n  const responseEvent = createEventHook();\n  const errorEvent = createEventHook();\n  const finallyEvent = createEventHook();\n  const isFinished = ref(false);\n  const isFetching = ref(false);\n  const aborted = ref(false);\n  const statusCode = ref(null);\n  const response = shallowRef(null);\n  const error = shallowRef(null);\n  const data = shallowRef(initialData);\n  const canAbort = computed(() => supportsAbort && isFetching.value);\n  let controller;\n  let timer;\n  const abort = () => {\n    if (supportsAbort && controller) {\n      controller.abort();\n      controller = void 0;\n    }\n  };\n  const loading = (isLoading) => {\n    isFetching.value = isLoading;\n    isFinished.value = !isLoading;\n  };\n  if (timeout)\n    timer = useTimeoutFn(abort, timeout, { immediate: false });\n  const execute = async (throwOnFailed = false) => {\n    var _a2;\n    loading(true);\n    error.value = null;\n    statusCode.value = null;\n    aborted.value = false;\n    if (supportsAbort) {\n      abort();\n      controller = new AbortController();\n      controller.signal.onabort = () => aborted.value = true;\n      fetchOptions = __spreadProps$3(__spreadValues$d({}, fetchOptions), {\n        signal: controller.signal\n      });\n    }\n    const defaultFetchOptions = {\n      method: config.method,\n      headers: {}\n    };\n    if (config.payload) {\n      const headers = headersToObject(defaultFetchOptions.headers);\n      if (config.payloadType)\n        headers[\"Content-Type\"] = (_a2 = payloadMapping[config.payloadType]) != null ? _a2 : config.payloadType;\n      const payload = resolveUnref(config.payload);\n      defaultFetchOptions.body = config.payloadType === \"json\" ? JSON.stringify(payload) : payload;\n    }\n    let isCanceled = false;\n    const context = {\n      url: resolveUnref(url),\n      options: __spreadValues$d(__spreadValues$d({}, defaultFetchOptions), fetchOptions),\n      cancel: () => {\n        isCanceled = true;\n      }\n    };\n    if (options.beforeFetch)\n      Object.assign(context, await options.beforeFetch(context));\n    if (isCanceled || !fetch) {\n      loading(false);\n      return Promise.resolve(null);\n    }\n    let responseData = null;\n    if (timer)\n      timer.start();\n    return new Promise((resolve, reject) => {\n      var _a3;\n      fetch(context.url, __spreadProps$3(__spreadValues$d(__spreadValues$d({}, defaultFetchOptions), context.options), {\n        headers: __spreadValues$d(__spreadValues$d({}, headersToObject(defaultFetchOptions.headers)), headersToObject((_a3 = context.options) == null ? void 0 : _a3.headers))\n      })).then(async (fetchResponse) => {\n        response.value = fetchResponse;\n        statusCode.value = fetchResponse.status;\n        responseData = await fetchResponse[config.type]();\n        if (options.afterFetch && statusCode.value >= 200 && statusCode.value < 300)\n          ({ data: responseData } = await options.afterFetch({ data: responseData, response: fetchResponse }));\n        data.value = responseData;\n        if (!fetchResponse.ok)\n          throw new Error(fetchResponse.statusText);\n        responseEvent.trigger(fetchResponse);\n        return resolve(fetchResponse);\n      }).catch(async (fetchError) => {\n        let errorData = fetchError.message || fetchError.name;\n        if (options.onFetchError)\n          ({ data: responseData, error: errorData } = await options.onFetchError({ data: responseData, error: fetchError, response: response.value }));\n        data.value = responseData;\n        error.value = errorData;\n        errorEvent.trigger(fetchError);\n        if (throwOnFailed)\n          return reject(fetchError);\n        return resolve(null);\n      }).finally(() => {\n        loading(false);\n        if (timer)\n          timer.stop();\n        finallyEvent.trigger(null);\n      });\n    });\n  };\n  const refetch = resolveRef(options.refetch);\n  watch([\n    refetch,\n    resolveRef(url)\n  ], ([refetch2]) => refetch2 && execute(), { deep: true });\n  const shell = {\n    isFinished,\n    statusCode,\n    response,\n    error,\n    data,\n    isFetching,\n    canAbort,\n    aborted,\n    abort,\n    execute,\n    onFetchResponse: responseEvent.on,\n    onFetchError: errorEvent.on,\n    onFetchFinally: finallyEvent.on,\n    get: setMethod(\"GET\"),\n    put: setMethod(\"PUT\"),\n    post: setMethod(\"POST\"),\n    delete: setMethod(\"DELETE\"),\n    patch: setMethod(\"PATCH\"),\n    head: setMethod(\"HEAD\"),\n    options: setMethod(\"OPTIONS\"),\n    json: setType(\"json\"),\n    text: setType(\"text\"),\n    blob: setType(\"blob\"),\n    arrayBuffer: setType(\"arrayBuffer\"),\n    formData: setType(\"formData\")\n  };\n  function setMethod(method) {\n    return (payload, payloadType) => {\n      if (!isFetching.value) {\n        config.method = method;\n        config.payload = payload;\n        config.payloadType = payloadType;\n        if (isRef(config.payload)) {\n          watch([\n            refetch,\n            resolveRef(config.payload)\n          ], ([refetch2]) => refetch2 && execute(), { deep: true });\n        }\n        const rawPayload = resolveUnref(config.payload);\n        if (!payloadType && rawPayload && Object.getPrototypeOf(rawPayload) === Object.prototype && !(rawPayload instanceof FormData))\n          config.payloadType = \"json\";\n        return __spreadProps$3(__spreadValues$d({}, shell), {\n          then(onFulfilled, onRejected) {\n            return waitUntilFinished().then(onFulfilled, onRejected);\n          }\n        });\n      }\n      return void 0;\n    };\n  }\n  function waitUntilFinished() {\n    return new Promise((resolve, reject) => {\n      until(isFinished).toBe(true).then(() => resolve(shell)).catch((error2) => reject(error2));\n    });\n  }\n  function setType(type) {\n    return () => {\n      if (!isFetching.value) {\n        config.type = type;\n        return __spreadProps$3(__spreadValues$d({}, shell), {\n          then(onFulfilled, onRejected) {\n            return waitUntilFinished().then(onFulfilled, onRejected);\n          }\n        });\n      }\n      return void 0;\n    };\n  }\n  if (options.immediate)\n    setTimeout(execute, 0);\n  return __spreadProps$3(__spreadValues$d({}, shell), {\n    then(onFulfilled, onRejected) {\n      return waitUntilFinished().then(onFulfilled, onRejected);\n    }\n  });\n}\nfunction joinPaths(start, end) {\n  if (!start.endsWith(\"/\") && !end.startsWith(\"/\"))\n    return `${start}/${end}`;\n  return `${start}${end}`;\n}\n\nvar __defProp$c = Object.defineProperty;\nvar __getOwnPropSymbols$d = Object.getOwnPropertySymbols;\nvar __hasOwnProp$d = Object.prototype.hasOwnProperty;\nvar __propIsEnum$d = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$c = (obj, key, value) => key in obj ? __defProp$c(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$c = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$d.call(b, prop))\n      __defNormalProp$c(a, prop, b[prop]);\n  if (__getOwnPropSymbols$d)\n    for (var prop of __getOwnPropSymbols$d(b)) {\n      if (__propIsEnum$d.call(b, prop))\n        __defNormalProp$c(a, prop, b[prop]);\n    }\n  return a;\n};\nconst DEFAULT_OPTIONS = {\n  multiple: true,\n  accept: \"*\"\n};\nfunction useFileDialog(options = {}) {\n  const {\n    document = defaultDocument\n  } = options;\n  const files = ref(null);\n  let input;\n  if (document) {\n    input = document.createElement(\"input\");\n    input.type = \"file\";\n    input.onchange = (event) => {\n      const result = event.target;\n      files.value = result.files;\n    };\n  }\n  const open = (localOptions) => {\n    if (!input)\n      return;\n    const _options = __spreadValues$c(__spreadValues$c(__spreadValues$c({}, DEFAULT_OPTIONS), options), localOptions);\n    input.multiple = _options.multiple;\n    input.accept = _options.accept;\n    if (hasOwn(_options, \"capture\"))\n      input.capture = _options.capture;\n    input.click();\n  };\n  const reset = () => {\n    files.value = null;\n    if (input)\n      input.value = \"\";\n  };\n  return {\n    files: readonly(files),\n    open,\n    reset\n  };\n}\n\nvar __defProp$b = Object.defineProperty;\nvar __getOwnPropSymbols$c = Object.getOwnPropertySymbols;\nvar __hasOwnProp$c = Object.prototype.hasOwnProperty;\nvar __propIsEnum$c = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$b = (obj, key, value) => key in obj ? __defProp$b(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$b = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$c.call(b, prop))\n      __defNormalProp$b(a, prop, b[prop]);\n  if (__getOwnPropSymbols$c)\n    for (var prop of __getOwnPropSymbols$c(b)) {\n      if (__propIsEnum$c.call(b, prop))\n        __defNormalProp$b(a, prop, b[prop]);\n    }\n  return a;\n};\nfunction useFileSystemAccess(options = {}) {\n  const {\n    window: _window = defaultWindow,\n    dataType = \"Text\"\n  } = unref(options);\n  const window = _window;\n  const isSupported = useSupported(() => window && \"showSaveFilePicker\" in window && \"showOpenFilePicker\" in window);\n  const fileHandle = ref();\n  const data = ref();\n  const file = ref();\n  const fileName = computed(() => {\n    var _a, _b;\n    return (_b = (_a = file.value) == null ? void 0 : _a.name) != null ? _b : \"\";\n  });\n  const fileMIME = computed(() => {\n    var _a, _b;\n    return (_b = (_a = file.value) == null ? void 0 : _a.type) != null ? _b : \"\";\n  });\n  const fileSize = computed(() => {\n    var _a, _b;\n    return (_b = (_a = file.value) == null ? void 0 : _a.size) != null ? _b : 0;\n  });\n  const fileLastModified = computed(() => {\n    var _a, _b;\n    return (_b = (_a = file.value) == null ? void 0 : _a.lastModified) != null ? _b : 0;\n  });\n  async function open(_options = {}) {\n    if (!isSupported.value)\n      return;\n    const [handle] = await window.showOpenFilePicker(__spreadValues$b(__spreadValues$b({}, unref(options)), _options));\n    fileHandle.value = handle;\n    await updateFile();\n    await updateData();\n  }\n  async function create(_options = {}) {\n    if (!isSupported.value)\n      return;\n    fileHandle.value = await window.showSaveFilePicker(__spreadValues$b(__spreadValues$b({}, unref(options)), _options));\n    data.value = void 0;\n    await updateFile();\n    await updateData();\n  }\n  async function save(_options = {}) {\n    if (!isSupported.value)\n      return;\n    if (!fileHandle.value)\n      return saveAs(_options);\n    if (data.value) {\n      const writableStream = await fileHandle.value.createWritable();\n      await writableStream.write(data.value);\n      await writableStream.close();\n    }\n    await updateFile();\n  }\n  async function saveAs(_options = {}) {\n    if (!isSupported.value)\n      return;\n    fileHandle.value = await window.showSaveFilePicker(__spreadValues$b(__spreadValues$b({}, unref(options)), _options));\n    if (data.value) {\n      const writableStream = await fileHandle.value.createWritable();\n      await writableStream.write(data.value);\n      await writableStream.close();\n    }\n    await updateFile();\n  }\n  async function updateFile() {\n    var _a;\n    file.value = await ((_a = fileHandle.value) == null ? void 0 : _a.getFile());\n  }\n  async function updateData() {\n    var _a, _b;\n    if (unref(dataType) === \"Text\")\n      data.value = await ((_a = file.value) == null ? void 0 : _a.text());\n    if (unref(dataType) === \"ArrayBuffer\")\n      data.value = await ((_b = file.value) == null ? void 0 : _b.arrayBuffer());\n    if (unref(dataType) === \"Blob\")\n      data.value = file.value;\n  }\n  watch(() => unref(dataType), updateData);\n  return {\n    isSupported,\n    data,\n    file,\n    fileName,\n    fileMIME,\n    fileSize,\n    fileLastModified,\n    open,\n    create,\n    save,\n    saveAs,\n    updateData\n  };\n}\n\nfunction useFocus(target, options = {}) {\n  const { initialValue = false } = options;\n  const innerFocused = ref(false);\n  const targetElement = computed(() => unrefElement(target));\n  useEventListener(targetElement, \"focus\", () => innerFocused.value = true);\n  useEventListener(targetElement, \"blur\", () => innerFocused.value = false);\n  const focused = computed({\n    get: () => innerFocused.value,\n    set(value) {\n      var _a, _b;\n      if (!value && innerFocused.value)\n        (_a = targetElement.value) == null ? void 0 : _a.blur();\n      else if (value && !innerFocused.value)\n        (_b = targetElement.value) == null ? void 0 : _b.focus();\n    }\n  });\n  watch(targetElement, () => {\n    focused.value = initialValue;\n  }, { immediate: true, flush: \"post\" });\n  return { focused };\n}\n\nfunction useFocusWithin(target, options = {}) {\n  const activeElement = useActiveElement(options);\n  const targetElement = computed(() => unrefElement(target));\n  const focused = computed(() => targetElement.value && activeElement.value ? targetElement.value.contains(activeElement.value) : false);\n  return { focused };\n}\n\nfunction useFps(options) {\n  var _a;\n  const fps = ref(0);\n  if (typeof performance === \"undefined\")\n    return fps;\n  const every = (_a = options == null ? void 0 : options.every) != null ? _a : 10;\n  let last = performance.now();\n  let ticks = 0;\n  useRafFn(() => {\n    ticks += 1;\n    if (ticks >= every) {\n      const now = performance.now();\n      const diff = now - last;\n      fps.value = Math.round(1e3 / (diff / ticks));\n      last = now;\n      ticks = 0;\n    }\n  });\n  return fps;\n}\n\nconst functionsMap = [\n  [\n    \"requestFullscreen\",\n    \"exitFullscreen\",\n    \"fullscreenElement\",\n    \"fullscreenEnabled\",\n    \"fullscreenchange\",\n    \"fullscreenerror\"\n  ],\n  [\n    \"webkitRequestFullscreen\",\n    \"webkitExitFullscreen\",\n    \"webkitFullscreenElement\",\n    \"webkitFullscreenEnabled\",\n    \"webkitfullscreenchange\",\n    \"webkitfullscreenerror\"\n  ],\n  [\n    \"webkitRequestFullScreen\",\n    \"webkitCancelFullScreen\",\n    \"webkitCurrentFullScreenElement\",\n    \"webkitCancelFullScreen\",\n    \"webkitfullscreenchange\",\n    \"webkitfullscreenerror\"\n  ],\n  [\n    \"mozRequestFullScreen\",\n    \"mozCancelFullScreen\",\n    \"mozFullScreenElement\",\n    \"mozFullScreenEnabled\",\n    \"mozfullscreenchange\",\n    \"mozfullscreenerror\"\n  ],\n  [\n    \"msRequestFullscreen\",\n    \"msExitFullscreen\",\n    \"msFullscreenElement\",\n    \"msFullscreenEnabled\",\n    \"MSFullscreenChange\",\n    \"MSFullscreenError\"\n  ]\n];\nfunction useFullscreen(target, options = {}) {\n  const { document = defaultDocument, autoExit = false } = options;\n  const targetRef = target || (document == null ? void 0 : document.querySelector(\"html\"));\n  const isFullscreen = ref(false);\n  let map = functionsMap[0];\n  const isSupported = useSupported(() => {\n    if (!document) {\n      return false;\n    } else {\n      for (const m of functionsMap) {\n        if (m[1] in document) {\n          map = m;\n          return true;\n        }\n      }\n    }\n    return false;\n  });\n  const [REQUEST, EXIT, ELEMENT, , EVENT] = map;\n  async function exit() {\n    if (!isSupported.value)\n      return;\n    if (document == null ? void 0 : document[ELEMENT])\n      await document[EXIT]();\n    isFullscreen.value = false;\n  }\n  async function enter() {\n    if (!isSupported.value)\n      return;\n    await exit();\n    const target2 = unrefElement(targetRef);\n    if (target2) {\n      await target2[REQUEST]();\n      isFullscreen.value = true;\n    }\n  }\n  async function toggle() {\n    if (isFullscreen.value)\n      await exit();\n    else\n      await enter();\n  }\n  if (document) {\n    useEventListener(document, EVENT, () => {\n      isFullscreen.value = !!(document == null ? void 0 : document[ELEMENT]);\n    }, false);\n  }\n  if (autoExit)\n    tryOnScopeDispose(exit);\n  return {\n    isSupported,\n    isFullscreen,\n    enter,\n    exit,\n    toggle\n  };\n}\n\nfunction mapGamepadToXbox360Controller(gamepad) {\n  return computed(() => {\n    if (gamepad.value) {\n      return {\n        buttons: {\n          a: gamepad.value.buttons[0],\n          b: gamepad.value.buttons[1],\n          x: gamepad.value.buttons[2],\n          y: gamepad.value.buttons[3]\n        },\n        bumper: {\n          left: gamepad.value.buttons[4],\n          right: gamepad.value.buttons[5]\n        },\n        triggers: {\n          left: gamepad.value.buttons[6],\n          right: gamepad.value.buttons[7]\n        },\n        stick: {\n          left: {\n            horizontal: gamepad.value.axes[0],\n            vertical: gamepad.value.axes[1],\n            button: gamepad.value.buttons[10]\n          },\n          right: {\n            horizontal: gamepad.value.axes[2],\n            vertical: gamepad.value.axes[3],\n            button: gamepad.value.buttons[11]\n          }\n        },\n        dpad: {\n          up: gamepad.value.buttons[12],\n          down: gamepad.value.buttons[13],\n          left: gamepad.value.buttons[14],\n          right: gamepad.value.buttons[15]\n        },\n        back: gamepad.value.buttons[8],\n        start: gamepad.value.buttons[9]\n      };\n    }\n    return null;\n  });\n}\nfunction useGamepad(options = {}) {\n  const {\n    navigator = defaultNavigator\n  } = options;\n  const isSupported = useSupported(() => navigator && \"getGamepads\" in navigator);\n  const gamepads = ref([]);\n  const onConnectedHook = createEventHook();\n  const onDisconnectedHook = createEventHook();\n  const stateFromGamepad = (gamepad) => {\n    const hapticActuators = [];\n    const vibrationActuator = \"vibrationActuator\" in gamepad ? gamepad.vibrationActuator : null;\n    if (vibrationActuator)\n      hapticActuators.push(vibrationActuator);\n    if (gamepad.hapticActuators)\n      hapticActuators.push(...gamepad.hapticActuators);\n    return {\n      id: gamepad.id,\n      hapticActuators,\n      index: gamepad.index,\n      mapping: gamepad.mapping,\n      connected: gamepad.connected,\n      timestamp: gamepad.timestamp,\n      axes: gamepad.axes.map((axes) => axes),\n      buttons: gamepad.buttons.map((button) => ({ pressed: button.pressed, touched: button.touched, value: button.value }))\n    };\n  };\n  const updateGamepadState = () => {\n    const _gamepads = (navigator == null ? void 0 : navigator.getGamepads()) || [];\n    for (let i = 0; i < _gamepads.length; ++i) {\n      const gamepad = _gamepads[i];\n      if (gamepad) {\n        const index = gamepads.value.findIndex(({ index: index2 }) => index2 === gamepad.index);\n        if (index > -1)\n          gamepads.value[index] = stateFromGamepad(gamepad);\n      }\n    }\n  };\n  const { isActive, pause, resume } = useRafFn(updateGamepadState);\n  const onGamepadConnected = (gamepad) => {\n    if (!gamepads.value.some(({ index }) => index === gamepad.index)) {\n      gamepads.value.push(stateFromGamepad(gamepad));\n      onConnectedHook.trigger(gamepad.index);\n    }\n    resume();\n  };\n  const onGamepadDisconnected = (gamepad) => {\n    gamepads.value = gamepads.value.filter((x) => x.index !== gamepad.index);\n    onDisconnectedHook.trigger(gamepad.index);\n  };\n  useEventListener(\"gamepadconnected\", (e) => onGamepadConnected(e.gamepad));\n  useEventListener(\"gamepaddisconnected\", (e) => onGamepadDisconnected(e.gamepad));\n  tryOnMounted(() => {\n    const _gamepads = (navigator == null ? void 0 : navigator.getGamepads()) || [];\n    if (_gamepads) {\n      for (let i = 0; i < _gamepads.length; ++i) {\n        const gamepad = _gamepads[i];\n        if (gamepad)\n          onGamepadConnected(gamepad);\n      }\n    }\n  });\n  pause();\n  return {\n    isSupported,\n    onConnected: onConnectedHook.on,\n    onDisconnected: onDisconnectedHook.on,\n    gamepads,\n    pause,\n    resume,\n    isActive\n  };\n}\n\nfunction useGeolocation(options = {}) {\n  const {\n    enableHighAccuracy = true,\n    maximumAge = 3e4,\n    timeout = 27e3,\n    navigator = defaultNavigator,\n    immediate = true\n  } = options;\n  const isSupported = useSupported(() => navigator && \"geolocation\" in navigator);\n  const locatedAt = ref(null);\n  const error = ref(null);\n  const coords = ref({\n    accuracy: 0,\n    latitude: Infinity,\n    longitude: Infinity,\n    altitude: null,\n    altitudeAccuracy: null,\n    heading: null,\n    speed: null\n  });\n  function updatePosition(position) {\n    locatedAt.value = position.timestamp;\n    coords.value = position.coords;\n    error.value = null;\n  }\n  let watcher;\n  function resume() {\n    if (isSupported.value) {\n      watcher = navigator.geolocation.watchPosition(updatePosition, (err) => error.value = err, {\n        enableHighAccuracy,\n        maximumAge,\n        timeout\n      });\n    }\n  }\n  if (immediate)\n    resume();\n  function pause() {\n    if (watcher && navigator)\n      navigator.geolocation.clearWatch(watcher);\n  }\n  tryOnScopeDispose(() => {\n    pause();\n  });\n  return {\n    isSupported,\n    coords,\n    locatedAt,\n    error,\n    resume,\n    pause\n  };\n}\n\nconst defaultEvents$1 = [\"mousemove\", \"mousedown\", \"resize\", \"keydown\", \"touchstart\", \"wheel\"];\nconst oneMinute = 6e4;\nfunction useIdle(timeout = oneMinute, options = {}) {\n  const {\n    initialState = false,\n    listenForVisibilityChange = true,\n    events = defaultEvents$1,\n    window = defaultWindow,\n    eventFilter = throttleFilter(50)\n  } = options;\n  const idle = ref(initialState);\n  const lastActive = ref(timestamp());\n  let timer;\n  const onEvent = createFilterWrapper(eventFilter, () => {\n    idle.value = false;\n    lastActive.value = timestamp();\n    clearTimeout(timer);\n    timer = setTimeout(() => idle.value = true, timeout);\n  });\n  if (window) {\n    const document = window.document;\n    for (const event of events)\n      useEventListener(window, event, onEvent, { passive: true });\n    if (listenForVisibilityChange) {\n      useEventListener(document, \"visibilitychange\", () => {\n        if (!document.hidden)\n          onEvent();\n      });\n    }\n  }\n  timer = setTimeout(() => idle.value = true, timeout);\n  return { idle, lastActive };\n}\n\nvar __defProp$a = Object.defineProperty;\nvar __getOwnPropSymbols$b = Object.getOwnPropertySymbols;\nvar __hasOwnProp$b = Object.prototype.hasOwnProperty;\nvar __propIsEnum$b = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$a = (obj, key, value) => key in obj ? __defProp$a(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$a = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$b.call(b, prop))\n      __defNormalProp$a(a, prop, b[prop]);\n  if (__getOwnPropSymbols$b)\n    for (var prop of __getOwnPropSymbols$b(b)) {\n      if (__propIsEnum$b.call(b, prop))\n        __defNormalProp$a(a, prop, b[prop]);\n    }\n  return a;\n};\nasync function loadImage(options) {\n  return new Promise((resolve, reject) => {\n    const img = new Image();\n    const { src, srcset, sizes } = options;\n    img.src = src;\n    if (srcset)\n      img.srcset = srcset;\n    if (sizes)\n      img.sizes = sizes;\n    img.onload = () => resolve(img);\n    img.onerror = reject;\n  });\n}\nconst useImage = (options, asyncStateOptions = {}) => {\n  const state = useAsyncState(() => loadImage(resolveUnref(options)), void 0, __spreadValues$a({\n    resetOnExecute: true\n  }, asyncStateOptions));\n  watch(() => resolveUnref(options), () => state.execute(asyncStateOptions.delay), { deep: true });\n  return state;\n};\n\nconst ARRIVED_STATE_THRESHOLD_PIXELS = 1;\nfunction useScroll(element, options = {}) {\n  const {\n    throttle = 0,\n    idle = 200,\n    onStop = noop,\n    onScroll = noop,\n    offset = {\n      left: 0,\n      right: 0,\n      top: 0,\n      bottom: 0\n    },\n    eventListenerOptions = {\n      capture: false,\n      passive: true\n    },\n    behavior = \"auto\"\n  } = options;\n  const internalX = ref(0);\n  const internalY = ref(0);\n  const x = computed({\n    get() {\n      return internalX.value;\n    },\n    set(x2) {\n      scrollTo(x2, void 0);\n    }\n  });\n  const y = computed({\n    get() {\n      return internalY.value;\n    },\n    set(y2) {\n      scrollTo(void 0, y2);\n    }\n  });\n  function scrollTo(_x, _y) {\n    var _a, _b, _c;\n    const _element = resolveUnref(element);\n    if (!_element)\n      return;\n    (_c = _element instanceof Document ? document.body : _element) == null ? void 0 : _c.scrollTo({\n      top: (_a = resolveUnref(_y)) != null ? _a : y.value,\n      left: (_b = resolveUnref(_x)) != null ? _b : x.value,\n      behavior: resolveUnref(behavior)\n    });\n  }\n  const isScrolling = ref(false);\n  const arrivedState = reactive({\n    left: true,\n    right: false,\n    top: true,\n    bottom: false\n  });\n  const directions = reactive({\n    left: false,\n    right: false,\n    top: false,\n    bottom: false\n  });\n  const onScrollEnd = (e) => {\n    if (!isScrolling.value)\n      return;\n    isScrolling.value = false;\n    directions.left = false;\n    directions.right = false;\n    directions.top = false;\n    directions.bottom = false;\n    onStop(e);\n  };\n  const onScrollEndDebounced = useDebounceFn(onScrollEnd, throttle + idle);\n  const onScrollHandler = (e) => {\n    const eventTarget = e.target === document ? e.target.documentElement : e.target;\n    const scrollLeft = eventTarget.scrollLeft;\n    directions.left = scrollLeft < internalX.value;\n    directions.right = scrollLeft > internalY.value;\n    arrivedState.left = scrollLeft <= 0 + (offset.left || 0);\n    arrivedState.right = scrollLeft + eventTarget.clientWidth >= eventTarget.scrollWidth - (offset.right || 0) - ARRIVED_STATE_THRESHOLD_PIXELS;\n    internalX.value = scrollLeft;\n    let scrollTop = eventTarget.scrollTop;\n    if (e.target === document && !scrollTop)\n      scrollTop = document.body.scrollTop;\n    directions.top = scrollTop < internalY.value;\n    directions.bottom = scrollTop > internalY.value;\n    arrivedState.top = scrollTop <= 0 + (offset.top || 0);\n    arrivedState.bottom = scrollTop + eventTarget.clientHeight >= eventTarget.scrollHeight - (offset.bottom || 0) - ARRIVED_STATE_THRESHOLD_PIXELS;\n    internalY.value = scrollTop;\n    isScrolling.value = true;\n    onScrollEndDebounced(e);\n    onScroll(e);\n  };\n  useEventListener(element, \"scroll\", throttle ? useThrottleFn(onScrollHandler, throttle, true, false) : onScrollHandler, eventListenerOptions);\n  useEventListener(element, \"scrollend\", onScrollEnd, eventListenerOptions);\n  return {\n    x,\n    y,\n    isScrolling,\n    arrivedState,\n    directions\n  };\n}\n\nvar __defProp$9 = Object.defineProperty;\nvar __defProps$2 = Object.defineProperties;\nvar __getOwnPropDescs$2 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$a = Object.getOwnPropertySymbols;\nvar __hasOwnProp$a = Object.prototype.hasOwnProperty;\nvar __propIsEnum$a = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$9 = (obj, key, value) => key in obj ? __defProp$9(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$9 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$a.call(b, prop))\n      __defNormalProp$9(a, prop, b[prop]);\n  if (__getOwnPropSymbols$a)\n    for (var prop of __getOwnPropSymbols$a(b)) {\n      if (__propIsEnum$a.call(b, prop))\n        __defNormalProp$9(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$2 = (a, b) => __defProps$2(a, __getOwnPropDescs$2(b));\nfunction useInfiniteScroll(element, onLoadMore, options = {}) {\n  var _a, _b;\n  const direction = (_a = options.direction) != null ? _a : \"bottom\";\n  const state = reactive(useScroll(element, __spreadProps$2(__spreadValues$9({}, options), {\n    offset: __spreadValues$9({\n      [direction]: (_b = options.distance) != null ? _b : 0\n    }, options.offset)\n  })));\n  watch(() => state.arrivedState[direction], async (v) => {\n    var _a2, _b2;\n    if (v) {\n      const elem = resolveUnref(element);\n      const previous = {\n        height: (_a2 = elem == null ? void 0 : elem.scrollHeight) != null ? _a2 : 0,\n        width: (_b2 = elem == null ? void 0 : elem.scrollWidth) != null ? _b2 : 0\n      };\n      await onLoadMore(state);\n      if (options.preserveScrollPosition && elem) {\n        nextTick(() => {\n          elem.scrollTo({\n            top: elem.scrollHeight - previous.height,\n            left: elem.scrollWidth - previous.width\n          });\n        });\n      }\n    }\n  });\n}\n\nfunction useIntersectionObserver(target, callback, options = {}) {\n  const {\n    root,\n    rootMargin = \"0px\",\n    threshold = 0.1,\n    window = defaultWindow\n  } = options;\n  const isSupported = useSupported(() => window && \"IntersectionObserver\" in window);\n  let cleanup = noop;\n  const stopWatch = isSupported.value ? watch(() => ({\n    el: unrefElement(target),\n    root: unrefElement(root)\n  }), ({ el, root: root2 }) => {\n    cleanup();\n    if (!el)\n      return;\n    const observer = new IntersectionObserver(callback, {\n      root: root2,\n      rootMargin,\n      threshold\n    });\n    observer.observe(el);\n    cleanup = () => {\n      observer.disconnect();\n      cleanup = noop;\n    };\n  }, { immediate: true, flush: \"post\" }) : noop;\n  const stop = () => {\n    cleanup();\n    stopWatch();\n  };\n  tryOnScopeDispose(stop);\n  return {\n    isSupported,\n    stop\n  };\n}\n\nconst defaultEvents = [\"mousedown\", \"mouseup\", \"keydown\", \"keyup\"];\nfunction useKeyModifier(modifier, options = {}) {\n  const {\n    events = defaultEvents,\n    document = defaultDocument,\n    initial = null\n  } = options;\n  const state = ref(initial);\n  if (document) {\n    events.forEach((listenerEvent) => {\n      useEventListener(document, listenerEvent, (evt) => {\n        if (typeof evt.getModifierState === \"function\")\n          state.value = evt.getModifierState(modifier);\n      });\n    });\n  }\n  return state;\n}\n\nfunction useLocalStorage(key, initialValue, options = {}) {\n  const { window = defaultWindow } = options;\n  return useStorage(key, initialValue, window == null ? void 0 : window.localStorage, options);\n}\n\nconst DefaultMagicKeysAliasMap = {\n  ctrl: \"control\",\n  command: \"meta\",\n  cmd: \"meta\",\n  option: \"alt\",\n  up: \"arrowup\",\n  down: \"arrowdown\",\n  left: \"arrowleft\",\n  right: \"arrowright\"\n};\n\nfunction useMagicKeys(options = {}) {\n  const {\n    reactive: useReactive = false,\n    target = defaultWindow,\n    aliasMap = DefaultMagicKeysAliasMap,\n    passive = true,\n    onEventFired = noop\n  } = options;\n  const current = reactive(new Set());\n  const obj = {\n    toJSON() {\n      return {};\n    },\n    current\n  };\n  const refs = useReactive ? reactive(obj) : obj;\n  const metaDeps = new Set();\n  const usedKeys = new Set();\n  function setRefs(key, value) {\n    if (key in refs) {\n      if (useReactive)\n        refs[key] = value;\n      else\n        refs[key].value = value;\n    }\n  }\n  function reset() {\n    current.clear();\n    for (const key of usedKeys)\n      setRefs(key, false);\n  }\n  function updateRefs(e, value) {\n    var _a, _b;\n    const key = (_a = e.key) == null ? void 0 : _a.toLowerCase();\n    const code = (_b = e.code) == null ? void 0 : _b.toLowerCase();\n    const values = [code, key].filter(Boolean);\n    if (key) {\n      if (value)\n        current.add(key);\n      else\n        current.delete(key);\n    }\n    for (const key2 of values) {\n      usedKeys.add(key2);\n      setRefs(key2, value);\n    }\n    if (key === \"meta\" && !value) {\n      metaDeps.forEach((key2) => {\n        current.delete(key2);\n        setRefs(key2, false);\n      });\n      metaDeps.clear();\n    } else if (typeof e.getModifierState === \"function\" && e.getModifierState(\"Meta\") && value) {\n      [...current, ...values].forEach((key2) => metaDeps.add(key2));\n    }\n  }\n  useEventListener(target, \"keydown\", (e) => {\n    updateRefs(e, true);\n    return onEventFired(e);\n  }, { passive });\n  useEventListener(target, \"keyup\", (e) => {\n    updateRefs(e, false);\n    return onEventFired(e);\n  }, { passive });\n  useEventListener(\"blur\", reset, { passive: true });\n  useEventListener(\"focus\", reset, { passive: true });\n  const proxy = new Proxy(refs, {\n    get(target2, prop, rec) {\n      if (typeof prop !== \"string\")\n        return Reflect.get(target2, prop, rec);\n      prop = prop.toLowerCase();\n      if (prop in aliasMap)\n        prop = aliasMap[prop];\n      if (!(prop in refs)) {\n        if (/[+_-]/.test(prop)) {\n          const keys = prop.split(/[+_-]/g).map((i) => i.trim());\n          refs[prop] = computed(() => keys.every((key) => unref(proxy[key])));\n        } else {\n          refs[prop] = ref(false);\n        }\n      }\n      const r = Reflect.get(target2, prop, rec);\n      return useReactive ? unref(r) : r;\n    }\n  });\n  return proxy;\n}\n\nvar __defProp$8 = Object.defineProperty;\nvar __getOwnPropSymbols$9 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$9 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$9 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$8 = (obj, key, value) => key in obj ? __defProp$8(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$8 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$9.call(b, prop))\n      __defNormalProp$8(a, prop, b[prop]);\n  if (__getOwnPropSymbols$9)\n    for (var prop of __getOwnPropSymbols$9(b)) {\n      if (__propIsEnum$9.call(b, prop))\n        __defNormalProp$8(a, prop, b[prop]);\n    }\n  return a;\n};\nfunction usingElRef(source, cb) {\n  if (resolveUnref(source))\n    cb(resolveUnref(source));\n}\nfunction timeRangeToArray(timeRanges) {\n  let ranges = [];\n  for (let i = 0; i < timeRanges.length; ++i)\n    ranges = [...ranges, [timeRanges.start(i), timeRanges.end(i)]];\n  return ranges;\n}\nfunction tracksToArray(tracks) {\n  return Array.from(tracks).map(({ label, kind, language, mode, activeCues, cues, inBandMetadataTrackDispatchType }, id) => ({ id, label, kind, language, mode, activeCues, cues, inBandMetadataTrackDispatchType }));\n}\nconst defaultOptions = {\n  src: \"\",\n  tracks: []\n};\nfunction useMediaControls(target, options = {}) {\n  options = __spreadValues$8(__spreadValues$8({}, defaultOptions), options);\n  const {\n    document = defaultDocument\n  } = options;\n  const currentTime = ref(0);\n  const duration = ref(0);\n  const seeking = ref(false);\n  const volume = ref(1);\n  const waiting = ref(false);\n  const ended = ref(false);\n  const playing = ref(false);\n  const rate = ref(1);\n  const stalled = ref(false);\n  const buffered = ref([]);\n  const tracks = ref([]);\n  const selectedTrack = ref(-1);\n  const isPictureInPicture = ref(false);\n  const muted = ref(false);\n  const supportsPictureInPicture = document && \"pictureInPictureEnabled\" in document;\n  const sourceErrorEvent = createEventHook();\n  const disableTrack = (track) => {\n    usingElRef(target, (el) => {\n      if (track) {\n        const id = isNumber(track) ? track : track.id;\n        el.textTracks[id].mode = \"disabled\";\n      } else {\n        for (let i = 0; i < el.textTracks.length; ++i)\n          el.textTracks[i].mode = \"disabled\";\n      }\n      selectedTrack.value = -1;\n    });\n  };\n  const enableTrack = (track, disableTracks = true) => {\n    usingElRef(target, (el) => {\n      const id = isNumber(track) ? track : track.id;\n      if (disableTracks)\n        disableTrack();\n      el.textTracks[id].mode = \"showing\";\n      selectedTrack.value = id;\n    });\n  };\n  const togglePictureInPicture = () => {\n    return new Promise((resolve, reject) => {\n      usingElRef(target, async (el) => {\n        if (supportsPictureInPicture) {\n          if (!isPictureInPicture.value) {\n            el.requestPictureInPicture().then(resolve).catch(reject);\n          } else {\n            document.exitPictureInPicture().then(resolve).catch(reject);\n          }\n        }\n      });\n    });\n  };\n  watchEffect(() => {\n    if (!document)\n      return;\n    const el = resolveUnref(target);\n    if (!el)\n      return;\n    const src = resolveUnref(options.src);\n    let sources = [];\n    if (!src)\n      return;\n    if (isString(src))\n      sources = [{ src }];\n    else if (Array.isArray(src))\n      sources = src;\n    else if (isObject(src))\n      sources = [src];\n    el.querySelectorAll(\"source\").forEach((e) => {\n      e.removeEventListener(\"error\", sourceErrorEvent.trigger);\n      e.remove();\n    });\n    sources.forEach(({ src: src2, type }) => {\n      const source = document.createElement(\"source\");\n      source.setAttribute(\"src\", src2);\n      source.setAttribute(\"type\", type || \"\");\n      source.addEventListener(\"error\", sourceErrorEvent.trigger);\n      el.appendChild(source);\n    });\n    el.load();\n  });\n  tryOnScopeDispose(() => {\n    const el = resolveUnref(target);\n    if (!el)\n      return;\n    el.querySelectorAll(\"source\").forEach((e) => e.removeEventListener(\"error\", sourceErrorEvent.trigger));\n  });\n  watch(volume, (vol) => {\n    const el = resolveUnref(target);\n    if (!el)\n      return;\n    el.volume = vol;\n  });\n  watch(muted, (mute) => {\n    const el = resolveUnref(target);\n    if (!el)\n      return;\n    el.muted = mute;\n  });\n  watch(rate, (rate2) => {\n    const el = resolveUnref(target);\n    if (!el)\n      return;\n    el.playbackRate = rate2;\n  });\n  watchEffect(() => {\n    if (!document)\n      return;\n    const textTracks = resolveUnref(options.tracks);\n    const el = resolveUnref(target);\n    if (!textTracks || !textTracks.length || !el)\n      return;\n    el.querySelectorAll(\"track\").forEach((e) => e.remove());\n    textTracks.forEach(({ default: isDefault, kind, label, src, srcLang }, i) => {\n      const track = document.createElement(\"track\");\n      track.default = isDefault || false;\n      track.kind = kind;\n      track.label = label;\n      track.src = src;\n      track.srclang = srcLang;\n      if (track.default)\n        selectedTrack.value = i;\n      el.appendChild(track);\n    });\n  });\n  const { ignoreUpdates: ignoreCurrentTimeUpdates } = watchIgnorable(currentTime, (time) => {\n    const el = resolveUnref(target);\n    if (!el)\n      return;\n    el.currentTime = time;\n  });\n  const { ignoreUpdates: ignorePlayingUpdates } = watchIgnorable(playing, (isPlaying) => {\n    const el = resolveUnref(target);\n    if (!el)\n      return;\n    isPlaying ? el.play() : el.pause();\n  });\n  useEventListener(target, \"timeupdate\", () => ignoreCurrentTimeUpdates(() => currentTime.value = resolveUnref(target).currentTime));\n  useEventListener(target, \"durationchange\", () => duration.value = resolveUnref(target).duration);\n  useEventListener(target, \"progress\", () => buffered.value = timeRangeToArray(resolveUnref(target).buffered));\n  useEventListener(target, \"seeking\", () => seeking.value = true);\n  useEventListener(target, \"seeked\", () => seeking.value = false);\n  useEventListener(target, \"waiting\", () => waiting.value = true);\n  useEventListener(target, \"playing\", () => {\n    waiting.value = false;\n    ended.value = false;\n  });\n  useEventListener(target, \"ratechange\", () => rate.value = resolveUnref(target).playbackRate);\n  useEventListener(target, \"stalled\", () => stalled.value = true);\n  useEventListener(target, \"ended\", () => ended.value = true);\n  useEventListener(target, \"pause\", () => ignorePlayingUpdates(() => playing.value = false));\n  useEventListener(target, \"play\", () => ignorePlayingUpdates(() => playing.value = true));\n  useEventListener(target, \"enterpictureinpicture\", () => isPictureInPicture.value = true);\n  useEventListener(target, \"leavepictureinpicture\", () => isPictureInPicture.value = false);\n  useEventListener(target, \"volumechange\", () => {\n    const el = resolveUnref(target);\n    if (!el)\n      return;\n    volume.value = el.volume;\n    muted.value = el.muted;\n  });\n  const listeners = [];\n  const stop = watch([target], () => {\n    const el = resolveUnref(target);\n    if (!el)\n      return;\n    stop();\n    listeners[0] = useEventListener(el.textTracks, \"addtrack\", () => tracks.value = tracksToArray(el.textTracks));\n    listeners[1] = useEventListener(el.textTracks, \"removetrack\", () => tracks.value = tracksToArray(el.textTracks));\n    listeners[2] = useEventListener(el.textTracks, \"change\", () => tracks.value = tracksToArray(el.textTracks));\n  });\n  tryOnScopeDispose(() => listeners.forEach((listener) => listener()));\n  return {\n    currentTime,\n    duration,\n    waiting,\n    seeking,\n    ended,\n    stalled,\n    buffered,\n    playing,\n    rate,\n    volume,\n    muted,\n    tracks,\n    selectedTrack,\n    enableTrack,\n    disableTrack,\n    supportsPictureInPicture,\n    togglePictureInPicture,\n    isPictureInPicture,\n    onSourceError: sourceErrorEvent.on\n  };\n}\n\nconst getMapVue2Compat = () => {\n  const data = reactive({});\n  return {\n    get: (key) => data[key],\n    set: (key, value) => set(data, key, value),\n    has: (key) => hasOwn(data, key),\n    delete: (key) => del(data, key),\n    clear: () => {\n      Object.keys(data).forEach((key) => {\n        del(data, key);\n      });\n    }\n  };\n};\nfunction useMemoize(resolver, options) {\n  const initCache = () => {\n    if (options == null ? void 0 : options.cache)\n      return reactive(options.cache);\n    if (isVue2)\n      return getMapVue2Compat();\n    return reactive(new Map());\n  };\n  const cache = initCache();\n  const generateKey = (...args) => (options == null ? void 0 : options.getKey) ? options.getKey(...args) : JSON.stringify(args);\n  const _loadData = (key, ...args) => {\n    cache.set(key, resolver(...args));\n    return cache.get(key);\n  };\n  const loadData = (...args) => _loadData(generateKey(...args), ...args);\n  const deleteData = (...args) => {\n    cache.delete(generateKey(...args));\n  };\n  const clearData = () => {\n    cache.clear();\n  };\n  const memoized = (...args) => {\n    const key = generateKey(...args);\n    if (cache.has(key))\n      return cache.get(key);\n    return _loadData(key, ...args);\n  };\n  memoized.load = loadData;\n  memoized.delete = deleteData;\n  memoized.clear = clearData;\n  memoized.generateKey = generateKey;\n  memoized.cache = cache;\n  return memoized;\n}\n\nfunction useMemory(options = {}) {\n  const memory = ref();\n  const isSupported = useSupported(() => typeof performance !== \"undefined\" && \"memory\" in performance);\n  if (isSupported.value) {\n    const { interval = 1e3 } = options;\n    useIntervalFn(() => {\n      memory.value = performance.memory;\n    }, interval, { immediate: options.immediate, immediateCallback: options.immediateCallback });\n  }\n  return { isSupported, memory };\n}\n\nfunction useMounted() {\n  const isMounted = ref(false);\n  onMounted(() => {\n    isMounted.value = true;\n  });\n  return isMounted;\n}\n\nfunction useMouse(options = {}) {\n  const {\n    type = \"page\",\n    touch = true,\n    resetOnTouchEnds = false,\n    initialValue = { x: 0, y: 0 },\n    window = defaultWindow,\n    eventFilter\n  } = options;\n  const x = ref(initialValue.x);\n  const y = ref(initialValue.y);\n  const sourceType = ref(null);\n  const mouseHandler = (event) => {\n    if (type === \"page\") {\n      x.value = event.pageX;\n      y.value = event.pageY;\n    } else if (type === \"client\") {\n      x.value = event.clientX;\n      y.value = event.clientY;\n    } else if (type === \"movement\") {\n      x.value = event.movementX;\n      y.value = event.movementY;\n    }\n    sourceType.value = \"mouse\";\n  };\n  const reset = () => {\n    x.value = initialValue.x;\n    y.value = initialValue.y;\n  };\n  const touchHandler = (event) => {\n    if (event.touches.length > 0) {\n      const touch2 = event.touches[0];\n      if (type === \"page\") {\n        x.value = touch2.pageX;\n        y.value = touch2.pageY;\n      } else if (type === \"client\") {\n        x.value = touch2.clientX;\n        y.value = touch2.clientY;\n      }\n      sourceType.value = \"touch\";\n    }\n  };\n  const mouseHandlerWrapper = (event) => {\n    return eventFilter === void 0 ? mouseHandler(event) : eventFilter(() => mouseHandler(event), {});\n  };\n  const touchHandlerWrapper = (event) => {\n    return eventFilter === void 0 ? touchHandler(event) : eventFilter(() => touchHandler(event), {});\n  };\n  if (window) {\n    useEventListener(window, \"mousemove\", mouseHandlerWrapper, { passive: true });\n    useEventListener(window, \"dragover\", mouseHandlerWrapper, { passive: true });\n    if (touch && type !== \"movement\") {\n      useEventListener(window, \"touchstart\", touchHandlerWrapper, { passive: true });\n      useEventListener(window, \"touchmove\", touchHandlerWrapper, { passive: true });\n      if (resetOnTouchEnds)\n        useEventListener(window, \"touchend\", reset, { passive: true });\n    }\n  }\n  return {\n    x,\n    y,\n    sourceType\n  };\n}\n\nfunction useMouseInElement(target, options = {}) {\n  const {\n    handleOutside = true,\n    window = defaultWindow\n  } = options;\n  const { x, y, sourceType } = useMouse(options);\n  const targetRef = ref(target != null ? target : window == null ? void 0 : window.document.body);\n  const elementX = ref(0);\n  const elementY = ref(0);\n  const elementPositionX = ref(0);\n  const elementPositionY = ref(0);\n  const elementHeight = ref(0);\n  const elementWidth = ref(0);\n  const isOutside = ref(true);\n  let stop = () => {\n  };\n  if (window) {\n    stop = watch([targetRef, x, y], () => {\n      const el = unrefElement(targetRef);\n      if (!el)\n        return;\n      const {\n        left,\n        top,\n        width,\n        height\n      } = el.getBoundingClientRect();\n      elementPositionX.value = left + window.pageXOffset;\n      elementPositionY.value = top + window.pageYOffset;\n      elementHeight.value = height;\n      elementWidth.value = width;\n      const elX = x.value - elementPositionX.value;\n      const elY = y.value - elementPositionY.value;\n      isOutside.value = width === 0 || height === 0 || elX < 0 || elY < 0 || elX > width || elY > height;\n      if (handleOutside || !isOutside.value) {\n        elementX.value = elX;\n        elementY.value = elY;\n      }\n    }, { immediate: true });\n    useEventListener(document, \"mouseleave\", () => {\n      isOutside.value = true;\n    });\n  }\n  return {\n    x,\n    y,\n    sourceType,\n    elementX,\n    elementY,\n    elementPositionX,\n    elementPositionY,\n    elementHeight,\n    elementWidth,\n    isOutside,\n    stop\n  };\n}\n\nfunction useMousePressed(options = {}) {\n  const {\n    touch = true,\n    drag = true,\n    initialValue = false,\n    window = defaultWindow\n  } = options;\n  const pressed = ref(initialValue);\n  const sourceType = ref(null);\n  if (!window) {\n    return {\n      pressed,\n      sourceType\n    };\n  }\n  const onPressed = (srcType) => () => {\n    pressed.value = true;\n    sourceType.value = srcType;\n  };\n  const onReleased = () => {\n    pressed.value = false;\n    sourceType.value = null;\n  };\n  const target = computed(() => unrefElement(options.target) || window);\n  useEventListener(target, \"mousedown\", onPressed(\"mouse\"), { passive: true });\n  useEventListener(window, \"mouseleave\", onReleased, { passive: true });\n  useEventListener(window, \"mouseup\", onReleased, { passive: true });\n  if (drag) {\n    useEventListener(target, \"dragstart\", onPressed(\"mouse\"), { passive: true });\n    useEventListener(window, \"drop\", onReleased, { passive: true });\n    useEventListener(window, \"dragend\", onReleased, { passive: true });\n  }\n  if (touch) {\n    useEventListener(target, \"touchstart\", onPressed(\"touch\"), { passive: true });\n    useEventListener(window, \"touchend\", onReleased, { passive: true });\n    useEventListener(window, \"touchcancel\", onReleased, { passive: true });\n  }\n  return {\n    pressed,\n    sourceType\n  };\n}\n\nvar __getOwnPropSymbols$8 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$8 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$8 = Object.prototype.propertyIsEnumerable;\nvar __objRest$1 = (source, exclude) => {\n  var target = {};\n  for (var prop in source)\n    if (__hasOwnProp$8.call(source, prop) && exclude.indexOf(prop) < 0)\n      target[prop] = source[prop];\n  if (source != null && __getOwnPropSymbols$8)\n    for (var prop of __getOwnPropSymbols$8(source)) {\n      if (exclude.indexOf(prop) < 0 && __propIsEnum$8.call(source, prop))\n        target[prop] = source[prop];\n    }\n  return target;\n};\nfunction useMutationObserver(target, callback, options = {}) {\n  const _a = options, { window = defaultWindow } = _a, mutationOptions = __objRest$1(_a, [\"window\"]);\n  let observer;\n  const isSupported = useSupported(() => window && \"MutationObserver\" in window);\n  const cleanup = () => {\n    if (observer) {\n      observer.disconnect();\n      observer = void 0;\n    }\n  };\n  const stopWatch = watch(() => unrefElement(target), (el) => {\n    cleanup();\n    if (isSupported.value && window && el) {\n      observer = new MutationObserver(callback);\n      observer.observe(el, mutationOptions);\n    }\n  }, { immediate: true });\n  const stop = () => {\n    cleanup();\n    stopWatch();\n  };\n  tryOnScopeDispose(stop);\n  return {\n    isSupported,\n    stop\n  };\n}\n\nconst useNavigatorLanguage = (options = {}) => {\n  const { window = defaultWindow } = options;\n  const navigator = window == null ? void 0 : window.navigator;\n  const isSupported = useSupported(() => navigator && \"language\" in navigator);\n  const language = ref(navigator == null ? void 0 : navigator.language);\n  useEventListener(window, \"languagechange\", () => {\n    if (navigator)\n      language.value = navigator.language;\n  });\n  return {\n    isSupported,\n    language\n  };\n};\n\nfunction useNetwork(options = {}) {\n  const { window = defaultWindow } = options;\n  const navigator = window == null ? void 0 : window.navigator;\n  const isSupported = useSupported(() => navigator && \"connection\" in navigator);\n  const isOnline = ref(true);\n  const saveData = ref(false);\n  const offlineAt = ref(void 0);\n  const onlineAt = ref(void 0);\n  const downlink = ref(void 0);\n  const downlinkMax = ref(void 0);\n  const rtt = ref(void 0);\n  const effectiveType = ref(void 0);\n  const type = ref(\"unknown\");\n  const connection = isSupported.value && navigator.connection;\n  function updateNetworkInformation() {\n    if (!navigator)\n      return;\n    isOnline.value = navigator.onLine;\n    offlineAt.value = isOnline.value ? void 0 : Date.now();\n    onlineAt.value = isOnline.value ? Date.now() : void 0;\n    if (connection) {\n      downlink.value = connection.downlink;\n      downlinkMax.value = connection.downlinkMax;\n      effectiveType.value = connection.effectiveType;\n      rtt.value = connection.rtt;\n      saveData.value = connection.saveData;\n      type.value = connection.type;\n    }\n  }\n  if (window) {\n    useEventListener(window, \"offline\", () => {\n      isOnline.value = false;\n      offlineAt.value = Date.now();\n    });\n    useEventListener(window, \"online\", () => {\n      isOnline.value = true;\n      onlineAt.value = Date.now();\n    });\n  }\n  if (connection)\n    useEventListener(connection, \"change\", updateNetworkInformation, false);\n  updateNetworkInformation();\n  return {\n    isSupported,\n    isOnline,\n    saveData,\n    offlineAt,\n    onlineAt,\n    downlink,\n    downlinkMax,\n    effectiveType,\n    rtt,\n    type\n  };\n}\n\nvar __defProp$7 = Object.defineProperty;\nvar __getOwnPropSymbols$7 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$7 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$7 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$7 = (obj, key, value) => key in obj ? __defProp$7(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$7 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$7.call(b, prop))\n      __defNormalProp$7(a, prop, b[prop]);\n  if (__getOwnPropSymbols$7)\n    for (var prop of __getOwnPropSymbols$7(b)) {\n      if (__propIsEnum$7.call(b, prop))\n        __defNormalProp$7(a, prop, b[prop]);\n    }\n  return a;\n};\nfunction useNow(options = {}) {\n  const {\n    controls: exposeControls = false,\n    interval = \"requestAnimationFrame\"\n  } = options;\n  const now = ref(new Date());\n  const update = () => now.value = new Date();\n  const controls = interval === \"requestAnimationFrame\" ? useRafFn(update, { immediate: true }) : useIntervalFn(update, interval, { immediate: true });\n  if (exposeControls) {\n    return __spreadValues$7({\n      now\n    }, controls);\n  } else {\n    return now;\n  }\n}\n\nfunction useObjectUrl(object) {\n  const url = ref();\n  const release = () => {\n    if (url.value)\n      URL.revokeObjectURL(url.value);\n    url.value = void 0;\n  };\n  watch(() => unref(object), (newObject) => {\n    release();\n    if (newObject)\n      url.value = URL.createObjectURL(newObject);\n  }, { immediate: true });\n  tryOnScopeDispose(release);\n  return readonly(url);\n}\n\nfunction useClamp(value, min, max) {\n  if (isFunction(value) || isReadonly(value))\n    return computed(() => clamp(resolveUnref(value), resolveUnref(min), resolveUnref(max)));\n  const _value = ref(value);\n  return computed({\n    get() {\n      return _value.value = clamp(_value.value, resolveUnref(min), resolveUnref(max));\n    },\n    set(value2) {\n      _value.value = clamp(value2, resolveUnref(min), resolveUnref(max));\n    }\n  });\n}\n\nfunction useOffsetPagination(options) {\n  const {\n    total = Infinity,\n    pageSize = 10,\n    page = 1,\n    onPageChange = noop,\n    onPageSizeChange = noop,\n    onPageCountChange = noop\n  } = options;\n  const currentPageSize = useClamp(pageSize, 1, Infinity);\n  const pageCount = computed(() => Math.max(1, Math.ceil(unref(total) / unref(currentPageSize))));\n  const currentPage = useClamp(page, 1, pageCount);\n  const isFirstPage = computed(() => currentPage.value === 1);\n  const isLastPage = computed(() => currentPage.value === pageCount.value);\n  if (isRef(page))\n    syncRef(page, currentPage);\n  if (isRef(pageSize))\n    syncRef(pageSize, currentPageSize);\n  function prev() {\n    currentPage.value--;\n  }\n  function next() {\n    currentPage.value++;\n  }\n  const returnValue = {\n    currentPage,\n    currentPageSize,\n    pageCount,\n    isFirstPage,\n    isLastPage,\n    prev,\n    next\n  };\n  watch(currentPage, () => {\n    onPageChange(reactive(returnValue));\n  });\n  watch(currentPageSize, () => {\n    onPageSizeChange(reactive(returnValue));\n  });\n  watch(pageCount, () => {\n    onPageCountChange(reactive(returnValue));\n  });\n  return returnValue;\n}\n\nfunction useOnline(options = {}) {\n  const { isOnline } = useNetwork(options);\n  return isOnline;\n}\n\nfunction usePageLeave(options = {}) {\n  const { window = defaultWindow } = options;\n  const isLeft = ref(false);\n  const handler = (event) => {\n    if (!window)\n      return;\n    event = event || window.event;\n    const from = event.relatedTarget || event.toElement;\n    isLeft.value = !from;\n  };\n  if (window) {\n    useEventListener(window, \"mouseout\", handler, { passive: true });\n    useEventListener(window.document, \"mouseleave\", handler, { passive: true });\n    useEventListener(window.document, \"mouseenter\", handler, { passive: true });\n  }\n  return isLeft;\n}\n\nfunction useParallax(target, options = {}) {\n  const {\n    deviceOrientationTiltAdjust = (i) => i,\n    deviceOrientationRollAdjust = (i) => i,\n    mouseTiltAdjust = (i) => i,\n    mouseRollAdjust = (i) => i,\n    window = defaultWindow\n  } = options;\n  const orientation = reactive(useDeviceOrientation({ window }));\n  const {\n    elementX: x,\n    elementY: y,\n    elementWidth: width,\n    elementHeight: height\n  } = useMouseInElement(target, { handleOutside: false, window });\n  const source = computed(() => {\n    if (orientation.isSupported && (orientation.alpha != null && orientation.alpha !== 0 || orientation.gamma != null && orientation.gamma !== 0))\n      return \"deviceOrientation\";\n    return \"mouse\";\n  });\n  const roll = computed(() => {\n    if (source.value === \"deviceOrientation\") {\n      const value = -orientation.beta / 90;\n      return deviceOrientationRollAdjust(value);\n    } else {\n      const value = -(y.value - height.value / 2) / height.value;\n      return mouseRollAdjust(value);\n    }\n  });\n  const tilt = computed(() => {\n    if (source.value === \"deviceOrientation\") {\n      const value = orientation.gamma / 90;\n      return deviceOrientationTiltAdjust(value);\n    } else {\n      const value = (x.value - width.value / 2) / width.value;\n      return mouseTiltAdjust(value);\n    }\n  });\n  return { roll, tilt, source };\n}\n\nvar __defProp$6 = Object.defineProperty;\nvar __defProps$1 = Object.defineProperties;\nvar __getOwnPropDescs$1 = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$6 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$6 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$6 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$6 = (obj, key, value) => key in obj ? __defProp$6(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$6 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$6.call(b, prop))\n      __defNormalProp$6(a, prop, b[prop]);\n  if (__getOwnPropSymbols$6)\n    for (var prop of __getOwnPropSymbols$6(b)) {\n      if (__propIsEnum$6.call(b, prop))\n        __defNormalProp$6(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps$1 = (a, b) => __defProps$1(a, __getOwnPropDescs$1(b));\nconst defaultState = {\n  x: 0,\n  y: 0,\n  pointerId: 0,\n  pressure: 0,\n  tiltX: 0,\n  tiltY: 0,\n  width: 0,\n  height: 0,\n  twist: 0,\n  pointerType: null\n};\nconst keys = /* @__PURE__ */ Object.keys(defaultState);\nfunction usePointer(options = {}) {\n  const {\n    target = defaultWindow\n  } = options;\n  const isInside = ref(false);\n  const state = ref(options.initialValue || {});\n  Object.assign(state.value, defaultState, state.value);\n  const handler = (event) => {\n    isInside.value = true;\n    if (options.pointerTypes && !options.pointerTypes.includes(event.pointerType))\n      return;\n    state.value = objectPick(event, keys, false);\n  };\n  if (target) {\n    useEventListener(target, \"pointerdown\", handler, { passive: true });\n    useEventListener(target, \"pointermove\", handler, { passive: true });\n    useEventListener(target, \"pointerleave\", () => isInside.value = false, { passive: true });\n  }\n  return __spreadProps$1(__spreadValues$6({}, toRefs(state)), {\n    isInside\n  });\n}\n\nfunction usePointerLock(target, options = {}) {\n  const { document = defaultDocument, pointerLockOptions } = options;\n  const isSupported = useSupported(() => document && \"pointerLockElement\" in document);\n  const element = ref();\n  const triggerElement = ref();\n  let targetElement;\n  if (isSupported.value) {\n    useEventListener(document, \"pointerlockchange\", () => {\n      var _a;\n      const currentElement = (_a = document.pointerLockElement) != null ? _a : element.value;\n      if (targetElement && currentElement === targetElement) {\n        element.value = document.pointerLockElement;\n        if (!element.value)\n          targetElement = triggerElement.value = null;\n      }\n    });\n    useEventListener(document, \"pointerlockerror\", () => {\n      var _a;\n      const currentElement = (_a = document.pointerLockElement) != null ? _a : element.value;\n      if (targetElement && currentElement === targetElement) {\n        const action = document.pointerLockElement ? \"release\" : \"acquire\";\n        throw new Error(`Failed to ${action} pointer lock.`);\n      }\n    });\n  }\n  async function lock(e, options2) {\n    var _a;\n    if (!isSupported.value)\n      throw new Error(\"Pointer Lock API is not supported by your browser.\");\n    triggerElement.value = e instanceof Event ? e.currentTarget : null;\n    targetElement = e instanceof Event ? (_a = unrefElement(target)) != null ? _a : triggerElement.value : unrefElement(e);\n    if (!targetElement)\n      throw new Error(\"Target element undefined.\");\n    targetElement.requestPointerLock(options2 != null ? options2 : pointerLockOptions);\n    return await until(element).toBe(targetElement);\n  }\n  async function unlock() {\n    if (!element.value)\n      return false;\n    document.exitPointerLock();\n    await until(element).toBeNull();\n    return true;\n  }\n  return {\n    isSupported,\n    element,\n    triggerElement,\n    lock,\n    unlock\n  };\n}\n\nvar SwipeDirection;\n(function(SwipeDirection2) {\n  SwipeDirection2[\"UP\"] = \"UP\";\n  SwipeDirection2[\"RIGHT\"] = \"RIGHT\";\n  SwipeDirection2[\"DOWN\"] = \"DOWN\";\n  SwipeDirection2[\"LEFT\"] = \"LEFT\";\n  SwipeDirection2[\"NONE\"] = \"NONE\";\n})(SwipeDirection || (SwipeDirection = {}));\nfunction useSwipe(target, options = {}) {\n  const {\n    threshold = 50,\n    onSwipe,\n    onSwipeEnd,\n    onSwipeStart,\n    passive = true,\n    window = defaultWindow\n  } = options;\n  const coordsStart = reactive({ x: 0, y: 0 });\n  const coordsEnd = reactive({ x: 0, y: 0 });\n  const diffX = computed(() => coordsStart.x - coordsEnd.x);\n  const diffY = computed(() => coordsStart.y - coordsEnd.y);\n  const { max, abs } = Math;\n  const isThresholdExceeded = computed(() => max(abs(diffX.value), abs(diffY.value)) >= threshold);\n  const isSwiping = ref(false);\n  const direction = computed(() => {\n    if (!isThresholdExceeded.value)\n      return SwipeDirection.NONE;\n    if (abs(diffX.value) > abs(diffY.value)) {\n      return diffX.value > 0 ? SwipeDirection.LEFT : SwipeDirection.RIGHT;\n    } else {\n      return diffY.value > 0 ? SwipeDirection.UP : SwipeDirection.DOWN;\n    }\n  });\n  const getTouchEventCoords = (e) => [e.touches[0].clientX, e.touches[0].clientY];\n  const updateCoordsStart = (x, y) => {\n    coordsStart.x = x;\n    coordsStart.y = y;\n  };\n  const updateCoordsEnd = (x, y) => {\n    coordsEnd.x = x;\n    coordsEnd.y = y;\n  };\n  let listenerOptions;\n  const isPassiveEventSupported = checkPassiveEventSupport(window == null ? void 0 : window.document);\n  if (!passive)\n    listenerOptions = isPassiveEventSupported ? { passive: false, capture: true } : { capture: true };\n  else\n    listenerOptions = isPassiveEventSupported ? { passive: true } : { capture: false };\n  const onTouchEnd = (e) => {\n    if (isSwiping.value)\n      onSwipeEnd == null ? void 0 : onSwipeEnd(e, direction.value);\n    isSwiping.value = false;\n  };\n  const stops = [\n    useEventListener(target, \"touchstart\", (e) => {\n      if (listenerOptions.capture && !listenerOptions.passive)\n        e.preventDefault();\n      const [x, y] = getTouchEventCoords(e);\n      updateCoordsStart(x, y);\n      updateCoordsEnd(x, y);\n      onSwipeStart == null ? void 0 : onSwipeStart(e);\n    }, listenerOptions),\n    useEventListener(target, \"touchmove\", (e) => {\n      const [x, y] = getTouchEventCoords(e);\n      updateCoordsEnd(x, y);\n      if (!isSwiping.value && isThresholdExceeded.value)\n        isSwiping.value = true;\n      if (isSwiping.value)\n        onSwipe == null ? void 0 : onSwipe(e);\n    }, listenerOptions),\n    useEventListener(target, \"touchend\", onTouchEnd, listenerOptions),\n    useEventListener(target, \"touchcancel\", onTouchEnd, listenerOptions)\n  ];\n  const stop = () => stops.forEach((s) => s());\n  return {\n    isPassiveEventSupported,\n    isSwiping,\n    direction,\n    coordsStart,\n    coordsEnd,\n    lengthX: diffX,\n    lengthY: diffY,\n    stop\n  };\n}\nfunction checkPassiveEventSupport(document) {\n  if (!document)\n    return false;\n  let supportsPassive = false;\n  const optionsBlock = {\n    get passive() {\n      supportsPassive = true;\n      return false;\n    }\n  };\n  document.addEventListener(\"x\", noop, optionsBlock);\n  document.removeEventListener(\"x\", noop);\n  return supportsPassive;\n}\n\nfunction usePointerSwipe(target, options = {}) {\n  const targetRef = resolveRef(target);\n  const {\n    threshold = 50,\n    onSwipe,\n    onSwipeEnd,\n    onSwipeStart\n  } = options;\n  const posStart = reactive({ x: 0, y: 0 });\n  const updatePosStart = (x, y) => {\n    posStart.x = x;\n    posStart.y = y;\n  };\n  const posEnd = reactive({ x: 0, y: 0 });\n  const updatePosEnd = (x, y) => {\n    posEnd.x = x;\n    posEnd.y = y;\n  };\n  const distanceX = computed(() => posStart.x - posEnd.x);\n  const distanceY = computed(() => posStart.y - posEnd.y);\n  const { max, abs } = Math;\n  const isThresholdExceeded = computed(() => max(abs(distanceX.value), abs(distanceY.value)) >= threshold);\n  const isSwiping = ref(false);\n  const isPointerDown = ref(false);\n  const direction = computed(() => {\n    if (!isThresholdExceeded.value)\n      return SwipeDirection.NONE;\n    if (abs(distanceX.value) > abs(distanceY.value)) {\n      return distanceX.value > 0 ? SwipeDirection.LEFT : SwipeDirection.RIGHT;\n    } else {\n      return distanceY.value > 0 ? SwipeDirection.UP : SwipeDirection.DOWN;\n    }\n  });\n  const eventIsAllowed = (e) => {\n    var _a, _b, _c;\n    const isReleasingButton = e.buttons === 0;\n    const isPrimaryButton = e.buttons === 1;\n    return (_c = (_b = (_a = options.pointerTypes) == null ? void 0 : _a.includes(e.pointerType)) != null ? _b : isReleasingButton || isPrimaryButton) != null ? _c : true;\n  };\n  const stops = [\n    useEventListener(target, \"pointerdown\", (e) => {\n      var _a, _b;\n      if (!eventIsAllowed(e))\n        return;\n      isPointerDown.value = true;\n      (_b = (_a = targetRef.value) == null ? void 0 : _a.style) == null ? void 0 : _b.setProperty(\"touch-action\", \"none\");\n      const eventTarget = e.target;\n      eventTarget == null ? void 0 : eventTarget.setPointerCapture(e.pointerId);\n      const { clientX: x, clientY: y } = e;\n      updatePosStart(x, y);\n      updatePosEnd(x, y);\n      onSwipeStart == null ? void 0 : onSwipeStart(e);\n    }),\n    useEventListener(target, \"pointermove\", (e) => {\n      if (!eventIsAllowed(e))\n        return;\n      if (!isPointerDown.value)\n        return;\n      const { clientX: x, clientY: y } = e;\n      updatePosEnd(x, y);\n      if (!isSwiping.value && isThresholdExceeded.value)\n        isSwiping.value = true;\n      if (isSwiping.value)\n        onSwipe == null ? void 0 : onSwipe(e);\n    }),\n    useEventListener(target, \"pointerup\", (e) => {\n      var _a, _b;\n      if (!eventIsAllowed(e))\n        return;\n      if (isSwiping.value)\n        onSwipeEnd == null ? void 0 : onSwipeEnd(e, direction.value);\n      isPointerDown.value = false;\n      isSwiping.value = false;\n      (_b = (_a = targetRef.value) == null ? void 0 : _a.style) == null ? void 0 : _b.setProperty(\"touch-action\", \"initial\");\n    })\n  ];\n  const stop = () => stops.forEach((s) => s());\n  return {\n    isSwiping: readonly(isSwiping),\n    direction: readonly(direction),\n    posStart: readonly(posStart),\n    posEnd: readonly(posEnd),\n    distanceX,\n    distanceY,\n    stop\n  };\n}\n\nfunction usePreferredColorScheme(options) {\n  const isLight = useMediaQuery(\"(prefers-color-scheme: light)\", options);\n  const isDark = useMediaQuery(\"(prefers-color-scheme: dark)\", options);\n  return computed(() => {\n    if (isDark.value)\n      return \"dark\";\n    if (isLight.value)\n      return \"light\";\n    return \"no-preference\";\n  });\n}\n\nfunction usePreferredContrast(options) {\n  const isMore = useMediaQuery(\"(prefers-contrast: more)\", options);\n  const isLess = useMediaQuery(\"(prefers-contrast: less)\", options);\n  const isCustom = useMediaQuery(\"(prefers-contrast: custom)\", options);\n  return computed(() => {\n    if (isMore.value)\n      return \"more\";\n    if (isLess.value)\n      return \"less\";\n    if (isCustom.value)\n      return \"custom\";\n    return \"no-preference\";\n  });\n}\n\nfunction usePreferredLanguages(options = {}) {\n  const { window = defaultWindow } = options;\n  if (!window)\n    return ref([\"en\"]);\n  const navigator = window.navigator;\n  const value = ref(navigator.languages);\n  useEventListener(window, \"languagechange\", () => {\n    value.value = navigator.languages;\n  });\n  return value;\n}\n\nfunction usePreferredReducedMotion(options) {\n  const isReduced = useMediaQuery(\"(prefers-reduced-motion: reduce)\", options);\n  return computed(() => {\n    if (isReduced.value)\n      return \"reduce\";\n    return \"no-preference\";\n  });\n}\n\nfunction usePrevious(value, initialValue) {\n  const previous = shallowRef(initialValue);\n  watch(resolveRef(value), (_, oldValue) => {\n    previous.value = oldValue;\n  }, { flush: \"sync\" });\n  return readonly(previous);\n}\n\nconst useScreenOrientation = (options = {}) => {\n  const {\n    window = defaultWindow\n  } = options;\n  const isSupported = useSupported(() => window && \"screen\" in window && \"orientation\" in window.screen);\n  const screenOrientation = isSupported.value ? window.screen.orientation : {};\n  const orientation = ref(screenOrientation.type);\n  const angle = ref(screenOrientation.angle || 0);\n  if (isSupported.value) {\n    useEventListener(window, \"orientationchange\", () => {\n      orientation.value = screenOrientation.type;\n      angle.value = screenOrientation.angle;\n    });\n  }\n  const lockOrientation = (type) => {\n    if (!isSupported.value)\n      return Promise.reject(new Error(\"Not supported\"));\n    return screenOrientation.lock(type);\n  };\n  const unlockOrientation = () => {\n    if (isSupported.value)\n      screenOrientation.unlock();\n  };\n  return {\n    isSupported,\n    orientation,\n    angle,\n    lockOrientation,\n    unlockOrientation\n  };\n};\n\nconst topVarName = \"--vueuse-safe-area-top\";\nconst rightVarName = \"--vueuse-safe-area-right\";\nconst bottomVarName = \"--vueuse-safe-area-bottom\";\nconst leftVarName = \"--vueuse-safe-area-left\";\nfunction useScreenSafeArea() {\n  const top = ref(\"\");\n  const right = ref(\"\");\n  const bottom = ref(\"\");\n  const left = ref(\"\");\n  if (isClient) {\n    const topCssVar = useCssVar(topVarName);\n    const rightCssVar = useCssVar(rightVarName);\n    const bottomCssVar = useCssVar(bottomVarName);\n    const leftCssVar = useCssVar(leftVarName);\n    topCssVar.value = \"env(safe-area-inset-top, 0px)\";\n    rightCssVar.value = \"env(safe-area-inset-right, 0px)\";\n    bottomCssVar.value = \"env(safe-area-inset-bottom, 0px)\";\n    leftCssVar.value = \"env(safe-area-inset-left, 0px)\";\n    update();\n    useEventListener(\"resize\", useDebounceFn(update));\n  }\n  function update() {\n    top.value = getValue(topVarName);\n    right.value = getValue(rightVarName);\n    bottom.value = getValue(bottomVarName);\n    left.value = getValue(leftVarName);\n  }\n  return {\n    top,\n    right,\n    bottom,\n    left,\n    update\n  };\n}\nfunction getValue(position) {\n  return getComputedStyle(document.documentElement).getPropertyValue(position);\n}\n\nfunction useScriptTag(src, onLoaded = noop, options = {}) {\n  const {\n    immediate = true,\n    manual = false,\n    type = \"text/javascript\",\n    async = true,\n    crossOrigin,\n    referrerPolicy,\n    noModule,\n    defer,\n    document = defaultDocument,\n    attrs = {}\n  } = options;\n  const scriptTag = ref(null);\n  let _promise = null;\n  const loadScript = (waitForScriptLoad) => new Promise((resolve, reject) => {\n    const resolveWithElement = (el2) => {\n      scriptTag.value = el2;\n      resolve(el2);\n      return el2;\n    };\n    if (!document) {\n      resolve(false);\n      return;\n    }\n    let shouldAppend = false;\n    let el = document.querySelector(`script[src=\"${resolveUnref(src)}\"]`);\n    if (!el) {\n      el = document.createElement(\"script\");\n      el.type = type;\n      el.async = async;\n      el.src = resolveUnref(src);\n      if (defer)\n        el.defer = defer;\n      if (crossOrigin)\n        el.crossOrigin = crossOrigin;\n      if (noModule)\n        el.noModule = noModule;\n      if (referrerPolicy)\n        el.referrerPolicy = referrerPolicy;\n      Object.entries(attrs).forEach(([name, value]) => el == null ? void 0 : el.setAttribute(name, value));\n      shouldAppend = true;\n    } else if (el.hasAttribute(\"data-loaded\")) {\n      resolveWithElement(el);\n    }\n    el.addEventListener(\"error\", (event) => reject(event));\n    el.addEventListener(\"abort\", (event) => reject(event));\n    el.addEventListener(\"load\", () => {\n      el.setAttribute(\"data-loaded\", \"true\");\n      onLoaded(el);\n      resolveWithElement(el);\n    });\n    if (shouldAppend)\n      el = document.head.appendChild(el);\n    if (!waitForScriptLoad)\n      resolveWithElement(el);\n  });\n  const load = (waitForScriptLoad = true) => {\n    if (!_promise)\n      _promise = loadScript(waitForScriptLoad);\n    return _promise;\n  };\n  const unload = () => {\n    if (!document)\n      return;\n    _promise = null;\n    if (scriptTag.value)\n      scriptTag.value = null;\n    const el = document.querySelector(`script[src=\"${resolveUnref(src)}\"]`);\n    if (el)\n      document.head.removeChild(el);\n  };\n  if (immediate && !manual)\n    tryOnMounted(load);\n  if (!manual)\n    tryOnUnmounted(unload);\n  return { scriptTag, load, unload };\n}\n\nfunction checkOverflowScroll(ele) {\n  const style = window.getComputedStyle(ele);\n  if (style.overflowX === \"scroll\" || style.overflowY === \"scroll\" || style.overflowX === \"auto\" && ele.clientHeight < ele.scrollHeight || style.overflowY === \"auto\" && ele.clientWidth < ele.scrollWidth) {\n    return true;\n  } else {\n    const parent = ele.parentNode;\n    if (!parent || parent.tagName === \"BODY\")\n      return false;\n    return checkOverflowScroll(parent);\n  }\n}\nfunction preventDefault(rawEvent) {\n  const e = rawEvent || window.event;\n  const _target = e.target;\n  if (checkOverflowScroll(_target))\n    return false;\n  if (e.touches.length > 1)\n    return true;\n  if (e.preventDefault)\n    e.preventDefault();\n  return false;\n}\nfunction useScrollLock(element, initialState = false) {\n  const isLocked = ref(initialState);\n  let stopTouchMoveListener = null;\n  let initialOverflow;\n  watch(resolveRef(element), (el) => {\n    if (el) {\n      const ele = el;\n      initialOverflow = ele.style.overflow;\n      if (isLocked.value)\n        ele.style.overflow = \"hidden\";\n    }\n  }, {\n    immediate: true\n  });\n  const lock = () => {\n    const ele = resolveUnref(element);\n    if (!ele || isLocked.value)\n      return;\n    if (isIOS) {\n      stopTouchMoveListener = useEventListener(ele, \"touchmove\", (e) => {\n        preventDefault(e);\n      }, { passive: false });\n    }\n    ele.style.overflow = \"hidden\";\n    isLocked.value = true;\n  };\n  const unlock = () => {\n    const ele = resolveUnref(element);\n    if (!ele || !isLocked.value)\n      return;\n    isIOS && (stopTouchMoveListener == null ? void 0 : stopTouchMoveListener());\n    ele.style.overflow = initialOverflow;\n    isLocked.value = false;\n  };\n  tryOnScopeDispose(unlock);\n  return computed({\n    get() {\n      return isLocked.value;\n    },\n    set(v) {\n      if (v)\n        lock();\n      else\n        unlock();\n    }\n  });\n}\n\nfunction useSessionStorage(key, initialValue, options = {}) {\n  const { window = defaultWindow } = options;\n  return useStorage(key, initialValue, window == null ? void 0 : window.sessionStorage, options);\n}\n\nvar __defProp$5 = Object.defineProperty;\nvar __getOwnPropSymbols$5 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$5 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$5 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$5 = (obj, key, value) => key in obj ? __defProp$5(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$5 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$5.call(b, prop))\n      __defNormalProp$5(a, prop, b[prop]);\n  if (__getOwnPropSymbols$5)\n    for (var prop of __getOwnPropSymbols$5(b)) {\n      if (__propIsEnum$5.call(b, prop))\n        __defNormalProp$5(a, prop, b[prop]);\n    }\n  return a;\n};\nfunction useShare(shareOptions = {}, options = {}) {\n  const { navigator = defaultNavigator } = options;\n  const _navigator = navigator;\n  const isSupported = useSupported(() => _navigator && \"canShare\" in _navigator);\n  const share = async (overrideOptions = {}) => {\n    if (isSupported.value) {\n      const data = __spreadValues$5(__spreadValues$5({}, resolveUnref(shareOptions)), resolveUnref(overrideOptions));\n      let granted = true;\n      if (data.files && _navigator.canShare)\n        granted = _navigator.canShare({ files: data.files });\n      if (granted)\n        return _navigator.share(data);\n    }\n  };\n  return {\n    isSupported,\n    share\n  };\n}\n\nconst defaultSortFn = (source, compareFn) => source.sort(compareFn);\nconst defaultCompare = (a, b) => a - b;\nfunction useSorted(...args) {\n  var _a, _b, _c, _d;\n  const [source] = args;\n  let compareFn = defaultCompare;\n  let options = {};\n  if (args.length === 2) {\n    if (typeof args[1] === \"object\") {\n      options = args[1];\n      compareFn = (_a = options.compareFn) != null ? _a : defaultCompare;\n    } else {\n      compareFn = (_b = args[1]) != null ? _b : defaultCompare;\n    }\n  } else if (args.length > 2) {\n    compareFn = (_c = args[1]) != null ? _c : defaultCompare;\n    options = (_d = args[2]) != null ? _d : {};\n  }\n  const {\n    dirty = false,\n    sortFn = defaultSortFn\n  } = options;\n  if (!dirty)\n    return computed(() => sortFn([...unref(source)], compareFn));\n  watchEffect(() => {\n    const result = sortFn(unref(source), compareFn);\n    if (isRef(source))\n      source.value = result;\n    else\n      source.splice(0, source.length, ...result);\n  });\n  return source;\n}\n\nfunction useSpeechRecognition(options = {}) {\n  const {\n    interimResults = true,\n    continuous = true,\n    window = defaultWindow\n  } = options;\n  const lang = resolveRef(options.lang || \"en-US\");\n  const isListening = ref(false);\n  const isFinal = ref(false);\n  const result = ref(\"\");\n  const error = shallowRef(void 0);\n  const toggle = (value = !isListening.value) => {\n    isListening.value = value;\n  };\n  const start = () => {\n    isListening.value = true;\n  };\n  const stop = () => {\n    isListening.value = false;\n  };\n  const SpeechRecognition = window && (window.SpeechRecognition || window.webkitSpeechRecognition);\n  const isSupported = useSupported(() => SpeechRecognition);\n  let recognition;\n  if (isSupported.value) {\n    recognition = new SpeechRecognition();\n    recognition.continuous = continuous;\n    recognition.interimResults = interimResults;\n    recognition.lang = unref(lang);\n    recognition.onstart = () => {\n      isFinal.value = false;\n    };\n    watch(lang, (lang2) => {\n      if (recognition && !isListening.value)\n        recognition.lang = lang2;\n    });\n    recognition.onresult = (event) => {\n      const transcript = Array.from(event.results).map((result2) => {\n        isFinal.value = result2.isFinal;\n        return result2[0];\n      }).map((result2) => result2.transcript).join(\"\");\n      result.value = transcript;\n      error.value = void 0;\n    };\n    recognition.onerror = (event) => {\n      error.value = event;\n    };\n    recognition.onend = () => {\n      isListening.value = false;\n      recognition.lang = unref(lang);\n    };\n    watch(isListening, () => {\n      if (isListening.value)\n        recognition.start();\n      else\n        recognition.stop();\n    });\n  }\n  tryOnScopeDispose(() => {\n    isListening.value = false;\n  });\n  return {\n    isSupported,\n    isListening,\n    isFinal,\n    recognition,\n    result,\n    error,\n    toggle,\n    start,\n    stop\n  };\n}\n\nfunction useSpeechSynthesis(text, options = {}) {\n  const {\n    pitch = 1,\n    rate = 1,\n    volume = 1,\n    window = defaultWindow\n  } = options;\n  const synth = window && window.speechSynthesis;\n  const isSupported = useSupported(() => synth);\n  const isPlaying = ref(false);\n  const status = ref(\"init\");\n  const spokenText = resolveRef(text || \"\");\n  const lang = resolveRef(options.lang || \"en-US\");\n  const error = shallowRef(void 0);\n  const toggle = (value = !isPlaying.value) => {\n    isPlaying.value = value;\n  };\n  const bindEventsForUtterance = (utterance2) => {\n    utterance2.lang = unref(lang);\n    utterance2.voice = unref(options.voice) || null;\n    utterance2.pitch = pitch;\n    utterance2.rate = rate;\n    utterance2.volume = volume;\n    utterance2.onstart = () => {\n      isPlaying.value = true;\n      status.value = \"play\";\n    };\n    utterance2.onpause = () => {\n      isPlaying.value = false;\n      status.value = \"pause\";\n    };\n    utterance2.onresume = () => {\n      isPlaying.value = true;\n      status.value = \"play\";\n    };\n    utterance2.onend = () => {\n      isPlaying.value = false;\n      status.value = \"end\";\n    };\n    utterance2.onerror = (event) => {\n      error.value = event;\n    };\n  };\n  const utterance = computed(() => {\n    isPlaying.value = false;\n    status.value = \"init\";\n    const newUtterance = new SpeechSynthesisUtterance(spokenText.value);\n    bindEventsForUtterance(newUtterance);\n    return newUtterance;\n  });\n  const speak = () => {\n    synth.cancel();\n    utterance && synth.speak(utterance.value);\n  };\n  const stop = () => {\n    synth.cancel();\n    isPlaying.value = false;\n  };\n  if (isSupported.value) {\n    bindEventsForUtterance(utterance.value);\n    watch(lang, (lang2) => {\n      if (utterance.value && !isPlaying.value)\n        utterance.value.lang = lang2;\n    });\n    if (options.voice) {\n      watch(options.voice, () => {\n        synth.cancel();\n      });\n    }\n    watch(isPlaying, () => {\n      if (isPlaying.value)\n        synth.resume();\n      else\n        synth.pause();\n    });\n  }\n  tryOnScopeDispose(() => {\n    isPlaying.value = false;\n  });\n  return {\n    isSupported,\n    isPlaying,\n    status,\n    utterance,\n    error,\n    stop,\n    toggle,\n    speak\n  };\n}\n\nfunction useStepper(steps, initialStep) {\n  const stepsRef = ref(steps);\n  const stepNames = computed(() => Array.isArray(stepsRef.value) ? stepsRef.value : Object.keys(stepsRef.value));\n  const index = ref(stepNames.value.indexOf(initialStep != null ? initialStep : stepNames.value[0]));\n  const current = computed(() => at(index.value));\n  const isFirst = computed(() => index.value === 0);\n  const isLast = computed(() => index.value === stepNames.value.length - 1);\n  const next = computed(() => stepNames.value[index.value + 1]);\n  const previous = computed(() => stepNames.value[index.value - 1]);\n  function at(index2) {\n    if (Array.isArray(stepsRef.value))\n      return stepsRef.value[index2];\n    return stepsRef.value[stepNames.value[index2]];\n  }\n  function get(step) {\n    if (!stepNames.value.includes(step))\n      return;\n    return at(stepNames.value.indexOf(step));\n  }\n  function goTo(step) {\n    if (stepNames.value.includes(step))\n      index.value = stepNames.value.indexOf(step);\n  }\n  function goToNext() {\n    if (isLast.value)\n      return;\n    index.value++;\n  }\n  function goToPrevious() {\n    if (isFirst.value)\n      return;\n    index.value--;\n  }\n  function goBackTo(step) {\n    if (isAfter(step))\n      goTo(step);\n  }\n  function isNext(step) {\n    return stepNames.value.indexOf(step) === index.value + 1;\n  }\n  function isPrevious(step) {\n    return stepNames.value.indexOf(step) === index.value - 1;\n  }\n  function isCurrent(step) {\n    return stepNames.value.indexOf(step) === index.value;\n  }\n  function isBefore(step) {\n    return index.value < stepNames.value.indexOf(step);\n  }\n  function isAfter(step) {\n    return index.value > stepNames.value.indexOf(step);\n  }\n  return {\n    steps: stepsRef,\n    stepNames,\n    index,\n    current,\n    next,\n    previous,\n    isFirst,\n    isLast,\n    at,\n    get,\n    goTo,\n    goToNext,\n    goToPrevious,\n    goBackTo,\n    isNext,\n    isPrevious,\n    isCurrent,\n    isBefore,\n    isAfter\n  };\n}\n\nvar __defProp$4 = Object.defineProperty;\nvar __getOwnPropSymbols$4 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$4 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$4 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$4 = (obj, key, value) => key in obj ? __defProp$4(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$4 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$4.call(b, prop))\n      __defNormalProp$4(a, prop, b[prop]);\n  if (__getOwnPropSymbols$4)\n    for (var prop of __getOwnPropSymbols$4(b)) {\n      if (__propIsEnum$4.call(b, prop))\n        __defNormalProp$4(a, prop, b[prop]);\n    }\n  return a;\n};\nfunction useStorageAsync(key, initialValue, storage, options = {}) {\n  var _a;\n  const {\n    flush = \"pre\",\n    deep = true,\n    listenToStorageChanges = true,\n    writeDefaults = true,\n    mergeDefaults = false,\n    shallow,\n    window = defaultWindow,\n    eventFilter,\n    onError = (e) => {\n      console.error(e);\n    }\n  } = options;\n  const rawInit = resolveUnref(initialValue);\n  const type = guessSerializerType(rawInit);\n  const data = (shallow ? shallowRef : ref)(initialValue);\n  const serializer = (_a = options.serializer) != null ? _a : StorageSerializers[type];\n  if (!storage) {\n    try {\n      storage = getSSRHandler(\"getDefaultStorage\", () => {\n        var _a2;\n        return (_a2 = defaultWindow) == null ? void 0 : _a2.localStorage;\n      })();\n    } catch (e) {\n      onError(e);\n    }\n  }\n  async function read(event) {\n    if (!storage || event && event.key !== key)\n      return;\n    try {\n      const rawValue = event ? event.newValue : await storage.getItem(key);\n      if (rawValue == null) {\n        data.value = rawInit;\n        if (writeDefaults && rawInit !== null)\n          await storage.setItem(key, await serializer.write(rawInit));\n      } else if (mergeDefaults) {\n        const value = await serializer.read(rawValue);\n        if (isFunction(mergeDefaults))\n          data.value = mergeDefaults(value, rawInit);\n        else if (type === \"object\" && !Array.isArray(value))\n          data.value = __spreadValues$4(__spreadValues$4({}, rawInit), value);\n        else\n          data.value = value;\n      } else {\n        data.value = await serializer.read(rawValue);\n      }\n    } catch (e) {\n      onError(e);\n    }\n  }\n  read();\n  if (window && listenToStorageChanges)\n    useEventListener(window, \"storage\", (e) => setTimeout(() => read(e), 0));\n  if (storage) {\n    watchWithFilter(data, async () => {\n      try {\n        if (data.value == null)\n          await storage.removeItem(key);\n        else\n          await storage.setItem(key, await serializer.write(data.value));\n      } catch (e) {\n        onError(e);\n      }\n    }, {\n      flush,\n      deep,\n      eventFilter\n    });\n  }\n  return data;\n}\n\nlet _id = 0;\nfunction useStyleTag(css, options = {}) {\n  const isLoaded = ref(false);\n  const {\n    document = defaultDocument,\n    immediate = true,\n    manual = false,\n    id = `vueuse_styletag_${++_id}`\n  } = options;\n  const cssRef = ref(css);\n  let stop = () => {\n  };\n  const load = () => {\n    if (!document)\n      return;\n    const el = document.getElementById(id) || document.createElement(\"style\");\n    if (!el.isConnected) {\n      el.type = \"text/css\";\n      el.id = id;\n      if (options.media)\n        el.media = options.media;\n      document.head.appendChild(el);\n    }\n    if (isLoaded.value)\n      return;\n    stop = watch(cssRef, (value) => {\n      el.textContent = value;\n    }, { immediate: true });\n    isLoaded.value = true;\n  };\n  const unload = () => {\n    if (!document || !isLoaded.value)\n      return;\n    stop();\n    document.head.removeChild(document.getElementById(id));\n    isLoaded.value = false;\n  };\n  if (immediate && !manual)\n    tryOnMounted(load);\n  if (!manual)\n    tryOnScopeDispose(unload);\n  return {\n    id,\n    css: cssRef,\n    unload,\n    load,\n    isLoaded: readonly(isLoaded)\n  };\n}\n\nfunction useTemplateRefsList() {\n  const refs = ref([]);\n  refs.value.set = (el) => {\n    if (el)\n      refs.value.push(el);\n  };\n  onBeforeUpdate(() => {\n    refs.value.length = 0;\n  });\n  return refs;\n}\n\nfunction useTextDirection(options = {}) {\n  const {\n    document = defaultDocument,\n    selector = \"html\",\n    observe = false,\n    initialValue = \"ltr\"\n  } = options;\n  function getValue() {\n    var _a, _b;\n    return (_b = (_a = document == null ? void 0 : document.querySelector(selector)) == null ? void 0 : _a.getAttribute(\"dir\")) != null ? _b : initialValue;\n  }\n  const dir = ref(getValue());\n  tryOnMounted(() => dir.value = getValue());\n  if (observe && document) {\n    useMutationObserver(document.querySelector(selector), () => dir.value = getValue(), { attributes: true });\n  }\n  return computed({\n    get() {\n      return dir.value;\n    },\n    set(v) {\n      var _a, _b;\n      dir.value = v;\n      if (!document)\n        return;\n      if (dir.value)\n        (_a = document.querySelector(selector)) == null ? void 0 : _a.setAttribute(\"dir\", dir.value);\n      else\n        (_b = document.querySelector(selector)) == null ? void 0 : _b.removeAttribute(\"dir\");\n    }\n  });\n}\n\nfunction getRangesFromSelection(selection) {\n  var _a;\n  const rangeCount = (_a = selection.rangeCount) != null ? _a : 0;\n  const ranges = new Array(rangeCount);\n  for (let i = 0; i < rangeCount; i++) {\n    const range = selection.getRangeAt(i);\n    ranges[i] = range;\n  }\n  return ranges;\n}\nfunction useTextSelection(options = {}) {\n  const {\n    window = defaultWindow\n  } = options;\n  const selection = ref(null);\n  const text = computed(() => {\n    var _a, _b;\n    return (_b = (_a = selection.value) == null ? void 0 : _a.toString()) != null ? _b : \"\";\n  });\n  const ranges = computed(() => selection.value ? getRangesFromSelection(selection.value) : []);\n  const rects = computed(() => ranges.value.map((range) => range.getBoundingClientRect()));\n  function onSelectionChange() {\n    selection.value = null;\n    if (window)\n      selection.value = window.getSelection();\n  }\n  if (window)\n    useEventListener(window.document, \"selectionchange\", onSelectionChange);\n  return {\n    text,\n    rects,\n    ranges,\n    selection\n  };\n}\n\nfunction useTextareaAutosize(options) {\n  const textarea = ref(options == null ? void 0 : options.element);\n  const input = ref(options == null ? void 0 : options.input);\n  function triggerResize() {\n    var _a, _b;\n    if (!textarea.value)\n      return;\n    textarea.value.style.height = \"1px\";\n    textarea.value.style.height = `${(_a = textarea.value) == null ? void 0 : _a.scrollHeight}px`;\n    (_b = options == null ? void 0 : options.onResize) == null ? void 0 : _b.call(options);\n  }\n  watch([input, textarea], triggerResize, { immediate: true });\n  useResizeObserver(textarea, () => triggerResize());\n  if (options == null ? void 0 : options.watch)\n    watch(options.watch, triggerResize, { immediate: true, deep: true });\n  return {\n    textarea,\n    input,\n    triggerResize\n  };\n}\n\nvar __defProp$3 = Object.defineProperty;\nvar __defProps = Object.defineProperties;\nvar __getOwnPropDescs = Object.getOwnPropertyDescriptors;\nvar __getOwnPropSymbols$3 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$3 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$3 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$3 = (obj, key, value) => key in obj ? __defProp$3(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$3 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$3.call(b, prop))\n      __defNormalProp$3(a, prop, b[prop]);\n  if (__getOwnPropSymbols$3)\n    for (var prop of __getOwnPropSymbols$3(b)) {\n      if (__propIsEnum$3.call(b, prop))\n        __defNormalProp$3(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));\nfunction useThrottledRefHistory(source, options = {}) {\n  const { throttle = 200, trailing = true } = options;\n  const filter = throttleFilter(throttle, trailing);\n  const history = useRefHistory(source, __spreadProps(__spreadValues$3({}, options), { eventFilter: filter }));\n  return __spreadValues$3({}, history);\n}\n\nvar __defProp$2 = Object.defineProperty;\nvar __getOwnPropSymbols$2 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$2 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$2 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$2 = (obj, key, value) => key in obj ? __defProp$2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$2 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$2.call(b, prop))\n      __defNormalProp$2(a, prop, b[prop]);\n  if (__getOwnPropSymbols$2)\n    for (var prop of __getOwnPropSymbols$2(b)) {\n      if (__propIsEnum$2.call(b, prop))\n        __defNormalProp$2(a, prop, b[prop]);\n    }\n  return a;\n};\nvar __objRest = (source, exclude) => {\n  var target = {};\n  for (var prop in source)\n    if (__hasOwnProp$2.call(source, prop) && exclude.indexOf(prop) < 0)\n      target[prop] = source[prop];\n  if (source != null && __getOwnPropSymbols$2)\n    for (var prop of __getOwnPropSymbols$2(source)) {\n      if (exclude.indexOf(prop) < 0 && __propIsEnum$2.call(source, prop))\n        target[prop] = source[prop];\n    }\n  return target;\n};\nconst DEFAULT_UNITS = [\n  { max: 6e4, value: 1e3, name: \"second\" },\n  { max: 276e4, value: 6e4, name: \"minute\" },\n  { max: 72e6, value: 36e5, name: \"hour\" },\n  { max: 5184e5, value: 864e5, name: \"day\" },\n  { max: 24192e5, value: 6048e5, name: \"week\" },\n  { max: 28512e6, value: 2592e6, name: \"month\" },\n  { max: Infinity, value: 31536e6, name: \"year\" }\n];\nconst DEFAULT_MESSAGES = {\n  justNow: \"just now\",\n  past: (n) => n.match(/\\d/) ? `${n} ago` : n,\n  future: (n) => n.match(/\\d/) ? `in ${n}` : n,\n  month: (n, past) => n === 1 ? past ? \"last month\" : \"next month\" : `${n} month${n > 1 ? \"s\" : \"\"}`,\n  year: (n, past) => n === 1 ? past ? \"last year\" : \"next year\" : `${n} year${n > 1 ? \"s\" : \"\"}`,\n  day: (n, past) => n === 1 ? past ? \"yesterday\" : \"tomorrow\" : `${n} day${n > 1 ? \"s\" : \"\"}`,\n  week: (n, past) => n === 1 ? past ? \"last week\" : \"next week\" : `${n} week${n > 1 ? \"s\" : \"\"}`,\n  hour: (n) => `${n} hour${n > 1 ? \"s\" : \"\"}`,\n  minute: (n) => `${n} minute${n > 1 ? \"s\" : \"\"}`,\n  second: (n) => `${n} second${n > 1 ? \"s\" : \"\"}`,\n  invalid: \"\"\n};\nconst DEFAULT_FORMATTER = (date) => date.toISOString().slice(0, 10);\nfunction useTimeAgo(time, options = {}) {\n  const {\n    controls: exposeControls = false,\n    updateInterval = 3e4\n  } = options;\n  const _a = useNow({ interval: updateInterval, controls: true }), { now } = _a, controls = __objRest(_a, [\"now\"]);\n  const timeAgo = computed(() => formatTimeAgo(new Date(resolveUnref(time)), options, unref(now.value)));\n  if (exposeControls) {\n    return __spreadValues$2({\n      timeAgo\n    }, controls);\n  } else {\n    return timeAgo;\n  }\n}\nfunction formatTimeAgo(from, options = {}, now = Date.now()) {\n  var _a;\n  const {\n    max,\n    messages = DEFAULT_MESSAGES,\n    fullDateFormatter = DEFAULT_FORMATTER,\n    units = DEFAULT_UNITS,\n    showSecond = false,\n    rounding = \"round\"\n  } = options;\n  const roundFn = typeof rounding === \"number\" ? (n) => +n.toFixed(rounding) : Math[rounding];\n  const diff = +now - +from;\n  const absDiff = Math.abs(diff);\n  function getValue(diff2, unit) {\n    return roundFn(Math.abs(diff2) / unit.value);\n  }\n  function format(diff2, unit) {\n    const val = getValue(diff2, unit);\n    const past = diff2 > 0;\n    const str = applyFormat(unit.name, val, past);\n    return applyFormat(past ? \"past\" : \"future\", str, past);\n  }\n  function applyFormat(name, val, isPast) {\n    const formatter = messages[name];\n    if (typeof formatter === \"function\")\n      return formatter(val, isPast);\n    return formatter.replace(\"{0}\", val.toString());\n  }\n  if (absDiff < 6e4 && !showSecond)\n    return messages.justNow;\n  if (typeof max === \"number\" && absDiff > max)\n    return fullDateFormatter(new Date(from));\n  if (typeof max === \"string\") {\n    const unitMax = (_a = units.find((i) => i.name === max)) == null ? void 0 : _a.max;\n    if (unitMax && absDiff > unitMax)\n      return fullDateFormatter(new Date(from));\n  }\n  for (const [idx, unit] of units.entries()) {\n    const val = getValue(diff, unit);\n    if (val <= 0 && units[idx - 1])\n      return format(diff, units[idx - 1]);\n    if (absDiff < unit.max)\n      return format(diff, unit);\n  }\n  return messages.invalid;\n}\n\nfunction useTimeoutPoll(fn, interval, timeoutPollOptions) {\n  const { start } = useTimeoutFn(loop, interval);\n  const isActive = ref(false);\n  async function loop() {\n    if (!isActive.value)\n      return;\n    await fn();\n    start();\n  }\n  function resume() {\n    if (!isActive.value) {\n      isActive.value = true;\n      loop();\n    }\n  }\n  function pause() {\n    isActive.value = false;\n  }\n  if (timeoutPollOptions == null ? void 0 : timeoutPollOptions.immediate)\n    resume();\n  tryOnScopeDispose(pause);\n  return {\n    isActive,\n    pause,\n    resume\n  };\n}\n\nvar __defProp$1 = Object.defineProperty;\nvar __getOwnPropSymbols$1 = Object.getOwnPropertySymbols;\nvar __hasOwnProp$1 = Object.prototype.hasOwnProperty;\nvar __propIsEnum$1 = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues$1 = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp$1.call(b, prop))\n      __defNormalProp$1(a, prop, b[prop]);\n  if (__getOwnPropSymbols$1)\n    for (var prop of __getOwnPropSymbols$1(b)) {\n      if (__propIsEnum$1.call(b, prop))\n        __defNormalProp$1(a, prop, b[prop]);\n    }\n  return a;\n};\nfunction useTimestamp(options = {}) {\n  const {\n    controls: exposeControls = false,\n    offset = 0,\n    immediate = true,\n    interval = \"requestAnimationFrame\",\n    callback\n  } = options;\n  const ts = ref(timestamp() + offset);\n  const update = () => ts.value = timestamp() + offset;\n  const cb = callback ? () => {\n    update();\n    callback(ts.value);\n  } : update;\n  const controls = interval === \"requestAnimationFrame\" ? useRafFn(cb, { immediate }) : useIntervalFn(cb, interval, { immediate });\n  if (exposeControls) {\n    return __spreadValues$1({\n      timestamp: ts\n    }, controls);\n  } else {\n    return ts;\n  }\n}\n\nfunction useTitle(newTitle = null, options = {}) {\n  var _a, _b;\n  const {\n    document = defaultDocument\n  } = options;\n  const title = resolveRef((_a = newTitle != null ? newTitle : document == null ? void 0 : document.title) != null ? _a : null);\n  const isReadonly = newTitle && isFunction(newTitle);\n  function format(t) {\n    if (!(\"titleTemplate\" in options))\n      return t;\n    const template = options.titleTemplate || \"%s\";\n    return isFunction(template) ? template(t) : unref(template).replace(/%s/g, t);\n  }\n  watch(title, (t, o) => {\n    if (t !== o && document)\n      document.title = format(isString(t) ? t : \"\");\n  }, { immediate: true });\n  if (options.observe && !options.titleTemplate && document && !isReadonly) {\n    useMutationObserver((_b = document.head) == null ? void 0 : _b.querySelector(\"title\"), () => {\n      if (document && document.title !== title.value)\n        title.value = format(document.title);\n    }, { childList: true });\n  }\n  return title;\n}\n\nvar __defProp = Object.defineProperty;\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __spreadValues = (a, b) => {\n  for (var prop in b || (b = {}))\n    if (__hasOwnProp.call(b, prop))\n      __defNormalProp(a, prop, b[prop]);\n  if (__getOwnPropSymbols)\n    for (var prop of __getOwnPropSymbols(b)) {\n      if (__propIsEnum.call(b, prop))\n        __defNormalProp(a, prop, b[prop]);\n    }\n  return a;\n};\nconst _TransitionPresets = {\n  easeInSine: [0.12, 0, 0.39, 0],\n  easeOutSine: [0.61, 1, 0.88, 1],\n  easeInOutSine: [0.37, 0, 0.63, 1],\n  easeInQuad: [0.11, 0, 0.5, 0],\n  easeOutQuad: [0.5, 1, 0.89, 1],\n  easeInOutQuad: [0.45, 0, 0.55, 1],\n  easeInCubic: [0.32, 0, 0.67, 0],\n  easeOutCubic: [0.33, 1, 0.68, 1],\n  easeInOutCubic: [0.65, 0, 0.35, 1],\n  easeInQuart: [0.5, 0, 0.75, 0],\n  easeOutQuart: [0.25, 1, 0.5, 1],\n  easeInOutQuart: [0.76, 0, 0.24, 1],\n  easeInQuint: [0.64, 0, 0.78, 0],\n  easeOutQuint: [0.22, 1, 0.36, 1],\n  easeInOutQuint: [0.83, 0, 0.17, 1],\n  easeInExpo: [0.7, 0, 0.84, 0],\n  easeOutExpo: [0.16, 1, 0.3, 1],\n  easeInOutExpo: [0.87, 0, 0.13, 1],\n  easeInCirc: [0.55, 0, 1, 0.45],\n  easeOutCirc: [0, 0.55, 0.45, 1],\n  easeInOutCirc: [0.85, 0, 0.15, 1],\n  easeInBack: [0.36, 0, 0.66, -0.56],\n  easeOutBack: [0.34, 1.56, 0.64, 1],\n  easeInOutBack: [0.68, -0.6, 0.32, 1.6]\n};\nconst TransitionPresets = __spreadValues({\n  linear: identity\n}, _TransitionPresets);\nfunction createEasingFunction([p0, p1, p2, p3]) {\n  const a = (a1, a2) => 1 - 3 * a2 + 3 * a1;\n  const b = (a1, a2) => 3 * a2 - 6 * a1;\n  const c = (a1) => 3 * a1;\n  const calcBezier = (t, a1, a2) => ((a(a1, a2) * t + b(a1, a2)) * t + c(a1)) * t;\n  const getSlope = (t, a1, a2) => 3 * a(a1, a2) * t * t + 2 * b(a1, a2) * t + c(a1);\n  const getTforX = (x) => {\n    let aGuessT = x;\n    for (let i = 0; i < 4; ++i) {\n      const currentSlope = getSlope(aGuessT, p0, p2);\n      if (currentSlope === 0)\n        return aGuessT;\n      const currentX = calcBezier(aGuessT, p0, p2) - x;\n      aGuessT -= currentX / currentSlope;\n    }\n    return aGuessT;\n  };\n  return (x) => p0 === p1 && p2 === p3 ? x : calcBezier(getTforX(x), p1, p3);\n}\nfunction useTransition(source, options = {}) {\n  const {\n    delay = 0,\n    disabled = false,\n    duration = 1e3,\n    onFinished = noop,\n    onStarted = noop,\n    transition = identity\n  } = options;\n  const currentTransition = computed(() => {\n    const t = unref(transition);\n    return isFunction(t) ? t : createEasingFunction(t);\n  });\n  const sourceValue = computed(() => {\n    const s = unref(source);\n    return isNumber(s) ? s : s.map(unref);\n  });\n  const sourceVector = computed(() => isNumber(sourceValue.value) ? [sourceValue.value] : sourceValue.value);\n  const outputVector = ref(sourceVector.value.slice(0));\n  let currentDuration;\n  let diffVector;\n  let endAt;\n  let startAt;\n  let startVector;\n  const { resume, pause } = useRafFn(() => {\n    const now = Date.now();\n    const progress = clamp(1 - (endAt - now) / currentDuration, 0, 1);\n    outputVector.value = startVector.map((val, i) => {\n      var _a;\n      return val + ((_a = diffVector[i]) != null ? _a : 0) * currentTransition.value(progress);\n    });\n    if (progress >= 1) {\n      pause();\n      onFinished();\n    }\n  }, { immediate: false });\n  const start = () => {\n    pause();\n    currentDuration = unref(duration);\n    diffVector = outputVector.value.map((n, i) => {\n      var _a, _b;\n      return ((_a = sourceVector.value[i]) != null ? _a : 0) - ((_b = outputVector.value[i]) != null ? _b : 0);\n    });\n    startVector = outputVector.value.slice(0);\n    startAt = Date.now();\n    endAt = startAt + currentDuration;\n    resume();\n    onStarted();\n  };\n  const timeout = useTimeoutFn(start, delay, { immediate: false });\n  watch(sourceVector, () => {\n    if (unref(disabled))\n      return;\n    if (unref(delay) <= 0)\n      start();\n    else\n      timeout.start();\n  }, { deep: true });\n  watch(() => unref(disabled), (v) => {\n    if (v) {\n      outputVector.value = sourceVector.value.slice(0);\n      pause();\n    }\n  });\n  return computed(() => {\n    const targetVector = unref(disabled) ? sourceVector : outputVector;\n    return isNumber(sourceValue.value) ? targetVector.value[0] : targetVector.value;\n  });\n}\n\nfunction useUrlSearchParams(mode = \"history\", options = {}) {\n  const {\n    initialValue = {},\n    removeNullishValues = true,\n    removeFalsyValues = false,\n    write: enableWrite = true,\n    window = defaultWindow\n  } = options;\n  if (!window)\n    return reactive(initialValue);\n  const state = reactive({});\n  function getRawParams() {\n    if (mode === \"history\") {\n      return window.location.search || \"\";\n    } else if (mode === \"hash\") {\n      const hash = window.location.hash || \"\";\n      const index = hash.indexOf(\"?\");\n      return index > 0 ? hash.slice(index) : \"\";\n    } else {\n      return (window.location.hash || \"\").replace(/^#/, \"\");\n    }\n  }\n  function constructQuery(params) {\n    const stringified = params.toString();\n    if (mode === \"history\")\n      return `${stringified ? `?${stringified}` : \"\"}${window.location.hash || \"\"}`;\n    if (mode === \"hash-params\")\n      return `${window.location.search || \"\"}${stringified ? `#${stringified}` : \"\"}`;\n    const hash = window.location.hash || \"#\";\n    const index = hash.indexOf(\"?\");\n    if (index > 0)\n      return `${hash.slice(0, index)}${stringified ? `?${stringified}` : \"\"}`;\n    return `${hash}${stringified ? `?${stringified}` : \"\"}`;\n  }\n  function read() {\n    return new URLSearchParams(getRawParams());\n  }\n  function updateState(params) {\n    const unusedKeys = new Set(Object.keys(state));\n    for (const key of params.keys()) {\n      const paramsForKey = params.getAll(key);\n      state[key] = paramsForKey.length > 1 ? paramsForKey : params.get(key) || \"\";\n      unusedKeys.delete(key);\n    }\n    Array.from(unusedKeys).forEach((key) => delete state[key]);\n  }\n  const { pause, resume } = pausableWatch(state, () => {\n    const params = new URLSearchParams(\"\");\n    Object.keys(state).forEach((key) => {\n      const mapEntry = state[key];\n      if (Array.isArray(mapEntry))\n        mapEntry.forEach((value) => params.append(key, value));\n      else if (removeNullishValues && mapEntry == null)\n        params.delete(key);\n      else if (removeFalsyValues && !mapEntry)\n        params.delete(key);\n      else\n        params.set(key, mapEntry);\n    });\n    write(params);\n  }, { deep: true });\n  function write(params, shouldUpdate) {\n    pause();\n    if (shouldUpdate)\n      updateState(params);\n    window.history.replaceState(window.history.state, window.document.title, window.location.pathname + constructQuery(params));\n    resume();\n  }\n  function onChanged() {\n    if (!enableWrite)\n      return;\n    write(read(), true);\n  }\n  useEventListener(window, \"popstate\", onChanged, false);\n  if (mode !== \"history\")\n    useEventListener(window, \"hashchange\", onChanged, false);\n  const initial = read();\n  if (initial.keys().next().value)\n    updateState(initial);\n  else\n    Object.assign(state, initialValue);\n  return state;\n}\n\nfunction useUserMedia(options = {}) {\n  var _a, _b;\n  const enabled = ref((_a = options.enabled) != null ? _a : false);\n  const autoSwitch = ref((_b = options.autoSwitch) != null ? _b : true);\n  const videoDeviceId = ref(options.videoDeviceId);\n  const audioDeviceId = ref(options.audioDeviceId);\n  const { navigator = defaultNavigator } = options;\n  const isSupported = useSupported(() => {\n    var _a2;\n    return (_a2 = navigator == null ? void 0 : navigator.mediaDevices) == null ? void 0 : _a2.getUserMedia;\n  });\n  const stream = shallowRef();\n  function getDeviceOptions(device) {\n    if (device.value === \"none\" || device.value === false)\n      return false;\n    if (device.value == null)\n      return true;\n    return {\n      deviceId: device.value\n    };\n  }\n  async function _start() {\n    if (!isSupported.value || stream.value)\n      return;\n    stream.value = await navigator.mediaDevices.getUserMedia({\n      video: getDeviceOptions(videoDeviceId),\n      audio: getDeviceOptions(audioDeviceId)\n    });\n    return stream.value;\n  }\n  async function _stop() {\n    var _a2;\n    (_a2 = stream.value) == null ? void 0 : _a2.getTracks().forEach((t) => t.stop());\n    stream.value = void 0;\n  }\n  function stop() {\n    _stop();\n    enabled.value = false;\n  }\n  async function start() {\n    await _start();\n    if (stream.value)\n      enabled.value = true;\n    return stream.value;\n  }\n  async function restart() {\n    _stop();\n    return await start();\n  }\n  watch(enabled, (v) => {\n    if (v)\n      _start();\n    else\n      _stop();\n  }, { immediate: true });\n  watch([videoDeviceId, audioDeviceId], () => {\n    if (autoSwitch.value && stream.value)\n      restart();\n  }, { immediate: true });\n  return {\n    isSupported,\n    stream,\n    start,\n    stop,\n    restart,\n    videoDeviceId,\n    audioDeviceId,\n    enabled,\n    autoSwitch\n  };\n}\n\nfunction useVModel(props, key, emit, options = {}) {\n  var _a, _b, _c, _d, _e;\n  const {\n    clone = false,\n    passive = false,\n    eventName,\n    deep = false,\n    defaultValue\n  } = options;\n  const vm = getCurrentInstance();\n  const _emit = emit || (vm == null ? void 0 : vm.emit) || ((_a = vm == null ? void 0 : vm.$emit) == null ? void 0 : _a.bind(vm)) || ((_c = (_b = vm == null ? void 0 : vm.proxy) == null ? void 0 : _b.$emit) == null ? void 0 : _c.bind(vm == null ? void 0 : vm.proxy));\n  let event = eventName;\n  if (!key) {\n    if (isVue2) {\n      const modelOptions = (_e = (_d = vm == null ? void 0 : vm.proxy) == null ? void 0 : _d.$options) == null ? void 0 : _e.model;\n      key = (modelOptions == null ? void 0 : modelOptions.value) || \"value\";\n      if (!eventName)\n        event = (modelOptions == null ? void 0 : modelOptions.event) || \"input\";\n    } else {\n      key = \"modelValue\";\n    }\n  }\n  event = eventName || event || `update:${key.toString()}`;\n  const cloneFn = (val) => !clone ? val : isFunction(clone) ? clone(val) : cloneFnJSON(val);\n  const getValue = () => isDef(props[key]) ? cloneFn(props[key]) : defaultValue;\n  if (passive) {\n    const initialValue = getValue();\n    const proxy = ref(initialValue);\n    watch(() => props[key], (v) => proxy.value = cloneFn(v));\n    watch(proxy, (v) => {\n      if (v !== props[key] || deep)\n        _emit(event, v);\n    }, { deep });\n    return proxy;\n  } else {\n    return computed({\n      get() {\n        return getValue();\n      },\n      set(value) {\n        _emit(event, value);\n      }\n    });\n  }\n}\n\nfunction useVModels(props, emit, options = {}) {\n  const ret = {};\n  for (const key in props)\n    ret[key] = useVModel(props, key, emit, options);\n  return ret;\n}\n\nfunction useVibrate(options) {\n  const {\n    pattern = [],\n    interval = 0,\n    navigator = defaultNavigator\n  } = options || {};\n  const isSupported = useSupported(() => typeof navigator !== \"undefined\" && \"vibrate\" in navigator);\n  const patternRef = resolveRef(pattern);\n  let intervalControls;\n  const vibrate = (pattern2 = patternRef.value) => {\n    if (isSupported.value)\n      navigator.vibrate(pattern2);\n  };\n  const stop = () => {\n    if (isSupported.value)\n      navigator.vibrate(0);\n    intervalControls == null ? void 0 : intervalControls.pause();\n  };\n  if (interval > 0) {\n    intervalControls = useIntervalFn(vibrate, interval, {\n      immediate: false,\n      immediateCallback: false\n    });\n  }\n  return {\n    isSupported,\n    pattern,\n    intervalControls,\n    vibrate,\n    stop\n  };\n}\n\nfunction useVirtualList(list, options) {\n  const { containerStyle, wrapperProps, scrollTo, calculateRange, currentList, containerRef } = \"itemHeight\" in options ? useVerticalVirtualList(options, list) : useHorizontalVirtualList(options, list);\n  return {\n    list: currentList,\n    scrollTo,\n    containerProps: {\n      ref: containerRef,\n      onScroll: () => {\n        calculateRange();\n      },\n      style: containerStyle\n    },\n    wrapperProps\n  };\n}\nfunction useVirtualListResources(list) {\n  const containerRef = ref(null);\n  const size = useElementSize(containerRef);\n  const currentList = ref([]);\n  const source = shallowRef(list);\n  const state = ref({ start: 0, end: 10 });\n  return { state, source, currentList, size, containerRef };\n}\nfunction createGetViewCapacity(state, source, itemSize) {\n  return (containerSize) => {\n    if (typeof itemSize === \"number\")\n      return Math.ceil(containerSize / itemSize);\n    const { start = 0 } = state.value;\n    let sum = 0;\n    let capacity = 0;\n    for (let i = start; i < source.value.length; i++) {\n      const size = itemSize(i);\n      sum += size;\n      capacity = i;\n      if (sum > containerSize)\n        break;\n    }\n    return capacity - start;\n  };\n}\nfunction createGetOffset(source, itemSize) {\n  return (scrollDirection) => {\n    if (typeof itemSize === \"number\")\n      return Math.floor(scrollDirection / itemSize) + 1;\n    let sum = 0;\n    let offset = 0;\n    for (let i = 0; i < source.value.length; i++) {\n      const size = itemSize(i);\n      sum += size;\n      if (sum >= scrollDirection) {\n        offset = i;\n        break;\n      }\n    }\n    return offset + 1;\n  };\n}\nfunction createCalculateRange(type, overscan, getOffset, getViewCapacity, { containerRef, state, currentList, source }) {\n  return () => {\n    const element = containerRef.value;\n    if (element) {\n      const offset = getOffset(type === \"vertical\" ? element.scrollTop : element.scrollLeft);\n      const viewCapacity = getViewCapacity(type === \"vertical\" ? element.clientHeight : element.clientWidth);\n      const from = offset - overscan;\n      const to = offset + viewCapacity + overscan;\n      state.value = {\n        start: from < 0 ? 0 : from,\n        end: to > source.value.length ? source.value.length : to\n      };\n      currentList.value = source.value.slice(state.value.start, state.value.end).map((ele, index) => ({\n        data: ele,\n        index: index + state.value.start\n      }));\n    }\n  };\n}\nfunction createGetDistance(itemSize, source) {\n  return (index) => {\n    if (typeof itemSize === \"number\") {\n      const size2 = index * itemSize;\n      return size2;\n    }\n    const size = source.value.slice(0, index).reduce((sum, _, i) => sum + itemSize(i), 0);\n    return size;\n  };\n}\nfunction useWatchForSizes(size, list, calculateRange) {\n  watch([size.width, size.height, list], () => {\n    calculateRange();\n  });\n}\nfunction createComputedTotalSize(itemSize, source) {\n  return computed(() => {\n    if (typeof itemSize === \"number\")\n      return source.value.length * itemSize;\n    return source.value.reduce((sum, _, index) => sum + itemSize(index), 0);\n  });\n}\nconst scrollToDictionaryForElementScrollKey = {\n  horizontal: \"scrollLeft\",\n  vertical: \"scrollTop\"\n};\nfunction createScrollTo(type, calculateRange, getDistance, containerRef) {\n  return (index) => {\n    if (containerRef.value) {\n      containerRef.value[scrollToDictionaryForElementScrollKey[type]] = getDistance(index);\n      calculateRange();\n    }\n  };\n}\nfunction useHorizontalVirtualList(options, list) {\n  const resources = useVirtualListResources(list);\n  const { state, source, currentList, size, containerRef } = resources;\n  const containerStyle = { overflowX: \"auto\" };\n  const { itemWidth, overscan = 5 } = options;\n  const getViewCapacity = createGetViewCapacity(state, source, itemWidth);\n  const getOffset = createGetOffset(source, itemWidth);\n  const calculateRange = createCalculateRange(\"horizontal\", overscan, getOffset, getViewCapacity, resources);\n  const getDistanceLeft = createGetDistance(itemWidth, source);\n  const offsetLeft = computed(() => getDistanceLeft(state.value.start));\n  const totalWidth = createComputedTotalSize(itemWidth, source);\n  useWatchForSizes(size, list, calculateRange);\n  const scrollTo = createScrollTo(\"horizontal\", calculateRange, getDistanceLeft, containerRef);\n  const wrapperProps = computed(() => {\n    return {\n      style: {\n        height: \"100%\",\n        width: `${totalWidth.value - offsetLeft.value}px`,\n        marginLeft: `${offsetLeft.value}px`,\n        display: \"flex\"\n      }\n    };\n  });\n  return {\n    scrollTo,\n    calculateRange,\n    wrapperProps,\n    containerStyle,\n    currentList,\n    containerRef\n  };\n}\nfunction useVerticalVirtualList(options, list) {\n  const resources = useVirtualListResources(list);\n  const { state, source, currentList, size, containerRef } = resources;\n  const containerStyle = { overflowY: \"auto\" };\n  const { itemHeight, overscan = 5 } = options;\n  const getViewCapacity = createGetViewCapacity(state, source, itemHeight);\n  const getOffset = createGetOffset(source, itemHeight);\n  const calculateRange = createCalculateRange(\"vertical\", overscan, getOffset, getViewCapacity, resources);\n  const getDistanceTop = createGetDistance(itemHeight, source);\n  const offsetTop = computed(() => getDistanceTop(state.value.start));\n  const totalHeight = createComputedTotalSize(itemHeight, source);\n  useWatchForSizes(size, list, calculateRange);\n  const scrollTo = createScrollTo(\"vertical\", calculateRange, getDistanceTop, containerRef);\n  const wrapperProps = computed(() => {\n    return {\n      style: {\n        width: \"100%\",\n        height: `${totalHeight.value - offsetTop.value}px`,\n        marginTop: `${offsetTop.value}px`\n      }\n    };\n  });\n  return {\n    calculateRange,\n    scrollTo,\n    containerStyle,\n    wrapperProps,\n    currentList,\n    containerRef\n  };\n}\n\nconst useWakeLock = (options = {}) => {\n  const {\n    navigator = defaultNavigator,\n    document = defaultDocument\n  } = options;\n  let wakeLock;\n  const isSupported = useSupported(() => navigator && \"wakeLock\" in navigator);\n  const isActive = ref(false);\n  async function onVisibilityChange() {\n    if (!isSupported.value || !wakeLock)\n      return;\n    if (document && document.visibilityState === \"visible\")\n      wakeLock = await navigator.wakeLock.request(\"screen\");\n    isActive.value = !wakeLock.released;\n  }\n  if (document)\n    useEventListener(document, \"visibilitychange\", onVisibilityChange, { passive: true });\n  async function request(type) {\n    if (!isSupported.value)\n      return;\n    wakeLock = await navigator.wakeLock.request(type);\n    isActive.value = !wakeLock.released;\n  }\n  async function release() {\n    if (!isSupported.value || !wakeLock)\n      return;\n    await wakeLock.release();\n    isActive.value = !wakeLock.released;\n    wakeLock = null;\n  }\n  return {\n    isSupported,\n    isActive,\n    request,\n    release\n  };\n};\n\nconst useWebNotification = (defaultOptions = {}) => {\n  const {\n    window = defaultWindow\n  } = defaultOptions;\n  const isSupported = useSupported(() => !!window && \"Notification\" in window);\n  const notification = ref(null);\n  const requestPermission = async () => {\n    if (!isSupported.value)\n      return;\n    if (\"permission\" in Notification && Notification.permission !== \"denied\")\n      await Notification.requestPermission();\n  };\n  const onClick = createEventHook();\n  const onShow = createEventHook();\n  const onError = createEventHook();\n  const onClose = createEventHook();\n  const show = async (overrides) => {\n    if (!isSupported.value)\n      return;\n    await requestPermission();\n    const options = Object.assign({}, defaultOptions, overrides);\n    notification.value = new Notification(options.title || \"\", options);\n    notification.value.onclick = (event) => onClick.trigger(event);\n    notification.value.onshow = (event) => onShow.trigger(event);\n    notification.value.onerror = (event) => onError.trigger(event);\n    notification.value.onclose = (event) => onClose.trigger(event);\n    return notification.value;\n  };\n  const close = () => {\n    if (notification.value)\n      notification.value.close();\n    notification.value = null;\n  };\n  tryOnMounted(async () => {\n    if (isSupported.value)\n      await requestPermission();\n  });\n  tryOnScopeDispose(close);\n  if (isSupported.value && window) {\n    const document = window.document;\n    useEventListener(document, \"visibilitychange\", (e) => {\n      e.preventDefault();\n      if (document.visibilityState === \"visible\") {\n        close();\n      }\n    });\n  }\n  return {\n    isSupported,\n    notification,\n    show,\n    close,\n    onClick,\n    onShow,\n    onError,\n    onClose\n  };\n};\n\nconst DEFAULT_PING_MESSAGE = \"ping\";\nfunction resolveNestedOptions(options) {\n  if (options === true)\n    return {};\n  return options;\n}\nfunction useWebSocket(url, options = {}) {\n  const {\n    onConnected,\n    onDisconnected,\n    onError,\n    onMessage,\n    immediate = true,\n    autoClose = true,\n    protocols = []\n  } = options;\n  const data = ref(null);\n  const status = ref(\"CLOSED\");\n  const wsRef = ref();\n  const urlRef = resolveRef(url);\n  let heartbeatPause;\n  let heartbeatResume;\n  let explicitlyClosed = false;\n  let retried = 0;\n  let bufferedData = [];\n  let pongTimeoutWait;\n  const close = (code = 1e3, reason) => {\n    if (!wsRef.value)\n      return;\n    explicitlyClosed = true;\n    heartbeatPause == null ? void 0 : heartbeatPause();\n    wsRef.value.close(code, reason);\n  };\n  const _sendBuffer = () => {\n    if (bufferedData.length && wsRef.value && status.value === \"OPEN\") {\n      for (const buffer of bufferedData)\n        wsRef.value.send(buffer);\n      bufferedData = [];\n    }\n  };\n  const resetHeartbeat = () => {\n    clearTimeout(pongTimeoutWait);\n    pongTimeoutWait = void 0;\n  };\n  const send = (data2, useBuffer = true) => {\n    if (!wsRef.value || status.value !== \"OPEN\") {\n      if (useBuffer)\n        bufferedData.push(data2);\n      return false;\n    }\n    _sendBuffer();\n    wsRef.value.send(data2);\n    return true;\n  };\n  const _init = () => {\n    if (explicitlyClosed || typeof urlRef.value === \"undefined\")\n      return;\n    const ws = new WebSocket(urlRef.value, protocols);\n    wsRef.value = ws;\n    status.value = \"CONNECTING\";\n    ws.onopen = () => {\n      status.value = \"OPEN\";\n      onConnected == null ? void 0 : onConnected(ws);\n      heartbeatResume == null ? void 0 : heartbeatResume();\n      _sendBuffer();\n    };\n    ws.onclose = (ev) => {\n      status.value = \"CLOSED\";\n      wsRef.value = void 0;\n      onDisconnected == null ? void 0 : onDisconnected(ws, ev);\n      if (!explicitlyClosed && options.autoReconnect) {\n        const {\n          retries = -1,\n          delay = 1e3,\n          onFailed\n        } = resolveNestedOptions(options.autoReconnect);\n        retried += 1;\n        if (typeof retries === \"number\" && (retries < 0 || retried < retries))\n          setTimeout(_init, delay);\n        else if (typeof retries === \"function\" && retries())\n          setTimeout(_init, delay);\n        else\n          onFailed == null ? void 0 : onFailed();\n      }\n    };\n    ws.onerror = (e) => {\n      onError == null ? void 0 : onError(ws, e);\n    };\n    ws.onmessage = (e) => {\n      if (options.heartbeat) {\n        resetHeartbeat();\n        const {\n          message = DEFAULT_PING_MESSAGE\n        } = resolveNestedOptions(options.heartbeat);\n        if (e.data === message)\n          return;\n      }\n      data.value = e.data;\n      onMessage == null ? void 0 : onMessage(ws, e);\n    };\n  };\n  if (options.heartbeat) {\n    const {\n      message = DEFAULT_PING_MESSAGE,\n      interval = 1e3,\n      pongTimeout = 1e3\n    } = resolveNestedOptions(options.heartbeat);\n    const { pause, resume } = useIntervalFn(() => {\n      send(message, false);\n      if (pongTimeoutWait != null)\n        return;\n      pongTimeoutWait = setTimeout(() => {\n        close();\n      }, pongTimeout);\n    }, interval, { immediate: false });\n    heartbeatPause = pause;\n    heartbeatResume = resume;\n  }\n  if (autoClose) {\n    useEventListener(window, \"beforeunload\", () => close());\n    tryOnScopeDispose(close);\n  }\n  const open = () => {\n    close();\n    explicitlyClosed = false;\n    retried = 0;\n    _init();\n  };\n  if (immediate)\n    watch(urlRef, open, { immediate: true });\n  return {\n    data,\n    status,\n    close,\n    send,\n    open,\n    ws: wsRef\n  };\n}\n\nfunction useWebWorker(arg0, workerOptions, options) {\n  const {\n    window = defaultWindow\n  } = options != null ? options : {};\n  const data = ref(null);\n  const worker = shallowRef();\n  const post = function post2(val) {\n    if (!worker.value)\n      return;\n    worker.value.postMessage(val);\n  };\n  const terminate = function terminate2() {\n    if (!worker.value)\n      return;\n    worker.value.terminate();\n  };\n  if (window) {\n    if (isString(arg0))\n      worker.value = new Worker(arg0, workerOptions);\n    else if (isFunction(arg0))\n      worker.value = arg0();\n    else\n      worker.value = arg0;\n    worker.value.onmessage = (e) => {\n      data.value = e.data;\n    };\n    tryOnScopeDispose(() => {\n      if (worker.value)\n        worker.value.terminate();\n    });\n  }\n  return {\n    data,\n    post,\n    terminate,\n    worker\n  };\n}\n\nconst jobRunner = (userFunc) => (e) => {\n  const userFuncArgs = e.data[0];\n  return Promise.resolve(userFunc.apply(void 0, userFuncArgs)).then((result) => {\n    postMessage([\"SUCCESS\", result]);\n  }).catch((error) => {\n    postMessage([\"ERROR\", error]);\n  });\n};\n\nconst depsParser = (deps) => {\n  if (deps.length === 0)\n    return \"\";\n  const depsString = deps.map((dep) => `'${dep}'`).toString();\n  return `importScripts(${depsString})`;\n};\n\nconst createWorkerBlobUrl = (fn, deps) => {\n  const blobCode = `${depsParser(deps)}; onmessage=(${jobRunner})(${fn})`;\n  const blob = new Blob([blobCode], { type: \"text/javascript\" });\n  const url = URL.createObjectURL(blob);\n  return url;\n};\n\nconst useWebWorkerFn = (fn, options = {}) => {\n  const {\n    dependencies = [],\n    timeout,\n    window = defaultWindow\n  } = options;\n  const worker = ref();\n  const workerStatus = ref(\"PENDING\");\n  const promise = ref({});\n  const timeoutId = ref();\n  const workerTerminate = (status = \"PENDING\") => {\n    if (worker.value && worker.value._url && window) {\n      worker.value.terminate();\n      URL.revokeObjectURL(worker.value._url);\n      promise.value = {};\n      worker.value = void 0;\n      window.clearTimeout(timeoutId.value);\n      workerStatus.value = status;\n    }\n  };\n  workerTerminate();\n  tryOnScopeDispose(workerTerminate);\n  const generateWorker = () => {\n    const blobUrl = createWorkerBlobUrl(fn, dependencies);\n    const newWorker = new Worker(blobUrl);\n    newWorker._url = blobUrl;\n    newWorker.onmessage = (e) => {\n      const { resolve = () => {\n      }, reject = () => {\n      } } = promise.value;\n      const [status, result] = e.data;\n      switch (status) {\n        case \"SUCCESS\":\n          resolve(result);\n          workerTerminate(status);\n          break;\n        default:\n          reject(result);\n          workerTerminate(\"ERROR\");\n          break;\n      }\n    };\n    newWorker.onerror = (e) => {\n      const { reject = () => {\n      } } = promise.value;\n      reject(e);\n      workerTerminate(\"ERROR\");\n    };\n    if (timeout) {\n      timeoutId.value = setTimeout(() => workerTerminate(\"TIMEOUT_EXPIRED\"), timeout);\n    }\n    return newWorker;\n  };\n  const callWorker = (...fnArgs) => new Promise((resolve, reject) => {\n    promise.value = {\n      resolve,\n      reject\n    };\n    worker.value && worker.value.postMessage([[...fnArgs]]);\n    workerStatus.value = \"RUNNING\";\n  });\n  const workerFn = (...fnArgs) => {\n    if (workerStatus.value === \"RUNNING\") {\n      console.error(\"[useWebWorkerFn] You can only run one instance of the worker at a time.\");\n      return Promise.reject();\n    }\n    worker.value = generateWorker();\n    return callWorker(...fnArgs);\n  };\n  return {\n    workerFn,\n    workerStatus,\n    workerTerminate\n  };\n};\n\nfunction useWindowFocus({ window = defaultWindow } = {}) {\n  if (!window)\n    return ref(false);\n  const focused = ref(window.document.hasFocus());\n  useEventListener(window, \"blur\", () => {\n    focused.value = false;\n  });\n  useEventListener(window, \"focus\", () => {\n    focused.value = true;\n  });\n  return focused;\n}\n\nfunction useWindowScroll({ window = defaultWindow } = {}) {\n  if (!window) {\n    return {\n      x: ref(0),\n      y: ref(0)\n    };\n  }\n  const x = ref(window.scrollX);\n  const y = ref(window.scrollY);\n  useEventListener(window, \"scroll\", () => {\n    x.value = window.scrollX;\n    y.value = window.scrollY;\n  }, {\n    capture: false,\n    passive: true\n  });\n  return { x, y };\n}\n\nfunction useWindowSize(options = {}) {\n  const {\n    window = defaultWindow,\n    initialWidth = Infinity,\n    initialHeight = Infinity,\n    listenOrientation = true,\n    includeScrollbar = true\n  } = options;\n  const width = ref(initialWidth);\n  const height = ref(initialHeight);\n  const update = () => {\n    if (window) {\n      if (includeScrollbar) {\n        width.value = window.innerWidth;\n        height.value = window.innerHeight;\n      } else {\n        width.value = window.document.documentElement.clientWidth;\n        height.value = window.document.documentElement.clientHeight;\n      }\n    }\n  };\n  update();\n  tryOnMounted(update);\n  useEventListener(\"resize\", update, { passive: true });\n  if (listenOrientation)\n    useEventListener(\"orientationchange\", update, { passive: true });\n  return { width, height };\n}\n\nexport { DefaultMagicKeysAliasMap, StorageSerializers, SwipeDirection, TransitionPresets, computedAsync as asyncComputed, breakpointsAntDesign, breakpointsBootstrapV5, breakpointsMasterCss, breakpointsQuasar, breakpointsSematic, breakpointsTailwind, breakpointsVuetify, cloneFnJSON, computedAsync, computedInject, createFetch, createUnrefFn, customStorageEventName, defaultDocument, defaultLocation, defaultNavigator, defaultWindow, formatTimeAgo, getSSRHandler, mapGamepadToXbox360Controller, onClickOutside, onKeyDown, onKeyPressed, onKeyStroke, onKeyUp, onLongPress, onStartTyping, setSSRHandler, templateRef, unrefElement, useActiveElement, useAsyncQueue, useAsyncState, useBase64, useBattery, useBluetooth, useBreakpoints, useBroadcastChannel, useBrowserLocation, useCached, useClipboard, useCloned, useColorMode, useConfirmDialog, useCssVar, useCurrentElement, useCycleList, useDark, useDebouncedRefHistory, useDeviceMotion, useDeviceOrientation, useDevicePixelRatio, useDevicesList, useDisplayMedia, useDocumentVisibility, useDraggable, useDropZone, useElementBounding, useElementByPoint, useElementHover, useElementSize, useElementVisibility, useEventBus, useEventListener, useEventSource, useEyeDropper, useFavicon, useFetch, useFileDialog, useFileSystemAccess, useFocus, useFocusWithin, useFps, useFullscreen, useGamepad, useGeolocation, useIdle, useImage, useInfiniteScroll, useIntersectionObserver, useKeyModifier, useLocalStorage, useMagicKeys, useManualRefHistory, useMediaControls, useMediaQuery, useMemoize, useMemory, useMounted, useMouse, useMouseInElement, useMousePressed, useMutationObserver, useNavigatorLanguage, useNetwork, useNow, useObjectUrl, useOffsetPagination, useOnline, usePageLeave, useParallax, usePermission, usePointer, usePointerLock, usePointerSwipe, usePreferredColorScheme, usePreferredContrast, usePreferredDark, usePreferredLanguages, usePreferredReducedMotion, usePrevious, useRafFn, useRefHistory, useResizeObserver, useScreenOrientation, useScreenSafeArea, useScriptTag, useScroll, useScrollLock, useSessionStorage, useShare, useSorted, useSpeechRecognition, useSpeechSynthesis, useStepper, useStorage, useStorageAsync, useStyleTag, useSupported, useSwipe, useTemplateRefsList, useTextDirection, useTextSelection, useTextareaAutosize, useThrottledRefHistory, useTimeAgo, useTimeoutPoll, useTimestamp, useTitle, useTransition, useUrlSearchParams, useUserMedia, useVModel, useVModels, useVibrate, useVirtualList, useWakeLock, useWebNotification, useWebSocket, useWebWorker, useWebWorkerFn, useWindowFocus, useWindowScroll, useWindowSize };\n", "import { isClient, isIOS } from '@vueuse/core'\n\nexport const isFirefox = (): boolean =>\n  isClient && /firefox/i.test(window.navigator.userAgent)\n\nexport { isClient, isIOS }\n", "import { isClient } from '../browser'\n\nexport const isInContainer = (\n  el?: Element,\n  container?: Element | Window\n): boolean => {\n  if (!isClient || !el || !container) return false\n\n  const elRect = el.getBoundingClientRect()\n\n  let containerRect: Pick<DOMRect, 'top' | 'bottom' | 'left' | 'right'>\n  if (container instanceof Element) {\n    containerRect = container.getBoundingClientRect()\n  } else {\n    containerRect = {\n      top: 0,\n      right: window.innerWidth,\n      bottom: window.innerHeight,\n      left: 0,\n    }\n  }\n  return (\n    elRect.top < containerRect.bottom &&\n    elRect.bottom > containerRect.top &&\n    elRect.right > containerRect.left &&\n    elRect.left < containerRect.right\n  )\n}\n\nexport const getOffsetTop = (el: HTMLElement) => {\n  let offset = 0\n  let parent = el\n\n  while (parent) {\n    offset += parent.offsetTop\n    parent = parent.offsetParent as HTMLElement\n  }\n\n  return offset\n}\n\nexport const getOffsetTopDistance = (\n  el: HTMLElement,\n  containerEl: HTMLElement\n) => {\n  return Math.abs(getOffsetTop(el) - getOffsetTop(containerEl))\n}\n\nexport const getClientXY = (event: MouseEvent | TouchEvent) => {\n  let clientX: number\n  let clientY: number\n  if (event.type === 'touchend') {\n    clientY = (event as TouchEvent).changedTouches[0].clientY\n    clientX = (event as TouchEvent).changedTouches[0].clientX\n  } else if (event.type.startsWith('touch')) {\n    clientY = (event as TouchEvent).touches[0].clientY\n    clientX = (event as TouchEvent).touches[0].clientX\n  } else {\n    clientY = (event as MouseEvent).clientY\n    clientX = (event as MouseEvent).clientX\n  }\n  return {\n    clientX,\n    clientY,\n  }\n}\n", "export function easeInOutCubic(t: number, b: number, c: number, d: number) {\n  const cc = c - b\n  t /= d / 2\n  if (t < 1) {\n    return (cc / 2) * t * t * t + b\n  }\n  return (cc / 2) * ((t -= 2) * t * t + 2) + b\n}\n", "/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nexport default freeGlobal;\n", "import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nexport default root;\n", "import root from './_root.js';\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nexport default Symbol;\n", "import Symbol from './_Symbol.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n  var isOwn = hasOwnProperty.call(value, symToStringTag),\n      tag = value[symToStringTag];\n\n  try {\n    value[symToStringTag] = undefined;\n    var unmasked = true;\n  } catch (e) {}\n\n  var result = nativeObjectToString.call(value);\n  if (unmasked) {\n    if (isOwn) {\n      value[symToStringTag] = tag;\n    } else {\n      delete value[symToStringTag];\n    }\n  }\n  return result;\n}\n\nexport default getRawTag;\n", "/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n  return nativeObjectToString.call(value);\n}\n\nexport default objectToString;\n", "import Symbol from './_Symbol.js';\nimport getRawTag from './_getRawTag.js';\nimport objectToString from './_objectToString.js';\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n    undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n  if (value == null) {\n    return value === undefined ? undefinedTag : nullTag;\n  }\n  return (symToStringTag && symToStringTag in Object(value))\n    ? getRawTag(value)\n    : objectToString(value);\n}\n\nexport default baseGetTag;\n", "/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n  return value != null && typeof value == 'object';\n}\n\nexport default isObjectLike;\n", "import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n  return typeof value == 'symbol' ||\n    (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nexport default isSymbol;\n", "import isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/**\n * The base implementation of `_.toNumber` which doesn't ensure correct\n * conversions of binary, hexadecimal, or octal string values.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n */\nfunction baseToNumber(value) {\n  if (typeof value == 'number') {\n    return value;\n  }\n  if (isSymbol(value)) {\n    return NAN;\n  }\n  return +value;\n}\n\nexport default baseToNumber;\n", "/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n  var index = -1,\n      length = array == null ? 0 : array.length,\n      result = Array(length);\n\n  while (++index < length) {\n    result[index] = iteratee(array[index], index, array);\n  }\n  return result;\n}\n\nexport default arrayMap;\n", "/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nexport default isArray;\n", "import Symbol from './_Symbol.js';\nimport arrayMap from './_arrayMap.js';\nimport isArray from './isArray.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n  // Exit early for strings to avoid a performance hit in some environments.\n  if (typeof value == 'string') {\n    return value;\n  }\n  if (isArray(value)) {\n    // Recursively convert values (susceptible to call stack limits).\n    return arrayMap(value, baseToString) + '';\n  }\n  if (isSymbol(value)) {\n    return symbolToString ? symbolToString.call(value) : '';\n  }\n  var result = (value + '');\n  return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nexport default baseToString;\n", "import baseToNumber from './_baseToNumber.js';\nimport baseToString from './_baseToString.js';\n\n/**\n * Creates a function that performs a mathematical operation on two values.\n *\n * @private\n * @param {Function} operator The function to perform the operation.\n * @param {number} [defaultValue] The value used for `undefined` arguments.\n * @returns {Function} Returns the new mathematical operation function.\n */\nfunction createMathOperation(operator, defaultValue) {\n  return function(value, other) {\n    var result;\n    if (value === undefined && other === undefined) {\n      return defaultValue;\n    }\n    if (value !== undefined) {\n      result = value;\n    }\n    if (other !== undefined) {\n      if (result === undefined) {\n        return other;\n      }\n      if (typeof value == 'string' || typeof other == 'string') {\n        value = baseToString(value);\n        other = baseToString(other);\n      } else {\n        value = baseToNumber(value);\n        other = baseToNumber(other);\n      }\n      result = operator(value, other);\n    }\n    return result;\n  };\n}\n\nexport default createMathOperation;\n", "import createMathOperation from './_createMathOperation.js';\n\n/**\n * Adds two numbers.\n *\n * @static\n * @memberOf _\n * @since 3.4.0\n * @category Math\n * @param {number} augend The first number in an addition.\n * @param {number} addend The second number in an addition.\n * @returns {number} Returns the total.\n * @example\n *\n * _.add(6, 4);\n * // => 10\n */\nvar add = createMathOperation(function(augend, addend) {\n  return augend + addend;\n}, 0);\n\nexport default add;\n", "/** Used to match a single whitespace character. */\nvar reWhitespace = /\\s/;\n\n/**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\nfunction trimmedEndIndex(string) {\n  var index = string.length;\n\n  while (index-- && reWhitespace.test(string.charAt(index))) {}\n  return index;\n}\n\nexport default trimmedEndIndex;\n", "import trimmedEndIndex from './_trimmedEndIndex.js';\n\n/** Used to match leading whitespace. */\nvar reTrimStart = /^\\s+/;\n\n/**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\nfunction baseTrim(string) {\n  return string\n    ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n    : string;\n}\n\nexport default baseTrim;\n", "/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n  var type = typeof value;\n  return value != null && (type == 'object' || type == 'function');\n}\n\nexport default isObject;\n", "import baseTrim from './_baseTrim.js';\nimport isObject from './isObject.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n  if (typeof value == 'number') {\n    return value;\n  }\n  if (isSymbol(value)) {\n    return NAN;\n  }\n  if (isObject(value)) {\n    var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n    value = isObject(other) ? (other + '') : other;\n  }\n  if (typeof value != 'string') {\n    return value === 0 ? value : +value;\n  }\n  value = baseTrim(value);\n  var isBinary = reIsBinary.test(value);\n  return (isBinary || reIsOctal.test(value))\n    ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n    : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nexport default toNumber;\n", "import toNumber from './toNumber.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n    MAX_INTEGER = 1.7976931348623157e+308;\n\n/**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\nfunction toFinite(value) {\n  if (!value) {\n    return value === 0 ? value : 0;\n  }\n  value = toNumber(value);\n  if (value === INFINITY || value === -INFINITY) {\n    var sign = (value < 0 ? -1 : 1);\n    return sign * MAX_INTEGER;\n  }\n  return value === value ? value : 0;\n}\n\nexport default toFinite;\n", "import toFinite from './toFinite.js';\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\nfunction toInteger(value) {\n  var result = toFinite(value),\n      remainder = result % 1;\n\n  return result === result ? (remainder ? result - remainder : result) : 0;\n}\n\nexport default toInteger;\n", "import toInteger from './toInteger.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * The opposite of `_.before`; this method creates a function that invokes\n * `func` once it's called `n` or more times.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {number} n The number of calls before `func` is invoked.\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * var saves = ['profile', 'settings'];\n *\n * var done = _.after(saves.length, function() {\n *   console.log('done saving!');\n * });\n *\n * _.forEach(saves, function(type) {\n *   asyncSave({ 'type': type, 'complete': done });\n * });\n * // => Logs 'done saving!' after the two async saves have completed.\n */\nfunction after(n, func) {\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  n = toInteger(n);\n  return function() {\n    if (--n < 1) {\n      return func.apply(this, arguments);\n    }\n  };\n}\n\nexport default after;\n", "/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n  return value;\n}\n\nexport default identity;\n", "import baseGetTag from './_baseGetTag.js';\nimport isObject from './isObject.js';\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n    funcTag = '[object Function]',\n    genTag = '[object GeneratorFunction]',\n    proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n  if (!isObject(value)) {\n    return false;\n  }\n  // The use of `Object#toString` avoids issues with the `typeof` operator\n  // in Safari 9 which returns 'object' for typed arrays and other constructors.\n  var tag = baseGetTag(value);\n  return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nexport default isFunction;\n", "import root from './_root.js';\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nexport default coreJsData;\n", "import coreJsData from './_coreJsData.js';\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n  var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n  return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n  return !!maskSrcKey && (maskSrcKey in func);\n}\n\nexport default isMasked;\n", "/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n  if (func != null) {\n    try {\n      return funcToString.call(func);\n    } catch (e) {}\n    try {\n      return (func + '');\n    } catch (e) {}\n  }\n  return '';\n}\n\nexport default toSource;\n", "import isFunction from './isFunction.js';\nimport isMasked from './_isMasked.js';\nimport isObject from './isObject.js';\nimport toSource from './_toSource.js';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n  funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n  .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n *  else `false`.\n */\nfunction baseIsNative(value) {\n  if (!isObject(value) || isMasked(value)) {\n    return false;\n  }\n  var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n  return pattern.test(toSource(value));\n}\n\nexport default baseIsNative;\n", "/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n  return object == null ? undefined : object[key];\n}\n\nexport default getValue;\n", "import baseIsNative from './_baseIsNative.js';\nimport getValue from './_getValue.js';\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n  var value = getValue(object, key);\n  return baseIsNative(value) ? value : undefined;\n}\n\nexport default getNative;\n", "import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nexport default WeakMap;\n", "import WeakMap from './_WeakMap.js';\n\n/** Used to store function metadata. */\nvar metaMap = WeakMap && new WeakMap;\n\nexport default metaMap;\n", "import identity from './identity.js';\nimport metaMap from './_metaMap.js';\n\n/**\n * The base implementation of `setData` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\nvar baseSetData = !metaMap ? identity : function(func, data) {\n  metaMap.set(func, data);\n  return func;\n};\n\nexport default baseSetData;\n", "import isObject from './isObject.js';\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n  function object() {}\n  return function(proto) {\n    if (!isObject(proto)) {\n      return {};\n    }\n    if (objectCreate) {\n      return objectCreate(proto);\n    }\n    object.prototype = proto;\n    var result = new object;\n    object.prototype = undefined;\n    return result;\n  };\n}());\n\nexport default baseCreate;\n", "import baseCreate from './_baseCreate.js';\nimport isObject from './isObject.js';\n\n/**\n * Creates a function that produces an instance of `Ctor` regardless of\n * whether it was invoked as part of a `new` expression or by `call` or `apply`.\n *\n * @private\n * @param {Function} Ctor The constructor to wrap.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createCtor(Ctor) {\n  return function() {\n    // Use a `switch` statement to work with class constructors. See\n    // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist\n    // for more details.\n    var args = arguments;\n    switch (args.length) {\n      case 0: return new Ctor;\n      case 1: return new Ctor(args[0]);\n      case 2: return new Ctor(args[0], args[1]);\n      case 3: return new Ctor(args[0], args[1], args[2]);\n      case 4: return new Ctor(args[0], args[1], args[2], args[3]);\n      case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]);\n      case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]);\n      case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]);\n    }\n    var thisBinding = baseCreate(Ctor.prototype),\n        result = Ctor.apply(thisBinding, args);\n\n    // Mimic the constructor's `return` behavior.\n    // See https://es5.github.io/#x13.2.2 for more details.\n    return isObject(result) ? result : thisBinding;\n  };\n}\n\nexport default createCtor;\n", "import createCtor from './_createCtor.js';\nimport root from './_root.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1;\n\n/**\n * Creates a function that wraps `func` to invoke it with the optional `this`\n * binding of `thisArg`.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createBind(func, bitmask, thisArg) {\n  var isBind = bitmask & WRAP_BIND_FLAG,\n      Ctor = createCtor(func);\n\n  function wrapper() {\n    var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n    return fn.apply(isBind ? thisArg : this, arguments);\n  }\n  return wrapper;\n}\n\nexport default createBind;\n", "/**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\nfunction apply(func, thisArg, args) {\n  switch (args.length) {\n    case 0: return func.call(thisArg);\n    case 1: return func.call(thisArg, args[0]);\n    case 2: return func.call(thisArg, args[0], args[1]);\n    case 3: return func.call(thisArg, args[0], args[1], args[2]);\n  }\n  return func.apply(thisArg, args);\n}\n\nexport default apply;\n", "/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates an array that is the composition of partially applied arguments,\n * placeholders, and provided arguments into a single array of arguments.\n *\n * @private\n * @param {Array} args The provided arguments.\n * @param {Array} partials The arguments to prepend to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @params {boolean} [isCurried] Specify composing for a curried function.\n * @returns {Array} Returns the new array of composed arguments.\n */\nfunction composeArgs(args, partials, holders, isCurried) {\n  var argsIndex = -1,\n      argsLength = args.length,\n      holdersLength = holders.length,\n      leftIndex = -1,\n      leftLength = partials.length,\n      rangeLength = nativeMax(argsLength - holdersLength, 0),\n      result = Array(leftLength + rangeLength),\n      isUncurried = !isCurried;\n\n  while (++leftIndex < leftLength) {\n    result[leftIndex] = partials[leftIndex];\n  }\n  while (++argsIndex < holdersLength) {\n    if (isUncurried || argsIndex < argsLength) {\n      result[holders[argsIndex]] = args[argsIndex];\n    }\n  }\n  while (rangeLength--) {\n    result[leftIndex++] = args[argsIndex++];\n  }\n  return result;\n}\n\nexport default composeArgs;\n", "/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * This function is like `composeArgs` except that the arguments composition\n * is tailored for `_.partialRight`.\n *\n * @private\n * @param {Array} args The provided arguments.\n * @param {Array} partials The arguments to append to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @params {boolean} [isCurried] Specify composing for a curried function.\n * @returns {Array} Returns the new array of composed arguments.\n */\nfunction composeArgsRight(args, partials, holders, isCurried) {\n  var argsIndex = -1,\n      argsLength = args.length,\n      holdersIndex = -1,\n      holdersLength = holders.length,\n      rightIndex = -1,\n      rightLength = partials.length,\n      rangeLength = nativeMax(argsLength - holdersLength, 0),\n      result = Array(rangeLength + rightLength),\n      isUncurried = !isCurried;\n\n  while (++argsIndex < rangeLength) {\n    result[argsIndex] = args[argsIndex];\n  }\n  var offset = argsIndex;\n  while (++rightIndex < rightLength) {\n    result[offset + rightIndex] = partials[rightIndex];\n  }\n  while (++holdersIndex < holdersLength) {\n    if (isUncurried || argsIndex < argsLength) {\n      result[offset + holders[holdersIndex]] = args[argsIndex++];\n    }\n  }\n  return result;\n}\n\nexport default composeArgsRight;\n", "/**\n * Gets the number of `placeholder` occurrences in `array`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} placeholder The placeholder to search for.\n * @returns {number} Returns the placeholder count.\n */\nfunction countHolders(array, placeholder) {\n  var length = array.length,\n      result = 0;\n\n  while (length--) {\n    if (array[length] === placeholder) {\n      ++result;\n    }\n  }\n  return result;\n}\n\nexport default countHolders;\n", "/**\n * The function whose prototype chain sequence wrappers inherit from.\n *\n * @private\n */\nfunction baseLodash() {\n  // No operation performed.\n}\n\nexport default baseLodash;\n", "import baseCreate from './_baseCreate.js';\nimport baseLodash from './_baseLodash.js';\n\n/** Used as references for the maximum length and index of an array. */\nvar MAX_ARRAY_LENGTH = 4294967295;\n\n/**\n * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation.\n *\n * @private\n * @constructor\n * @param {*} value The value to wrap.\n */\nfunction LazyWrapper(value) {\n  this.__wrapped__ = value;\n  this.__actions__ = [];\n  this.__dir__ = 1;\n  this.__filtered__ = false;\n  this.__iteratees__ = [];\n  this.__takeCount__ = MAX_ARRAY_LENGTH;\n  this.__views__ = [];\n}\n\n// Ensure `LazyWrapper` is an instance of `baseLodash`.\nLazyWrapper.prototype = baseCreate(baseLodash.prototype);\nLazyWrapper.prototype.constructor = LazyWrapper;\n\nexport default LazyWrapper;\n", "/**\n * This method returns `undefined`.\n *\n * @static\n * @memberOf _\n * @since 2.3.0\n * @category Util\n * @example\n *\n * _.times(2, _.noop);\n * // => [undefined, undefined]\n */\nfunction noop() {\n  // No operation performed.\n}\n\nexport default noop;\n", "import metaMap from './_metaMap.js';\nimport noop from './noop.js';\n\n/**\n * Gets metadata for `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {*} Returns the metadata for `func`.\n */\nvar getData = !metaMap ? noop : function(func) {\n  return metaMap.get(func);\n};\n\nexport default getData;\n", "/** Used to lookup unminified function names. */\nvar realNames = {};\n\nexport default realNames;\n", "import realNames from './_realNames.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the name of `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {string} Returns the function name.\n */\nfunction getFuncName(func) {\n  var result = (func.name + ''),\n      array = realNames[result],\n      length = hasOwnProperty.call(realNames, result) ? array.length : 0;\n\n  while (length--) {\n    var data = array[length],\n        otherFunc = data.func;\n    if (otherFunc == null || otherFunc == func) {\n      return data.name;\n    }\n  }\n  return result;\n}\n\nexport default getFuncName;\n", "import baseCreate from './_baseCreate.js';\nimport baseLodash from './_baseLodash.js';\n\n/**\n * The base constructor for creating `lodash` wrapper objects.\n *\n * @private\n * @param {*} value The value to wrap.\n * @param {boolean} [chainAll] Enable explicit method chain sequences.\n */\nfunction LodashWrapper(value, chainAll) {\n  this.__wrapped__ = value;\n  this.__actions__ = [];\n  this.__chain__ = !!chainAll;\n  this.__index__ = 0;\n  this.__values__ = undefined;\n}\n\nLodashWrapper.prototype = baseCreate(baseLodash.prototype);\nLodashWrapper.prototype.constructor = LodashWrapper;\n\nexport default LodashWrapper;\n", "/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n  var index = -1,\n      length = source.length;\n\n  array || (array = Array(length));\n  while (++index < length) {\n    array[index] = source[index];\n  }\n  return array;\n}\n\nexport default copyArray;\n", "import LazyWrapper from './_LazyWrapper.js';\nimport LodashWrapper from './_LodashWrapper.js';\nimport copyArray from './_copyArray.js';\n\n/**\n * Creates a clone of `wrapper`.\n *\n * @private\n * @param {Object} wrapper The wrapper to clone.\n * @returns {Object} Returns the cloned wrapper.\n */\nfunction wrapperClone(wrapper) {\n  if (wrapper instanceof LazyWrapper) {\n    return wrapper.clone();\n  }\n  var result = new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__);\n  result.__actions__ = copyArray(wrapper.__actions__);\n  result.__index__  = wrapper.__index__;\n  result.__values__ = wrapper.__values__;\n  return result;\n}\n\nexport default wrapperClone;\n", "import LazyWrapper from './_LazyWrapper.js';\nimport LodashWrapper from './_LodashWrapper.js';\nimport baseLodash from './_baseLodash.js';\nimport isArray from './isArray.js';\nimport isObjectLike from './isObjectLike.js';\nimport wrapperClone from './_wrapperClone.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates a `lodash` object which wraps `value` to enable implicit method\n * chain sequences. Methods that operate on and return arrays, collections,\n * and functions can be chained together. Methods that retrieve a single value\n * or may return a primitive value will automatically end the chain sequence\n * and return the unwrapped value. Otherwise, the value must be unwrapped\n * with `_#value`.\n *\n * Explicit chain sequences, which must be unwrapped with `_#value`, may be\n * enabled using `_.chain`.\n *\n * The execution of chained methods is lazy, that is, it's deferred until\n * `_#value` is implicitly or explicitly called.\n *\n * Lazy evaluation allows several methods to support shortcut fusion.\n * Shortcut fusion is an optimization to merge iteratee calls; this avoids\n * the creation of intermediate arrays and can greatly reduce the number of\n * iteratee executions. Sections of a chain sequence qualify for shortcut\n * fusion if the section is applied to an array and iteratees accept only\n * one argument. The heuristic for whether a section qualifies for shortcut\n * fusion is subject to change.\n *\n * Chaining is supported in custom builds as long as the `_#value` method is\n * directly or indirectly included in the build.\n *\n * In addition to lodash methods, wrappers have `Array` and `String` methods.\n *\n * The wrapper `Array` methods are:\n * `concat`, `join`, `pop`, `push`, `shift`, `sort`, `splice`, and `unshift`\n *\n * The wrapper `String` methods are:\n * `replace` and `split`\n *\n * The wrapper methods that support shortcut fusion are:\n * `at`, `compact`, `drop`, `dropRight`, `dropWhile`, `filter`, `find`,\n * `findLast`, `head`, `initial`, `last`, `map`, `reject`, `reverse`, `slice`,\n * `tail`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, and `toArray`\n *\n * The chainable wrapper methods are:\n * `after`, `ary`, `assign`, `assignIn`, `assignInWith`, `assignWith`, `at`,\n * `before`, `bind`, `bindAll`, `bindKey`, `castArray`, `chain`, `chunk`,\n * `commit`, `compact`, `concat`, `conforms`, `constant`, `countBy`, `create`,\n * `curry`, `debounce`, `defaults`, `defaultsDeep`, `defer`, `delay`,\n * `difference`, `differenceBy`, `differenceWith`, `drop`, `dropRight`,\n * `dropRightWhile`, `dropWhile`, `extend`, `extendWith`, `fill`, `filter`,\n * `flatMap`, `flatMapDeep`, `flatMapDepth`, `flatten`, `flattenDeep`,\n * `flattenDepth`, `flip`, `flow`, `flowRight`, `fromPairs`, `functions`,\n * `functionsIn`, `groupBy`, `initial`, `intersection`, `intersectionBy`,\n * `intersectionWith`, `invert`, `invertBy`, `invokeMap`, `iteratee`, `keyBy`,\n * `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, `matchesProperty`,\n * `memoize`, `merge`, `mergeWith`, `method`, `methodOf`, `mixin`, `negate`,\n * `nthArg`, `omit`, `omitBy`, `once`, `orderBy`, `over`, `overArgs`,\n * `overEvery`, `overSome`, `partial`, `partialRight`, `partition`, `pick`,\n * `pickBy`, `plant`, `property`, `propertyOf`, `pull`, `pullAll`, `pullAllBy`,\n * `pullAllWith`, `pullAt`, `push`, `range`, `rangeRight`, `rearg`, `reject`,\n * `remove`, `rest`, `reverse`, `sampleSize`, `set`, `setWith`, `shuffle`,\n * `slice`, `sort`, `sortBy`, `splice`, `spread`, `tail`, `take`, `takeRight`,\n * `takeRightWhile`, `takeWhile`, `tap`, `throttle`, `thru`, `toArray`,\n * `toPairs`, `toPairsIn`, `toPath`, `toPlainObject`, `transform`, `unary`,\n * `union`, `unionBy`, `unionWith`, `uniq`, `uniqBy`, `uniqWith`, `unset`,\n * `unshift`, `unzip`, `unzipWith`, `update`, `updateWith`, `values`,\n * `valuesIn`, `without`, `wrap`, `xor`, `xorBy`, `xorWith`, `zip`,\n * `zipObject`, `zipObjectDeep`, and `zipWith`\n *\n * The wrapper methods that are **not** chainable by default are:\n * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clamp`, `clone`,\n * `cloneDeep`, `cloneDeepWith`, `cloneWith`, `conformsTo`, `deburr`,\n * `defaultTo`, `divide`, `each`, `eachRight`, `endsWith`, `eq`, `escape`,\n * `escapeRegExp`, `every`, `find`, `findIndex`, `findKey`, `findLast`,\n * `findLastIndex`, `findLastKey`, `first`, `floor`, `forEach`, `forEachRight`,\n * `forIn`, `forInRight`, `forOwn`, `forOwnRight`, `get`, `gt`, `gte`, `has`,\n * `hasIn`, `head`, `identity`, `includes`, `indexOf`, `inRange`, `invoke`,\n * `isArguments`, `isArray`, `isArrayBuffer`, `isArrayLike`, `isArrayLikeObject`,\n * `isBoolean`, `isBuffer`, `isDate`, `isElement`, `isEmpty`, `isEqual`,\n * `isEqualWith`, `isError`, `isFinite`, `isFunction`, `isInteger`, `isLength`,\n * `isMap`, `isMatch`, `isMatchWith`, `isNaN`, `isNative`, `isNil`, `isNull`,\n * `isNumber`, `isObject`, `isObjectLike`, `isPlainObject`, `isRegExp`,\n * `isSafeInteger`, `isSet`, `isString`, `isUndefined`, `isTypedArray`,\n * `isWeakMap`, `isWeakSet`, `join`, `kebabCase`, `last`, `lastIndexOf`,\n * `lowerCase`, `lowerFirst`, `lt`, `lte`, `max`, `maxBy`, `mean`, `meanBy`,\n * `min`, `minBy`, `multiply`, `noConflict`, `noop`, `now`, `nth`, `pad`,\n * `padEnd`, `padStart`, `parseInt`, `pop`, `random`, `reduce`, `reduceRight`,\n * `repeat`, `result`, `round`, `runInContext`, `sample`, `shift`, `size`,\n * `snakeCase`, `some`, `sortedIndex`, `sortedIndexBy`, `sortedLastIndex`,\n * `sortedLastIndexBy`, `startCase`, `startsWith`, `stubArray`, `stubFalse`,\n * `stubObject`, `stubString`, `stubTrue`, `subtract`, `sum`, `sumBy`,\n * `template`, `times`, `toFinite`, `toInteger`, `toJSON`, `toLength`,\n * `toLower`, `toNumber`, `toSafeInteger`, `toString`, `toUpper`, `trim`,\n * `trimEnd`, `trimStart`, `truncate`, `unescape`, `uniqueId`, `upperCase`,\n * `upperFirst`, `value`, and `words`\n *\n * @name _\n * @constructor\n * @category Seq\n * @param {*} value The value to wrap in a `lodash` instance.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * function square(n) {\n *   return n * n;\n * }\n *\n * var wrapped = _([1, 2, 3]);\n *\n * // Returns an unwrapped value.\n * wrapped.reduce(_.add);\n * // => 6\n *\n * // Returns a wrapped value.\n * var squares = wrapped.map(square);\n *\n * _.isArray(squares);\n * // => false\n *\n * _.isArray(squares.value());\n * // => true\n */\nfunction lodash(value) {\n  if (isObjectLike(value) && !isArray(value) && !(value instanceof LazyWrapper)) {\n    if (value instanceof LodashWrapper) {\n      return value;\n    }\n    if (hasOwnProperty.call(value, '__wrapped__')) {\n      return wrapperClone(value);\n    }\n  }\n  return new LodashWrapper(value);\n}\n\n// Ensure wrappers are instances of `baseLodash`.\nlodash.prototype = baseLodash.prototype;\nlodash.prototype.constructor = lodash;\n\nexport default lodash;\n", "import LazyWrapper from './_LazyWrapper.js';\nimport getData from './_getData.js';\nimport getFuncName from './_getFuncName.js';\nimport lodash from './wrapperLodash.js';\n\n/**\n * Checks if `func` has a lazy counterpart.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` has a lazy counterpart,\n *  else `false`.\n */\nfunction isLaziable(func) {\n  var funcName = getFuncName(func),\n      other = lodash[funcName];\n\n  if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) {\n    return false;\n  }\n  if (func === other) {\n    return true;\n  }\n  var data = getData(other);\n  return !!data && func === data[0];\n}\n\nexport default isLaziable;\n", "/** Used to detect hot functions by number of calls within a span of milliseconds. */\nvar HOT_COUNT = 800,\n    HOT_SPAN = 16;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeNow = Date.now;\n\n/**\n * Creates a function that'll short out and invoke `identity` instead\n * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`\n * milliseconds.\n *\n * @private\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new shortable function.\n */\nfunction shortOut(func) {\n  var count = 0,\n      lastCalled = 0;\n\n  return function() {\n    var stamp = nativeNow(),\n        remaining = HOT_SPAN - (stamp - lastCalled);\n\n    lastCalled = stamp;\n    if (remaining > 0) {\n      if (++count >= HOT_COUNT) {\n        return arguments[0];\n      }\n    } else {\n      count = 0;\n    }\n    return func.apply(undefined, arguments);\n  };\n}\n\nexport default shortOut;\n", "import baseSetData from './_baseSetData.js';\nimport shortOut from './_shortOut.js';\n\n/**\n * Sets metadata for `func`.\n *\n * **Note:** If this function becomes hot, i.e. is invoked a lot in a short\n * period of time, it will trip its breaker and transition to an identity\n * function to avoid garbage collection pauses in V8. See\n * [V8 issue 2070](https://bugs.chromium.org/p/v8/issues/detail?id=2070)\n * for more details.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\nvar setData = shortOut(baseSetData);\n\nexport default setData;\n", "/** Used to match wrap detail comments. */\nvar reWrapDetails = /\\{\\n\\/\\* \\[wrapped with (.+)\\] \\*/,\n    reSplitDetails = /,? & /;\n\n/**\n * Extracts wrapper details from the `source` body comment.\n *\n * @private\n * @param {string} source The source to inspect.\n * @returns {Array} Returns the wrapper details.\n */\nfunction getWrapDetails(source) {\n  var match = source.match(reWrapDetails);\n  return match ? match[1].split(reSplitDetails) : [];\n}\n\nexport default getWrapDetails;\n", "/** Used to match wrap detail comments. */\nvar reWrapComment = /\\{(?:\\n\\/\\* \\[wrapped with .+\\] \\*\\/)?\\n?/;\n\n/**\n * Inserts wrapper `details` in a comment at the top of the `source` body.\n *\n * @private\n * @param {string} source The source to modify.\n * @returns {Array} details The details to insert.\n * @returns {string} Returns the modified source.\n */\nfunction insertWrapDetails(source, details) {\n  var length = details.length;\n  if (!length) {\n    return source;\n  }\n  var lastIndex = length - 1;\n  details[lastIndex] = (length > 1 ? '& ' : '') + details[lastIndex];\n  details = details.join(length > 2 ? ', ' : ' ');\n  return source.replace(reWrapComment, '{\\n/* [wrapped with ' + details + '] */\\n');\n}\n\nexport default insertWrapDetails;\n", "/**\n * Creates a function that returns `value`.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {*} value The value to return from the new function.\n * @returns {Function} Returns the new constant function.\n * @example\n *\n * var objects = _.times(2, _.constant({ 'a': 1 }));\n *\n * console.log(objects);\n * // => [{ 'a': 1 }, { 'a': 1 }]\n *\n * console.log(objects[0] === objects[1]);\n * // => true\n */\nfunction constant(value) {\n  return function() {\n    return value;\n  };\n}\n\nexport default constant;\n", "import getNative from './_getNative.js';\n\nvar defineProperty = (function() {\n  try {\n    var func = getNative(Object, 'defineProperty');\n    func({}, '', {});\n    return func;\n  } catch (e) {}\n}());\n\nexport default defineProperty;\n", "import constant from './constant.js';\nimport defineProperty from './_defineProperty.js';\nimport identity from './identity.js';\n\n/**\n * The base implementation of `setToString` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar baseSetToString = !defineProperty ? identity : function(func, string) {\n  return defineProperty(func, 'toString', {\n    'configurable': true,\n    'enumerable': false,\n    'value': constant(string),\n    'writable': true\n  });\n};\n\nexport default baseSetToString;\n", "import baseSetToString from './_baseSetToString.js';\nimport shortOut from './_shortOut.js';\n\n/**\n * Sets the `toString` method of `func` to return `string`.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar setToString = shortOut(baseSetToString);\n\nexport default setToString;\n", "/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEach(array, iteratee) {\n  var index = -1,\n      length = array == null ? 0 : array.length;\n\n  while (++index < length) {\n    if (iteratee(array[index], index, array) === false) {\n      break;\n    }\n  }\n  return array;\n}\n\nexport default arrayEach;\n", "/**\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {number} fromIndex The index to search from.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseFindIndex(array, predicate, fromIndex, fromRight) {\n  var length = array.length,\n      index = fromIndex + (fromRight ? 1 : -1);\n\n  while ((fromRight ? index-- : ++index < length)) {\n    if (predicate(array[index], index, array)) {\n      return index;\n    }\n  }\n  return -1;\n}\n\nexport default baseFindIndex;\n", "/**\n * The base implementation of `_.isNaN` without support for number objects.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n */\nfunction baseIsNaN(value) {\n  return value !== value;\n}\n\nexport default baseIsNaN;\n", "/**\n * A specialized version of `_.indexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction strictIndexOf(array, value, fromIndex) {\n  var index = fromIndex - 1,\n      length = array.length;\n\n  while (++index < length) {\n    if (array[index] === value) {\n      return index;\n    }\n  }\n  return -1;\n}\n\nexport default strictIndexOf;\n", "import baseFindIndex from './_baseFindIndex.js';\nimport baseIsNaN from './_baseIsNaN.js';\nimport strictIndexOf from './_strictIndexOf.js';\n\n/**\n * The base implementation of `_.indexOf` without `fromIndex` bounds checks.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseIndexOf(array, value, fromIndex) {\n  return value === value\n    ? strictIndexOf(array, value, fromIndex)\n    : baseFindIndex(array, baseIsNaN, fromIndex);\n}\n\nexport default baseIndexOf;\n", "import baseIndexOf from './_baseIndexOf.js';\n\n/**\n * A specialized version of `_.includes` for arrays without support for\n * specifying an index to search from.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\nfunction arrayIncludes(array, value) {\n  var length = array == null ? 0 : array.length;\n  return !!length && baseIndexOf(array, value, 0) > -1;\n}\n\nexport default arrayIncludes;\n", "import arrayEach from './_arrayEach.js';\nimport arrayIncludes from './_arrayIncludes.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1,\n    WRAP_BIND_KEY_FLAG = 2,\n    WRAP_CURRY_FLAG = 8,\n    WRAP_CURRY_RIGHT_FLAG = 16,\n    WRAP_PARTIAL_FLAG = 32,\n    WRAP_PARTIAL_RIGHT_FLAG = 64,\n    WRAP_ARY_FLAG = 128,\n    WRAP_REARG_FLAG = 256,\n    WRAP_FLIP_FLAG = 512;\n\n/** Used to associate wrap methods with their bit flags. */\nvar wrapFlags = [\n  ['ary', WRAP_ARY_FLAG],\n  ['bind', WRAP_BIND_FLAG],\n  ['bindKey', WRAP_BIND_KEY_FLAG],\n  ['curry', WRAP_CURRY_FLAG],\n  ['curryRight', WRAP_CURRY_RIGHT_FLAG],\n  ['flip', WRAP_FLIP_FLAG],\n  ['partial', WRAP_PARTIAL_FLAG],\n  ['partialRight', WRAP_PARTIAL_RIGHT_FLAG],\n  ['rearg', WRAP_REARG_FLAG]\n];\n\n/**\n * Updates wrapper `details` based on `bitmask` flags.\n *\n * @private\n * @returns {Array} details The details to modify.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @returns {Array} Returns `details`.\n */\nfunction updateWrapDetails(details, bitmask) {\n  arrayEach(wrapFlags, function(pair) {\n    var value = '_.' + pair[0];\n    if ((bitmask & pair[1]) && !arrayIncludes(details, value)) {\n      details.push(value);\n    }\n  });\n  return details.sort();\n}\n\nexport default updateWrapDetails;\n", "import getWrapDetails from './_getWrapDetails.js';\nimport insertWrapDetails from './_insertWrapDetails.js';\nimport setToString from './_setToString.js';\nimport updateWrapDetails from './_updateWrapDetails.js';\n\n/**\n * Sets the `toString` method of `wrapper` to mimic the source of `reference`\n * with wrapper details in a comment at the top of the source body.\n *\n * @private\n * @param {Function} wrapper The function to modify.\n * @param {Function} reference The reference function.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @returns {Function} Returns `wrapper`.\n */\nfunction setWrapToString(wrapper, reference, bitmask) {\n  var source = (reference + '');\n  return setToString(wrapper, insertWrapDetails(source, updateWrapDetails(getWrapDetails(source), bitmask)));\n}\n\nexport default setWrapToString;\n", "import isLaziable from './_isLaziable.js';\nimport setData from './_setData.js';\nimport setWrapToString from './_setWrapToString.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1,\n    WRAP_BIND_KEY_FLAG = 2,\n    WRAP_CURRY_BOUND_FLAG = 4,\n    WRAP_CURRY_FLAG = 8,\n    WRAP_PARTIAL_FLAG = 32,\n    WRAP_PARTIAL_RIGHT_FLAG = 64;\n\n/**\n * Creates a function that wraps `func` to continue currying.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {Function} wrapFunc The function to create the `func` wrapper.\n * @param {*} placeholder The placeholder value.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to\n *  the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createRecurry(func, bitmask, wrapFunc, placeholder, thisArg, partials, holders, argPos, ary, arity) {\n  var isCurry = bitmask & WRAP_CURRY_FLAG,\n      newHolders = isCurry ? holders : undefined,\n      newHoldersRight = isCurry ? undefined : holders,\n      newPartials = isCurry ? partials : undefined,\n      newPartialsRight = isCurry ? undefined : partials;\n\n  bitmask |= (isCurry ? WRAP_PARTIAL_FLAG : WRAP_PARTIAL_RIGHT_FLAG);\n  bitmask &= ~(isCurry ? WRAP_PARTIAL_RIGHT_FLAG : WRAP_PARTIAL_FLAG);\n\n  if (!(bitmask & WRAP_CURRY_BOUND_FLAG)) {\n    bitmask &= ~(WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG);\n  }\n  var newData = [\n    func, bitmask, thisArg, newPartials, newHolders, newPartialsRight,\n    newHoldersRight, argPos, ary, arity\n  ];\n\n  var result = wrapFunc.apply(undefined, newData);\n  if (isLaziable(func)) {\n    setData(result, newData);\n  }\n  result.placeholder = placeholder;\n  return setWrapToString(result, func, bitmask);\n}\n\nexport default createRecurry;\n", "/**\n * Gets the argument placeholder value for `func`.\n *\n * @private\n * @param {Function} func The function to inspect.\n * @returns {*} Returns the placeholder value.\n */\nfunction getHolder(func) {\n  var object = func;\n  return object.placeholder;\n}\n\nexport default getHolder;\n", "/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n  var type = typeof value;\n  length = length == null ? MAX_SAFE_INTEGER : length;\n\n  return !!length &&\n    (type == 'number' ||\n      (type != 'symbol' && reIsUint.test(value))) &&\n        (value > -1 && value % 1 == 0 && value < length);\n}\n\nexport default isIndex;\n", "import copyArray from './_copyArray.js';\nimport isIndex from './_isIndex.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMin = Math.min;\n\n/**\n * Reorder `array` according to the specified indexes where the element at\n * the first index is assigned as the first element, the element at\n * the second index is assigned as the second element, and so on.\n *\n * @private\n * @param {Array} array The array to reorder.\n * @param {Array} indexes The arranged array indexes.\n * @returns {Array} Returns `array`.\n */\nfunction reorder(array, indexes) {\n  var arrLength = array.length,\n      length = nativeMin(indexes.length, arrLength),\n      oldArray = copyArray(array);\n\n  while (length--) {\n    var index = indexes[length];\n    array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined;\n  }\n  return array;\n}\n\nexport default reorder;\n", "/** Used as the internal argument placeholder. */\nvar PLACEHOLDER = '__lodash_placeholder__';\n\n/**\n * Replaces all `placeholder` elements in `array` with an internal placeholder\n * and returns an array of their indexes.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {*} placeholder The placeholder to replace.\n * @returns {Array} Returns the new array of placeholder indexes.\n */\nfunction replaceHolders(array, placeholder) {\n  var index = -1,\n      length = array.length,\n      resIndex = 0,\n      result = [];\n\n  while (++index < length) {\n    var value = array[index];\n    if (value === placeholder || value === PLACEHOLDER) {\n      array[index] = PLACEHOLDER;\n      result[resIndex++] = index;\n    }\n  }\n  return result;\n}\n\nexport default replaceHolders;\n", "import composeArgs from './_composeArgs.js';\nimport composeArgsRight from './_composeArgsRight.js';\nimport countHolders from './_countHolders.js';\nimport createCtor from './_createCtor.js';\nimport createRecurry from './_createRecurry.js';\nimport getHolder from './_getHolder.js';\nimport reorder from './_reorder.js';\nimport replaceHolders from './_replaceHolders.js';\nimport root from './_root.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1,\n    WRAP_BIND_KEY_FLAG = 2,\n    WRAP_CURRY_FLAG = 8,\n    WRAP_CURRY_RIGHT_FLAG = 16,\n    WRAP_ARY_FLAG = 128,\n    WRAP_FLIP_FLAG = 512;\n\n/**\n * Creates a function that wraps `func` to invoke it with optional `this`\n * binding of `thisArg`, partial application, and currying.\n *\n * @private\n * @param {Function|string} func The function or method name to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to\n *  the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [partialsRight] The arguments to append to those provided\n *  to the new function.\n * @param {Array} [holdersRight] The `partialsRight` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createHybrid(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) {\n  var isAry = bitmask & WRAP_ARY_FLAG,\n      isBind = bitmask & WRAP_BIND_FLAG,\n      isBindKey = bitmask & WRAP_BIND_KEY_FLAG,\n      isCurried = bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG),\n      isFlip = bitmask & WRAP_FLIP_FLAG,\n      Ctor = isBindKey ? undefined : createCtor(func);\n\n  function wrapper() {\n    var length = arguments.length,\n        args = Array(length),\n        index = length;\n\n    while (index--) {\n      args[index] = arguments[index];\n    }\n    if (isCurried) {\n      var placeholder = getHolder(wrapper),\n          holdersCount = countHolders(args, placeholder);\n    }\n    if (partials) {\n      args = composeArgs(args, partials, holders, isCurried);\n    }\n    if (partialsRight) {\n      args = composeArgsRight(args, partialsRight, holdersRight, isCurried);\n    }\n    length -= holdersCount;\n    if (isCurried && length < arity) {\n      var newHolders = replaceHolders(args, placeholder);\n      return createRecurry(\n        func, bitmask, createHybrid, wrapper.placeholder, thisArg,\n        args, newHolders, argPos, ary, arity - length\n      );\n    }\n    var thisBinding = isBind ? thisArg : this,\n        fn = isBindKey ? thisBinding[func] : func;\n\n    length = args.length;\n    if (argPos) {\n      args = reorder(args, argPos);\n    } else if (isFlip && length > 1) {\n      args.reverse();\n    }\n    if (isAry && ary < length) {\n      args.length = ary;\n    }\n    if (this && this !== root && this instanceof wrapper) {\n      fn = Ctor || createCtor(fn);\n    }\n    return fn.apply(thisBinding, args);\n  }\n  return wrapper;\n}\n\nexport default createHybrid;\n", "import apply from './_apply.js';\nimport createCtor from './_createCtor.js';\nimport createHybrid from './_createHybrid.js';\nimport createRecurry from './_createRecurry.js';\nimport getHolder from './_getHolder.js';\nimport replaceHolders from './_replaceHolders.js';\nimport root from './_root.js';\n\n/**\n * Creates a function that wraps `func` to enable currying.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {number} arity The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createCurry(func, bitmask, arity) {\n  var Ctor = createCtor(func);\n\n  function wrapper() {\n    var length = arguments.length,\n        args = Array(length),\n        index = length,\n        placeholder = getHolder(wrapper);\n\n    while (index--) {\n      args[index] = arguments[index];\n    }\n    var holders = (length < 3 && args[0] !== placeholder && args[length - 1] !== placeholder)\n      ? []\n      : replaceHolders(args, placeholder);\n\n    length -= holders.length;\n    if (length < arity) {\n      return createRecurry(\n        func, bitmask, createHybrid, wrapper.placeholder, undefined,\n        args, holders, undefined, undefined, arity - length);\n    }\n    var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n    return apply(fn, this, args);\n  }\n  return wrapper;\n}\n\nexport default createCurry;\n", "import apply from './_apply.js';\nimport createCtor from './_createCtor.js';\nimport root from './_root.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1;\n\n/**\n * Creates a function that wraps `func` to invoke it with the `this` binding\n * of `thisArg` and `partials` prepended to the arguments it receives.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} partials The arguments to prepend to those provided to\n *  the new function.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createPartial(func, bitmask, thisArg, partials) {\n  var isBind = bitmask & WRAP_BIND_FLAG,\n      Ctor = createCtor(func);\n\n  function wrapper() {\n    var argsIndex = -1,\n        argsLength = arguments.length,\n        leftIndex = -1,\n        leftLength = partials.length,\n        args = Array(leftLength + argsLength),\n        fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n\n    while (++leftIndex < leftLength) {\n      args[leftIndex] = partials[leftIndex];\n    }\n    while (argsLength--) {\n      args[leftIndex++] = arguments[++argsIndex];\n    }\n    return apply(fn, isBind ? thisArg : this, args);\n  }\n  return wrapper;\n}\n\nexport default createPartial;\n", "import composeArgs from './_composeArgs.js';\nimport composeArgsRight from './_composeArgsRight.js';\nimport replaceHolders from './_replaceHolders.js';\n\n/** Used as the internal argument placeholder. */\nvar PLACEHOLDER = '__lodash_placeholder__';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1,\n    WRAP_BIND_KEY_FLAG = 2,\n    WRAP_CURRY_BOUND_FLAG = 4,\n    WRAP_CURRY_FLAG = 8,\n    WRAP_ARY_FLAG = 128,\n    WRAP_REARG_FLAG = 256;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMin = Math.min;\n\n/**\n * Merges the function metadata of `source` into `data`.\n *\n * Merging metadata reduces the number of wrappers used to invoke a function.\n * This is possible because methods like `_.bind`, `_.curry`, and `_.partial`\n * may be applied regardless of execution order. Methods like `_.ary` and\n * `_.rearg` modify function arguments, making the order in which they are\n * executed important, preventing the merging of metadata. However, we make\n * an exception for a safe combined case where curried functions have `_.ary`\n * and or `_.rearg` applied.\n *\n * @private\n * @param {Array} data The destination metadata.\n * @param {Array} source The source metadata.\n * @returns {Array} Returns `data`.\n */\nfunction mergeData(data, source) {\n  var bitmask = data[1],\n      srcBitmask = source[1],\n      newBitmask = bitmask | srcBitmask,\n      isCommon = newBitmask < (WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG | WRAP_ARY_FLAG);\n\n  var isCombo =\n    ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_CURRY_FLAG)) ||\n    ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_REARG_FLAG) && (data[7].length <= source[8])) ||\n    ((srcBitmask == (WRAP_ARY_FLAG | WRAP_REARG_FLAG)) && (source[7].length <= source[8]) && (bitmask == WRAP_CURRY_FLAG));\n\n  // Exit early if metadata can't be merged.\n  if (!(isCommon || isCombo)) {\n    return data;\n  }\n  // Use source `thisArg` if available.\n  if (srcBitmask & WRAP_BIND_FLAG) {\n    data[2] = source[2];\n    // Set when currying a bound function.\n    newBitmask |= bitmask & WRAP_BIND_FLAG ? 0 : WRAP_CURRY_BOUND_FLAG;\n  }\n  // Compose partial arguments.\n  var value = source[3];\n  if (value) {\n    var partials = data[3];\n    data[3] = partials ? composeArgs(partials, value, source[4]) : value;\n    data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : source[4];\n  }\n  // Compose partial right arguments.\n  value = source[5];\n  if (value) {\n    partials = data[5];\n    data[5] = partials ? composeArgsRight(partials, value, source[6]) : value;\n    data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : source[6];\n  }\n  // Use source `argPos` if available.\n  value = source[7];\n  if (value) {\n    data[7] = value;\n  }\n  // Use source `ary` if it's smaller.\n  if (srcBitmask & WRAP_ARY_FLAG) {\n    data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]);\n  }\n  // Use source `arity` if one is not provided.\n  if (data[9] == null) {\n    data[9] = source[9];\n  }\n  // Use source `func` and merge bitmasks.\n  data[0] = source[0];\n  data[1] = newBitmask;\n\n  return data;\n}\n\nexport default mergeData;\n", "import baseSetData from './_baseSetData.js';\nimport createBind from './_createBind.js';\nimport createCurry from './_createCurry.js';\nimport createHybrid from './_createHybrid.js';\nimport createPartial from './_createPartial.js';\nimport getData from './_getData.js';\nimport mergeData from './_mergeData.js';\nimport setData from './_setData.js';\nimport setWrapToString from './_setWrapToString.js';\nimport toInteger from './toInteger.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1,\n    WRAP_BIND_KEY_FLAG = 2,\n    WRAP_CURRY_FLAG = 8,\n    WRAP_CURRY_RIGHT_FLAG = 16,\n    WRAP_PARTIAL_FLAG = 32,\n    WRAP_PARTIAL_RIGHT_FLAG = 64;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates a function that either curries or invokes `func` with optional\n * `this` binding and partially applied arguments.\n *\n * @private\n * @param {Function|string} func The function or method name to wrap.\n * @param {number} bitmask The bitmask flags.\n *    1 - `_.bind`\n *    2 - `_.bindKey`\n *    4 - `_.curry` or `_.curryRight` of a bound function\n *    8 - `_.curry`\n *   16 - `_.curryRight`\n *   32 - `_.partial`\n *   64 - `_.partialRight`\n *  128 - `_.rearg`\n *  256 - `_.ary`\n *  512 - `_.flip`\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to be partially applied.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createWrap(func, bitmask, thisArg, partials, holders, argPos, ary, arity) {\n  var isBindKey = bitmask & WRAP_BIND_KEY_FLAG;\n  if (!isBindKey && typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  var length = partials ? partials.length : 0;\n  if (!length) {\n    bitmask &= ~(WRAP_PARTIAL_FLAG | WRAP_PARTIAL_RIGHT_FLAG);\n    partials = holders = undefined;\n  }\n  ary = ary === undefined ? ary : nativeMax(toInteger(ary), 0);\n  arity = arity === undefined ? arity : toInteger(arity);\n  length -= holders ? holders.length : 0;\n\n  if (bitmask & WRAP_PARTIAL_RIGHT_FLAG) {\n    var partialsRight = partials,\n        holdersRight = holders;\n\n    partials = holders = undefined;\n  }\n  var data = isBindKey ? undefined : getData(func);\n\n  var newData = [\n    func, bitmask, thisArg, partials, holders, partialsRight, holdersRight,\n    argPos, ary, arity\n  ];\n\n  if (data) {\n    mergeData(newData, data);\n  }\n  func = newData[0];\n  bitmask = newData[1];\n  thisArg = newData[2];\n  partials = newData[3];\n  holders = newData[4];\n  arity = newData[9] = newData[9] === undefined\n    ? (isBindKey ? 0 : func.length)\n    : nativeMax(newData[9] - length, 0);\n\n  if (!arity && bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG)) {\n    bitmask &= ~(WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG);\n  }\n  if (!bitmask || bitmask == WRAP_BIND_FLAG) {\n    var result = createBind(func, bitmask, thisArg);\n  } else if (bitmask == WRAP_CURRY_FLAG || bitmask == WRAP_CURRY_RIGHT_FLAG) {\n    result = createCurry(func, bitmask, arity);\n  } else if ((bitmask == WRAP_PARTIAL_FLAG || bitmask == (WRAP_BIND_FLAG | WRAP_PARTIAL_FLAG)) && !holders.length) {\n    result = createPartial(func, bitmask, thisArg, partials);\n  } else {\n    result = createHybrid.apply(undefined, newData);\n  }\n  var setter = data ? baseSetData : setData;\n  return setWrapToString(setter(result, newData), func, bitmask);\n}\n\nexport default createWrap;\n", "import createWrap from './_createWrap.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_ARY_FLAG = 128;\n\n/**\n * Creates a function that invokes `func`, with up to `n` arguments,\n * ignoring any additional arguments.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to cap arguments for.\n * @param {number} [n=func.length] The arity cap.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new capped function.\n * @example\n *\n * _.map(['6', '8', '10'], _.ary(parseInt, 1));\n * // => [6, 8, 10]\n */\nfunction ary(func, n, guard) {\n  n = guard ? undefined : n;\n  n = (func && n == null) ? func.length : n;\n  return createWrap(func, WRAP_ARY_FLAG, undefined, undefined, undefined, undefined, n);\n}\n\nexport default ary;\n", "import defineProperty from './_defineProperty.js';\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n  if (key == '__proto__' && defineProperty) {\n    defineProperty(object, key, {\n      'configurable': true,\n      'enumerable': true,\n      'value': value,\n      'writable': true\n    });\n  } else {\n    object[key] = value;\n  }\n}\n\nexport default baseAssignValue;\n", "/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n  return value === other || (value !== value && other !== other);\n}\n\nexport default eq;\n", "import baseAssignValue from './_baseAssignValue.js';\nimport eq from './eq.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n  var objValue = object[key];\n  if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n      (value === undefined && !(key in object))) {\n    baseAssignValue(object, key, value);\n  }\n}\n\nexport default assignValue;\n", "import assignValue from './_assignValue.js';\nimport baseAssignValue from './_baseAssignValue.js';\n\n/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object, customizer) {\n  var isNew = !object;\n  object || (object = {});\n\n  var index = -1,\n      length = props.length;\n\n  while (++index < length) {\n    var key = props[index];\n\n    var newValue = customizer\n      ? customizer(object[key], source[key], key, object, source)\n      : undefined;\n\n    if (newValue === undefined) {\n      newValue = source[key];\n    }\n    if (isNew) {\n      baseAssignValue(object, key, newValue);\n    } else {\n      assignValue(object, key, newValue);\n    }\n  }\n  return object;\n}\n\nexport default copyObject;\n", "import apply from './_apply.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * A specialized version of `baseRest` which transforms the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @param {Function} transform The rest array transform.\n * @returns {Function} Returns the new function.\n */\nfunction overRest(func, start, transform) {\n  start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n  return function() {\n    var args = arguments,\n        index = -1,\n        length = nativeMax(args.length - start, 0),\n        array = Array(length);\n\n    while (++index < length) {\n      array[index] = args[start + index];\n    }\n    index = -1;\n    var otherArgs = Array(start + 1);\n    while (++index < start) {\n      otherArgs[index] = args[index];\n    }\n    otherArgs[start] = transform(array);\n    return apply(func, this, otherArgs);\n  };\n}\n\nexport default overRest;\n", "import identity from './identity.js';\nimport overRest from './_overRest.js';\nimport setToString from './_setToString.js';\n\n/**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\nfunction baseRest(func, start) {\n  return setToString(overRest(func, start, identity), func + '');\n}\n\nexport default baseRest;\n", "/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n  return typeof value == 'number' &&\n    value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nexport default isLength;\n", "import isFunction from './isFunction.js';\nimport isLength from './isLength.js';\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n  return value != null && isLength(value.length) && !isFunction(value);\n}\n\nexport default isArrayLike;\n", "import eq from './eq.js';\nimport isArrayLike from './isArrayLike.js';\nimport isIndex from './_isIndex.js';\nimport isObject from './isObject.js';\n\n/**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n *  else `false`.\n */\nfunction isIterateeCall(value, index, object) {\n  if (!isObject(object)) {\n    return false;\n  }\n  var type = typeof index;\n  if (type == 'number'\n        ? (isArrayLike(object) && isIndex(index, object.length))\n        : (type == 'string' && index in object)\n      ) {\n    return eq(object[index], value);\n  }\n  return false;\n}\n\nexport default isIterateeCall;\n", "import baseRest from './_baseRest.js';\nimport isIterateeCall from './_isIterateeCall.js';\n\n/**\n * Creates a function like `_.assign`.\n *\n * @private\n * @param {Function} assigner The function to assign values.\n * @returns {Function} Returns the new assigner function.\n */\nfunction createAssigner(assigner) {\n  return baseRest(function(object, sources) {\n    var index = -1,\n        length = sources.length,\n        customizer = length > 1 ? sources[length - 1] : undefined,\n        guard = length > 2 ? sources[2] : undefined;\n\n    customizer = (assigner.length > 3 && typeof customizer == 'function')\n      ? (length--, customizer)\n      : undefined;\n\n    if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n      customizer = length < 3 ? undefined : customizer;\n      length = 1;\n    }\n    object = Object(object);\n    while (++index < length) {\n      var source = sources[index];\n      if (source) {\n        assigner(object, source, index, customizer);\n      }\n    }\n    return object;\n  });\n}\n\nexport default createAssigner;\n", "/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n  var Ctor = value && value.constructor,\n      proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n  return value === proto;\n}\n\nexport default isPrototype;\n", "/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n  var index = -1,\n      result = Array(n);\n\n  while (++index < n) {\n    result[index] = iteratee(index);\n  }\n  return result;\n}\n\nexport default baseTimes;\n", "import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n  return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nexport default baseIsArguments;\n", "import baseIsArguments from './_baseIsArguments.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n *  else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n  return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n    !propertyIsEnumerable.call(value, 'callee');\n};\n\nexport default isArguments;\n", "/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n  return false;\n}\n\nexport default stubFalse;\n", "import root from './_root.js';\nimport stubFalse from './stubFalse.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nexport default isBuffer;\n", "import baseGetTag from './_baseGetTag.js';\nimport isLength from './isLength.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    funcTag = '[object Function]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    objectTag = '[object Object]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n    dataViewTag = '[object DataView]',\n    float32Tag = '[object Float32Array]',\n    float64Tag = '[object Float64Array]',\n    int8Tag = '[object Int8Array]',\n    int16Tag = '[object Int16Array]',\n    int32Tag = '[object Int32Array]',\n    uint8Tag = '[object Uint8Array]',\n    uint8ClampedTag = '[object Uint8ClampedArray]',\n    uint16Tag = '[object Uint16Array]',\n    uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n  return isObjectLike(value) &&\n    isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nexport default baseIsTypedArray;\n", "/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n  return function(value) {\n    return func(value);\n  };\n}\n\nexport default baseUnary;\n", "import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n  try {\n    // Use `util.types` for Node.js 10+.\n    var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n    if (types) {\n      return types;\n    }\n\n    // Legacy `process.binding('util')` for Node.js < 10.\n    return freeProcess && freeProcess.binding && freeProcess.binding('util');\n  } catch (e) {}\n}());\n\nexport default nodeUtil;\n", "import baseIsTypedArray from './_baseIsTypedArray.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nexport default isTypedArray;\n", "import baseTimes from './_baseTimes.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isIndex from './_isIndex.js';\nimport isTypedArray from './isTypedArray.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n  var isArr = isArray(value),\n      isArg = !isArr && isArguments(value),\n      isBuff = !isArr && !isArg && isBuffer(value),\n      isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n      skipIndexes = isArr || isArg || isBuff || isType,\n      result = skipIndexes ? baseTimes(value.length, String) : [],\n      length = result.length;\n\n  for (var key in value) {\n    if ((inherited || hasOwnProperty.call(value, key)) &&\n        !(skipIndexes && (\n           // Safari 9 has enumerable `arguments.length` in strict mode.\n           key == 'length' ||\n           // Node.js 0.10 has enumerable non-index properties on buffers.\n           (isBuff && (key == 'offset' || key == 'parent')) ||\n           // PhantomJS 2 has enumerable non-index properties on typed arrays.\n           (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n           // Skip index properties.\n           isIndex(key, length)\n        ))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nexport default arrayLikeKeys;\n", "/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n  return function(arg) {\n    return func(transform(arg));\n  };\n}\n\nexport default overArg;\n", "import overArg from './_overArg.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nexport default nativeKeys;\n", "import isPrototype from './_isPrototype.js';\nimport nativeKeys from './_nativeKeys.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n  if (!isPrototype(object)) {\n    return nativeKeys(object);\n  }\n  var result = [];\n  for (var key in Object(object)) {\n    if (hasOwnProperty.call(object, key) && key != 'constructor') {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nexport default baseKeys;\n", "import arrayLikeKeys from './_arrayLikeKeys.js';\nimport baseKeys from './_baseKeys.js';\nimport isArrayLike from './isArrayLike.js';\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nexport default keys;\n", "import assignValue from './_assignValue.js';\nimport copyObject from './_copyObject.js';\nimport createAssigner from './_createAssigner.js';\nimport isArrayLike from './isArrayLike.js';\nimport isPrototype from './_isPrototype.js';\nimport keys from './keys.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns own enumerable string keyed properties of source objects to the\n * destination object. Source objects are applied from left to right.\n * Subsequent sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object` and is loosely based on\n * [`Object.assign`](https://mdn.io/Object/assign).\n *\n * @static\n * @memberOf _\n * @since 0.10.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.assignIn\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n * }\n *\n * function Bar() {\n *   this.c = 3;\n * }\n *\n * Foo.prototype.b = 2;\n * Bar.prototype.d = 4;\n *\n * _.assign({ 'a': 0 }, new Foo, new Bar);\n * // => { 'a': 1, 'c': 3 }\n */\nvar assign = createAssigner(function(object, source) {\n  if (isPrototype(source) || isArrayLike(source)) {\n    copyObject(source, keys(source), object);\n    return;\n  }\n  for (var key in source) {\n    if (hasOwnProperty.call(source, key)) {\n      assignValue(object, key, source[key]);\n    }\n  }\n});\n\nexport default assign;\n", "/**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction nativeKeysIn(object) {\n  var result = [];\n  if (object != null) {\n    for (var key in Object(object)) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nexport default nativeKeysIn;\n", "import isObject from './isObject.js';\nimport isPrototype from './_isPrototype.js';\nimport nativeKeysIn from './_nativeKeysIn.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeysIn(object) {\n  if (!isObject(object)) {\n    return nativeKeysIn(object);\n  }\n  var isProto = isPrototype(object),\n      result = [];\n\n  for (var key in object) {\n    if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nexport default baseKeysIn;\n", "import arrayLikeKeys from './_arrayLikeKeys.js';\nimport baseKeysIn from './_baseKeysIn.js';\nimport isArrayLike from './isArrayLike.js';\n\n/**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\nfunction keysIn(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n}\n\nexport default keysIn;\n", "import copyObject from './_copyObject.js';\nimport createAssigner from './_createAssigner.js';\nimport keysIn from './keysIn.js';\n\n/**\n * This method is like `_.assign` except that it iterates over own and\n * inherited source properties.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias extend\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.assign\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n * }\n *\n * function Bar() {\n *   this.c = 3;\n * }\n *\n * Foo.prototype.b = 2;\n * Bar.prototype.d = 4;\n *\n * _.assignIn({ 'a': 0 }, new Foo, new Bar);\n * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 }\n */\nvar assignIn = createAssigner(function(object, source) {\n  copyObject(source, keysIn(source), object);\n});\n\nexport default assignIn;\n", "import copyObject from './_copyObject.js';\nimport createAssigner from './_createAssigner.js';\nimport keysIn from './keysIn.js';\n\n/**\n * This method is like `_.assignIn` except that it accepts `customizer`\n * which is invoked to produce the assigned values. If `customizer` returns\n * `undefined`, assignment is handled by the method instead. The `customizer`\n * is invoked with five arguments: (objValue, srcValue, key, object, source).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias extendWith\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @see _.assignWith\n * @example\n *\n * function customizer(objValue, srcValue) {\n *   return _.isUndefined(objValue) ? srcValue : objValue;\n * }\n *\n * var defaults = _.partialRight(_.assignInWith, customizer);\n *\n * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\nvar assignInWith = createAssigner(function(object, source, srcIndex, customizer) {\n  copyObject(source, keysIn(source), object, customizer);\n});\n\nexport default assignInWith;\n", "import copyObject from './_copyObject.js';\nimport createAssigner from './_createAssigner.js';\nimport keys from './keys.js';\n\n/**\n * This method is like `_.assign` except that it accepts `customizer`\n * which is invoked to produce the assigned values. If `customizer` returns\n * `undefined`, assignment is handled by the method instead. The `customizer`\n * is invoked with five arguments: (objValue, srcValue, key, object, source).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @see _.assignInWith\n * @example\n *\n * function customizer(objValue, srcValue) {\n *   return _.isUndefined(objValue) ? srcValue : objValue;\n * }\n *\n * var defaults = _.partialRight(_.assignWith, customizer);\n *\n * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\nvar assignWith = createAssigner(function(object, source, srcIndex, customizer) {\n  copyObject(source, keys(source), object, customizer);\n});\n\nexport default assignWith;\n", "import isArray from './isArray.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n    reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n  if (isArray(value)) {\n    return false;\n  }\n  var type = typeof value;\n  if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n      value == null || isSymbol(value)) {\n    return true;\n  }\n  return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n    (object != null && value in Object(object));\n}\n\nexport default isKey;\n", "import getNative from './_getNative.js';\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nexport default nativeCreate;\n", "import nativeCreate from './_nativeCreate.js';\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n  this.__data__ = nativeCreate ? nativeCreate(null) : {};\n  this.size = 0;\n}\n\nexport default hashClear;\n", "/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n  var result = this.has(key) && delete this.__data__[key];\n  this.size -= result ? 1 : 0;\n  return result;\n}\n\nexport default hashDelete;\n", "import nativeCreate from './_nativeCreate.js';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n  var data = this.__data__;\n  if (nativeCreate) {\n    var result = data[key];\n    return result === HASH_UNDEFINED ? undefined : result;\n  }\n  return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nexport default hashGet;\n", "import nativeCreate from './_nativeCreate.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n  var data = this.__data__;\n  return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nexport default hashHas;\n", "import nativeCreate from './_nativeCreate.js';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n  var data = this.__data__;\n  this.size += this.has(key) ? 0 : 1;\n  data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n  return this;\n}\n\nexport default hashSet;\n", "import hashClear from './_hashClear.js';\nimport hashDelete from './_hashDelete.js';\nimport hashGet from './_hashGet.js';\nimport hashHas from './_hashHas.js';\nimport hashSet from './_hashSet.js';\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n  var index = -1,\n      length = entries == null ? 0 : entries.length;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nexport default Hash;\n", "/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n  this.__data__ = [];\n  this.size = 0;\n}\n\nexport default listCacheClear;\n", "import eq from './eq.js';\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n  var length = array.length;\n  while (length--) {\n    if (eq(array[length][0], key)) {\n      return length;\n    }\n  }\n  return -1;\n}\n\nexport default assocIndexOf;\n", "import assocIndexOf from './_assocIndexOf.js';\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  if (index < 0) {\n    return false;\n  }\n  var lastIndex = data.length - 1;\n  if (index == lastIndex) {\n    data.pop();\n  } else {\n    splice.call(data, index, 1);\n  }\n  --this.size;\n  return true;\n}\n\nexport default listCacheDelete;\n", "import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  return index < 0 ? undefined : data[index][1];\n}\n\nexport default listCacheGet;\n", "import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n  return assocIndexOf(this.__data__, key) > -1;\n}\n\nexport default listCacheHas;\n", "import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n  var data = this.__data__,\n      index = assocIndexOf(data, key);\n\n  if (index < 0) {\n    ++this.size;\n    data.push([key, value]);\n  } else {\n    data[index][1] = value;\n  }\n  return this;\n}\n\nexport default listCacheSet;\n", "import listCacheClear from './_listCacheClear.js';\nimport listCacheDelete from './_listCacheDelete.js';\nimport listCacheGet from './_listCacheGet.js';\nimport listCacheHas from './_listCacheHas.js';\nimport listCacheSet from './_listCacheSet.js';\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n  var index = -1,\n      length = entries == null ? 0 : entries.length;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nexport default ListCache;\n", "import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nexport default Map;\n", "import Hash from './_Hash.js';\nimport ListCache from './_ListCache.js';\nimport Map from './_Map.js';\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n  this.size = 0;\n  this.__data__ = {\n    'hash': new Hash,\n    'map': new (Map || ListCache),\n    'string': new Hash\n  };\n}\n\nexport default mapCacheClear;\n", "/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n  var type = typeof value;\n  return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n    ? (value !== '__proto__')\n    : (value === null);\n}\n\nexport default isKeyable;\n", "import isKeyable from './_isKeyable.js';\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n  var data = map.__data__;\n  return isKeyable(key)\n    ? data[typeof key == 'string' ? 'string' : 'hash']\n    : data.map;\n}\n\nexport default getMapData;\n", "import getMapData from './_getMapData.js';\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n  var result = getMapData(this, key)['delete'](key);\n  this.size -= result ? 1 : 0;\n  return result;\n}\n\nexport default mapCacheDelete;\n", "import getMapData from './_getMapData.js';\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n  return getMapData(this, key).get(key);\n}\n\nexport default mapCacheGet;\n", "import getMapData from './_getMapData.js';\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n  return getMapData(this, key).has(key);\n}\n\nexport default mapCacheHas;\n", "import getMapData from './_getMapData.js';\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n  var data = getMapData(this, key),\n      size = data.size;\n\n  data.set(key, value);\n  this.size += data.size == size ? 0 : 1;\n  return this;\n}\n\nexport default mapCacheSet;\n", "import mapCacheClear from './_mapCacheClear.js';\nimport mapCacheDelete from './_mapCacheDelete.js';\nimport mapCacheGet from './_mapCacheGet.js';\nimport mapCacheHas from './_mapCacheHas.js';\nimport mapCacheSet from './_mapCacheSet.js';\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n  var index = -1,\n      length = entries == null ? 0 : entries.length;\n\n  this.clear();\n  while (++index < length) {\n    var entry = entries[index];\n    this.set(entry[0], entry[1]);\n  }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nexport default MapCache;\n", "import MapCache from './_MapCache.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n  if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  var memoized = function() {\n    var args = arguments,\n        key = resolver ? resolver.apply(this, args) : args[0],\n        cache = memoized.cache;\n\n    if (cache.has(key)) {\n      return cache.get(key);\n    }\n    var result = func.apply(this, args);\n    memoized.cache = cache.set(key, result) || cache;\n    return result;\n  };\n  memoized.cache = new (memoize.Cache || MapCache);\n  return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nexport default memoize;\n", "import memoize from './memoize.js';\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n  var result = memoize(func, function(key) {\n    if (cache.size === MAX_MEMOIZE_SIZE) {\n      cache.clear();\n    }\n    return key;\n  });\n\n  var cache = result.cache;\n  return result;\n}\n\nexport default memoizeCapped;\n", "import memoizeCapped from './_memoizeCapped.js';\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n  var result = [];\n  if (string.charCodeAt(0) === 46 /* . */) {\n    result.push('');\n  }\n  string.replace(rePropName, function(match, number, quote, subString) {\n    result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n  });\n  return result;\n});\n\nexport default stringToPath;\n", "import baseToString from './_baseToString.js';\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n  return value == null ? '' : baseToString(value);\n}\n\nexport default toString;\n", "import isArray from './isArray.js';\nimport isKey from './_isKey.js';\nimport stringToPath from './_stringToPath.js';\nimport toString from './toString.js';\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n  if (isArray(value)) {\n    return value;\n  }\n  return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nexport default castPath;\n", "import isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n  if (typeof value == 'string' || isSymbol(value)) {\n    return value;\n  }\n  var result = (value + '');\n  return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nexport default toKey;\n", "import castPath from './_castPath.js';\nimport toKey from './_toKey.js';\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n  path = castPath(path, object);\n\n  var index = 0,\n      length = path.length;\n\n  while (object != null && index < length) {\n    object = object[toKey(path[index++])];\n  }\n  return (index && index == length) ? object : undefined;\n}\n\nexport default baseGet;\n", "import baseGet from './_baseGet.js';\n\n/**\n * Gets the value at `path` of `object`. If the resolved value is\n * `undefined`, the `defaultValue` is returned in its place.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.get(object, 'a[0].b.c');\n * // => 3\n *\n * _.get(object, ['a', '0', 'b', 'c']);\n * // => 3\n *\n * _.get(object, 'a.b.c', 'default');\n * // => 'default'\n */\nfunction get(object, path, defaultValue) {\n  var result = object == null ? undefined : baseGet(object, path);\n  return result === undefined ? defaultValue : result;\n}\n\nexport default get;\n", "import get from './get.js';\n\n/**\n * The base implementation of `_.at` without support for individual paths.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {string[]} paths The property paths to pick.\n * @returns {Array} Returns the picked elements.\n */\nfunction baseAt(object, paths) {\n  var index = -1,\n      length = paths.length,\n      result = Array(length),\n      skip = object == null;\n\n  while (++index < length) {\n    result[index] = skip ? undefined : get(object, paths[index]);\n  }\n  return result;\n}\n\nexport default baseAt;\n", "/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n  var index = -1,\n      length = values.length,\n      offset = array.length;\n\n  while (++index < length) {\n    array[offset + index] = values[index];\n  }\n  return array;\n}\n\nexport default arrayPush;\n", "import Symbol from './_Symbol.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\n\n/** Built-in value references. */\nvar spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined;\n\n/**\n * Checks if `value` is a flattenable `arguments` object or array.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\n */\nfunction isFlattenable(value) {\n  return isArray(value) || isArguments(value) ||\n    !!(spreadableSymbol && value && value[spreadableSymbol]);\n}\n\nexport default isFlattenable;\n", "import arrayPush from './_arrayPush.js';\nimport isFlattenable from './_isFlattenable.js';\n\n/**\n * The base implementation of `_.flatten` with support for restricting flattening.\n *\n * @private\n * @param {Array} array The array to flatten.\n * @param {number} depth The maximum recursion depth.\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\nfunction baseFlatten(array, depth, predicate, isStrict, result) {\n  var index = -1,\n      length = array.length;\n\n  predicate || (predicate = isFlattenable);\n  result || (result = []);\n\n  while (++index < length) {\n    var value = array[index];\n    if (depth > 0 && predicate(value)) {\n      if (depth > 1) {\n        // Recursively flatten arrays (susceptible to call stack limits).\n        baseFlatten(value, depth - 1, predicate, isStrict, result);\n      } else {\n        arrayPush(result, value);\n      }\n    } else if (!isStrict) {\n      result[result.length] = value;\n    }\n  }\n  return result;\n}\n\nexport default baseFlatten;\n", "import baseFlatten from './_baseFlatten.js';\n\n/**\n * Flattens `array` a single level deep.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flatten([1, [2, [3, [4]], 5]]);\n * // => [1, 2, [3, [4]], 5]\n */\nfunction flatten(array) {\n  var length = array == null ? 0 : array.length;\n  return length ? baseFlatten(array, 1) : [];\n}\n\nexport default flatten;\n", "import flatten from './flatten.js';\nimport overRest from './_overRest.js';\nimport setToString from './_setToString.js';\n\n/**\n * A specialized version of `baseRest` which flattens the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\nfunction flatRest(func) {\n  return setToString(overRest(func, undefined, flatten), func + '');\n}\n\nexport default flatRest;\n", "import baseAt from './_baseAt.js';\nimport flatRest from './_flatRest.js';\n\n/**\n * Creates an array of values corresponding to `paths` of `object`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Array} Returns the picked values.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };\n *\n * _.at(object, ['a[0].b.c', 'a[1]']);\n * // => [3, 4]\n */\nvar at = flatRest(baseAt);\n\nexport default at;\n", "import overArg from './_overArg.js';\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nexport default getPrototype;\n", "import baseGetTag from './_baseGetTag.js';\nimport getPrototype from './_getPrototype.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n  if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\n    return false;\n  }\n  var proto = getPrototype(value);\n  if (proto === null) {\n    return true;\n  }\n  var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n  return typeof Ctor == 'function' && Ctor instanceof Ctor &&\n    funcToString.call(Ctor) == objectCtorString;\n}\n\nexport default isPlainObject;\n", "import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\nimport isPlainObject from './isPlainObject.js';\n\n/** `Object#toString` result references. */\nvar domExcTag = '[object DOMException]',\n    errorTag = '[object Error]';\n\n/**\n * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`,\n * `SyntaxError`, `TypeError`, or `URIError` object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an error object, else `false`.\n * @example\n *\n * _.isError(new Error);\n * // => true\n *\n * _.isError(Error);\n * // => false\n */\nfunction isError(value) {\n  if (!isObjectLike(value)) {\n    return false;\n  }\n  var tag = baseGetTag(value);\n  return tag == errorTag || tag == domExcTag ||\n    (typeof value.message == 'string' && typeof value.name == 'string' && !isPlainObject(value));\n}\n\nexport default isError;\n", "import apply from './_apply.js';\nimport baseRest from './_baseRest.js';\nimport isError from './isError.js';\n\n/**\n * Attempts to invoke `func`, returning either the result or the caught error\n * object. Any additional arguments are provided to `func` when it's invoked.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Util\n * @param {Function} func The function to attempt.\n * @param {...*} [args] The arguments to invoke `func` with.\n * @returns {*} Returns the `func` result or error object.\n * @example\n *\n * // Avoid throwing errors for invalid selectors.\n * var elements = _.attempt(function(selector) {\n *   return document.querySelectorAll(selector);\n * }, '>_>');\n *\n * if (_.isError(elements)) {\n *   elements = [];\n * }\n */\nvar attempt = baseRest(function(func, args) {\n  try {\n    return apply(func, undefined, args);\n  } catch (e) {\n    return isError(e) ? e : new Error(e);\n  }\n});\n\nexport default attempt;\n", "import toInteger from './toInteger.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that invokes `func`, with the `this` binding and arguments\n * of the created function, while it's called less than `n` times. Subsequent\n * calls to the created function return the result of the last `func` invocation.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {number} n The number of calls at which `func` is no longer invoked.\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * jQuery(element).on('click', _.before(5, addContactToList));\n * // => Allows adding up to 4 contacts to the list.\n */\nfunction before(n, func) {\n  var result;\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  n = toInteger(n);\n  return function() {\n    if (--n > 0) {\n      result = func.apply(this, arguments);\n    }\n    if (n <= 1) {\n      func = undefined;\n    }\n    return result;\n  };\n}\n\nexport default before;\n", "import baseRest from './_baseRest.js';\nimport createWrap from './_createWrap.js';\nimport getHolder from './_getHolder.js';\nimport replaceHolders from './_replaceHolders.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1,\n    WRAP_PARTIAL_FLAG = 32;\n\n/**\n * Creates a function that invokes `func` with the `this` binding of `thisArg`\n * and `partials` prepended to the arguments it receives.\n *\n * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds,\n * may be used as a placeholder for partially applied arguments.\n *\n * **Note:** Unlike native `Function#bind`, this method doesn't set the \"length\"\n * property of bound functions.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to bind.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new bound function.\n * @example\n *\n * function greet(greeting, punctuation) {\n *   return greeting + ' ' + this.user + punctuation;\n * }\n *\n * var object = { 'user': 'fred' };\n *\n * var bound = _.bind(greet, object, 'hi');\n * bound('!');\n * // => 'hi fred!'\n *\n * // Bound with placeholders.\n * var bound = _.bind(greet, object, _, '!');\n * bound('hi');\n * // => 'hi fred!'\n */\nvar bind = baseRest(function(func, thisArg, partials) {\n  var bitmask = WRAP_BIND_FLAG;\n  if (partials.length) {\n    var holders = replaceHolders(partials, getHolder(bind));\n    bitmask |= WRAP_PARTIAL_FLAG;\n  }\n  return createWrap(func, bitmask, thisArg, partials, holders);\n});\n\n// Assign default placeholders.\nbind.placeholder = {};\n\nexport default bind;\n", "import arrayEach from './_arrayEach.js';\nimport baseAssignValue from './_baseAssignValue.js';\nimport bind from './bind.js';\nimport flatRest from './_flatRest.js';\nimport toKey from './_toKey.js';\n\n/**\n * Binds methods of an object to the object itself, overwriting the existing\n * method.\n *\n * **Note:** This method doesn't set the \"length\" property of bound functions.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {Object} object The object to bind and assign the bound methods to.\n * @param {...(string|string[])} methodNames The object method names to bind.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var view = {\n *   'label': 'docs',\n *   'click': function() {\n *     console.log('clicked ' + this.label);\n *   }\n * };\n *\n * _.bindAll(view, ['click']);\n * jQuery(element).on('click', view.click);\n * // => Logs 'clicked docs' when clicked.\n */\nvar bindAll = flatRest(function(object, methodNames) {\n  arrayEach(methodNames, function(key) {\n    key = toKey(key);\n    baseAssignValue(object, key, bind(object[key], object));\n  });\n  return object;\n});\n\nexport default bindAll;\n", "import baseRest from './_baseRest.js';\nimport createWrap from './_createWrap.js';\nimport getHolder from './_getHolder.js';\nimport replaceHolders from './_replaceHolders.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1,\n    WRAP_BIND_KEY_FLAG = 2,\n    WRAP_PARTIAL_FLAG = 32;\n\n/**\n * Creates a function that invokes the method at `object[key]` with `partials`\n * prepended to the arguments it receives.\n *\n * This method differs from `_.bind` by allowing bound functions to reference\n * methods that may be redefined or don't yet exist. See\n * [Peter Michaux's article](http://peter.michaux.ca/articles/lazy-function-definition-pattern)\n * for more details.\n *\n * The `_.bindKey.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * @static\n * @memberOf _\n * @since 0.10.0\n * @category Function\n * @param {Object} object The object to invoke the method on.\n * @param {string} key The key of the method.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new bound function.\n * @example\n *\n * var object = {\n *   'user': 'fred',\n *   'greet': function(greeting, punctuation) {\n *     return greeting + ' ' + this.user + punctuation;\n *   }\n * };\n *\n * var bound = _.bindKey(object, 'greet', 'hi');\n * bound('!');\n * // => 'hi fred!'\n *\n * object.greet = function(greeting, punctuation) {\n *   return greeting + 'ya ' + this.user + punctuation;\n * };\n *\n * bound('!');\n * // => 'hiya fred!'\n *\n * // Bound with placeholders.\n * var bound = _.bindKey(object, 'greet', _, '!');\n * bound('hi');\n * // => 'hiya fred!'\n */\nvar bindKey = baseRest(function(object, key, partials) {\n  var bitmask = WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG;\n  if (partials.length) {\n    var holders = replaceHolders(partials, getHolder(bindKey));\n    bitmask |= WRAP_PARTIAL_FLAG;\n  }\n  return createWrap(key, bitmask, object, partials, holders);\n});\n\n// Assign default placeholders.\nbindKey.placeholder = {};\n\nexport default bindKey;\n", "/**\n * The base implementation of `_.slice` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\nfunction baseSlice(array, start, end) {\n  var index = -1,\n      length = array.length;\n\n  if (start < 0) {\n    start = -start > length ? 0 : (length + start);\n  }\n  end = end > length ? length : end;\n  if (end < 0) {\n    end += length;\n  }\n  length = start > end ? 0 : ((end - start) >>> 0);\n  start >>>= 0;\n\n  var result = Array(length);\n  while (++index < length) {\n    result[index] = array[index + start];\n  }\n  return result;\n}\n\nexport default baseSlice;\n", "import baseSlice from './_baseSlice.js';\n\n/**\n * Casts `array` to a slice if it's needed.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {number} start The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the cast slice.\n */\nfunction castSlice(array, start, end) {\n  var length = array.length;\n  end = end === undefined ? length : end;\n  return (!start && end >= length) ? array : baseSlice(array, start, end);\n}\n\nexport default castSlice;\n", "/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n    rsComboMarksRange = '\\\\u0300-\\\\u036f',\n    reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n    rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n    rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n    rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsZWJ = '\\\\u200d';\n\n/** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */\nvar reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange  + rsComboRange + rsVarRange + ']');\n\n/**\n * Checks if `string` contains Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a symbol is found, else `false`.\n */\nfunction hasUnicode(string) {\n  return reHasUnicode.test(string);\n}\n\nexport default hasUnicode;\n", "/**\n * Converts an ASCII `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction asciiToArray(string) {\n  return string.split('');\n}\n\nexport default asciiToArray;\n", "/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n    rsComboMarksRange = '\\\\u0300-\\\\u036f',\n    reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n    rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n    rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n    rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsAstral = '[' + rsAstralRange + ']',\n    rsCombo = '[' + rsComboRange + ']',\n    rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n    rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n    rsNonAstral = '[^' + rsAstralRange + ']',\n    rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n    rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n    rsZWJ = '\\\\u200d';\n\n/** Used to compose unicode regexes. */\nvar reOptMod = rsModifier + '?',\n    rsOptVar = '[' + rsVarRange + ']?',\n    rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n    rsSeq = rsOptVar + reOptMod + rsOptJoin,\n    rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\n/** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\nvar reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n\n/**\n * Converts a Unicode `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction unicodeToArray(string) {\n  return string.match(reUnicode) || [];\n}\n\nexport default unicodeToArray;\n", "import asciiToArray from './_asciiToArray.js';\nimport hasUnicode from './_hasUnicode.js';\nimport unicodeToArray from './_unicodeToArray.js';\n\n/**\n * Converts `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction stringToArray(string) {\n  return hasUnicode(string)\n    ? unicodeToArray(string)\n    : asciiToArray(string);\n}\n\nexport default stringToArray;\n", "import castSlice from './_castSlice.js';\nimport hasUnicode from './_hasUnicode.js';\nimport stringToArray from './_stringToArray.js';\nimport toString from './toString.js';\n\n/**\n * Creates a function like `_.lowerFirst`.\n *\n * @private\n * @param {string} methodName The name of the `String` case method to use.\n * @returns {Function} Returns the new case function.\n */\nfunction createCaseFirst(methodName) {\n  return function(string) {\n    string = toString(string);\n\n    var strSymbols = hasUnicode(string)\n      ? stringToArray(string)\n      : undefined;\n\n    var chr = strSymbols\n      ? strSymbols[0]\n      : string.charAt(0);\n\n    var trailing = strSymbols\n      ? castSlice(strSymbols, 1).join('')\n      : string.slice(1);\n\n    return chr[methodName]() + trailing;\n  };\n}\n\nexport default createCaseFirst;\n", "import createCaseFirst from './_createCaseFirst.js';\n\n/**\n * Converts the first character of `string` to upper case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.upperFirst('fred');\n * // => 'Fred'\n *\n * _.upperFirst('FRED');\n * // => 'FRED'\n */\nvar upperFirst = createCaseFirst('toUpperCase');\n\nexport default upperFirst;\n", "import toString from './toString.js';\nimport upperFirst from './upperFirst.js';\n\n/**\n * Converts the first character of `string` to upper case and the remaining\n * to lower case.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to capitalize.\n * @returns {string} Returns the capitalized string.\n * @example\n *\n * _.capitalize('FRED');\n * // => 'Fred'\n */\nfunction capitalize(string) {\n  return upperFirst(toString(string).toLowerCase());\n}\n\nexport default capitalize;\n", "/**\n * A specialized version of `_.reduce` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the first element of `array` as\n *  the initial value.\n * @returns {*} Returns the accumulated value.\n */\nfunction arrayReduce(array, iteratee, accumulator, initAccum) {\n  var index = -1,\n      length = array == null ? 0 : array.length;\n\n  if (initAccum && length) {\n    accumulator = array[++index];\n  }\n  while (++index < length) {\n    accumulator = iteratee(accumulator, array[index], index, array);\n  }\n  return accumulator;\n}\n\nexport default arrayReduce;\n", "/**\n * The base implementation of `_.propertyOf` without support for deep paths.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Function} Returns the new accessor function.\n */\nfunction basePropertyOf(object) {\n  return function(key) {\n    return object == null ? undefined : object[key];\n  };\n}\n\nexport default basePropertyOf;\n", "import basePropertyOf from './_basePropertyOf.js';\n\n/** Used to map Latin Unicode letters to basic Latin letters. */\nvar deburredLetters = {\n  // Latin-1 Supplement block.\n  '\\xc0': 'A',  '\\xc1': 'A', '\\xc2': 'A', '\\xc3': 'A', '\\xc4': 'A', '\\xc5': 'A',\n  '\\xe0': 'a',  '\\xe1': 'a', '\\xe2': 'a', '\\xe3': 'a', '\\xe4': 'a', '\\xe5': 'a',\n  '\\xc7': 'C',  '\\xe7': 'c',\n  '\\xd0': 'D',  '\\xf0': 'd',\n  '\\xc8': 'E',  '\\xc9': 'E', '\\xca': 'E', '\\xcb': 'E',\n  '\\xe8': 'e',  '\\xe9': 'e', '\\xea': 'e', '\\xeb': 'e',\n  '\\xcc': 'I',  '\\xcd': 'I', '\\xce': 'I', '\\xcf': 'I',\n  '\\xec': 'i',  '\\xed': 'i', '\\xee': 'i', '\\xef': 'i',\n  '\\xd1': 'N',  '\\xf1': 'n',\n  '\\xd2': 'O',  '\\xd3': 'O', '\\xd4': 'O', '\\xd5': 'O', '\\xd6': 'O', '\\xd8': 'O',\n  '\\xf2': 'o',  '\\xf3': 'o', '\\xf4': 'o', '\\xf5': 'o', '\\xf6': 'o', '\\xf8': 'o',\n  '\\xd9': 'U',  '\\xda': 'U', '\\xdb': 'U', '\\xdc': 'U',\n  '\\xf9': 'u',  '\\xfa': 'u', '\\xfb': 'u', '\\xfc': 'u',\n  '\\xdd': 'Y',  '\\xfd': 'y', '\\xff': 'y',\n  '\\xc6': 'Ae', '\\xe6': 'ae',\n  '\\xde': 'Th', '\\xfe': 'th',\n  '\\xdf': 'ss',\n  // Latin Extended-A block.\n  '\\u0100': 'A',  '\\u0102': 'A', '\\u0104': 'A',\n  '\\u0101': 'a',  '\\u0103': 'a', '\\u0105': 'a',\n  '\\u0106': 'C',  '\\u0108': 'C', '\\u010a': 'C', '\\u010c': 'C',\n  '\\u0107': 'c',  '\\u0109': 'c', '\\u010b': 'c', '\\u010d': 'c',\n  '\\u010e': 'D',  '\\u0110': 'D', '\\u010f': 'd', '\\u0111': 'd',\n  '\\u0112': 'E',  '\\u0114': 'E', '\\u0116': 'E', '\\u0118': 'E', '\\u011a': 'E',\n  '\\u0113': 'e',  '\\u0115': 'e', '\\u0117': 'e', '\\u0119': 'e', '\\u011b': 'e',\n  '\\u011c': 'G',  '\\u011e': 'G', '\\u0120': 'G', '\\u0122': 'G',\n  '\\u011d': 'g',  '\\u011f': 'g', '\\u0121': 'g', '\\u0123': 'g',\n  '\\u0124': 'H',  '\\u0126': 'H', '\\u0125': 'h', '\\u0127': 'h',\n  '\\u0128': 'I',  '\\u012a': 'I', '\\u012c': 'I', '\\u012e': 'I', '\\u0130': 'I',\n  '\\u0129': 'i',  '\\u012b': 'i', '\\u012d': 'i', '\\u012f': 'i', '\\u0131': 'i',\n  '\\u0134': 'J',  '\\u0135': 'j',\n  '\\u0136': 'K',  '\\u0137': 'k', '\\u0138': 'k',\n  '\\u0139': 'L',  '\\u013b': 'L', '\\u013d': 'L', '\\u013f': 'L', '\\u0141': 'L',\n  '\\u013a': 'l',  '\\u013c': 'l', '\\u013e': 'l', '\\u0140': 'l', '\\u0142': 'l',\n  '\\u0143': 'N',  '\\u0145': 'N', '\\u0147': 'N', '\\u014a': 'N',\n  '\\u0144': 'n',  '\\u0146': 'n', '\\u0148': 'n', '\\u014b': 'n',\n  '\\u014c': 'O',  '\\u014e': 'O', '\\u0150': 'O',\n  '\\u014d': 'o',  '\\u014f': 'o', '\\u0151': 'o',\n  '\\u0154': 'R',  '\\u0156': 'R', '\\u0158': 'R',\n  '\\u0155': 'r',  '\\u0157': 'r', '\\u0159': 'r',\n  '\\u015a': 'S',  '\\u015c': 'S', '\\u015e': 'S', '\\u0160': 'S',\n  '\\u015b': 's',  '\\u015d': 's', '\\u015f': 's', '\\u0161': 's',\n  '\\u0162': 'T',  '\\u0164': 'T', '\\u0166': 'T',\n  '\\u0163': 't',  '\\u0165': 't', '\\u0167': 't',\n  '\\u0168': 'U',  '\\u016a': 'U', '\\u016c': 'U', '\\u016e': 'U', '\\u0170': 'U', '\\u0172': 'U',\n  '\\u0169': 'u',  '\\u016b': 'u', '\\u016d': 'u', '\\u016f': 'u', '\\u0171': 'u', '\\u0173': 'u',\n  '\\u0174': 'W',  '\\u0175': 'w',\n  '\\u0176': 'Y',  '\\u0177': 'y', '\\u0178': 'Y',\n  '\\u0179': 'Z',  '\\u017b': 'Z', '\\u017d': 'Z',\n  '\\u017a': 'z',  '\\u017c': 'z', '\\u017e': 'z',\n  '\\u0132': 'IJ', '\\u0133': 'ij',\n  '\\u0152': 'Oe', '\\u0153': 'oe',\n  '\\u0149': \"'n\", '\\u017f': 's'\n};\n\n/**\n * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A\n * letters to basic Latin letters.\n *\n * @private\n * @param {string} letter The matched letter to deburr.\n * @returns {string} Returns the deburred letter.\n */\nvar deburrLetter = basePropertyOf(deburredLetters);\n\nexport default deburrLetter;\n", "import deburrLetter from './_deburrLetter.js';\nimport toString from './toString.js';\n\n/** Used to match Latin Unicode letters (excluding mathematical operators). */\nvar reLatin = /[\\xc0-\\xd6\\xd8-\\xf6\\xf8-\\xff\\u0100-\\u017f]/g;\n\n/** Used to compose unicode character classes. */\nvar rsComboMarksRange = '\\\\u0300-\\\\u036f',\n    reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n    rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n    rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange;\n\n/** Used to compose unicode capture groups. */\nvar rsCombo = '[' + rsComboRange + ']';\n\n/**\n * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and\n * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols).\n */\nvar reComboMark = RegExp(rsCombo, 'g');\n\n/**\n * Deburrs `string` by converting\n * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table)\n * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A)\n * letters to basic Latin letters and removing\n * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to deburr.\n * @returns {string} Returns the deburred string.\n * @example\n *\n * _.deburr('déjà vu');\n * // => 'deja vu'\n */\nfunction deburr(string) {\n  string = toString(string);\n  return string && string.replace(reLatin, deburrLetter).replace(reComboMark, '');\n}\n\nexport default deburr;\n", "/** Used to match words composed of alphanumeric characters. */\nvar reAsciiWord = /[^\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\x7f]+/g;\n\n/**\n * Splits an ASCII `string` into an array of its words.\n *\n * @private\n * @param {string} The string to inspect.\n * @returns {Array} Returns the words of `string`.\n */\nfunction asciiWords(string) {\n  return string.match(reAsciiWord) || [];\n}\n\nexport default asciiWords;\n", "/** Used to detect strings that need a more robust regexp to match words. */\nvar reHasUnicodeWord = /[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;\n\n/**\n * Checks if `string` contains a word composed of Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a word is found, else `false`.\n */\nfunction hasUnicodeWord(string) {\n  return reHasUnicodeWord.test(string);\n}\n\nexport default hasUnicodeWord;\n", "/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n    rsComboMarksRange = '\\\\u0300-\\\\u036f',\n    reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n    rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n    rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n    rsDingbatRange = '\\\\u2700-\\\\u27bf',\n    rsLowerRange = 'a-z\\\\xdf-\\\\xf6\\\\xf8-\\\\xff',\n    rsMathOpRange = '\\\\xac\\\\xb1\\\\xd7\\\\xf7',\n    rsNonCharRange = '\\\\x00-\\\\x2f\\\\x3a-\\\\x40\\\\x5b-\\\\x60\\\\x7b-\\\\xbf',\n    rsPunctuationRange = '\\\\u2000-\\\\u206f',\n    rsSpaceRange = ' \\\\t\\\\x0b\\\\f\\\\xa0\\\\ufeff\\\\n\\\\r\\\\u2028\\\\u2029\\\\u1680\\\\u180e\\\\u2000\\\\u2001\\\\u2002\\\\u2003\\\\u2004\\\\u2005\\\\u2006\\\\u2007\\\\u2008\\\\u2009\\\\u200a\\\\u202f\\\\u205f\\\\u3000',\n    rsUpperRange = 'A-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde',\n    rsVarRange = '\\\\ufe0e\\\\ufe0f',\n    rsBreakRange = rsMathOpRange + rsNonCharRange + rsPunctuationRange + rsSpaceRange;\n\n/** Used to compose unicode capture groups. */\nvar rsApos = \"['\\u2019]\",\n    rsBreak = '[' + rsBreakRange + ']',\n    rsCombo = '[' + rsComboRange + ']',\n    rsDigits = '\\\\d+',\n    rsDingbat = '[' + rsDingbatRange + ']',\n    rsLower = '[' + rsLowerRange + ']',\n    rsMisc = '[^' + rsAstralRange + rsBreakRange + rsDigits + rsDingbatRange + rsLowerRange + rsUpperRange + ']',\n    rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n    rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n    rsNonAstral = '[^' + rsAstralRange + ']',\n    rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n    rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n    rsUpper = '[' + rsUpperRange + ']',\n    rsZWJ = '\\\\u200d';\n\n/** Used to compose unicode regexes. */\nvar rsMiscLower = '(?:' + rsLower + '|' + rsMisc + ')',\n    rsMiscUpper = '(?:' + rsUpper + '|' + rsMisc + ')',\n    rsOptContrLower = '(?:' + rsApos + '(?:d|ll|m|re|s|t|ve))?',\n    rsOptContrUpper = '(?:' + rsApos + '(?:D|LL|M|RE|S|T|VE))?',\n    reOptMod = rsModifier + '?',\n    rsOptVar = '[' + rsVarRange + ']?',\n    rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n    rsOrdLower = '\\\\d*(?:1st|2nd|3rd|(?![123])\\\\dth)(?=\\\\b|[A-Z_])',\n    rsOrdUpper = '\\\\d*(?:1ST|2ND|3RD|(?![123])\\\\dTH)(?=\\\\b|[a-z_])',\n    rsSeq = rsOptVar + reOptMod + rsOptJoin,\n    rsEmoji = '(?:' + [rsDingbat, rsRegional, rsSurrPair].join('|') + ')' + rsSeq;\n\n/** Used to match complex or compound words. */\nvar reUnicodeWord = RegExp([\n  rsUpper + '?' + rsLower + '+' + rsOptContrLower + '(?=' + [rsBreak, rsUpper, '$'].join('|') + ')',\n  rsMiscUpper + '+' + rsOptContrUpper + '(?=' + [rsBreak, rsUpper + rsMiscLower, '$'].join('|') + ')',\n  rsUpper + '?' + rsMiscLower + '+' + rsOptContrLower,\n  rsUpper + '+' + rsOptContrUpper,\n  rsOrdUpper,\n  rsOrdLower,\n  rsDigits,\n  rsEmoji\n].join('|'), 'g');\n\n/**\n * Splits a Unicode `string` into an array of its words.\n *\n * @private\n * @param {string} The string to inspect.\n * @returns {Array} Returns the words of `string`.\n */\nfunction unicodeWords(string) {\n  return string.match(reUnicodeWord) || [];\n}\n\nexport default unicodeWords;\n", "import asciiWords from './_asciiWords.js';\nimport hasUnicodeWord from './_hasUnicodeWord.js';\nimport toString from './toString.js';\nimport unicodeWords from './_unicodeWords.js';\n\n/**\n * Splits `string` into an array of its words.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {RegExp|string} [pattern] The pattern to match words.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the words of `string`.\n * @example\n *\n * _.words('fred, barney, & pebbles');\n * // => ['fred', 'barney', 'pebbles']\n *\n * _.words('fred, barney, & pebbles', /[^, ]+/g);\n * // => ['fred', 'barney', '&', 'pebbles']\n */\nfunction words(string, pattern, guard) {\n  string = toString(string);\n  pattern = guard ? undefined : pattern;\n\n  if (pattern === undefined) {\n    return hasUnicodeWord(string) ? unicodeWords(string) : asciiWords(string);\n  }\n  return string.match(pattern) || [];\n}\n\nexport default words;\n", "import arrayReduce from './_arrayReduce.js';\nimport deburr from './deburr.js';\nimport words from './words.js';\n\n/** Used to compose unicode capture groups. */\nvar rsApos = \"['\\u2019]\";\n\n/** Used to match apostrophes. */\nvar reApos = RegExp(rsApos, 'g');\n\n/**\n * Creates a function like `_.camelCase`.\n *\n * @private\n * @param {Function} callback The function to combine each word.\n * @returns {Function} Returns the new compounder function.\n */\nfunction createCompounder(callback) {\n  return function(string) {\n    return arrayReduce(words(deburr(string).replace(reApos, '')), callback, '');\n  };\n}\n\nexport default createCompounder;\n", "import capitalize from './capitalize.js';\nimport createCompounder from './_createCompounder.js';\n\n/**\n * Converts `string` to [camel case](https://en.wikipedia.org/wiki/CamelCase).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the camel cased string.\n * @example\n *\n * _.camelCase('Foo Bar');\n * // => 'fooBar'\n *\n * _.camelCase('--foo-bar--');\n * // => 'fooBar'\n *\n * _.camelCase('__FOO_BAR__');\n * // => 'fooBar'\n */\nvar camelCase = createCompounder(function(result, word, index) {\n  word = word.toLowerCase();\n  return result + (index ? capitalize(word) : word);\n});\n\nexport default camelCase;\n", "import isArray from './isArray.js';\n\n/**\n * Casts `value` as an array if it's not one.\n *\n * @static\n * @memberOf _\n * @since 4.4.0\n * @category Lang\n * @param {*} value The value to inspect.\n * @returns {Array} Returns the cast array.\n * @example\n *\n * _.castArray(1);\n * // => [1]\n *\n * _.castArray({ 'a': 1 });\n * // => [{ 'a': 1 }]\n *\n * _.castArray('abc');\n * // => ['abc']\n *\n * _.castArray(null);\n * // => [null]\n *\n * _.castArray(undefined);\n * // => [undefined]\n *\n * _.castArray();\n * // => []\n *\n * var array = [1, 2, 3];\n * console.log(_.castArray(array) === array);\n * // => true\n */\nfunction castArray() {\n  if (!arguments.length) {\n    return [];\n  }\n  var value = arguments[0];\n  return isArray(value) ? value : [value];\n}\n\nexport default castArray;\n", "import root from './_root.js';\nimport toInteger from './toInteger.js';\nimport toNumber from './toNumber.js';\nimport toString from './toString.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsFinite = root.isFinite,\n    nativeMin = Math.min;\n\n/**\n * Creates a function like `_.round`.\n *\n * @private\n * @param {string} methodName The name of the `Math` method to use when rounding.\n * @returns {Function} Returns the new round function.\n */\nfunction createRound(methodName) {\n  var func = Math[methodName];\n  return function(number, precision) {\n    number = toNumber(number);\n    precision = precision == null ? 0 : nativeMin(toInteger(precision), 292);\n    if (precision && nativeIsFinite(number)) {\n      // Shift with exponential notation to avoid floating-point issues.\n      // See [MDN](https://mdn.io/round#Examples) for more details.\n      var pair = (toString(number) + 'e').split('e'),\n          value = func(pair[0] + 'e' + (+pair[1] + precision));\n\n      pair = (toString(value) + 'e').split('e');\n      return +(pair[0] + 'e' + (+pair[1] - precision));\n    }\n    return func(number);\n  };\n}\n\nexport default createRound;\n", "import createRound from './_createRound.js';\n\n/**\n * Computes `number` rounded up to `precision`.\n *\n * @static\n * @memberOf _\n * @since 3.10.0\n * @category Math\n * @param {number} number The number to round up.\n * @param {number} [precision=0] The precision to round up to.\n * @returns {number} Returns the rounded up number.\n * @example\n *\n * _.ceil(4.006);\n * // => 5\n *\n * _.ceil(6.004, 2);\n * // => 6.01\n *\n * _.ceil(6040, -2);\n * // => 6100\n */\nvar ceil = createRound('ceil');\n\nexport default ceil;\n", "import lodash from './wrapperLodash.js';\n\n/**\n * Creates a `lodash` wrapper instance that wraps `value` with explicit method\n * chain sequences enabled. The result of such sequences must be unwrapped\n * with `_#value`.\n *\n * @static\n * @memberOf _\n * @since 1.3.0\n * @category Seq\n * @param {*} value The value to wrap.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var users = [\n *   { 'user': 'barney',  'age': 36 },\n *   { 'user': 'fred',    'age': 40 },\n *   { 'user': 'pebbles', 'age': 1 }\n * ];\n *\n * var youngest = _\n *   .chain(users)\n *   .sortBy('age')\n *   .map(function(o) {\n *     return o.user + ' is ' + o.age;\n *   })\n *   .head()\n *   .value();\n * // => 'pebbles is 1'\n */\nfunction chain(value) {\n  var result = lodash(value);\n  result.__chain__ = true;\n  return result;\n}\n\nexport default chain;\n", "import baseSlice from './_baseSlice.js';\nimport isIterateeCall from './_isIterateeCall.js';\nimport toInteger from './toInteger.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeCeil = Math.ceil,\n    nativeMax = Math.max;\n\n/**\n * Creates an array of elements split into groups the length of `size`.\n * If `array` can't be split evenly, the final chunk will be the remaining\n * elements.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to process.\n * @param {number} [size=1] The length of each chunk\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the new array of chunks.\n * @example\n *\n * _.chunk(['a', 'b', 'c', 'd'], 2);\n * // => [['a', 'b'], ['c', 'd']]\n *\n * _.chunk(['a', 'b', 'c', 'd'], 3);\n * // => [['a', 'b', 'c'], ['d']]\n */\nfunction chunk(array, size, guard) {\n  if ((guard ? isIterateeCall(array, size, guard) : size === undefined)) {\n    size = 1;\n  } else {\n    size = nativeMax(toInteger(size), 0);\n  }\n  var length = array == null ? 0 : array.length;\n  if (!length || size < 1) {\n    return [];\n  }\n  var index = 0,\n      resIndex = 0,\n      result = Array(nativeCeil(length / size));\n\n  while (index < length) {\n    result[resIndex++] = baseSlice(array, index, (index += size));\n  }\n  return result;\n}\n\nexport default chunk;\n", "/**\n * The base implementation of `_.clamp` which doesn't coerce arguments.\n *\n * @private\n * @param {number} number The number to clamp.\n * @param {number} [lower] The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the clamped number.\n */\nfunction baseClamp(number, lower, upper) {\n  if (number === number) {\n    if (upper !== undefined) {\n      number = number <= upper ? number : upper;\n    }\n    if (lower !== undefined) {\n      number = number >= lower ? number : lower;\n    }\n  }\n  return number;\n}\n\nexport default baseClamp;\n", "import baseClamp from './_baseClamp.js';\nimport toNumber from './toNumber.js';\n\n/**\n * Clamps `number` within the inclusive `lower` and `upper` bounds.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Number\n * @param {number} number The number to clamp.\n * @param {number} [lower] The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the clamped number.\n * @example\n *\n * _.clamp(-10, -5, 5);\n * // => -5\n *\n * _.clamp(10, -5, 5);\n * // => 5\n */\nfunction clamp(number, lower, upper) {\n  if (upper === undefined) {\n    upper = lower;\n    lower = undefined;\n  }\n  if (upper !== undefined) {\n    upper = toNumber(upper);\n    upper = upper === upper ? upper : 0;\n  }\n  if (lower !== undefined) {\n    lower = toNumber(lower);\n    lower = lower === lower ? lower : 0;\n  }\n  return baseClamp(toNumber(number), lower, upper);\n}\n\nexport default clamp;\n", "import ListCache from './_ListCache.js';\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n  this.__data__ = new ListCache;\n  this.size = 0;\n}\n\nexport default stackClear;\n", "/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n  var data = this.__data__,\n      result = data['delete'](key);\n\n  this.size = data.size;\n  return result;\n}\n\nexport default stackDelete;\n", "/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n  return this.__data__.get(key);\n}\n\nexport default stackGet;\n", "/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n  return this.__data__.has(key);\n}\n\nexport default stackHas;\n", "import ListCache from './_ListCache.js';\nimport Map from './_Map.js';\nimport MapCache from './_MapCache.js';\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n  var data = this.__data__;\n  if (data instanceof ListCache) {\n    var pairs = data.__data__;\n    if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n      pairs.push([key, value]);\n      this.size = ++data.size;\n      return this;\n    }\n    data = this.__data__ = new MapCache(pairs);\n  }\n  data.set(key, value);\n  this.size = data.size;\n  return this;\n}\n\nexport default stackSet;\n", "import ListCache from './_ListCache.js';\nimport stackClear from './_stackClear.js';\nimport stackDelete from './_stackDelete.js';\nimport stackGet from './_stackGet.js';\nimport stackHas from './_stackHas.js';\nimport stackSet from './_stackSet.js';\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n  var data = this.__data__ = new ListCache(entries);\n  this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nexport default Stack;\n", "import copyObject from './_copyObject.js';\nimport keys from './keys.js';\n\n/**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssign(object, source) {\n  return object && copyObject(source, keys(source), object);\n}\n\nexport default baseAssign;\n", "import copyObject from './_copyObject.js';\nimport keysIn from './keysIn.js';\n\n/**\n * The base implementation of `_.assignIn` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssignIn(object, source) {\n  return object && copyObject(source, keysIn(source), object);\n}\n\nexport default baseAssignIn;\n", "import root from './_root.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n    allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined;\n\n/**\n * Creates a clone of  `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n  if (isDeep) {\n    return buffer.slice();\n  }\n  var length = buffer.length,\n      result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n  buffer.copy(result);\n  return result;\n}\n\nexport default cloneBuffer;\n", "/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n  var index = -1,\n      length = array == null ? 0 : array.length,\n      resIndex = 0,\n      result = [];\n\n  while (++index < length) {\n    var value = array[index];\n    if (predicate(value, index, array)) {\n      result[resIndex++] = value;\n    }\n  }\n  return result;\n}\n\nexport default arrayFilter;\n", "/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n  return [];\n}\n\nexport default stubArray;\n", "import arrayFilter from './_arrayFilter.js';\nimport stubArray from './stubArray.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n  if (object == null) {\n    return [];\n  }\n  object = Object(object);\n  return arrayFilter(nativeGetSymbols(object), function(symbol) {\n    return propertyIsEnumerable.call(object, symbol);\n  });\n};\n\nexport default getSymbols;\n", "import copyObject from './_copyObject.js';\nimport getSymbols from './_getSymbols.js';\n\n/**\n * Copies own symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbols(source, object) {\n  return copyObject(source, getSymbols(source), object);\n}\n\nexport default copySymbols;\n", "import arrayPush from './_arrayPush.js';\nimport getPrototype from './_getPrototype.js';\nimport getSymbols from './_getSymbols.js';\nimport stubArray from './stubArray.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own and inherited enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\n  var result = [];\n  while (object) {\n    arrayPush(result, getSymbols(object));\n    object = getPrototype(object);\n  }\n  return result;\n};\n\nexport default getSymbolsIn;\n", "import copyObject from './_copyObject.js';\nimport getSymbolsIn from './_getSymbolsIn.js';\n\n/**\n * Copies own and inherited symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbolsIn(source, object) {\n  return copyObject(source, getSymbolsIn(source), object);\n}\n\nexport default copySymbolsIn;\n", "import arrayPush from './_arrayPush.js';\nimport isArray from './isArray.js';\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n  var result = keysFunc(object);\n  return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\nexport default baseGetAllKeys;\n", "import baseGetAllKeys from './_baseGetAllKeys.js';\nimport getSymbols from './_getSymbols.js';\nimport keys from './keys.js';\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n  return baseGetAllKeys(object, keys, getSymbols);\n}\n\nexport default getAllKeys;\n", "import baseGetAllKeys from './_baseGetAllKeys.js';\nimport getSymbolsIn from './_getSymbolsIn.js';\nimport keysIn from './keysIn.js';\n\n/**\n * Creates an array of own and inherited enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeysIn(object) {\n  return baseGetAllKeys(object, keysIn, getSymbolsIn);\n}\n\nexport default getAllKeysIn;\n", "import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nexport default DataView;\n", "import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nexport default Promise;\n", "import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nexport default Set;\n", "import DataView from './_DataView.js';\nimport Map from './_Map.js';\nimport Promise from './_Promise.js';\nimport Set from './_Set.js';\nimport WeakMap from './_WeakMap.js';\nimport baseGetTag from './_baseGetTag.js';\nimport toSource from './_toSource.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n    objectTag = '[object Object]',\n    promiseTag = '[object Promise]',\n    setTag = '[object Set]',\n    weakMapTag = '[object WeakMap]';\n\nvar dataViewTag = '[object DataView]';\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n    mapCtorString = toSource(Map),\n    promiseCtorString = toSource(Promise),\n    setCtorString = toSource(Set),\n    weakMapCtorString = toSource(WeakMap);\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n    (Map && getTag(new Map) != mapTag) ||\n    (Promise && getTag(Promise.resolve()) != promiseTag) ||\n    (Set && getTag(new Set) != setTag) ||\n    (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n  getTag = function(value) {\n    var result = baseGetTag(value),\n        Ctor = result == objectTag ? value.constructor : undefined,\n        ctorString = Ctor ? toSource(Ctor) : '';\n\n    if (ctorString) {\n      switch (ctorString) {\n        case dataViewCtorString: return dataViewTag;\n        case mapCtorString: return mapTag;\n        case promiseCtorString: return promiseTag;\n        case setCtorString: return setTag;\n        case weakMapCtorString: return weakMapTag;\n      }\n    }\n    return result;\n  };\n}\n\nexport default getTag;\n", "/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n  var length = array.length,\n      result = new array.constructor(length);\n\n  // Add properties assigned by `RegExp#exec`.\n  if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n    result.index = array.index;\n    result.input = array.input;\n  }\n  return result;\n}\n\nexport default initCloneArray;\n", "import root from './_root.js';\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nexport default Uint8Array;\n", "import Uint8Array from './_Uint8Array.js';\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n  var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n  new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n  return result;\n}\n\nexport default cloneArrayBuffer;\n", "import cloneArrayBuffer from './_cloneArrayBuffer.js';\n\n/**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\nfunction cloneDataView(dataView, isDeep) {\n  var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n  return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n}\n\nexport default cloneDataView;\n", "/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\nfunction cloneRegExp(regexp) {\n  var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n  result.lastIndex = regexp.lastIndex;\n  return result;\n}\n\nexport default cloneRegExp;\n", "import Symbol from './_Symbol.js';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\nfunction cloneSymbol(symbol) {\n  return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\nexport default cloneSymbol;\n", "import cloneArrayBuffer from './_cloneArrayBuffer.js';\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n  var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n  return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nexport default cloneTypedArray;\n", "import cloneArrayBuffer from './_cloneArrayBuffer.js';\nimport cloneDataView from './_cloneDataView.js';\nimport cloneRegExp from './_cloneRegExp.js';\nimport cloneSymbol from './_cloneSymbol.js';\nimport cloneTypedArray from './_cloneTypedArray.js';\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n    dataViewTag = '[object DataView]',\n    float32Tag = '[object Float32Array]',\n    float64Tag = '[object Float64Array]',\n    int8Tag = '[object Int8Array]',\n    int16Tag = '[object Int16Array]',\n    int32Tag = '[object Int32Array]',\n    uint8Tag = '[object Uint8Array]',\n    uint8ClampedTag = '[object Uint8ClampedArray]',\n    uint16Tag = '[object Uint16Array]',\n    uint32Tag = '[object Uint32Array]';\n\n/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, isDeep) {\n  var Ctor = object.constructor;\n  switch (tag) {\n    case arrayBufferTag:\n      return cloneArrayBuffer(object);\n\n    case boolTag:\n    case dateTag:\n      return new Ctor(+object);\n\n    case dataViewTag:\n      return cloneDataView(object, isDeep);\n\n    case float32Tag: case float64Tag:\n    case int8Tag: case int16Tag: case int32Tag:\n    case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n      return cloneTypedArray(object, isDeep);\n\n    case mapTag:\n      return new Ctor;\n\n    case numberTag:\n    case stringTag:\n      return new Ctor(object);\n\n    case regexpTag:\n      return cloneRegExp(object);\n\n    case setTag:\n      return new Ctor;\n\n    case symbolTag:\n      return cloneSymbol(object);\n  }\n}\n\nexport default initCloneByTag;\n", "import baseCreate from './_baseCreate.js';\nimport getPrototype from './_getPrototype.js';\nimport isPrototype from './_isPrototype.js';\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n  return (typeof object.constructor == 'function' && !isPrototype(object))\n    ? baseCreate(getPrototype(object))\n    : {};\n}\n\nexport default initCloneObject;\n", "import getTag from './_getTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]';\n\n/**\n * The base implementation of `_.isMap` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n */\nfunction baseIsMap(value) {\n  return isObjectLike(value) && getTag(value) == mapTag;\n}\n\nexport default baseIsMap;\n", "import baseIsMap from './_baseIsMap.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsMap = nodeUtil && nodeUtil.isMap;\n\n/**\n * Checks if `value` is classified as a `Map` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n * @example\n *\n * _.isMap(new Map);\n * // => true\n *\n * _.isMap(new WeakMap);\n * // => false\n */\nvar isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\nexport default isMap;\n", "import getTag from './_getTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar setTag = '[object Set]';\n\n/**\n * The base implementation of `_.isSet` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n */\nfunction baseIsSet(value) {\n  return isObjectLike(value) && getTag(value) == setTag;\n}\n\nexport default baseIsSet;\n", "import baseIsSet from './_baseIsSet.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsSet = nodeUtil && nodeUtil.isSet;\n\n/**\n * Checks if `value` is classified as a `Set` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n * @example\n *\n * _.isSet(new Set);\n * // => true\n *\n * _.isSet(new WeakSet);\n * // => false\n */\nvar isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\n\nexport default isSet;\n", "import Stack from './_Stack.js';\nimport arrayEach from './_arrayEach.js';\nimport assignValue from './_assignValue.js';\nimport baseAssign from './_baseAssign.js';\nimport baseAssignIn from './_baseAssignIn.js';\nimport cloneBuffer from './_cloneBuffer.js';\nimport copyArray from './_copyArray.js';\nimport copySymbols from './_copySymbols.js';\nimport copySymbolsIn from './_copySymbolsIn.js';\nimport getAllKeys from './_getAllKeys.js';\nimport getAllKeysIn from './_getAllKeysIn.js';\nimport getTag from './_getTag.js';\nimport initCloneArray from './_initCloneArray.js';\nimport initCloneByTag from './_initCloneByTag.js';\nimport initCloneObject from './_initCloneObject.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isMap from './isMap.js';\nimport isObject from './isObject.js';\nimport isSet from './isSet.js';\nimport keys from './keys.js';\nimport keysIn from './keysIn.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n    CLONE_FLAT_FLAG = 2,\n    CLONE_SYMBOLS_FLAG = 4;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    funcTag = '[object Function]',\n    genTag = '[object GeneratorFunction]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    objectTag = '[object Object]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    symbolTag = '[object Symbol]',\n    weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n    dataViewTag = '[object DataView]',\n    float32Tag = '[object Float32Array]',\n    float64Tag = '[object Float64Array]',\n    int8Tag = '[object Int8Array]',\n    int16Tag = '[object Int16Array]',\n    int32Tag = '[object Int32Array]',\n    uint8Tag = '[object Uint8Array]',\n    uint8ClampedTag = '[object Uint8ClampedArray]',\n    uint16Tag = '[object Uint16Array]',\n    uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\ncloneableTags[boolTag] = cloneableTags[dateTag] =\ncloneableTags[float32Tag] = cloneableTags[float64Tag] =\ncloneableTags[int8Tag] = cloneableTags[int16Tag] =\ncloneableTags[int32Tag] = cloneableTags[mapTag] =\ncloneableTags[numberTag] = cloneableTags[objectTag] =\ncloneableTags[regexpTag] = cloneableTags[setTag] =\ncloneableTags[stringTag] = cloneableTags[symbolTag] =\ncloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\ncloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} bitmask The bitmask flags.\n *  1 - Deep clone\n *  2 - Flatten inherited properties\n *  4 - Clone symbols\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, bitmask, customizer, key, object, stack) {\n  var result,\n      isDeep = bitmask & CLONE_DEEP_FLAG,\n      isFlat = bitmask & CLONE_FLAT_FLAG,\n      isFull = bitmask & CLONE_SYMBOLS_FLAG;\n\n  if (customizer) {\n    result = object ? customizer(value, key, object, stack) : customizer(value);\n  }\n  if (result !== undefined) {\n    return result;\n  }\n  if (!isObject(value)) {\n    return value;\n  }\n  var isArr = isArray(value);\n  if (isArr) {\n    result = initCloneArray(value);\n    if (!isDeep) {\n      return copyArray(value, result);\n    }\n  } else {\n    var tag = getTag(value),\n        isFunc = tag == funcTag || tag == genTag;\n\n    if (isBuffer(value)) {\n      return cloneBuffer(value, isDeep);\n    }\n    if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n      result = (isFlat || isFunc) ? {} : initCloneObject(value);\n      if (!isDeep) {\n        return isFlat\n          ? copySymbolsIn(value, baseAssignIn(result, value))\n          : copySymbols(value, baseAssign(result, value));\n      }\n    } else {\n      if (!cloneableTags[tag]) {\n        return object ? value : {};\n      }\n      result = initCloneByTag(value, tag, isDeep);\n    }\n  }\n  // Check for circular references and return its corresponding clone.\n  stack || (stack = new Stack);\n  var stacked = stack.get(value);\n  if (stacked) {\n    return stacked;\n  }\n  stack.set(value, result);\n\n  if (isSet(value)) {\n    value.forEach(function(subValue) {\n      result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\n    });\n  } else if (isMap(value)) {\n    value.forEach(function(subValue, key) {\n      result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\n    });\n  }\n\n  var keysFunc = isFull\n    ? (isFlat ? getAllKeysIn : getAllKeys)\n    : (isFlat ? keysIn : keys);\n\n  var props = isArr ? undefined : keysFunc(value);\n  arrayEach(props || value, function(subValue, key) {\n    if (props) {\n      key = subValue;\n      subValue = value[key];\n    }\n    // Recursively populate clone (susceptible to call stack limits).\n    assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\n  });\n  return result;\n}\n\nexport default baseClone;\n", "import baseClone from './_baseClone.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * Creates a shallow clone of `value`.\n *\n * **Note:** This method is loosely based on the\n * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)\n * and supports cloning arrays, array buffers, booleans, date objects, maps,\n * numbers, `Object` objects, regexes, sets, strings, symbols, and typed\n * arrays. The own enumerable properties of `arguments` objects are cloned\n * as plain objects. An empty object is returned for uncloneable values such\n * as error objects, functions, DOM nodes, and WeakMaps.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to clone.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeep\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var shallow = _.clone(objects);\n * console.log(shallow[0] === objects[0]);\n * // => true\n */\nfunction clone(value) {\n  return baseClone(value, CLONE_SYMBOLS_FLAG);\n}\n\nexport default clone;\n", "import baseClone from './_baseClone.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n    CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * This method is like `_.clone` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @returns {*} Returns the deep cloned value.\n * @see _.clone\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var deep = _.cloneDeep(objects);\n * console.log(deep[0] === objects[0]);\n * // => false\n */\nfunction cloneDeep(value) {\n  return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\n}\n\nexport default cloneDeep;\n", "import baseClone from './_baseClone.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n    CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * This method is like `_.cloneWith` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @param {Function} [customizer] The function to customize cloning.\n * @returns {*} Returns the deep cloned value.\n * @see _.cloneWith\n * @example\n *\n * function customizer(value) {\n *   if (_.isElement(value)) {\n *     return value.cloneNode(true);\n *   }\n * }\n *\n * var el = _.cloneDeepWith(document.body, customizer);\n *\n * console.log(el === document.body);\n * // => false\n * console.log(el.nodeName);\n * // => 'BODY'\n * console.log(el.childNodes.length);\n * // => 20\n */\nfunction cloneDeepWith(value, customizer) {\n  customizer = typeof customizer == 'function' ? customizer : undefined;\n  return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG, customizer);\n}\n\nexport default cloneDeepWith;\n", "import baseClone from './_baseClone.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * This method is like `_.clone` except that it accepts `customizer` which\n * is invoked to produce the cloned value. If `customizer` returns `undefined`,\n * cloning is handled by the method instead. The `customizer` is invoked with\n * up to four arguments; (value [, index|key, object, stack]).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to clone.\n * @param {Function} [customizer] The function to customize cloning.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeepWith\n * @example\n *\n * function customizer(value) {\n *   if (_.isElement(value)) {\n *     return value.cloneNode(false);\n *   }\n * }\n *\n * var el = _.cloneWith(document.body, customizer);\n *\n * console.log(el === document.body);\n * // => false\n * console.log(el.nodeName);\n * // => 'BODY'\n * console.log(el.childNodes.length);\n * // => 0\n */\nfunction cloneWith(value, customizer) {\n  customizer = typeof customizer == 'function' ? customizer : undefined;\n  return baseClone(value, CLONE_SYMBOLS_FLAG, customizer);\n}\n\nexport default cloneWith;\n", "import LodashWrapper from './_LodashWrapper.js';\n\n/**\n * Executes the chain sequence and returns the wrapped result.\n *\n * @name commit\n * @memberOf _\n * @since 3.2.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var array = [1, 2];\n * var wrapped = _(array).push(3);\n *\n * console.log(array);\n * // => [1, 2]\n *\n * wrapped = wrapped.commit();\n * console.log(array);\n * // => [1, 2, 3]\n *\n * wrapped.last();\n * // => 3\n *\n * console.log(array);\n * // => [1, 2, 3]\n */\nfunction wrapperCommit() {\n  return new LodashWrapper(this.value(), this.__chain__);\n}\n\nexport default wrapperCommit;\n", "/**\n * Creates an array with all falsey values removed. The values `false`, `null`,\n * `0`, `\"\"`, `undefined`, and `NaN` are falsey.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to compact.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.compact([0, 1, false, 2, '', 3]);\n * // => [1, 2, 3]\n */\nfunction compact(array) {\n  var index = -1,\n      length = array == null ? 0 : array.length,\n      resIndex = 0,\n      result = [];\n\n  while (++index < length) {\n    var value = array[index];\n    if (value) {\n      result[resIndex++] = value;\n    }\n  }\n  return result;\n}\n\nexport default compact;\n", "import arrayPush from './_arrayPush.js';\nimport baseFlatten from './_baseFlatten.js';\nimport copyArray from './_copyArray.js';\nimport isArray from './isArray.js';\n\n/**\n * Creates a new array concatenating `array` with any additional arrays\n * and/or values.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to concatenate.\n * @param {...*} [values] The values to concatenate.\n * @returns {Array} Returns the new concatenated array.\n * @example\n *\n * var array = [1];\n * var other = _.concat(array, 2, [3], [[4]]);\n *\n * console.log(other);\n * // => [1, 2, 3, [4]]\n *\n * console.log(array);\n * // => [1]\n */\nfunction concat() {\n  var length = arguments.length;\n  if (!length) {\n    return [];\n  }\n  var args = Array(length - 1),\n      array = arguments[0],\n      index = length;\n\n  while (index--) {\n    args[index - 1] = arguments[index];\n  }\n  return arrayPush(isArray(array) ? copyArray(array) : [array], baseFlatten(args, 1));\n}\n\nexport default concat;\n", "/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n  this.__data__.set(value, HASH_UNDEFINED);\n  return this;\n}\n\nexport default setCacheAdd;\n", "/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n  return this.__data__.has(value);\n}\n\nexport default setCacheHas;\n", "import MapCache from './_MapCache.js';\nimport setCacheAdd from './_setCacheAdd.js';\nimport setCacheHas from './_setCacheHas.js';\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n  var index = -1,\n      length = values == null ? 0 : values.length;\n\n  this.__data__ = new MapCache;\n  while (++index < length) {\n    this.add(values[index]);\n  }\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\nexport default SetCache;\n", "/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n *  else `false`.\n */\nfunction arraySome(array, predicate) {\n  var index = -1,\n      length = array == null ? 0 : array.length;\n\n  while (++index < length) {\n    if (predicate(array[index], index, array)) {\n      return true;\n    }\n  }\n  return false;\n}\n\nexport default arraySome;\n", "/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n  return cache.has(key);\n}\n\nexport default cacheHas;\n", "import SetCache from './_SetCache.js';\nimport arraySome from './_arraySome.js';\nimport cacheHas from './_cacheHas.js';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n    COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n  var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n      arrLength = array.length,\n      othLength = other.length;\n\n  if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n    return false;\n  }\n  // Check that cyclic values are equal.\n  var arrStacked = stack.get(array);\n  var othStacked = stack.get(other);\n  if (arrStacked && othStacked) {\n    return arrStacked == other && othStacked == array;\n  }\n  var index = -1,\n      result = true,\n      seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n  stack.set(array, other);\n  stack.set(other, array);\n\n  // Ignore non-index properties.\n  while (++index < arrLength) {\n    var arrValue = array[index],\n        othValue = other[index];\n\n    if (customizer) {\n      var compared = isPartial\n        ? customizer(othValue, arrValue, index, other, array, stack)\n        : customizer(arrValue, othValue, index, array, other, stack);\n    }\n    if (compared !== undefined) {\n      if (compared) {\n        continue;\n      }\n      result = false;\n      break;\n    }\n    // Recursively compare arrays (susceptible to call stack limits).\n    if (seen) {\n      if (!arraySome(other, function(othValue, othIndex) {\n            if (!cacheHas(seen, othIndex) &&\n                (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n              return seen.push(othIndex);\n            }\n          })) {\n        result = false;\n        break;\n      }\n    } else if (!(\n          arrValue === othValue ||\n            equalFunc(arrValue, othValue, bitmask, customizer, stack)\n        )) {\n      result = false;\n      break;\n    }\n  }\n  stack['delete'](array);\n  stack['delete'](other);\n  return result;\n}\n\nexport default equalArrays;\n", "/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n  var index = -1,\n      result = Array(map.size);\n\n  map.forEach(function(value, key) {\n    result[++index] = [key, value];\n  });\n  return result;\n}\n\nexport default mapToArray;\n", "/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n  var index = -1,\n      result = Array(set.size);\n\n  set.forEach(function(value) {\n    result[++index] = value;\n  });\n  return result;\n}\n\nexport default setToArray;\n", "import Symbol from './_Symbol.js';\nimport Uint8Array from './_Uint8Array.js';\nimport eq from './eq.js';\nimport equalArrays from './_equalArrays.js';\nimport mapToArray from './_mapToArray.js';\nimport setToArray from './_setToArray.js';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n    COMPARE_UNORDERED_FLAG = 2;\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n    dataViewTag = '[object DataView]';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n    symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n  switch (tag) {\n    case dataViewTag:\n      if ((object.byteLength != other.byteLength) ||\n          (object.byteOffset != other.byteOffset)) {\n        return false;\n      }\n      object = object.buffer;\n      other = other.buffer;\n\n    case arrayBufferTag:\n      if ((object.byteLength != other.byteLength) ||\n          !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n        return false;\n      }\n      return true;\n\n    case boolTag:\n    case dateTag:\n    case numberTag:\n      // Coerce booleans to `1` or `0` and dates to milliseconds.\n      // Invalid dates are coerced to `NaN`.\n      return eq(+object, +other);\n\n    case errorTag:\n      return object.name == other.name && object.message == other.message;\n\n    case regexpTag:\n    case stringTag:\n      // Coerce regexes to strings and treat strings, primitives and objects,\n      // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n      // for more details.\n      return object == (other + '');\n\n    case mapTag:\n      var convert = mapToArray;\n\n    case setTag:\n      var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n      convert || (convert = setToArray);\n\n      if (object.size != other.size && !isPartial) {\n        return false;\n      }\n      // Assume cyclic values are equal.\n      var stacked = stack.get(object);\n      if (stacked) {\n        return stacked == other;\n      }\n      bitmask |= COMPARE_UNORDERED_FLAG;\n\n      // Recursively compare objects (susceptible to call stack limits).\n      stack.set(object, other);\n      var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n      stack['delete'](object);\n      return result;\n\n    case symbolTag:\n      if (symbolValueOf) {\n        return symbolValueOf.call(object) == symbolValueOf.call(other);\n      }\n  }\n  return false;\n}\n\nexport default equalByTag;\n", "import getAllKeys from './_getAllKeys.js';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n  var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n      objProps = getAllKeys(object),\n      objLength = objProps.length,\n      othProps = getAllKeys(other),\n      othLength = othProps.length;\n\n  if (objLength != othLength && !isPartial) {\n    return false;\n  }\n  var index = objLength;\n  while (index--) {\n    var key = objProps[index];\n    if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n      return false;\n    }\n  }\n  // Check that cyclic values are equal.\n  var objStacked = stack.get(object);\n  var othStacked = stack.get(other);\n  if (objStacked && othStacked) {\n    return objStacked == other && othStacked == object;\n  }\n  var result = true;\n  stack.set(object, other);\n  stack.set(other, object);\n\n  var skipCtor = isPartial;\n  while (++index < objLength) {\n    key = objProps[index];\n    var objValue = object[key],\n        othValue = other[key];\n\n    if (customizer) {\n      var compared = isPartial\n        ? customizer(othValue, objValue, key, other, object, stack)\n        : customizer(objValue, othValue, key, object, other, stack);\n    }\n    // Recursively compare objects (susceptible to call stack limits).\n    if (!(compared === undefined\n          ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n          : compared\n        )) {\n      result = false;\n      break;\n    }\n    skipCtor || (skipCtor = key == 'constructor');\n  }\n  if (result && !skipCtor) {\n    var objCtor = object.constructor,\n        othCtor = other.constructor;\n\n    // Non `Object` object instances with different constructors are not equal.\n    if (objCtor != othCtor &&\n        ('constructor' in object && 'constructor' in other) &&\n        !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n          typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n      result = false;\n    }\n  }\n  stack['delete'](object);\n  stack['delete'](other);\n  return result;\n}\n\nexport default equalObjects;\n", "import Stack from './_Stack.js';\nimport equalArrays from './_equalArrays.js';\nimport equalByTag from './_equalByTag.js';\nimport equalObjects from './_equalObjects.js';\nimport getTag from './_getTag.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isTypedArray from './isTypedArray.js';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n  var objIsArr = isArray(object),\n      othIsArr = isArray(other),\n      objTag = objIsArr ? arrayTag : getTag(object),\n      othTag = othIsArr ? arrayTag : getTag(other);\n\n  objTag = objTag == argsTag ? objectTag : objTag;\n  othTag = othTag == argsTag ? objectTag : othTag;\n\n  var objIsObj = objTag == objectTag,\n      othIsObj = othTag == objectTag,\n      isSameTag = objTag == othTag;\n\n  if (isSameTag && isBuffer(object)) {\n    if (!isBuffer(other)) {\n      return false;\n    }\n    objIsArr = true;\n    objIsObj = false;\n  }\n  if (isSameTag && !objIsObj) {\n    stack || (stack = new Stack);\n    return (objIsArr || isTypedArray(object))\n      ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n      : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n  }\n  if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n    var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n        othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n    if (objIsWrapped || othIsWrapped) {\n      var objUnwrapped = objIsWrapped ? object.value() : object,\n          othUnwrapped = othIsWrapped ? other.value() : other;\n\n      stack || (stack = new Stack);\n      return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n    }\n  }\n  if (!isSameTag) {\n    return false;\n  }\n  stack || (stack = new Stack);\n  return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\nexport default baseIsEqualDeep;\n", "import baseIsEqualDeep from './_baseIsEqualDeep.js';\nimport isObjectLike from './isObjectLike.js';\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n *  1 - Unordered comparison\n *  2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n  if (value === other) {\n    return true;\n  }\n  if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n    return value !== value && other !== other;\n  }\n  return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\nexport default baseIsEqual;\n", "import Stack from './_Stack.js';\nimport baseIsEqual from './_baseIsEqual.js';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n    COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Array} matchData The property names, values, and compare flags to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n */\nfunction baseIsMatch(object, source, matchData, customizer) {\n  var index = matchData.length,\n      length = index,\n      noCustomizer = !customizer;\n\n  if (object == null) {\n    return !length;\n  }\n  object = Object(object);\n  while (index--) {\n    var data = matchData[index];\n    if ((noCustomizer && data[2])\n          ? data[1] !== object[data[0]]\n          : !(data[0] in object)\n        ) {\n      return false;\n    }\n  }\n  while (++index < length) {\n    data = matchData[index];\n    var key = data[0],\n        objValue = object[key],\n        srcValue = data[1];\n\n    if (noCustomizer && data[2]) {\n      if (objValue === undefined && !(key in object)) {\n        return false;\n      }\n    } else {\n      var stack = new Stack;\n      if (customizer) {\n        var result = customizer(objValue, srcValue, key, object, source, stack);\n      }\n      if (!(result === undefined\n            ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack)\n            : result\n          )) {\n        return false;\n      }\n    }\n  }\n  return true;\n}\n\nexport default baseIsMatch;\n", "import isObject from './isObject.js';\n\n/**\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` if suitable for strict\n *  equality comparisons, else `false`.\n */\nfunction isStrictComparable(value) {\n  return value === value && !isObject(value);\n}\n\nexport default isStrictComparable;\n", "import isStrictComparable from './_isStrictComparable.js';\nimport keys from './keys.js';\n\n/**\n * Gets the property names, values, and compare flags of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the match data of `object`.\n */\nfunction getMatchData(object) {\n  var result = keys(object),\n      length = result.length;\n\n  while (length--) {\n    var key = result[length],\n        value = object[key];\n\n    result[length] = [key, value, isStrictComparable(value)];\n  }\n  return result;\n}\n\nexport default getMatchData;\n", "/**\n * A specialized version of `matchesProperty` for source values suitable\n * for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction matchesStrictComparable(key, srcValue) {\n  return function(object) {\n    if (object == null) {\n      return false;\n    }\n    return object[key] === srcValue &&\n      (srcValue !== undefined || (key in Object(object)));\n  };\n}\n\nexport default matchesStrictComparable;\n", "import baseIsMatch from './_baseIsMatch.js';\nimport getMatchData from './_getMatchData.js';\nimport matchesStrictComparable from './_matchesStrictComparable.js';\n\n/**\n * The base implementation of `_.matches` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatches(source) {\n  var matchData = getMatchData(source);\n  if (matchData.length == 1 && matchData[0][2]) {\n    return matchesStrictComparable(matchData[0][0], matchData[0][1]);\n  }\n  return function(object) {\n    return object === source || baseIsMatch(object, source, matchData);\n  };\n}\n\nexport default baseMatches;\n", "/**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHasIn(object, key) {\n  return object != null && key in Object(object);\n}\n\nexport default baseHasIn;\n", "import castPath from './_castPath.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isIndex from './_isIndex.js';\nimport isLength from './isLength.js';\nimport toKey from './_toKey.js';\n\n/**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\nfunction hasPath(object, path, hasFunc) {\n  path = castPath(path, object);\n\n  var index = -1,\n      length = path.length,\n      result = false;\n\n  while (++index < length) {\n    var key = toKey(path[index]);\n    if (!(result = object != null && hasFunc(object, key))) {\n      break;\n    }\n    object = object[key];\n  }\n  if (result || ++index != length) {\n    return result;\n  }\n  length = object == null ? 0 : object.length;\n  return !!length && isLength(length) && isIndex(key, length) &&\n    (isArray(object) || isArguments(object));\n}\n\nexport default hasPath;\n", "import baseHasIn from './_baseHasIn.js';\nimport hasPath from './_hasPath.js';\n\n/**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\nfunction hasIn(object, path) {\n  return object != null && hasPath(object, path, baseHasIn);\n}\n\nexport default hasIn;\n", "import baseIsEqual from './_baseIsEqual.js';\nimport get from './get.js';\nimport hasIn from './hasIn.js';\nimport isKey from './_isKey.js';\nimport isStrictComparable from './_isStrictComparable.js';\nimport matchesStrictComparable from './_matchesStrictComparable.js';\nimport toKey from './_toKey.js';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n    COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\n *\n * @private\n * @param {string} path The path of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatchesProperty(path, srcValue) {\n  if (isKey(path) && isStrictComparable(srcValue)) {\n    return matchesStrictComparable(toKey(path), srcValue);\n  }\n  return function(object) {\n    var objValue = get(object, path);\n    return (objValue === undefined && objValue === srcValue)\n      ? hasIn(object, path)\n      : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG);\n  };\n}\n\nexport default baseMatchesProperty;\n", "/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction baseProperty(key) {\n  return function(object) {\n    return object == null ? undefined : object[key];\n  };\n}\n\nexport default baseProperty;\n", "import baseGet from './_baseGet.js';\n\n/**\n * A specialized version of `baseProperty` which supports deep paths.\n *\n * @private\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction basePropertyDeep(path) {\n  return function(object) {\n    return baseGet(object, path);\n  };\n}\n\nexport default basePropertyDeep;\n", "import baseProperty from './_baseProperty.js';\nimport basePropertyDeep from './_basePropertyDeep.js';\nimport isKey from './_isKey.js';\nimport toKey from './_toKey.js';\n\n/**\n * Creates a function that returns the value at `path` of a given object.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n * @example\n *\n * var objects = [\n *   { 'a': { 'b': 2 } },\n *   { 'a': { 'b': 1 } }\n * ];\n *\n * _.map(objects, _.property('a.b'));\n * // => [2, 1]\n *\n * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b');\n * // => [1, 2]\n */\nfunction property(path) {\n  return isKey(path) ? baseProperty(toKey(path)) : basePropertyDeep(path);\n}\n\nexport default property;\n", "import baseMatches from './_baseMatches.js';\nimport baseMatchesProperty from './_baseMatchesProperty.js';\nimport identity from './identity.js';\nimport isArray from './isArray.js';\nimport property from './property.js';\n\n/**\n * The base implementation of `_.iteratee`.\n *\n * @private\n * @param {*} [value=_.identity] The value to convert to an iteratee.\n * @returns {Function} Returns the iteratee.\n */\nfunction baseIteratee(value) {\n  // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\n  // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\n  if (typeof value == 'function') {\n    return value;\n  }\n  if (value == null) {\n    return identity;\n  }\n  if (typeof value == 'object') {\n    return isArray(value)\n      ? baseMatchesProperty(value[0], value[1])\n      : baseMatches(value);\n  }\n  return property(value);\n}\n\nexport default baseIteratee;\n", "import apply from './_apply.js';\nimport arrayMap from './_arrayMap.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseRest from './_baseRest.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that iterates over `pairs` and invokes the corresponding\n * function of the first predicate to return truthy. The predicate-function\n * pairs are invoked with the `this` binding and arguments of the created\n * function.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {Array} pairs The predicate-function pairs.\n * @returns {Function} Returns the new composite function.\n * @example\n *\n * var func = _.cond([\n *   [_.matches({ 'a': 1 }),           _.constant('matches A')],\n *   [_.conforms({ 'b': _.isNumber }), _.constant('matches B')],\n *   [_.stubTrue,                      _.constant('no match')]\n * ]);\n *\n * func({ 'a': 1, 'b': 2 });\n * // => 'matches A'\n *\n * func({ 'a': 0, 'b': 1 });\n * // => 'matches B'\n *\n * func({ 'a': '1', 'b': '2' });\n * // => 'no match'\n */\nfunction cond(pairs) {\n  var length = pairs == null ? 0 : pairs.length,\n      toIteratee = baseIteratee;\n\n  pairs = !length ? [] : arrayMap(pairs, function(pair) {\n    if (typeof pair[1] != 'function') {\n      throw new TypeError(FUNC_ERROR_TEXT);\n    }\n    return [toIteratee(pair[0]), pair[1]];\n  });\n\n  return baseRest(function(args) {\n    var index = -1;\n    while (++index < length) {\n      var pair = pairs[index];\n      if (apply(pair[0], this, args)) {\n        return apply(pair[1], this, args);\n      }\n    }\n  });\n}\n\nexport default cond;\n", "/**\n * The base implementation of `_.conformsTo` which accepts `props` to check.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property predicates to conform to.\n * @returns {boolean} Returns `true` if `object` conforms, else `false`.\n */\nfunction baseConformsTo(object, source, props) {\n  var length = props.length;\n  if (object == null) {\n    return !length;\n  }\n  object = Object(object);\n  while (length--) {\n    var key = props[length],\n        predicate = source[key],\n        value = object[key];\n\n    if ((value === undefined && !(key in object)) || !predicate(value)) {\n      return false;\n    }\n  }\n  return true;\n}\n\nexport default baseConformsTo;\n", "import baseConformsTo from './_baseConformsTo.js';\nimport keys from './keys.js';\n\n/**\n * The base implementation of `_.conforms` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property predicates to conform to.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseConforms(source) {\n  var props = keys(source);\n  return function(object) {\n    return baseConformsTo(object, source, props);\n  };\n}\n\nexport default baseConforms;\n", "import baseClone from './_baseClone.js';\nimport baseConforms from './_baseConforms.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1;\n\n/**\n * Creates a function that invokes the predicate properties of `source` with\n * the corresponding property values of a given object, returning `true` if\n * all predicates return truthy, else `false`.\n *\n * **Note:** The created function is equivalent to `_.conformsTo` with\n * `source` partially applied.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {Object} source The object of property predicates to conform to.\n * @returns {Function} Returns the new spec function.\n * @example\n *\n * var objects = [\n *   { 'a': 2, 'b': 1 },\n *   { 'a': 1, 'b': 2 }\n * ];\n *\n * _.filter(objects, _.conforms({ 'b': function(n) { return n > 1; } }));\n * // => [{ 'a': 1, 'b': 2 }]\n */\nfunction conforms(source) {\n  return baseConforms(baseClone(source, CLONE_DEEP_FLAG));\n}\n\nexport default conforms;\n", "import baseConformsTo from './_baseConformsTo.js';\nimport keys from './keys.js';\n\n/**\n * Checks if `object` conforms to `source` by invoking the predicate\n * properties of `source` with the corresponding property values of `object`.\n *\n * **Note:** This method is equivalent to `_.conforms` when `source` is\n * partially applied.\n *\n * @static\n * @memberOf _\n * @since 4.14.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property predicates to conform to.\n * @returns {boolean} Returns `true` if `object` conforms, else `false`.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n *\n * _.conformsTo(object, { 'b': function(n) { return n > 1; } });\n * // => true\n *\n * _.conformsTo(object, { 'b': function(n) { return n > 2; } });\n * // => false\n */\nfunction conformsTo(object, source) {\n  return source == null || baseConformsTo(object, source, keys(source));\n}\n\nexport default conformsTo;\n", "/**\n * A specialized version of `baseAggregator` for arrays.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\nfunction arrayAggregator(array, setter, iteratee, accumulator) {\n  var index = -1,\n      length = array == null ? 0 : array.length;\n\n  while (++index < length) {\n    var value = array[index];\n    setter(accumulator, value, iteratee(value), array);\n  }\n  return accumulator;\n}\n\nexport default arrayAggregator;\n", "/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n  return function(object, iteratee, keysFunc) {\n    var index = -1,\n        iterable = Object(object),\n        props = keysFunc(object),\n        length = props.length;\n\n    while (length--) {\n      var key = props[fromRight ? length : ++index];\n      if (iteratee(iterable[key], key, iterable) === false) {\n        break;\n      }\n    }\n    return object;\n  };\n}\n\nexport default createBaseFor;\n", "import createBaseFor from './_createBaseFor.js';\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nexport default baseFor;\n", "import baseFor from './_baseFor.js';\nimport keys from './keys.js';\n\n/**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForOwn(object, iteratee) {\n  return object && baseFor(object, iteratee, keys);\n}\n\nexport default baseForOwn;\n", "import isArrayLike from './isArrayLike.js';\n\n/**\n * Creates a `baseEach` or `baseEachRight` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseEach(eachFunc, fromRight) {\n  return function(collection, iteratee) {\n    if (collection == null) {\n      return collection;\n    }\n    if (!isArrayLike(collection)) {\n      return eachFunc(collection, iteratee);\n    }\n    var length = collection.length,\n        index = fromRight ? length : -1,\n        iterable = Object(collection);\n\n    while ((fromRight ? index-- : ++index < length)) {\n      if (iteratee(iterable[index], index, iterable) === false) {\n        break;\n      }\n    }\n    return collection;\n  };\n}\n\nexport default createBaseEach;\n", "import baseForOwn from './_baseForOwn.js';\nimport createBaseEach from './_createBaseEach.js';\n\n/**\n * The base implementation of `_.forEach` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\nvar baseEach = createBaseEach(baseForOwn);\n\nexport default baseEach;\n", "import baseEach from './_baseEach.js';\n\n/**\n * Aggregates elements of `collection` on `accumulator` with keys transformed\n * by `iteratee` and values set by `setter`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\nfunction baseAggregator(collection, setter, iteratee, accumulator) {\n  baseEach(collection, function(value, key, collection) {\n    setter(accumulator, value, iteratee(value), collection);\n  });\n  return accumulator;\n}\n\nexport default baseAggregator;\n", "import arrayAggregator from './_arrayAggregator.js';\nimport baseAggregator from './_baseAggregator.js';\nimport baseIteratee from './_baseIteratee.js';\nimport isArray from './isArray.js';\n\n/**\n * Creates a function like `_.groupBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} [initializer] The accumulator object initializer.\n * @returns {Function} Returns the new aggregator function.\n */\nfunction createAggregator(setter, initializer) {\n  return function(collection, iteratee) {\n    var func = isArray(collection) ? arrayAggregator : baseAggregator,\n        accumulator = initializer ? initializer() : {};\n\n    return func(collection, setter, baseIteratee(iteratee, 2), accumulator);\n  };\n}\n\nexport default createAggregator;\n", "import baseAssignValue from './_baseAssignValue.js';\nimport createAggregator from './_createAggregator.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The corresponding value of\n * each key is the number of times the key was returned by `iteratee`. The\n * iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * _.countBy([6.1, 4.2, 6.3], Math.floor);\n * // => { '4': 1, '6': 2 }\n *\n * // The `_.property` iteratee shorthand.\n * _.countBy(['one', 'two', 'three'], 'length');\n * // => { '3': 2, '5': 1 }\n */\nvar countBy = createAggregator(function(result, value, key) {\n  if (hasOwnProperty.call(result, key)) {\n    ++result[key];\n  } else {\n    baseAssignValue(result, key, 1);\n  }\n});\n\nexport default countBy;\n", "import baseAssign from './_baseAssign.js';\nimport baseCreate from './_baseCreate.js';\n\n/**\n * Creates an object that inherits from the `prototype` object. If a\n * `properties` object is given, its own enumerable string keyed properties\n * are assigned to the created object.\n *\n * @static\n * @memberOf _\n * @since 2.3.0\n * @category Object\n * @param {Object} prototype The object to inherit from.\n * @param {Object} [properties] The properties to assign to the object.\n * @returns {Object} Returns the new object.\n * @example\n *\n * function Shape() {\n *   this.x = 0;\n *   this.y = 0;\n * }\n *\n * function Circle() {\n *   Shape.call(this);\n * }\n *\n * Circle.prototype = _.create(Shape.prototype, {\n *   'constructor': Circle\n * });\n *\n * var circle = new Circle;\n * circle instanceof Circle;\n * // => true\n *\n * circle instanceof Shape;\n * // => true\n */\nfunction create(prototype, properties) {\n  var result = baseCreate(prototype);\n  return properties == null ? result : baseAssign(result, properties);\n}\n\nexport default create;\n", "import createWrap from './_createWrap.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_CURRY_FLAG = 8;\n\n/**\n * Creates a function that accepts arguments of `func` and either invokes\n * `func` returning its result, if at least `arity` number of arguments have\n * been provided, or returns a function that accepts the remaining `func`\n * arguments, and so on. The arity of `func` may be specified if `func.length`\n * is not sufficient.\n *\n * The `_.curry.placeholder` value, which defaults to `_` in monolithic builds,\n * may be used as a placeholder for provided arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of curried functions.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Function\n * @param {Function} func The function to curry.\n * @param {number} [arity=func.length] The arity of `func`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new curried function.\n * @example\n *\n * var abc = function(a, b, c) {\n *   return [a, b, c];\n * };\n *\n * var curried = _.curry(abc);\n *\n * curried(1)(2)(3);\n * // => [1, 2, 3]\n *\n * curried(1, 2)(3);\n * // => [1, 2, 3]\n *\n * curried(1, 2, 3);\n * // => [1, 2, 3]\n *\n * // Curried with placeholders.\n * curried(1)(_, 3)(2);\n * // => [1, 2, 3]\n */\nfunction curry(func, arity, guard) {\n  arity = guard ? undefined : arity;\n  var result = createWrap(func, WRAP_CURRY_FLAG, undefined, undefined, undefined, undefined, undefined, arity);\n  result.placeholder = curry.placeholder;\n  return result;\n}\n\n// Assign default placeholders.\ncurry.placeholder = {};\n\nexport default curry;\n", "import createWrap from './_createWrap.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_CURRY_RIGHT_FLAG = 16;\n\n/**\n * This method is like `_.curry` except that arguments are applied to `func`\n * in the manner of `_.partialRight` instead of `_.partial`.\n *\n * The `_.curryRight.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for provided arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of curried functions.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to curry.\n * @param {number} [arity=func.length] The arity of `func`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new curried function.\n * @example\n *\n * var abc = function(a, b, c) {\n *   return [a, b, c];\n * };\n *\n * var curried = _.curryRight(abc);\n *\n * curried(3)(2)(1);\n * // => [1, 2, 3]\n *\n * curried(2, 3)(1);\n * // => [1, 2, 3]\n *\n * curried(1, 2, 3);\n * // => [1, 2, 3]\n *\n * // Curried with placeholders.\n * curried(3)(1, _)(2);\n * // => [1, 2, 3]\n */\nfunction curryRight(func, arity, guard) {\n  arity = guard ? undefined : arity;\n  var result = createWrap(func, WRAP_CURRY_RIGHT_FLAG, undefined, undefined, undefined, undefined, undefined, arity);\n  result.placeholder = curryRight.placeholder;\n  return result;\n}\n\n// Assign default placeholders.\ncurryRight.placeholder = {};\n\nexport default curryRight;\n", "import root from './_root.js';\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n *   console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n  return root.Date.now();\n};\n\nexport default now;\n", "import isObject from './isObject.js';\nimport now from './now.js';\nimport toNumber from './toNumber.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n    nativeMin = Math.min;\n\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n *  Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n *  The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n *  Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n *   'leading': true,\n *   'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\nfunction debounce(func, wait, options) {\n  var lastArgs,\n      lastThis,\n      maxWait,\n      result,\n      timerId,\n      lastCallTime,\n      lastInvokeTime = 0,\n      leading = false,\n      maxing = false,\n      trailing = true;\n\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  wait = toNumber(wait) || 0;\n  if (isObject(options)) {\n    leading = !!options.leading;\n    maxing = 'maxWait' in options;\n    maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n    trailing = 'trailing' in options ? !!options.trailing : trailing;\n  }\n\n  function invokeFunc(time) {\n    var args = lastArgs,\n        thisArg = lastThis;\n\n    lastArgs = lastThis = undefined;\n    lastInvokeTime = time;\n    result = func.apply(thisArg, args);\n    return result;\n  }\n\n  function leadingEdge(time) {\n    // Reset any `maxWait` timer.\n    lastInvokeTime = time;\n    // Start the timer for the trailing edge.\n    timerId = setTimeout(timerExpired, wait);\n    // Invoke the leading edge.\n    return leading ? invokeFunc(time) : result;\n  }\n\n  function remainingWait(time) {\n    var timeSinceLastCall = time - lastCallTime,\n        timeSinceLastInvoke = time - lastInvokeTime,\n        timeWaiting = wait - timeSinceLastCall;\n\n    return maxing\n      ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)\n      : timeWaiting;\n  }\n\n  function shouldInvoke(time) {\n    var timeSinceLastCall = time - lastCallTime,\n        timeSinceLastInvoke = time - lastInvokeTime;\n\n    // Either this is the first call, activity has stopped and we're at the\n    // trailing edge, the system time has gone backwards and we're treating\n    // it as the trailing edge, or we've hit the `maxWait` limit.\n    return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n      (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n  }\n\n  function timerExpired() {\n    var time = now();\n    if (shouldInvoke(time)) {\n      return trailingEdge(time);\n    }\n    // Restart the timer.\n    timerId = setTimeout(timerExpired, remainingWait(time));\n  }\n\n  function trailingEdge(time) {\n    timerId = undefined;\n\n    // Only invoke if we have `lastArgs` which means `func` has been\n    // debounced at least once.\n    if (trailing && lastArgs) {\n      return invokeFunc(time);\n    }\n    lastArgs = lastThis = undefined;\n    return result;\n  }\n\n  function cancel() {\n    if (timerId !== undefined) {\n      clearTimeout(timerId);\n    }\n    lastInvokeTime = 0;\n    lastArgs = lastCallTime = lastThis = timerId = undefined;\n  }\n\n  function flush() {\n    return timerId === undefined ? result : trailingEdge(now());\n  }\n\n  function debounced() {\n    var time = now(),\n        isInvoking = shouldInvoke(time);\n\n    lastArgs = arguments;\n    lastThis = this;\n    lastCallTime = time;\n\n    if (isInvoking) {\n      if (timerId === undefined) {\n        return leadingEdge(lastCallTime);\n      }\n      if (maxing) {\n        // Handle invocations in a tight loop.\n        clearTimeout(timerId);\n        timerId = setTimeout(timerExpired, wait);\n        return invokeFunc(lastCallTime);\n      }\n    }\n    if (timerId === undefined) {\n      timerId = setTimeout(timerExpired, wait);\n    }\n    return result;\n  }\n  debounced.cancel = cancel;\n  debounced.flush = flush;\n  return debounced;\n}\n\nexport default debounce;\n", "/**\n * Checks `value` to determine whether a default value should be returned in\n * its place. The `defaultValue` is returned if `value` is `NaN`, `null`,\n * or `undefined`.\n *\n * @static\n * @memberOf _\n * @since 4.14.0\n * @category Util\n * @param {*} value The value to check.\n * @param {*} defaultValue The default value.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * _.defaultTo(1, 10);\n * // => 1\n *\n * _.defaultTo(undefined, 10);\n * // => 10\n */\nfunction defaultTo(value, defaultValue) {\n  return (value == null || value !== value) ? defaultValue : value;\n}\n\nexport default defaultTo;\n", "import baseRest from './_baseRest.js';\nimport eq from './eq.js';\nimport isIterateeCall from './_isIterateeCall.js';\nimport keysIn from './keysIn.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns own and inherited enumerable string keyed properties of source\n * objects to the destination object for all destination properties that\n * resolve to `undefined`. Source objects are applied from left to right.\n * Once a property is set, additional values of the same property are ignored.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.defaultsDeep\n * @example\n *\n * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\nvar defaults = baseRest(function(object, sources) {\n  object = Object(object);\n\n  var index = -1;\n  var length = sources.length;\n  var guard = length > 2 ? sources[2] : undefined;\n\n  if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n    length = 1;\n  }\n\n  while (++index < length) {\n    var source = sources[index];\n    var props = keysIn(source);\n    var propsIndex = -1;\n    var propsLength = props.length;\n\n    while (++propsIndex < propsLength) {\n      var key = props[propsIndex];\n      var value = object[key];\n\n      if (value === undefined ||\n          (eq(value, objectProto[key]) && !hasOwnProperty.call(object, key))) {\n        object[key] = source[key];\n      }\n    }\n  }\n\n  return object;\n});\n\nexport default defaults;\n", "import baseAssignValue from './_baseAssignValue.js';\nimport eq from './eq.js';\n\n/**\n * This function is like `assignValue` except that it doesn't assign\n * `undefined` values.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignMergeValue(object, key, value) {\n  if ((value !== undefined && !eq(object[key], value)) ||\n      (value === undefined && !(key in object))) {\n    baseAssignValue(object, key, value);\n  }\n}\n\nexport default assignMergeValue;\n", "import isArrayLike from './isArrayLike.js';\nimport isObjectLike from './isObjectLike.js';\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n *  else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\nfunction isArrayLikeObject(value) {\n  return isObjectLike(value) && isArrayLike(value);\n}\n\nexport default isArrayLikeObject;\n", "/**\n * Gets the value at `key`, unless `key` is \"__proto__\" or \"constructor\".\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction safeGet(object, key) {\n  if (key === 'constructor' && typeof object[key] === 'function') {\n    return;\n  }\n\n  if (key == '__proto__') {\n    return;\n  }\n\n  return object[key];\n}\n\nexport default safeGet;\n", "import copyObject from './_copyObject.js';\nimport keysIn from './keysIn.js';\n\n/**\n * Converts `value` to a plain object flattening inherited enumerable string\n * keyed properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Object} Returns the converted plain object.\n * @example\n *\n * function Foo() {\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.assign({ 'a': 1 }, new Foo);\n * // => { 'a': 1, 'b': 2 }\n *\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\n * // => { 'a': 1, 'b': 2, 'c': 3 }\n */\nfunction toPlainObject(value) {\n  return copyObject(value, keysIn(value));\n}\n\nexport default toPlainObject;\n", "import assignMergeValue from './_assignMergeValue.js';\nimport cloneBuffer from './_cloneBuffer.js';\nimport cloneTypedArray from './_cloneTypedArray.js';\nimport copyArray from './_copyArray.js';\nimport initCloneObject from './_initCloneObject.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\nimport isBuffer from './isBuffer.js';\nimport isFunction from './isFunction.js';\nimport isObject from './isObject.js';\nimport isPlainObject from './isPlainObject.js';\nimport isTypedArray from './isTypedArray.js';\nimport safeGet from './_safeGet.js';\nimport toPlainObject from './toPlainObject.js';\n\n/**\n * A specialized version of `baseMerge` for arrays and objects which performs\n * deep merges and tracks traversed objects enabling objects with circular\n * references to be merged.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {string} key The key of the value to merge.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n *  counterparts.\n */\nfunction baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n  var objValue = safeGet(object, key),\n      srcValue = safeGet(source, key),\n      stacked = stack.get(srcValue);\n\n  if (stacked) {\n    assignMergeValue(object, key, stacked);\n    return;\n  }\n  var newValue = customizer\n    ? customizer(objValue, srcValue, (key + ''), object, source, stack)\n    : undefined;\n\n  var isCommon = newValue === undefined;\n\n  if (isCommon) {\n    var isArr = isArray(srcValue),\n        isBuff = !isArr && isBuffer(srcValue),\n        isTyped = !isArr && !isBuff && isTypedArray(srcValue);\n\n    newValue = srcValue;\n    if (isArr || isBuff || isTyped) {\n      if (isArray(objValue)) {\n        newValue = objValue;\n      }\n      else if (isArrayLikeObject(objValue)) {\n        newValue = copyArray(objValue);\n      }\n      else if (isBuff) {\n        isCommon = false;\n        newValue = cloneBuffer(srcValue, true);\n      }\n      else if (isTyped) {\n        isCommon = false;\n        newValue = cloneTypedArray(srcValue, true);\n      }\n      else {\n        newValue = [];\n      }\n    }\n    else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n      newValue = objValue;\n      if (isArguments(objValue)) {\n        newValue = toPlainObject(objValue);\n      }\n      else if (!isObject(objValue) || isFunction(objValue)) {\n        newValue = initCloneObject(srcValue);\n      }\n    }\n    else {\n      isCommon = false;\n    }\n  }\n  if (isCommon) {\n    // Recursively merge objects and arrays (susceptible to call stack limits).\n    stack.set(srcValue, newValue);\n    mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n    stack['delete'](srcValue);\n  }\n  assignMergeValue(object, key, newValue);\n}\n\nexport default baseMergeDeep;\n", "import Stack from './_Stack.js';\nimport assignMergeValue from './_assignMergeValue.js';\nimport baseFor from './_baseFor.js';\nimport baseMergeDeep from './_baseMergeDeep.js';\nimport isObject from './isObject.js';\nimport keysIn from './keysIn.js';\nimport safeGet from './_safeGet.js';\n\n/**\n * The base implementation of `_.merge` without support for multiple sources.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n *  counterparts.\n */\nfunction baseMerge(object, source, srcIndex, customizer, stack) {\n  if (object === source) {\n    return;\n  }\n  baseFor(source, function(srcValue, key) {\n    stack || (stack = new Stack);\n    if (isObject(srcValue)) {\n      baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\n    }\n    else {\n      var newValue = customizer\n        ? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack)\n        : undefined;\n\n      if (newValue === undefined) {\n        newValue = srcValue;\n      }\n      assignMergeValue(object, key, newValue);\n    }\n  }, keysIn);\n}\n\nexport default baseMerge;\n", "import baseMerge from './_baseMerge.js';\nimport isObject from './isObject.js';\n\n/**\n * Used by `_.defaultsDeep` to customize its `_.merge` use to merge source\n * objects into destination objects that are passed thru.\n *\n * @private\n * @param {*} objValue The destination value.\n * @param {*} srcValue The source value.\n * @param {string} key The key of the property to merge.\n * @param {Object} object The parent object of `objValue`.\n * @param {Object} source The parent object of `srcValue`.\n * @param {Object} [stack] Tracks traversed source values and their merged\n *  counterparts.\n * @returns {*} Returns the value to assign.\n */\nfunction customDefaultsMerge(objValue, srcValue, key, object, source, stack) {\n  if (isObject(objValue) && isObject(srcValue)) {\n    // Recursively merge objects and arrays (susceptible to call stack limits).\n    stack.set(srcValue, objValue);\n    baseMerge(objValue, srcValue, undefined, customDefaultsMerge, stack);\n    stack['delete'](srcValue);\n  }\n  return objValue;\n}\n\nexport default customDefaultsMerge;\n", "import baseMerge from './_baseMerge.js';\nimport createAssigner from './_createAssigner.js';\n\n/**\n * This method is like `_.merge` except that it accepts `customizer` which\n * is invoked to produce the merged values of the destination and source\n * properties. If `customizer` returns `undefined`, merging is handled by the\n * method instead. The `customizer` is invoked with six arguments:\n * (objValue, srcValue, key, object, source, stack).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} customizer The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * function customizer(objValue, srcValue) {\n *   if (_.isArray(objValue)) {\n *     return objValue.concat(srcValue);\n *   }\n * }\n *\n * var object = { 'a': [1], 'b': [2] };\n * var other = { 'a': [3], 'b': [4] };\n *\n * _.mergeWith(object, other, customizer);\n * // => { 'a': [1, 3], 'b': [2, 4] }\n */\nvar mergeWith = createAssigner(function(object, source, srcIndex, customizer) {\n  baseMerge(object, source, srcIndex, customizer);\n});\n\nexport default mergeWith;\n", "import apply from './_apply.js';\nimport baseRest from './_baseRest.js';\nimport customDefaultsMerge from './_customDefaultsMerge.js';\nimport mergeWith from './mergeWith.js';\n\n/**\n * This method is like `_.defaults` except that it recursively assigns\n * default properties.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 3.10.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.defaults\n * @example\n *\n * _.defaultsDeep({ 'a': { 'b': 2 } }, { 'a': { 'b': 1, 'c': 3 } });\n * // => { 'a': { 'b': 2, 'c': 3 } }\n */\nvar defaultsDeep = baseRest(function(args) {\n  args.push(undefined, customDefaultsMerge);\n  return apply(mergeWith, undefined, args);\n});\n\nexport default defaultsDeep;\n", "/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * The base implementation of `_.delay` and `_.defer` which accepts `args`\n * to provide to `func`.\n *\n * @private\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @param {Array} args The arguments to provide to `func`.\n * @returns {number|Object} Returns the timer id or timeout object.\n */\nfunction baseDelay(func, wait, args) {\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  return setTimeout(function() { func.apply(undefined, args); }, wait);\n}\n\nexport default baseDelay;\n", "import baseDelay from './_baseDelay.js';\nimport baseRest from './_baseRest.js';\n\n/**\n * Defers invoking the `func` until the current call stack has cleared. Any\n * additional arguments are provided to `func` when it's invoked.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to defer.\n * @param {...*} [args] The arguments to invoke `func` with.\n * @returns {number} Returns the timer id.\n * @example\n *\n * _.defer(function(text) {\n *   console.log(text);\n * }, 'deferred');\n * // => Logs 'deferred' after one millisecond.\n */\nvar defer = baseRest(function(func, args) {\n  return baseDelay(func, 1, args);\n});\n\nexport default defer;\n", "import baseDelay from './_baseDelay.js';\nimport baseRest from './_baseRest.js';\nimport toNumber from './toNumber.js';\n\n/**\n * Invokes `func` after `wait` milliseconds. Any additional arguments are\n * provided to `func` when it's invoked.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @param {...*} [args] The arguments to invoke `func` with.\n * @returns {number} Returns the timer id.\n * @example\n *\n * _.delay(function(text) {\n *   console.log(text);\n * }, 1000, 'later');\n * // => Logs 'later' after one second.\n */\nvar delay = baseRest(function(func, wait, args) {\n  return baseDelay(func, toNumber(wait) || 0, args);\n});\n\nexport default delay;\n", "/**\n * This function is like `arrayIncludes` except that it accepts a comparator.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @param {Function} comparator The comparator invoked per element.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\nfunction arrayIncludesWith(array, value, comparator) {\n  var index = -1,\n      length = array == null ? 0 : array.length;\n\n  while (++index < length) {\n    if (comparator(value, array[index])) {\n      return true;\n    }\n  }\n  return false;\n}\n\nexport default arrayIncludesWith;\n", "import SetCache from './_SetCache.js';\nimport arrayIncludes from './_arrayIncludes.js';\nimport arrayIncludesWith from './_arrayIncludesWith.js';\nimport arrayMap from './_arrayMap.js';\nimport baseUnary from './_baseUnary.js';\nimport cacheHas from './_cacheHas.js';\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * The base implementation of methods like `_.difference` without support\n * for excluding multiple arrays or iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Array} values The values to exclude.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n */\nfunction baseDifference(array, values, iteratee, comparator) {\n  var index = -1,\n      includes = arrayIncludes,\n      isCommon = true,\n      length = array.length,\n      result = [],\n      valuesLength = values.length;\n\n  if (!length) {\n    return result;\n  }\n  if (iteratee) {\n    values = arrayMap(values, baseUnary(iteratee));\n  }\n  if (comparator) {\n    includes = arrayIncludesWith;\n    isCommon = false;\n  }\n  else if (values.length >= LARGE_ARRAY_SIZE) {\n    includes = cacheHas;\n    isCommon = false;\n    values = new SetCache(values);\n  }\n  outer:\n  while (++index < length) {\n    var value = array[index],\n        computed = iteratee == null ? value : iteratee(value);\n\n    value = (comparator || value !== 0) ? value : 0;\n    if (isCommon && computed === computed) {\n      var valuesIndex = valuesLength;\n      while (valuesIndex--) {\n        if (values[valuesIndex] === computed) {\n          continue outer;\n        }\n      }\n      result.push(value);\n    }\n    else if (!includes(values, computed, comparator)) {\n      result.push(value);\n    }\n  }\n  return result;\n}\n\nexport default baseDifference;\n", "import baseDifference from './_baseDifference.js';\nimport baseFlatten from './_baseFlatten.js';\nimport baseRest from './_baseRest.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\n\n/**\n * Creates an array of `array` values not included in the other given arrays\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. The order and references of result values are\n * determined by the first array.\n *\n * **Note:** Unlike `_.pullAll`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.without, _.xor\n * @example\n *\n * _.difference([2, 1], [2, 3]);\n * // => [1]\n */\nvar difference = baseRest(function(array, values) {\n  return isArrayLikeObject(array)\n    ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true))\n    : [];\n});\n\nexport default difference;\n", "/**\n * Gets the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the last element of `array`.\n * @example\n *\n * _.last([1, 2, 3]);\n * // => 3\n */\nfunction last(array) {\n  var length = array == null ? 0 : array.length;\n  return length ? array[length - 1] : undefined;\n}\n\nexport default last;\n", "import baseDifference from './_baseDifference.js';\nimport baseFlatten from './_baseFlatten.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseRest from './_baseRest.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\nimport last from './last.js';\n\n/**\n * This method is like `_.difference` except that it accepts `iteratee` which\n * is invoked for each element of `array` and `values` to generate the criterion\n * by which they're compared. The order and references of result values are\n * determined by the first array. The iteratee is invoked with one argument:\n * (value).\n *\n * **Note:** Unlike `_.pullAllBy`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.differenceBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.differenceBy([{ 'x': 2 }, { 'x': 1 }], [{ 'x': 1 }], 'x');\n * // => [{ 'x': 2 }]\n */\nvar differenceBy = baseRest(function(array, values) {\n  var iteratee = last(values);\n  if (isArrayLikeObject(iteratee)) {\n    iteratee = undefined;\n  }\n  return isArrayLikeObject(array)\n    ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), baseIteratee(iteratee, 2))\n    : [];\n});\n\nexport default differenceBy;\n", "import baseDifference from './_baseDifference.js';\nimport baseFlatten from './_baseFlatten.js';\nimport baseRest from './_baseRest.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\nimport last from './last.js';\n\n/**\n * This method is like `_.difference` except that it accepts `comparator`\n * which is invoked to compare elements of `array` to `values`. The order and\n * references of result values are determined by the first array. The comparator\n * is invoked with two arguments: (arrVal, othVal).\n *\n * **Note:** Unlike `_.pullAllWith`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n *\n * _.differenceWith(objects, [{ 'x': 1, 'y': 2 }], _.isEqual);\n * // => [{ 'x': 2, 'y': 1 }]\n */\nvar differenceWith = baseRest(function(array, values) {\n  var comparator = last(values);\n  if (isArrayLikeObject(comparator)) {\n    comparator = undefined;\n  }\n  return isArrayLikeObject(array)\n    ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), undefined, comparator)\n    : [];\n});\n\nexport default differenceWith;\n", "import createMathOperation from './_createMathOperation.js';\n\n/**\n * Divide two numbers.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Math\n * @param {number} dividend The first number in a division.\n * @param {number} divisor The second number in a division.\n * @returns {number} Returns the quotient.\n * @example\n *\n * _.divide(6, 4);\n * // => 1.5\n */\nvar divide = createMathOperation(function(dividend, divisor) {\n  return dividend / divisor;\n}, 1);\n\nexport default divide;\n", "import baseSlice from './_baseSlice.js';\nimport toInteger from './toInteger.js';\n\n/**\n * Creates a slice of `array` with `n` elements dropped from the beginning.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to drop.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.drop([1, 2, 3]);\n * // => [2, 3]\n *\n * _.drop([1, 2, 3], 2);\n * // => [3]\n *\n * _.drop([1, 2, 3], 5);\n * // => []\n *\n * _.drop([1, 2, 3], 0);\n * // => [1, 2, 3]\n */\nfunction drop(array, n, guard) {\n  var length = array == null ? 0 : array.length;\n  if (!length) {\n    return [];\n  }\n  n = (guard || n === undefined) ? 1 : toInteger(n);\n  return baseSlice(array, n < 0 ? 0 : n, length);\n}\n\nexport default drop;\n", "import baseSlice from './_baseSlice.js';\nimport toInteger from './toInteger.js';\n\n/**\n * Creates a slice of `array` with `n` elements dropped from the end.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to drop.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.dropRight([1, 2, 3]);\n * // => [1, 2]\n *\n * _.dropRight([1, 2, 3], 2);\n * // => [1]\n *\n * _.dropRight([1, 2, 3], 5);\n * // => []\n *\n * _.dropRight([1, 2, 3], 0);\n * // => [1, 2, 3]\n */\nfunction dropRight(array, n, guard) {\n  var length = array == null ? 0 : array.length;\n  if (!length) {\n    return [];\n  }\n  n = (guard || n === undefined) ? 1 : toInteger(n);\n  n = length - n;\n  return baseSlice(array, 0, n < 0 ? 0 : n);\n}\n\nexport default dropRight;\n", "import baseSlice from './_baseSlice.js';\n\n/**\n * The base implementation of methods like `_.dropWhile` and `_.takeWhile`\n * without support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to query.\n * @param {Function} predicate The function invoked per iteration.\n * @param {boolean} [isDrop] Specify dropping elements instead of taking them.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the slice of `array`.\n */\nfunction baseWhile(array, predicate, isDrop, fromRight) {\n  var length = array.length,\n      index = fromRight ? length : -1;\n\n  while ((fromRight ? index-- : ++index < length) &&\n    predicate(array[index], index, array)) {}\n\n  return isDrop\n    ? baseSlice(array, (fromRight ? 0 : index), (fromRight ? index + 1 : length))\n    : baseSlice(array, (fromRight ? index + 1 : 0), (fromRight ? length : index));\n}\n\nexport default baseWhile;\n", "import baseIteratee from './_baseIteratee.js';\nimport baseWhile from './_baseWhile.js';\n\n/**\n * Creates a slice of `array` excluding elements dropped from the end.\n * Elements are dropped until `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n *   { 'user': 'barney',  'active': true },\n *   { 'user': 'fred',    'active': false },\n *   { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.dropRightWhile(users, function(o) { return !o.active; });\n * // => objects for ['barney']\n *\n * // The `_.matches` iteratee shorthand.\n * _.dropRightWhile(users, { 'user': 'pebbles', 'active': false });\n * // => objects for ['barney', 'fred']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.dropRightWhile(users, ['active', false]);\n * // => objects for ['barney']\n *\n * // The `_.property` iteratee shorthand.\n * _.dropRightWhile(users, 'active');\n * // => objects for ['barney', 'fred', 'pebbles']\n */\nfunction dropRightWhile(array, predicate) {\n  return (array && array.length)\n    ? baseWhile(array, baseIteratee(predicate, 3), true, true)\n    : [];\n}\n\nexport default dropRightWhile;\n", "import baseIteratee from './_baseIteratee.js';\nimport baseWhile from './_baseWhile.js';\n\n/**\n * Creates a slice of `array` excluding elements dropped from the beginning.\n * Elements are dropped until `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n *   { 'user': 'barney',  'active': false },\n *   { 'user': 'fred',    'active': false },\n *   { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.dropWhile(users, function(o) { return !o.active; });\n * // => objects for ['pebbles']\n *\n * // The `_.matches` iteratee shorthand.\n * _.dropWhile(users, { 'user': 'barney', 'active': false });\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.dropWhile(users, ['active', false]);\n * // => objects for ['pebbles']\n *\n * // The `_.property` iteratee shorthand.\n * _.dropWhile(users, 'active');\n * // => objects for ['barney', 'fred', 'pebbles']\n */\nfunction dropWhile(array, predicate) {\n  return (array && array.length)\n    ? baseWhile(array, baseIteratee(predicate, 3), true)\n    : [];\n}\n\nexport default dropWhile;\n", "import identity from './identity.js';\n\n/**\n * Casts `value` to `identity` if it's not a function.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Function} Returns cast function.\n */\nfunction castFunction(value) {\n  return typeof value == 'function' ? value : identity;\n}\n\nexport default castFunction;\n", "import arrayEach from './_arrayEach.js';\nimport baseEach from './_baseEach.js';\nimport castFunction from './_castFunction.js';\nimport isArray from './isArray.js';\n\n/**\n * Iterates over elements of `collection` and invokes `iteratee` for each element.\n * The iteratee is invoked with three arguments: (value, index|key, collection).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * **Note:** As with other \"Collections\" methods, objects with a \"length\"\n * property are iterated like arrays. To avoid this behavior use `_.forIn`\n * or `_.forOwn` for object iteration.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @alias each\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n * @see _.forEachRight\n * @example\n *\n * _.forEach([1, 2], function(value) {\n *   console.log(value);\n * });\n * // => Logs `1` then `2`.\n *\n * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) {\n *   console.log(key);\n * });\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\n */\nfunction forEach(collection, iteratee) {\n  var func = isArray(collection) ? arrayEach : baseEach;\n  return func(collection, castFunction(iteratee));\n}\n\nexport default forEach;\n", "/**\n * A specialized version of `_.forEachRight` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEachRight(array, iteratee) {\n  var length = array == null ? 0 : array.length;\n\n  while (length--) {\n    if (iteratee(array[length], length, array) === false) {\n      break;\n    }\n  }\n  return array;\n}\n\nexport default arrayEachRight;\n", "import createBaseFor from './_createBaseFor.js';\n\n/**\n * This function is like `baseFor` except that it iterates over properties\n * in the opposite order.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseForRight = createBaseFor(true);\n\nexport default baseForRight;\n", "import baseForRight from './_baseForRight.js';\nimport keys from './keys.js';\n\n/**\n * The base implementation of `_.forOwnRight` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForOwnRight(object, iteratee) {\n  return object && baseForRight(object, iteratee, keys);\n}\n\nexport default baseForOwnRight;\n", "import baseForOwnRight from './_baseForOwnRight.js';\nimport createBaseEach from './_createBaseEach.js';\n\n/**\n * The base implementation of `_.forEachRight` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\nvar baseEachRight = createBaseEach(baseForOwnRight, true);\n\nexport default baseEachRight;\n", "import arrayEachRight from './_arrayEachRight.js';\nimport baseEachRight from './_baseEachRight.js';\nimport castFunction from './_castFunction.js';\nimport isArray from './isArray.js';\n\n/**\n * This method is like `_.forEach` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @alias eachRight\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n * @see _.forEach\n * @example\n *\n * _.forEachRight([1, 2], function(value) {\n *   console.log(value);\n * });\n * // => Logs `2` then `1`.\n */\nfunction forEachRight(collection, iteratee) {\n  var func = isArray(collection) ? arrayEachRight : baseEachRight;\n  return func(collection, castFunction(iteratee));\n}\n\nexport default forEachRight;\n", "import baseClamp from './_baseClamp.js';\nimport baseToString from './_baseToString.js';\nimport toInteger from './toInteger.js';\nimport toString from './toString.js';\n\n/**\n * Checks if `string` ends with the given target string.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {string} [target] The string to search for.\n * @param {number} [position=string.length] The position to search up to.\n * @returns {boolean} Returns `true` if `string` ends with `target`,\n *  else `false`.\n * @example\n *\n * _.endsWith('abc', 'c');\n * // => true\n *\n * _.endsWith('abc', 'b');\n * // => false\n *\n * _.endsWith('abc', 'b', 2);\n * // => true\n */\nfunction endsWith(string, target, position) {\n  string = toString(string);\n  target = baseToString(target);\n\n  var length = string.length;\n  position = position === undefined\n    ? length\n    : baseClamp(toInteger(position), 0, length);\n\n  var end = position;\n  position -= target.length;\n  return position >= 0 && string.slice(position, end) == target;\n}\n\nexport default endsWith;\n", "import arrayMap from './_arrayMap.js';\n\n/**\n * The base implementation of `_.toPairs` and `_.toPairsIn` which creates an array\n * of key-value pairs for `object` corresponding to the property names of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the key-value pairs.\n */\nfunction baseToPairs(object, props) {\n  return arrayMap(props, function(key) {\n    return [key, object[key]];\n  });\n}\n\nexport default baseToPairs;\n", "/**\n * Converts `set` to its value-value pairs.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the value-value pairs.\n */\nfunction setToPairs(set) {\n  var index = -1,\n      result = Array(set.size);\n\n  set.forEach(function(value) {\n    result[++index] = [value, value];\n  });\n  return result;\n}\n\nexport default setToPairs;\n", "import baseToPairs from './_baseToPairs.js';\nimport getTag from './_getTag.js';\nimport mapToArray from './_mapToArray.js';\nimport setToPairs from './_setToPairs.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n    setTag = '[object Set]';\n\n/**\n * Creates a `_.toPairs` or `_.toPairsIn` function.\n *\n * @private\n * @param {Function} keysFunc The function to get the keys of a given object.\n * @returns {Function} Returns the new pairs function.\n */\nfunction createToPairs(keysFunc) {\n  return function(object) {\n    var tag = getTag(object);\n    if (tag == mapTag) {\n      return mapToArray(object);\n    }\n    if (tag == setTag) {\n      return setToPairs(object);\n    }\n    return baseToPairs(object, keysFunc(object));\n  };\n}\n\nexport default createToPairs;\n", "import createToPairs from './_createToPairs.js';\nimport keys from './keys.js';\n\n/**\n * Creates an array of own enumerable string keyed-value pairs for `object`\n * which can be consumed by `_.fromPairs`. If `object` is a map or set, its\n * entries are returned.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias entries\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the key-value pairs.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.toPairs(new Foo);\n * // => [['a', 1], ['b', 2]] (iteration order is not guaranteed)\n */\nvar toPairs = createToPairs(keys);\n\nexport default toPairs;\n", "import createToPairs from './_createToPairs.js';\nimport keysIn from './keysIn.js';\n\n/**\n * Creates an array of own and inherited enumerable string keyed-value pairs\n * for `object` which can be consumed by `_.fromPairs`. If `object` is a map\n * or set, its entries are returned.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias entriesIn\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the key-value pairs.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.toPairsIn(new Foo);\n * // => [['a', 1], ['b', 2], ['c', 3]] (iteration order is not guaranteed)\n */\nvar toPairsIn = createToPairs(keysIn);\n\nexport default toPairsIn;\n", "import basePropertyOf from './_basePropertyOf.js';\n\n/** Used to map characters to HTML entities. */\nvar htmlEscapes = {\n  '&': '&amp;',\n  '<': '&lt;',\n  '>': '&gt;',\n  '\"': '&quot;',\n  \"'\": '&#39;'\n};\n\n/**\n * Used by `_.escape` to convert characters to HTML entities.\n *\n * @private\n * @param {string} chr The matched character to escape.\n * @returns {string} Returns the escaped character.\n */\nvar escapeHtmlChar = basePropertyOf(htmlEscapes);\n\nexport default escapeHtmlChar;\n", "import escapeHtmlChar from './_escapeHtmlChar.js';\nimport toString from './toString.js';\n\n/** Used to match HTML entities and HTML characters. */\nvar reUnescapedHtml = /[&<>\"']/g,\n    reHasUnescapedHtml = RegExp(reUnescapedHtml.source);\n\n/**\n * Converts the characters \"&\", \"<\", \">\", '\"', and \"'\" in `string` to their\n * corresponding HTML entities.\n *\n * **Note:** No other characters are escaped. To escape additional\n * characters use a third-party library like [_he_](https://mths.be/he).\n *\n * Though the \">\" character is escaped for symmetry, characters like\n * \">\" and \"/\" don't need escaping in HTML and have no special meaning\n * unless they're part of a tag or unquoted attribute value. See\n * [Mathias Bynens's article](https://mathiasbynens.be/notes/ambiguous-ampersands)\n * (under \"semi-related fun fact\") for more details.\n *\n * When working with HTML you should always\n * [quote attribute values](http://wonko.com/post/html-escaping) to reduce\n * XSS vectors.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category String\n * @param {string} [string=''] The string to escape.\n * @returns {string} Returns the escaped string.\n * @example\n *\n * _.escape('fred, barney, & pebbles');\n * // => 'fred, barney, &amp; pebbles'\n */\nfunction escape(string) {\n  string = toString(string);\n  return (string && reHasUnescapedHtml.test(string))\n    ? string.replace(reUnescapedHtml, escapeHtmlChar)\n    : string;\n}\n\nexport default escape;\n", "import toString from './toString.js';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g,\n    reHasRegExpChar = RegExp(reRegExpChar.source);\n\n/**\n * Escapes the `RegExp` special characters \"^\", \"$\", \"\\\", \".\", \"*\", \"+\",\n * \"?\", \"(\", \")\", \"[\", \"]\", \"{\", \"}\", and \"|\" in `string`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to escape.\n * @returns {string} Returns the escaped string.\n * @example\n *\n * _.escapeRegExp('[lodash](https://lodash.com/)');\n * // => '\\[lodash\\]\\(https://lodash\\.com/\\)'\n */\nfunction escapeRegExp(string) {\n  string = toString(string);\n  return (string && reHasRegExpChar.test(string))\n    ? string.replace(reRegExpChar, '\\\\$&')\n    : string;\n}\n\nexport default escapeRegExp;\n", "/**\n * A specialized version of `_.every` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n *  else `false`.\n */\nfunction arrayEvery(array, predicate) {\n  var index = -1,\n      length = array == null ? 0 : array.length;\n\n  while (++index < length) {\n    if (!predicate(array[index], index, array)) {\n      return false;\n    }\n  }\n  return true;\n}\n\nexport default arrayEvery;\n", "import baseEach from './_baseEach.js';\n\n/**\n * The base implementation of `_.every` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n *  else `false`\n */\nfunction baseEvery(collection, predicate) {\n  var result = true;\n  baseEach(collection, function(value, index, collection) {\n    result = !!predicate(value, index, collection);\n    return result;\n  });\n  return result;\n}\n\nexport default baseEvery;\n", "import arrayEvery from './_arrayEvery.js';\nimport baseEvery from './_baseEvery.js';\nimport baseIteratee from './_baseIteratee.js';\nimport isArray from './isArray.js';\nimport isIterateeCall from './_isIterateeCall.js';\n\n/**\n * Checks if `predicate` returns truthy for **all** elements of `collection`.\n * Iteration is stopped once `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index|key, collection).\n *\n * **Note:** This method returns `true` for\n * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because\n * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of\n * elements of empty collections.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n *  else `false`.\n * @example\n *\n * _.every([true, 1, null, 'yes'], Boolean);\n * // => false\n *\n * var users = [\n *   { 'user': 'barney', 'age': 36, 'active': false },\n *   { 'user': 'fred',   'age': 40, 'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.every(users, { 'user': 'barney', 'active': false });\n * // => false\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.every(users, ['active', false]);\n * // => true\n *\n * // The `_.property` iteratee shorthand.\n * _.every(users, 'active');\n * // => false\n */\nfunction every(collection, predicate, guard) {\n  var func = isArray(collection) ? arrayEvery : baseEvery;\n  if (guard && isIterateeCall(collection, predicate, guard)) {\n    predicate = undefined;\n  }\n  return func(collection, baseIteratee(predicate, 3));\n}\n\nexport default every;\n", "import baseClamp from './_baseClamp.js';\nimport toInteger from './toInteger.js';\n\n/** Used as references for the maximum length and index of an array. */\nvar MAX_ARRAY_LENGTH = 4294967295;\n\n/**\n * Converts `value` to an integer suitable for use as the length of an\n * array-like object.\n *\n * **Note:** This method is based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toLength(3.2);\n * // => 3\n *\n * _.toLength(Number.MIN_VALUE);\n * // => 0\n *\n * _.toLength(Infinity);\n * // => 4294967295\n *\n * _.toLength('3.2');\n * // => 3\n */\nfunction toLength(value) {\n  return value ? baseClamp(toInteger(value), 0, MAX_ARRAY_LENGTH) : 0;\n}\n\nexport default toLength;\n", "import toInteger from './toInteger.js';\nimport toLength from './toLength.js';\n\n/**\n * The base implementation of `_.fill` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n */\nfunction baseFill(array, value, start, end) {\n  var length = array.length;\n\n  start = toInteger(start);\n  if (start < 0) {\n    start = -start > length ? 0 : (length + start);\n  }\n  end = (end === undefined || end > length) ? length : toInteger(end);\n  if (end < 0) {\n    end += length;\n  }\n  end = start > end ? 0 : toLength(end);\n  while (start < end) {\n    array[start++] = value;\n  }\n  return array;\n}\n\nexport default baseFill;\n", "import baseFill from './_baseFill.js';\nimport isIterateeCall from './_isIterateeCall.js';\n\n/**\n * Fills elements of `array` with `value` from `start` up to, but not\n * including, `end`.\n *\n * **Note:** This method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Array\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _.fill(array, 'a');\n * console.log(array);\n * // => ['a', 'a', 'a']\n *\n * _.fill(Array(3), 2);\n * // => [2, 2, 2]\n *\n * _.fill([4, 6, 8, 10], '*', 1, 3);\n * // => [4, '*', '*', 10]\n */\nfunction fill(array, value, start, end) {\n  var length = array == null ? 0 : array.length;\n  if (!length) {\n    return [];\n  }\n  if (start && typeof start != 'number' && isIterateeCall(array, value, start)) {\n    start = 0;\n    end = length;\n  }\n  return baseFill(array, value, start, end);\n}\n\nexport default fill;\n", "import baseEach from './_baseEach.js';\n\n/**\n * The base implementation of `_.filter` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction baseFilter(collection, predicate) {\n  var result = [];\n  baseEach(collection, function(value, index, collection) {\n    if (predicate(value, index, collection)) {\n      result.push(value);\n    }\n  });\n  return result;\n}\n\nexport default baseFilter;\n", "import arrayFilter from './_arrayFilter.js';\nimport baseFilter from './_baseFilter.js';\nimport baseIteratee from './_baseIteratee.js';\nimport isArray from './isArray.js';\n\n/**\n * Iterates over elements of `collection`, returning an array of all elements\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * **Note:** Unlike `_.remove`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.reject\n * @example\n *\n * var users = [\n *   { 'user': 'barney', 'age': 36, 'active': true },\n *   { 'user': 'fred',   'age': 40, 'active': false }\n * ];\n *\n * _.filter(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.filter(users, { 'age': 36, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.filter(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.filter(users, 'active');\n * // => objects for ['barney']\n *\n * // Combining several predicates using `_.overEvery` or `_.overSome`.\n * _.filter(users, _.overSome([{ 'age': 36 }, ['age', 40]]));\n * // => objects for ['fred', 'barney']\n */\nfunction filter(collection, predicate) {\n  var func = isArray(collection) ? arrayFilter : baseFilter;\n  return func(collection, baseIteratee(predicate, 3));\n}\n\nexport default filter;\n", "import baseIteratee from './_baseIteratee.js';\nimport isArrayLike from './isArrayLike.js';\nimport keys from './keys.js';\n\n/**\n * Creates a `_.find` or `_.findLast` function.\n *\n * @private\n * @param {Function} findIndexFunc The function to find the collection index.\n * @returns {Function} Returns the new find function.\n */\nfunction createFind(findIndexFunc) {\n  return function(collection, predicate, fromIndex) {\n    var iterable = Object(collection);\n    if (!isArrayLike(collection)) {\n      var iteratee = baseIteratee(predicate, 3);\n      collection = keys(collection);\n      predicate = function(key) { return iteratee(iterable[key], key, iterable); };\n    }\n    var index = findIndexFunc(collection, predicate, fromIndex);\n    return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined;\n  };\n}\n\nexport default createFind;\n", "import baseFindIndex from './_baseFindIndex.js';\nimport baseIteratee from './_baseIteratee.js';\nimport toInteger from './toInteger.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * This method is like `_.find` except that it returns the index of the first\n * element `predicate` returns truthy for instead of the element itself.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n *   { 'user': 'barney',  'active': false },\n *   { 'user': 'fred',    'active': false },\n *   { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.findIndex(users, function(o) { return o.user == 'barney'; });\n * // => 0\n *\n * // The `_.matches` iteratee shorthand.\n * _.findIndex(users, { 'user': 'fred', 'active': false });\n * // => 1\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findIndex(users, ['active', false]);\n * // => 0\n *\n * // The `_.property` iteratee shorthand.\n * _.findIndex(users, 'active');\n * // => 2\n */\nfunction findIndex(array, predicate, fromIndex) {\n  var length = array == null ? 0 : array.length;\n  if (!length) {\n    return -1;\n  }\n  var index = fromIndex == null ? 0 : toInteger(fromIndex);\n  if (index < 0) {\n    index = nativeMax(length + index, 0);\n  }\n  return baseFindIndex(array, baseIteratee(predicate, 3), index);\n}\n\nexport default findIndex;\n", "import createFind from './_createFind.js';\nimport findIndex from './findIndex.js';\n\n/**\n * Iterates over elements of `collection`, returning the first element\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * var users = [\n *   { 'user': 'barney',  'age': 36, 'active': true },\n *   { 'user': 'fred',    'age': 40, 'active': false },\n *   { 'user': 'pebbles', 'age': 1,  'active': true }\n * ];\n *\n * _.find(users, function(o) { return o.age < 40; });\n * // => object for 'barney'\n *\n * // The `_.matches` iteratee shorthand.\n * _.find(users, { 'age': 1, 'active': true });\n * // => object for 'pebbles'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.find(users, ['active', false]);\n * // => object for 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.find(users, 'active');\n * // => object for 'barney'\n */\nvar find = createFind(findIndex);\n\nexport default find;\n", "/**\n * The base implementation of methods like `_.findKey` and `_.findLastKey`,\n * without support for iteratee shorthands, which iterates over `collection`\n * using `eachFunc`.\n *\n * @private\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @returns {*} Returns the found element or its key, else `undefined`.\n */\nfunction baseFindKey(collection, predicate, eachFunc) {\n  var result;\n  eachFunc(collection, function(value, key, collection) {\n    if (predicate(value, key, collection)) {\n      result = key;\n      return false;\n    }\n  });\n  return result;\n}\n\nexport default baseFindKey;\n", "import baseFindKey from './_baseFindKey.js';\nimport baseForOwn from './_baseForOwn.js';\nimport baseIteratee from './_baseIteratee.js';\n\n/**\n * This method is like `_.find` except that it returns the key of the first\n * element `predicate` returns truthy for instead of the element itself.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {string|undefined} Returns the key of the matched element,\n *  else `undefined`.\n * @example\n *\n * var users = {\n *   'barney':  { 'age': 36, 'active': true },\n *   'fred':    { 'age': 40, 'active': false },\n *   'pebbles': { 'age': 1,  'active': true }\n * };\n *\n * _.findKey(users, function(o) { return o.age < 40; });\n * // => 'barney' (iteration order is not guaranteed)\n *\n * // The `_.matches` iteratee shorthand.\n * _.findKey(users, { 'age': 1, 'active': true });\n * // => 'pebbles'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findKey(users, ['active', false]);\n * // => 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.findKey(users, 'active');\n * // => 'barney'\n */\nfunction findKey(object, predicate) {\n  return baseFindKey(object, baseIteratee(predicate, 3), baseForOwn);\n}\n\nexport default findKey;\n", "import baseFindIndex from './_baseFindIndex.js';\nimport baseIteratee from './_baseIteratee.js';\nimport toInteger from './toInteger.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n    nativeMin = Math.min;\n\n/**\n * This method is like `_.findIndex` except that it iterates over elements\n * of `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=array.length-1] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n *   { 'user': 'barney',  'active': true },\n *   { 'user': 'fred',    'active': false },\n *   { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.findLastIndex(users, function(o) { return o.user == 'pebbles'; });\n * // => 2\n *\n * // The `_.matches` iteratee shorthand.\n * _.findLastIndex(users, { 'user': 'barney', 'active': true });\n * // => 0\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findLastIndex(users, ['active', false]);\n * // => 2\n *\n * // The `_.property` iteratee shorthand.\n * _.findLastIndex(users, 'active');\n * // => 0\n */\nfunction findLastIndex(array, predicate, fromIndex) {\n  var length = array == null ? 0 : array.length;\n  if (!length) {\n    return -1;\n  }\n  var index = length - 1;\n  if (fromIndex !== undefined) {\n    index = toInteger(fromIndex);\n    index = fromIndex < 0\n      ? nativeMax(length + index, 0)\n      : nativeMin(index, length - 1);\n  }\n  return baseFindIndex(array, baseIteratee(predicate, 3), index, true);\n}\n\nexport default findLastIndex;\n", "import createFind from './_createFind.js';\nimport findLastIndex from './findLastIndex.js';\n\n/**\n * This method is like `_.find` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=collection.length-1] The index to search from.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * _.findLast([1, 2, 3, 4], function(n) {\n *   return n % 2 == 1;\n * });\n * // => 3\n */\nvar findLast = createFind(findLastIndex);\n\nexport default findLast;\n", "import baseFindKey from './_baseFindKey.js';\nimport baseForOwnRight from './_baseForOwnRight.js';\nimport baseIteratee from './_baseIteratee.js';\n\n/**\n * This method is like `_.findKey` except that it iterates over elements of\n * a collection in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {string|undefined} Returns the key of the matched element,\n *  else `undefined`.\n * @example\n *\n * var users = {\n *   'barney':  { 'age': 36, 'active': true },\n *   'fred':    { 'age': 40, 'active': false },\n *   'pebbles': { 'age': 1,  'active': true }\n * };\n *\n * _.findLastKey(users, function(o) { return o.age < 40; });\n * // => returns 'pebbles' assuming `_.findKey` returns 'barney'\n *\n * // The `_.matches` iteratee shorthand.\n * _.findLastKey(users, { 'age': 36, 'active': true });\n * // => 'barney'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findLastKey(users, ['active', false]);\n * // => 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.findLastKey(users, 'active');\n * // => 'pebbles'\n */\nfunction findLastKey(object, predicate) {\n  return baseFindKey(object, baseIteratee(predicate, 3), baseForOwnRight);\n}\n\nexport default findLastKey;\n", "/**\n * Gets the first element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @alias first\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the first element of `array`.\n * @example\n *\n * _.head([1, 2, 3]);\n * // => 1\n *\n * _.head([]);\n * // => undefined\n */\nfunction head(array) {\n  return (array && array.length) ? array[0] : undefined;\n}\n\nexport default head;\n", "import baseEach from './_baseEach.js';\nimport isArrayLike from './isArrayLike.js';\n\n/**\n * The base implementation of `_.map` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction baseMap(collection, iteratee) {\n  var index = -1,\n      result = isArrayLike(collection) ? Array(collection.length) : [];\n\n  baseEach(collection, function(value, key, collection) {\n    result[++index] = iteratee(value, key, collection);\n  });\n  return result;\n}\n\nexport default baseMap;\n", "import arrayMap from './_arrayMap.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseMap from './_baseMap.js';\nimport isArray from './isArray.js';\n\n/**\n * Creates an array of values by running each element in `collection` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.\n *\n * The guarded methods are:\n * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`,\n * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`,\n * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`,\n * `template`, `trim`, `trimEnd`, `trimStart`, and `words`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n * @example\n *\n * function square(n) {\n *   return n * n;\n * }\n *\n * _.map([4, 8], square);\n * // => [16, 64]\n *\n * _.map({ 'a': 4, 'b': 8 }, square);\n * // => [16, 64] (iteration order is not guaranteed)\n *\n * var users = [\n *   { 'user': 'barney' },\n *   { 'user': 'fred' }\n * ];\n *\n * // The `_.property` iteratee shorthand.\n * _.map(users, 'user');\n * // => ['barney', 'fred']\n */\nfunction map(collection, iteratee) {\n  var func = isArray(collection) ? arrayMap : baseMap;\n  return func(collection, baseIteratee(iteratee, 3));\n}\n\nexport default map;\n", "import baseFlatten from './_baseFlatten.js';\nimport map from './map.js';\n\n/**\n * Creates a flattened array of values by running each element in `collection`\n * thru `iteratee` and flattening the mapped results. The iteratee is invoked\n * with three arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n *   return [n, n];\n * }\n *\n * _.flatMap([1, 2], duplicate);\n * // => [1, 1, 2, 2]\n */\nfunction flatMap(collection, iteratee) {\n  return baseFlatten(map(collection, iteratee), 1);\n}\n\nexport default flatMap;\n", "import baseFlatten from './_baseFlatten.js';\nimport map from './map.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * This method is like `_.flatMap` except that it recursively flattens the\n * mapped results.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n *   return [[[n, n]]];\n * }\n *\n * _.flatMapDeep([1, 2], duplicate);\n * // => [1, 1, 2, 2]\n */\nfunction flatMapDeep(collection, iteratee) {\n  return baseFlatten(map(collection, iteratee), INFINITY);\n}\n\nexport default flatMapDeep;\n", "import baseFlatten from './_baseFlatten.js';\nimport map from './map.js';\nimport toInteger from './toInteger.js';\n\n/**\n * This method is like `_.flatMap` except that it recursively flattens the\n * mapped results up to `depth` times.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {number} [depth=1] The maximum recursion depth.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n *   return [[[n, n]]];\n * }\n *\n * _.flatMapDepth([1, 2], duplicate, 2);\n * // => [[1, 1], [2, 2]]\n */\nfunction flatMapDepth(collection, iteratee, depth) {\n  depth = depth === undefined ? 1 : toInteger(depth);\n  return baseFlatten(map(collection, iteratee), depth);\n}\n\nexport default flatMapDepth;\n", "import baseFlatten from './_baseFlatten.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Recursively flattens `array`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flattenDeep([1, [2, [3, [4]], 5]]);\n * // => [1, 2, 3, 4, 5]\n */\nfunction flattenDeep(array) {\n  var length = array == null ? 0 : array.length;\n  return length ? baseFlatten(array, INFINITY) : [];\n}\n\nexport default flattenDeep;\n", "import baseFlatten from './_baseFlatten.js';\nimport toInteger from './toInteger.js';\n\n/**\n * Recursively flatten `array` up to `depth` times.\n *\n * @static\n * @memberOf _\n * @since 4.4.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @param {number} [depth=1] The maximum recursion depth.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * var array = [1, [2, [3, [4]], 5]];\n *\n * _.flattenDepth(array, 1);\n * // => [1, 2, [3, [4]], 5]\n *\n * _.flattenDepth(array, 2);\n * // => [1, 2, 3, [4], 5]\n */\nfunction flattenDepth(array, depth) {\n  var length = array == null ? 0 : array.length;\n  if (!length) {\n    return [];\n  }\n  depth = depth === undefined ? 1 : toInteger(depth);\n  return baseFlatten(array, depth);\n}\n\nexport default flattenDepth;\n", "import createWrap from './_createWrap.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_FLIP_FLAG = 512;\n\n/**\n * Creates a function that invokes `func` with arguments reversed.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to flip arguments for.\n * @returns {Function} Returns the new flipped function.\n * @example\n *\n * var flipped = _.flip(function() {\n *   return _.toArray(arguments);\n * });\n *\n * flipped('a', 'b', 'c', 'd');\n * // => ['d', 'c', 'b', 'a']\n */\nfunction flip(func) {\n  return createWrap(func, WRAP_FLIP_FLAG);\n}\n\nexport default flip;\n", "import createRound from './_createRound.js';\n\n/**\n * Computes `number` rounded down to `precision`.\n *\n * @static\n * @memberOf _\n * @since 3.10.0\n * @category Math\n * @param {number} number The number to round down.\n * @param {number} [precision=0] The precision to round down to.\n * @returns {number} Returns the rounded down number.\n * @example\n *\n * _.floor(4.006);\n * // => 4\n *\n * _.floor(0.046, 2);\n * // => 0.04\n *\n * _.floor(4060, -2);\n * // => 4000\n */\nvar floor = createRound('floor');\n\nexport default floor;\n", "import LodashWrapper from './_LodashWrapper.js';\nimport flatRest from './_flatRest.js';\nimport getData from './_getData.js';\nimport getFuncName from './_getFuncName.js';\nimport isArray from './isArray.js';\nimport isLaziable from './_isLaziable.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_CURRY_FLAG = 8,\n    WRAP_PARTIAL_FLAG = 32,\n    WRAP_ARY_FLAG = 128,\n    WRAP_REARG_FLAG = 256;\n\n/**\n * Creates a `_.flow` or `_.flowRight` function.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new flow function.\n */\nfunction createFlow(fromRight) {\n  return flatRest(function(funcs) {\n    var length = funcs.length,\n        index = length,\n        prereq = LodashWrapper.prototype.thru;\n\n    if (fromRight) {\n      funcs.reverse();\n    }\n    while (index--) {\n      var func = funcs[index];\n      if (typeof func != 'function') {\n        throw new TypeError(FUNC_ERROR_TEXT);\n      }\n      if (prereq && !wrapper && getFuncName(func) == 'wrapper') {\n        var wrapper = new LodashWrapper([], true);\n      }\n    }\n    index = wrapper ? index : length;\n    while (++index < length) {\n      func = funcs[index];\n\n      var funcName = getFuncName(func),\n          data = funcName == 'wrapper' ? getData(func) : undefined;\n\n      if (data && isLaziable(data[0]) &&\n            data[1] == (WRAP_ARY_FLAG | WRAP_CURRY_FLAG | WRAP_PARTIAL_FLAG | WRAP_REARG_FLAG) &&\n            !data[4].length && data[9] == 1\n          ) {\n        wrapper = wrapper[getFuncName(data[0])].apply(wrapper, data[3]);\n      } else {\n        wrapper = (func.length == 1 && isLaziable(func))\n          ? wrapper[funcName]()\n          : wrapper.thru(func);\n      }\n    }\n    return function() {\n      var args = arguments,\n          value = args[0];\n\n      if (wrapper && args.length == 1 && isArray(value)) {\n        return wrapper.plant(value).value();\n      }\n      var index = 0,\n          result = length ? funcs[index].apply(this, args) : value;\n\n      while (++index < length) {\n        result = funcs[index].call(this, result);\n      }\n      return result;\n    };\n  });\n}\n\nexport default createFlow;\n", "import createFlow from './_createFlow.js';\n\n/**\n * Creates a function that returns the result of invoking the given functions\n * with the `this` binding of the created function, where each successive\n * invocation is supplied the return value of the previous.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Util\n * @param {...(Function|Function[])} [funcs] The functions to invoke.\n * @returns {Function} Returns the new composite function.\n * @see _.flowRight\n * @example\n *\n * function square(n) {\n *   return n * n;\n * }\n *\n * var addSquare = _.flow([_.add, square]);\n * addSquare(1, 2);\n * // => 9\n */\nvar flow = createFlow();\n\nexport default flow;\n", "import createFlow from './_createFlow.js';\n\n/**\n * This method is like `_.flow` except that it creates a function that\n * invokes the given functions from right to left.\n *\n * @static\n * @since 3.0.0\n * @memberOf _\n * @category Util\n * @param {...(Function|Function[])} [funcs] The functions to invoke.\n * @returns {Function} Returns the new composite function.\n * @see _.flow\n * @example\n *\n * function square(n) {\n *   return n * n;\n * }\n *\n * var addSquare = _.flowRight([square, _.add]);\n * addSquare(1, 2);\n * // => 9\n */\nvar flowRight = createFlow(true);\n\nexport default flowRight;\n", "import baseFor from './_baseFor.js';\nimport castFunction from './_castFunction.js';\nimport keysIn from './keysIn.js';\n\n/**\n * Iterates over own and inherited enumerable string keyed properties of an\n * object and invokes `iteratee` for each property. The iteratee is invoked\n * with three arguments: (value, key, object). Iteratee functions may exit\n * iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forInRight\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forIn(new Foo, function(value, key) {\n *   console.log(key);\n * });\n * // => Logs 'a', 'b', then 'c' (iteration order is not guaranteed).\n */\nfunction forIn(object, iteratee) {\n  return object == null\n    ? object\n    : baseFor(object, castFunction(iteratee), keysIn);\n}\n\nexport default forIn;\n", "import baseForRight from './_baseForRight.js';\nimport castFunction from './_castFunction.js';\nimport keysIn from './keysIn.js';\n\n/**\n * This method is like `_.forIn` except that it iterates over properties of\n * `object` in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forIn\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forInRight(new Foo, function(value, key) {\n *   console.log(key);\n * });\n * // => Logs 'c', 'b', then 'a' assuming `_.forIn` logs 'a', 'b', then 'c'.\n */\nfunction forInRight(object, iteratee) {\n  return object == null\n    ? object\n    : baseForRight(object, castFunction(iteratee), keysIn);\n}\n\nexport default forInRight;\n", "import baseForOwn from './_baseForOwn.js';\nimport castFunction from './_castFunction.js';\n\n/**\n * Iterates over own enumerable string keyed properties of an object and\n * invokes `iteratee` for each property. The iteratee is invoked with three\n * arguments: (value, key, object). Iteratee functions may exit iteration\n * early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forOwnRight\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forOwn(new Foo, function(value, key) {\n *   console.log(key);\n * });\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\n */\nfunction forOwn(object, iteratee) {\n  return object && baseForOwn(object, castFunction(iteratee));\n}\n\nexport default forOwn;\n", "import baseForOwnRight from './_baseForOwnRight.js';\nimport castFunction from './_castFunction.js';\n\n/**\n * This method is like `_.forOwn` except that it iterates over properties of\n * `object` in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forOwn\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forOwnRight(new Foo, function(value, key) {\n *   console.log(key);\n * });\n * // => Logs 'b' then 'a' assuming `_.forOwn` logs 'a' then 'b'.\n */\nfunction forOwnRight(object, iteratee) {\n  return object && baseForOwnRight(object, castFunction(iteratee));\n}\n\nexport default forOwnRight;\n", "/**\n * The inverse of `_.toPairs`; this method returns an object composed\n * from key-value `pairs`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} pairs The key-value pairs.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.fromPairs([['a', 1], ['b', 2]]);\n * // => { 'a': 1, 'b': 2 }\n */\nfunction fromPairs(pairs) {\n  var index = -1,\n      length = pairs == null ? 0 : pairs.length,\n      result = {};\n\n  while (++index < length) {\n    var pair = pairs[index];\n    result[pair[0]] = pair[1];\n  }\n  return result;\n}\n\nexport default fromPairs;\n", "import arrayFilter from './_arrayFilter.js';\nimport isFunction from './isFunction.js';\n\n/**\n * The base implementation of `_.functions` which creates an array of\n * `object` function property names filtered from `props`.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Array} props The property names to filter.\n * @returns {Array} Returns the function names.\n */\nfunction baseFunctions(object, props) {\n  return arrayFilter(props, function(key) {\n    return isFunction(object[key]);\n  });\n}\n\nexport default baseFunctions;\n", "import baseFunctions from './_baseFunctions.js';\nimport keys from './keys.js';\n\n/**\n * Creates an array of function property names from own enumerable properties\n * of `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to inspect.\n * @returns {Array} Returns the function names.\n * @see _.functionsIn\n * @example\n *\n * function Foo() {\n *   this.a = _.constant('a');\n *   this.b = _.constant('b');\n * }\n *\n * Foo.prototype.c = _.constant('c');\n *\n * _.functions(new Foo);\n * // => ['a', 'b']\n */\nfunction functions(object) {\n  return object == null ? [] : baseFunctions(object, keys(object));\n}\n\nexport default functions;\n", "import baseFunctions from './_baseFunctions.js';\nimport keysIn from './keysIn.js';\n\n/**\n * Creates an array of function property names from own and inherited\n * enumerable properties of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @returns {Array} Returns the function names.\n * @see _.functions\n * @example\n *\n * function Foo() {\n *   this.a = _.constant('a');\n *   this.b = _.constant('b');\n * }\n *\n * Foo.prototype.c = _.constant('c');\n *\n * _.functionsIn(new Foo);\n * // => ['a', 'b', 'c']\n */\nfunction functionsIn(object) {\n  return object == null ? [] : baseFunctions(object, keysIn(object));\n}\n\nexport default functionsIn;\n", "import baseAssignValue from './_baseAssignValue.js';\nimport createAggregator from './_createAggregator.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The order of grouped values\n * is determined by the order they occur in `collection`. The corresponding\n * value of each key is an array of elements responsible for generating the\n * key. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * _.groupBy([6.1, 4.2, 6.3], Math.floor);\n * // => { '4': [4.2], '6': [6.1, 6.3] }\n *\n * // The `_.property` iteratee shorthand.\n * _.groupBy(['one', 'two', 'three'], 'length');\n * // => { '3': ['one', 'two'], '5': ['three'] }\n */\nvar groupBy = createAggregator(function(result, value, key) {\n  if (hasOwnProperty.call(result, key)) {\n    result[key].push(value);\n  } else {\n    baseAssignValue(result, key, [value]);\n  }\n});\n\nexport default groupBy;\n", "/**\n * The base implementation of `_.gt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\n *  else `false`.\n */\nfunction baseGt(value, other) {\n  return value > other;\n}\n\nexport default baseGt;\n", "import toNumber from './toNumber.js';\n\n/**\n * Creates a function that performs a relational operation on two values.\n *\n * @private\n * @param {Function} operator The function to perform the operation.\n * @returns {Function} Returns the new relational operation function.\n */\nfunction createRelationalOperation(operator) {\n  return function(value, other) {\n    if (!(typeof value == 'string' && typeof other == 'string')) {\n      value = toNumber(value);\n      other = toNumber(other);\n    }\n    return operator(value, other);\n  };\n}\n\nexport default createRelationalOperation;\n", "import baseGt from './_baseGt.js';\nimport createRelationalOperation from './_createRelationalOperation.js';\n\n/**\n * Checks if `value` is greater than `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\n *  else `false`.\n * @see _.lt\n * @example\n *\n * _.gt(3, 1);\n * // => true\n *\n * _.gt(3, 3);\n * // => false\n *\n * _.gt(1, 3);\n * // => false\n */\nvar gt = createRelationalOperation(baseGt);\n\nexport default gt;\n", "import createRelationalOperation from './_createRelationalOperation.js';\n\n/**\n * Checks if `value` is greater than or equal to `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than or equal to\n *  `other`, else `false`.\n * @see _.lte\n * @example\n *\n * _.gte(3, 1);\n * // => true\n *\n * _.gte(3, 3);\n * // => true\n *\n * _.gte(1, 3);\n * // => false\n */\nvar gte = createRelationalOperation(function(value, other) {\n  return value >= other;\n});\n\nexport default gte;\n", "/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.has` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHas(object, key) {\n  return object != null && hasOwnProperty.call(object, key);\n}\n\nexport default baseHas;\n", "import baseHas from './_baseHas.js';\nimport hasPath from './_hasPath.js';\n\n/**\n * Checks if `path` is a direct property of `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = { 'a': { 'b': 2 } };\n * var other = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.has(object, 'a');\n * // => true\n *\n * _.has(object, 'a.b');\n * // => true\n *\n * _.has(object, ['a', 'b']);\n * // => true\n *\n * _.has(other, 'a');\n * // => false\n */\nfunction has(object, path) {\n  return object != null && hasPath(object, path, baseHas);\n}\n\nexport default has;\n", "/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n    nativeMin = Math.min;\n\n/**\n * The base implementation of `_.inRange` which doesn't coerce arguments.\n *\n * @private\n * @param {number} number The number to check.\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @returns {boolean} Returns `true` if `number` is in the range, else `false`.\n */\nfunction baseInRange(number, start, end) {\n  return number >= nativeMin(start, end) && number < nativeMax(start, end);\n}\n\nexport default baseInRange;\n", "import baseInRange from './_baseInRange.js';\nimport toFinite from './toFinite.js';\nimport toNumber from './toNumber.js';\n\n/**\n * Checks if `n` is between `start` and up to, but not including, `end`. If\n * `end` is not specified, it's set to `start` with `start` then set to `0`.\n * If `start` is greater than `end` the params are swapped to support\n * negative ranges.\n *\n * @static\n * @memberOf _\n * @since 3.3.0\n * @category Number\n * @param {number} number The number to check.\n * @param {number} [start=0] The start of the range.\n * @param {number} end The end of the range.\n * @returns {boolean} Returns `true` if `number` is in the range, else `false`.\n * @see _.range, _.rangeRight\n * @example\n *\n * _.inRange(3, 2, 4);\n * // => true\n *\n * _.inRange(4, 8);\n * // => true\n *\n * _.inRange(4, 2);\n * // => false\n *\n * _.inRange(2, 2);\n * // => false\n *\n * _.inRange(1.2, 2);\n * // => true\n *\n * _.inRange(5.2, 4);\n * // => false\n *\n * _.inRange(-3, -2, -6);\n * // => true\n */\nfunction inRange(number, start, end) {\n  start = toFinite(start);\n  if (end === undefined) {\n    end = start;\n    start = 0;\n  } else {\n    end = toFinite(end);\n  }\n  number = toNumber(number);\n  return baseInRange(number, start, end);\n}\n\nexport default inRange;\n", "import baseGetTag from './_baseGetTag.js';\nimport isArray from './isArray.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar stringTag = '[object String]';\n\n/**\n * Checks if `value` is classified as a `String` primitive or object.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a string, else `false`.\n * @example\n *\n * _.isString('abc');\n * // => true\n *\n * _.isString(1);\n * // => false\n */\nfunction isString(value) {\n  return typeof value == 'string' ||\n    (!isArray(value) && isObjectLike(value) && baseGetTag(value) == stringTag);\n}\n\nexport default isString;\n", "import arrayMap from './_arrayMap.js';\n\n/**\n * The base implementation of `_.values` and `_.valuesIn` which creates an\n * array of `object` property values corresponding to the property names\n * of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the array of property values.\n */\nfunction baseValues(object, props) {\n  return arrayMap(props, function(key) {\n    return object[key];\n  });\n}\n\nexport default baseValues;\n", "import baseValues from './_baseValues.js';\nimport keys from './keys.js';\n\n/**\n * Creates an array of the own enumerable string keyed property values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.values(new Foo);\n * // => [1, 2] (iteration order is not guaranteed)\n *\n * _.values('hi');\n * // => ['h', 'i']\n */\nfunction values(object) {\n  return object == null ? [] : baseValues(object, keys(object));\n}\n\nexport default values;\n", "import baseIndexOf from './_baseIndexOf.js';\nimport isArrayLike from './isArrayLike.js';\nimport isString from './isString.js';\nimport toInteger from './toInteger.js';\nimport values from './values.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Checks if `value` is in `collection`. If `collection` is a string, it's\n * checked for a substring of `value`, otherwise\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * is used for equality comparisons. If `fromIndex` is negative, it's used as\n * the offset from the end of `collection`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=0] The index to search from.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.\n * @returns {boolean} Returns `true` if `value` is found, else `false`.\n * @example\n *\n * _.includes([1, 2, 3], 1);\n * // => true\n *\n * _.includes([1, 2, 3], 1, 2);\n * // => false\n *\n * _.includes({ 'a': 1, 'b': 2 }, 1);\n * // => true\n *\n * _.includes('abcd', 'bc');\n * // => true\n */\nfunction includes(collection, value, fromIndex, guard) {\n  collection = isArrayLike(collection) ? collection : values(collection);\n  fromIndex = (fromIndex && !guard) ? toInteger(fromIndex) : 0;\n\n  var length = collection.length;\n  if (fromIndex < 0) {\n    fromIndex = nativeMax(length + fromIndex, 0);\n  }\n  return isString(collection)\n    ? (fromIndex <= length && collection.indexOf(value, fromIndex) > -1)\n    : (!!length && baseIndexOf(collection, value, fromIndex) > -1);\n}\n\nexport default includes;\n", "import baseIndexOf from './_baseIndexOf.js';\nimport toInteger from './toInteger.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Gets the index at which the first occurrence of `value` is found in `array`\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. If `fromIndex` is negative, it's used as the\n * offset from the end of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.indexOf([1, 2, 1, 2], 2);\n * // => 1\n *\n * // Search from the `fromIndex`.\n * _.indexOf([1, 2, 1, 2], 2, 2);\n * // => 3\n */\nfunction indexOf(array, value, fromIndex) {\n  var length = array == null ? 0 : array.length;\n  if (!length) {\n    return -1;\n  }\n  var index = fromIndex == null ? 0 : toInteger(fromIndex);\n  if (index < 0) {\n    index = nativeMax(length + index, 0);\n  }\n  return baseIndexOf(array, value, index);\n}\n\nexport default indexOf;\n", "import baseSlice from './_baseSlice.js';\n\n/**\n * Gets all but the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.initial([1, 2, 3]);\n * // => [1, 2]\n */\nfunction initial(array) {\n  var length = array == null ? 0 : array.length;\n  return length ? baseSlice(array, 0, -1) : [];\n}\n\nexport default initial;\n", "import SetCache from './_SetCache.js';\nimport arrayIncludes from './_arrayIncludes.js';\nimport arrayIncludesWith from './_arrayIncludesWith.js';\nimport arrayMap from './_arrayMap.js';\nimport baseUnary from './_baseUnary.js';\nimport cacheHas from './_cacheHas.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMin = Math.min;\n\n/**\n * The base implementation of methods like `_.intersection`, without support\n * for iteratee shorthands, that accepts an array of arrays to inspect.\n *\n * @private\n * @param {Array} arrays The arrays to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of shared values.\n */\nfunction baseIntersection(arrays, iteratee, comparator) {\n  var includes = comparator ? arrayIncludesWith : arrayIncludes,\n      length = arrays[0].length,\n      othLength = arrays.length,\n      othIndex = othLength,\n      caches = Array(othLength),\n      maxLength = Infinity,\n      result = [];\n\n  while (othIndex--) {\n    var array = arrays[othIndex];\n    if (othIndex && iteratee) {\n      array = arrayMap(array, baseUnary(iteratee));\n    }\n    maxLength = nativeMin(array.length, maxLength);\n    caches[othIndex] = !comparator && (iteratee || (length >= 120 && array.length >= 120))\n      ? new SetCache(othIndex && array)\n      : undefined;\n  }\n  array = arrays[0];\n\n  var index = -1,\n      seen = caches[0];\n\n  outer:\n  while (++index < length && result.length < maxLength) {\n    var value = array[index],\n        computed = iteratee ? iteratee(value) : value;\n\n    value = (comparator || value !== 0) ? value : 0;\n    if (!(seen\n          ? cacheHas(seen, computed)\n          : includes(result, computed, comparator)\n        )) {\n      othIndex = othLength;\n      while (--othIndex) {\n        var cache = caches[othIndex];\n        if (!(cache\n              ? cacheHas(cache, computed)\n              : includes(arrays[othIndex], computed, comparator))\n            ) {\n          continue outer;\n        }\n      }\n      if (seen) {\n        seen.push(computed);\n      }\n      result.push(value);\n    }\n  }\n  return result;\n}\n\nexport default baseIntersection;\n", "import isArrayLikeObject from './isArrayLikeObject.js';\n\n/**\n * Casts `value` to an empty array if it's not an array like object.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Array|Object} Returns the cast array-like object.\n */\nfunction castArrayLikeObject(value) {\n  return isArrayLikeObject(value) ? value : [];\n}\n\nexport default castArrayLikeObject;\n", "import arrayMap from './_arrayMap.js';\nimport baseIntersection from './_baseIntersection.js';\nimport baseRest from './_baseRest.js';\nimport castArrayLikeObject from './_castArrayLikeObject.js';\n\n/**\n * Creates an array of unique values that are included in all given arrays\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. The order and references of result values are\n * determined by the first array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * _.intersection([2, 1], [2, 3]);\n * // => [2]\n */\nvar intersection = baseRest(function(arrays) {\n  var mapped = arrayMap(arrays, castArrayLikeObject);\n  return (mapped.length && mapped[0] === arrays[0])\n    ? baseIntersection(mapped)\n    : [];\n});\n\nexport default intersection;\n", "import arrayMap from './_arrayMap.js';\nimport baseIntersection from './_baseIntersection.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseRest from './_baseRest.js';\nimport castArrayLikeObject from './_castArrayLikeObject.js';\nimport last from './last.js';\n\n/**\n * This method is like `_.intersection` except that it accepts `iteratee`\n * which is invoked for each element of each `arrays` to generate the criterion\n * by which they're compared. The order and references of result values are\n * determined by the first array. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * _.intersectionBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [2.1]\n *\n * // The `_.property` iteratee shorthand.\n * _.intersectionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }]\n */\nvar intersectionBy = baseRest(function(arrays) {\n  var iteratee = last(arrays),\n      mapped = arrayMap(arrays, castArrayLikeObject);\n\n  if (iteratee === last(mapped)) {\n    iteratee = undefined;\n  } else {\n    mapped.pop();\n  }\n  return (mapped.length && mapped[0] === arrays[0])\n    ? baseIntersection(mapped, baseIteratee(iteratee, 2))\n    : [];\n});\n\nexport default intersectionBy;\n", "import arrayMap from './_arrayMap.js';\nimport baseIntersection from './_baseIntersection.js';\nimport baseRest from './_baseRest.js';\nimport castArrayLikeObject from './_castArrayLikeObject.js';\nimport last from './last.js';\n\n/**\n * This method is like `_.intersection` except that it accepts `comparator`\n * which is invoked to compare elements of `arrays`. The order and references\n * of result values are determined by the first array. The comparator is\n * invoked with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.intersectionWith(objects, others, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }]\n */\nvar intersectionWith = baseRest(function(arrays) {\n  var comparator = last(arrays),\n      mapped = arrayMap(arrays, castArrayLikeObject);\n\n  comparator = typeof comparator == 'function' ? comparator : undefined;\n  if (comparator) {\n    mapped.pop();\n  }\n  return (mapped.length && mapped[0] === arrays[0])\n    ? baseIntersection(mapped, undefined, comparator)\n    : [];\n});\n\nexport default intersectionWith;\n", "import baseForOwn from './_baseForOwn.js';\n\n/**\n * The base implementation of `_.invert` and `_.invertBy` which inverts\n * `object` with values transformed by `iteratee` and set by `setter`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform values.\n * @param {Object} accumulator The initial inverted object.\n * @returns {Function} Returns `accumulator`.\n */\nfunction baseInverter(object, setter, iteratee, accumulator) {\n  baseForOwn(object, function(value, key, object) {\n    setter(accumulator, iteratee(value), key, object);\n  });\n  return accumulator;\n}\n\nexport default baseInverter;\n", "import baseInverter from './_baseInverter.js';\n\n/**\n * Creates a function like `_.invertBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} toIteratee The function to resolve iteratees.\n * @returns {Function} Returns the new inverter function.\n */\nfunction createInverter(setter, toIteratee) {\n  return function(object, iteratee) {\n    return baseInverter(object, setter, toIteratee(iteratee), {});\n  };\n}\n\nexport default createInverter;\n", "import constant from './constant.js';\nimport createInverter from './_createInverter.js';\nimport identity from './identity.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Creates an object composed of the inverted keys and values of `object`.\n * If `object` contains duplicate values, subsequent values overwrite\n * property assignments of previous values.\n *\n * @static\n * @memberOf _\n * @since 0.7.0\n * @category Object\n * @param {Object} object The object to invert.\n * @returns {Object} Returns the new inverted object.\n * @example\n *\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\n *\n * _.invert(object);\n * // => { '1': 'c', '2': 'b' }\n */\nvar invert = createInverter(function(result, value, key) {\n  if (value != null &&\n      typeof value.toString != 'function') {\n    value = nativeObjectToString.call(value);\n  }\n\n  result[value] = key;\n}, constant(identity));\n\nexport default invert;\n", "import baseIteratee from './_baseIteratee.js';\nimport createInverter from './_createInverter.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * This method is like `_.invert` except that the inverted object is generated\n * from the results of running each element of `object` thru `iteratee`. The\n * corresponding inverted value of each inverted key is an array of keys\n * responsible for generating the inverted value. The iteratee is invoked\n * with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.1.0\n * @category Object\n * @param {Object} object The object to invert.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Object} Returns the new inverted object.\n * @example\n *\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\n *\n * _.invertBy(object);\n * // => { '1': ['a', 'c'], '2': ['b'] }\n *\n * _.invertBy(object, function(value) {\n *   return 'group' + value;\n * });\n * // => { 'group1': ['a', 'c'], 'group2': ['b'] }\n */\nvar invertBy = createInverter(function(result, value, key) {\n  if (value != null &&\n      typeof value.toString != 'function') {\n    value = nativeObjectToString.call(value);\n  }\n\n  if (hasOwnProperty.call(result, value)) {\n    result[value].push(key);\n  } else {\n    result[value] = [key];\n  }\n}, baseIteratee);\n\nexport default invertBy;\n", "import baseGet from './_baseGet.js';\nimport baseSlice from './_baseSlice.js';\n\n/**\n * Gets the parent value at `path` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} path The path to get the parent value of.\n * @returns {*} Returns the parent value.\n */\nfunction parent(object, path) {\n  return path.length < 2 ? object : baseGet(object, baseSlice(path, 0, -1));\n}\n\nexport default parent;\n", "import apply from './_apply.js';\nimport castPath from './_castPath.js';\nimport last from './last.js';\nimport parent from './_parent.js';\nimport toKey from './_toKey.js';\n\n/**\n * The base implementation of `_.invoke` without support for individual\n * method arguments.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the method to invoke.\n * @param {Array} args The arguments to invoke the method with.\n * @returns {*} Returns the result of the invoked method.\n */\nfunction baseInvoke(object, path, args) {\n  path = castPath(path, object);\n  object = parent(object, path);\n  var func = object == null ? object : object[toKey(last(path))];\n  return func == null ? undefined : apply(func, object, args);\n}\n\nexport default baseInvoke;\n", "import baseInvoke from './_baseInvoke.js';\nimport baseRest from './_baseRest.js';\n\n/**\n * Invokes the method at `path` of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the method to invoke.\n * @param {...*} [args] The arguments to invoke the method with.\n * @returns {*} Returns the result of the invoked method.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': [1, 2, 3, 4] } }] };\n *\n * _.invoke(object, 'a[0].b.c.slice', 1, 3);\n * // => [2, 3]\n */\nvar invoke = baseRest(baseInvoke);\n\nexport default invoke;\n", "import apply from './_apply.js';\nimport baseEach from './_baseEach.js';\nimport baseInvoke from './_baseInvoke.js';\nimport baseRest from './_baseRest.js';\nimport isArrayLike from './isArrayLike.js';\n\n/**\n * Invokes the method at `path` of each element in `collection`, returning\n * an array of the results of each invoked method. Any additional arguments\n * are provided to each invoked method. If `path` is a function, it's invoked\n * for, and `this` bound to, each element in `collection`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Array|Function|string} path The path of the method to invoke or\n *  the function invoked per iteration.\n * @param {...*} [args] The arguments to invoke each method with.\n * @returns {Array} Returns the array of results.\n * @example\n *\n * _.invokeMap([[5, 1, 7], [3, 2, 1]], 'sort');\n * // => [[1, 5, 7], [1, 2, 3]]\n *\n * _.invokeMap([123, 456], String.prototype.split, '');\n * // => [['1', '2', '3'], ['4', '5', '6']]\n */\nvar invokeMap = baseRest(function(collection, path, args) {\n  var index = -1,\n      isFunc = typeof path == 'function',\n      result = isArrayLike(collection) ? Array(collection.length) : [];\n\n  baseEach(collection, function(value) {\n    result[++index] = isFunc ? apply(path, value, args) : baseInvoke(value, path, args);\n  });\n  return result;\n});\n\nexport default invokeMap;\n", "import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\nvar arrayBufferTag = '[object ArrayBuffer]';\n\n/**\n * The base implementation of `_.isArrayBuffer` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`.\n */\nfunction baseIsArrayBuffer(value) {\n  return isObjectLike(value) && baseGetTag(value) == arrayBufferTag;\n}\n\nexport default baseIsArrayBuffer;\n", "import baseIsArrayBuffer from './_baseIsArrayBuffer.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsArrayBuffer = nodeUtil && nodeUtil.isArrayBuffer;\n\n/**\n * Checks if `value` is classified as an `ArrayBuffer` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`.\n * @example\n *\n * _.isArrayBuffer(new ArrayBuffer(2));\n * // => true\n *\n * _.isArrayBuffer(new Array(2));\n * // => false\n */\nvar isArrayBuffer = nodeIsArrayBuffer ? baseUnary(nodeIsArrayBuffer) : baseIsArrayBuffer;\n\nexport default isArrayBuffer;\n", "import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]';\n\n/**\n * Checks if `value` is classified as a boolean primitive or object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a boolean, else `false`.\n * @example\n *\n * _.isBoolean(false);\n * // => true\n *\n * _.isBoolean(null);\n * // => false\n */\nfunction isBoolean(value) {\n  return value === true || value === false ||\n    (isObjectLike(value) && baseGetTag(value) == boolTag);\n}\n\nexport default isBoolean;\n", "import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar dateTag = '[object Date]';\n\n/**\n * The base implementation of `_.isDate` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\n */\nfunction baseIsDate(value) {\n  return isObjectLike(value) && baseGetTag(value) == dateTag;\n}\n\nexport default baseIsDate;\n", "import baseIsDate from './_baseIsDate.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsDate = nodeUtil && nodeUtil.isDate;\n\n/**\n * Checks if `value` is classified as a `Date` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\n * @example\n *\n * _.isDate(new Date);\n * // => true\n *\n * _.isDate('Mon April 23 2012');\n * // => false\n */\nvar isDate = nodeIsDate ? baseUnary(nodeIsDate) : baseIsDate;\n\nexport default isDate;\n", "import isObjectLike from './isObjectLike.js';\nimport isPlainObject from './isPlainObject.js';\n\n/**\n * Checks if `value` is likely a DOM element.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a DOM element, else `false`.\n * @example\n *\n * _.isElement(document.body);\n * // => true\n *\n * _.isElement('<body>');\n * // => false\n */\nfunction isElement(value) {\n  return isObjectLike(value) && value.nodeType === 1 && !isPlainObject(value);\n}\n\nexport default isElement;\n", "import baseKeys from './_baseKeys.js';\nimport getTag from './_getTag.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isArrayLike from './isArrayLike.js';\nimport isBuffer from './isBuffer.js';\nimport isPrototype from './_isPrototype.js';\nimport isTypedArray from './isTypedArray.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n    setTag = '[object Set]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if `value` is an empty object, collection, map, or set.\n *\n * Objects are considered empty if they have no own enumerable string keyed\n * properties.\n *\n * Array-like values such as `arguments` objects, arrays, buffers, strings, or\n * jQuery-like collections are considered empty if they have a `length` of `0`.\n * Similarly, maps and sets are considered empty if they have a `size` of `0`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is empty, else `false`.\n * @example\n *\n * _.isEmpty(null);\n * // => true\n *\n * _.isEmpty(true);\n * // => true\n *\n * _.isEmpty(1);\n * // => true\n *\n * _.isEmpty([1, 2, 3]);\n * // => false\n *\n * _.isEmpty({ 'a': 1 });\n * // => false\n */\nfunction isEmpty(value) {\n  if (value == null) {\n    return true;\n  }\n  if (isArrayLike(value) &&\n      (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' ||\n        isBuffer(value) || isTypedArray(value) || isArguments(value))) {\n    return !value.length;\n  }\n  var tag = getTag(value);\n  if (tag == mapTag || tag == setTag) {\n    return !value.size;\n  }\n  if (isPrototype(value)) {\n    return !baseKeys(value).length;\n  }\n  for (var key in value) {\n    if (hasOwnProperty.call(value, key)) {\n      return false;\n    }\n  }\n  return true;\n}\n\nexport default isEmpty;\n", "import baseIsEqual from './_baseIsEqual.js';\n\n/**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\nfunction isEqual(value, other) {\n  return baseIsEqual(value, other);\n}\n\nexport default isEqual;\n", "import baseIsEqual from './_baseIsEqual.js';\n\n/**\n * This method is like `_.isEqual` except that it accepts `customizer` which\n * is invoked to compare values. If `customizer` returns `undefined`, comparisons\n * are handled by the method instead. The `customizer` is invoked with up to\n * six arguments: (objValue, othValue [, index|key, object, other, stack]).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * function isGreeting(value) {\n *   return /^h(?:i|ello)$/.test(value);\n * }\n *\n * function customizer(objValue, othValue) {\n *   if (isGreeting(objValue) && isGreeting(othValue)) {\n *     return true;\n *   }\n * }\n *\n * var array = ['hello', 'goodbye'];\n * var other = ['hi', 'goodbye'];\n *\n * _.isEqualWith(array, other, customizer);\n * // => true\n */\nfunction isEqualWith(value, other, customizer) {\n  customizer = typeof customizer == 'function' ? customizer : undefined;\n  var result = customizer ? customizer(value, other) : undefined;\n  return result === undefined ? baseIsEqual(value, other, undefined, customizer) : !!result;\n}\n\nexport default isEqualWith;\n", "import root from './_root.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsFinite = root.isFinite;\n\n/**\n * Checks if `value` is a finite primitive number.\n *\n * **Note:** This method is based on\n * [`Number.isFinite`](https://mdn.io/Number/isFinite).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a finite number, else `false`.\n * @example\n *\n * _.isFinite(3);\n * // => true\n *\n * _.isFinite(Number.MIN_VALUE);\n * // => true\n *\n * _.isFinite(Infinity);\n * // => false\n *\n * _.isFinite('3');\n * // => false\n */\nfunction isFinite(value) {\n  return typeof value == 'number' && nativeIsFinite(value);\n}\n\nexport default isFinite;\n", "import toInteger from './toInteger.js';\n\n/**\n * Checks if `value` is an integer.\n *\n * **Note:** This method is based on\n * [`Number.isInteger`](https://mdn.io/Number/isInteger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an integer, else `false`.\n * @example\n *\n * _.isInteger(3);\n * // => true\n *\n * _.isInteger(Number.MIN_VALUE);\n * // => false\n *\n * _.isInteger(Infinity);\n * // => false\n *\n * _.isInteger('3');\n * // => false\n */\nfunction isInteger(value) {\n  return typeof value == 'number' && value == toInteger(value);\n}\n\nexport default isInteger;\n", "import baseIsMatch from './_baseIsMatch.js';\nimport getMatchData from './_getMatchData.js';\n\n/**\n * Performs a partial deep comparison between `object` and `source` to\n * determine if `object` contains equivalent property values.\n *\n * **Note:** This method is equivalent to `_.matches` when `source` is\n * partially applied.\n *\n * Partial comparisons will match empty array and empty object `source`\n * values against any array or object value, respectively. See `_.isEqual`\n * for a list of supported value comparisons.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n *\n * _.isMatch(object, { 'b': 2 });\n * // => true\n *\n * _.isMatch(object, { 'b': 1 });\n * // => false\n */\nfunction isMatch(object, source) {\n  return object === source || baseIsMatch(object, source, getMatchData(source));\n}\n\nexport default isMatch;\n", "import baseIsMatch from './_baseIsMatch.js';\nimport getMatchData from './_getMatchData.js';\n\n/**\n * This method is like `_.isMatch` except that it accepts `customizer` which\n * is invoked to compare values. If `customizer` returns `undefined`, comparisons\n * are handled by the method instead. The `customizer` is invoked with five\n * arguments: (objValue, srcValue, index|key, object, source).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n * @example\n *\n * function isGreeting(value) {\n *   return /^h(?:i|ello)$/.test(value);\n * }\n *\n * function customizer(objValue, srcValue) {\n *   if (isGreeting(objValue) && isGreeting(srcValue)) {\n *     return true;\n *   }\n * }\n *\n * var object = { 'greeting': 'hello' };\n * var source = { 'greeting': 'hi' };\n *\n * _.isMatchWith(object, source, customizer);\n * // => true\n */\nfunction isMatchWith(object, source, customizer) {\n  customizer = typeof customizer == 'function' ? customizer : undefined;\n  return baseIsMatch(object, source, getMatchData(source), customizer);\n}\n\nexport default isMatchWith;\n", "import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar numberTag = '[object Number]';\n\n/**\n * Checks if `value` is classified as a `Number` primitive or object.\n *\n * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are\n * classified as numbers, use the `_.isFinite` method.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a number, else `false`.\n * @example\n *\n * _.isNumber(3);\n * // => true\n *\n * _.isNumber(Number.MIN_VALUE);\n * // => true\n *\n * _.isNumber(Infinity);\n * // => true\n *\n * _.isNumber('3');\n * // => false\n */\nfunction isNumber(value) {\n  return typeof value == 'number' ||\n    (isObjectLike(value) && baseGetTag(value) == numberTag);\n}\n\nexport default isNumber;\n", "import isNumber from './isNumber.js';\n\n/**\n * Checks if `value` is `NaN`.\n *\n * **Note:** This method is based on\n * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as\n * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for\n * `undefined` and other non-number values.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n * @example\n *\n * _.isNaN(NaN);\n * // => true\n *\n * _.isNaN(new Number(NaN));\n * // => true\n *\n * isNaN(undefined);\n * // => true\n *\n * _.isNaN(undefined);\n * // => false\n */\nfunction isNaN(value) {\n  // An `NaN` primitive is the only value that is not equal to itself.\n  // Perform the `toStringTag` check first to avoid errors with some\n  // ActiveX objects in IE.\n  return isNumber(value) && value != +value;\n}\n\nexport default isNaN;\n", "import coreJsData from './_coreJsData.js';\nimport isFunction from './isFunction.js';\nimport stubFalse from './stubFalse.js';\n\n/**\n * Checks if `func` is capable of being masked.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `func` is maskable, else `false`.\n */\nvar isMaskable = coreJsData ? isFunction : stubFalse;\n\nexport default isMaskable;\n", "import baseIsNative from './_baseIsNative.js';\nimport isMaskable from './_isMaskable.js';\n\n/** Error message constants. */\nvar CORE_ERROR_TEXT = 'Unsupported core-js use. Try https://npms.io/search?q=ponyfill.';\n\n/**\n * Checks if `value` is a pristine native function.\n *\n * **Note:** This method can't reliably detect native functions in the presence\n * of the core-js package because core-js circumvents this kind of detection.\n * Despite multiple requests, the core-js maintainer has made it clear: any\n * attempt to fix the detection will be obstructed. As a result, we're left\n * with little choice but to throw an error. Unfortunately, this also affects\n * packages, like [babel-polyfill](https://www.npmjs.com/package/babel-polyfill),\n * which rely on core-js.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n *  else `false`.\n * @example\n *\n * _.isNative(Array.prototype.push);\n * // => true\n *\n * _.isNative(_);\n * // => false\n */\nfunction isNative(value) {\n  if (isMaskable(value)) {\n    throw new Error(CORE_ERROR_TEXT);\n  }\n  return baseIsNative(value);\n}\n\nexport default isNative;\n", "/**\n * Checks if `value` is `null` or `undefined`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is nullish, else `false`.\n * @example\n *\n * _.isNil(null);\n * // => true\n *\n * _.isNil(void 0);\n * // => true\n *\n * _.isNil(NaN);\n * // => false\n */\nfunction isNil(value) {\n  return value == null;\n}\n\nexport default isNil;\n", "/**\n * Checks if `value` is `null`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `null`, else `false`.\n * @example\n *\n * _.isNull(null);\n * // => true\n *\n * _.isNull(void 0);\n * // => false\n */\nfunction isNull(value) {\n  return value === null;\n}\n\nexport default isNull;\n", "import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar regexpTag = '[object RegExp]';\n\n/**\n * The base implementation of `_.isRegExp` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\n */\nfunction baseIsRegExp(value) {\n  return isObjectLike(value) && baseGetTag(value) == regexpTag;\n}\n\nexport default baseIsRegExp;\n", "import baseIsRegExp from './_baseIsRegExp.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsRegExp = nodeUtil && nodeUtil.isRegExp;\n\n/**\n * Checks if `value` is classified as a `RegExp` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\n * @example\n *\n * _.isRegExp(/abc/);\n * // => true\n *\n * _.isRegExp('/abc/');\n * // => false\n */\nvar isRegExp = nodeIsRegExp ? baseUnary(nodeIsRegExp) : baseIsRegExp;\n\nexport default isRegExp;\n", "import isInteger from './isInteger.js';\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a safe integer. An integer is safe if it's an IEEE-754\n * double precision number which isn't the result of a rounded unsafe integer.\n *\n * **Note:** This method is based on\n * [`Number.isSafeInteger`](https://mdn.io/Number/isSafeInteger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a safe integer, else `false`.\n * @example\n *\n * _.isSafeInteger(3);\n * // => true\n *\n * _.isSafeInteger(Number.MIN_VALUE);\n * // => false\n *\n * _.isSafeInteger(Infinity);\n * // => false\n *\n * _.isSafeInteger('3');\n * // => false\n */\nfunction isSafeInteger(value) {\n  return isInteger(value) && value >= -MAX_SAFE_INTEGER && value <= MAX_SAFE_INTEGER;\n}\n\nexport default isSafeInteger;\n", "/**\n * Checks if `value` is `undefined`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`.\n * @example\n *\n * _.isUndefined(void 0);\n * // => true\n *\n * _.isUndefined(null);\n * // => false\n */\nfunction isUndefined(value) {\n  return value === undefined;\n}\n\nexport default isUndefined;\n", "import getTag from './_getTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar weakMapTag = '[object WeakMap]';\n\n/**\n * Checks if `value` is classified as a `WeakMap` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a weak map, else `false`.\n * @example\n *\n * _.isWeakMap(new WeakMap);\n * // => true\n *\n * _.isWeakMap(new Map);\n * // => false\n */\nfunction isWeakMap(value) {\n  return isObjectLike(value) && getTag(value) == weakMapTag;\n}\n\nexport default isWeakMap;\n", "import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar weakSetTag = '[object WeakSet]';\n\n/**\n * Checks if `value` is classified as a `WeakSet` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a weak set, else `false`.\n * @example\n *\n * _.isWeakSet(new WeakSet);\n * // => true\n *\n * _.isWeakSet(new Set);\n * // => false\n */\nfunction isWeakSet(value) {\n  return isObjectLike(value) && baseGetTag(value) == weakSetTag;\n}\n\nexport default isWeakSet;\n", "import baseClone from './_baseClone.js';\nimport baseIteratee from './_baseIteratee.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1;\n\n/**\n * Creates a function that invokes `func` with the arguments of the created\n * function. If `func` is a property name, the created function returns the\n * property value for a given element. If `func` is an array or object, the\n * created function returns `true` for elements that contain the equivalent\n * source properties, otherwise it returns `false`.\n *\n * @static\n * @since 4.0.0\n * @memberOf _\n * @category Util\n * @param {*} [func=_.identity] The value to convert to a callback.\n * @returns {Function} Returns the callback.\n * @example\n *\n * var users = [\n *   { 'user': 'barney', 'age': 36, 'active': true },\n *   { 'user': 'fred',   'age': 40, 'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.filter(users, _.iteratee({ 'user': 'barney', 'active': true }));\n * // => [{ 'user': 'barney', 'age': 36, 'active': true }]\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.filter(users, _.iteratee(['user', 'fred']));\n * // => [{ 'user': 'fred', 'age': 40 }]\n *\n * // The `_.property` iteratee shorthand.\n * _.map(users, _.iteratee('user'));\n * // => ['barney', 'fred']\n *\n * // Create custom iteratee shorthands.\n * _.iteratee = _.wrap(_.iteratee, function(iteratee, func) {\n *   return !_.isRegExp(func) ? iteratee(func) : function(string) {\n *     return func.test(string);\n *   };\n * });\n *\n * _.filter(['abc', 'def'], /ef/);\n * // => ['def']\n */\nfunction iteratee(func) {\n  return baseIteratee(typeof func == 'function' ? func : baseClone(func, CLONE_DEEP_FLAG));\n}\n\nexport default iteratee;\n", "/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeJoin = arrayProto.join;\n\n/**\n * Converts all elements in `array` into a string separated by `separator`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to convert.\n * @param {string} [separator=','] The element separator.\n * @returns {string} Returns the joined string.\n * @example\n *\n * _.join(['a', 'b', 'c'], '~');\n * // => 'a~b~c'\n */\nfunction join(array, separator) {\n  return array == null ? '' : nativeJoin.call(array, separator);\n}\n\nexport default join;\n", "import createCompounder from './_createCompounder.js';\n\n/**\n * Converts `string` to\n * [kebab case](https://en.wikipedia.org/wiki/Letter_case#Special_case_styles).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the kebab cased string.\n * @example\n *\n * _.kebabCase('Foo Bar');\n * // => 'foo-bar'\n *\n * _.kebabCase('fooBar');\n * // => 'foo-bar'\n *\n * _.kebabCase('__FOO_BAR__');\n * // => 'foo-bar'\n */\nvar kebabCase = createCompounder(function(result, word, index) {\n  return result + (index ? '-' : '') + word.toLowerCase();\n});\n\nexport default kebabCase;\n", "import baseAssignValue from './_baseAssignValue.js';\nimport createAggregator from './_createAggregator.js';\n\n/**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The corresponding value of\n * each key is the last element responsible for generating the key. The\n * iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * var array = [\n *   { 'dir': 'left', 'code': 97 },\n *   { 'dir': 'right', 'code': 100 }\n * ];\n *\n * _.keyBy(array, function(o) {\n *   return String.fromCharCode(o.code);\n * });\n * // => { 'a': { 'dir': 'left', 'code': 97 }, 'd': { 'dir': 'right', 'code': 100 } }\n *\n * _.keyBy(array, 'dir');\n * // => { 'left': { 'dir': 'left', 'code': 97 }, 'right': { 'dir': 'right', 'code': 100 } }\n */\nvar keyBy = createAggregator(function(result, value, key) {\n  baseAssignValue(result, key, value);\n});\n\nexport default keyBy;\n", "/**\n * A specialized version of `_.lastIndexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction strictLastIndexOf(array, value, fromIndex) {\n  var index = fromIndex + 1;\n  while (index--) {\n    if (array[index] === value) {\n      return index;\n    }\n  }\n  return index;\n}\n\nexport default strictLastIndexOf;\n", "import baseFindIndex from './_baseFindIndex.js';\nimport baseIsNaN from './_baseIsNaN.js';\nimport strictLastIndexOf from './_strictLastIndexOf.js';\nimport toInteger from './toInteger.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n    nativeMin = Math.min;\n\n/**\n * This method is like `_.indexOf` except that it iterates over elements of\n * `array` from right to left.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=array.length-1] The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.lastIndexOf([1, 2, 1, 2], 2);\n * // => 3\n *\n * // Search from the `fromIndex`.\n * _.lastIndexOf([1, 2, 1, 2], 2, 2);\n * // => 1\n */\nfunction lastIndexOf(array, value, fromIndex) {\n  var length = array == null ? 0 : array.length;\n  if (!length) {\n    return -1;\n  }\n  var index = length;\n  if (fromIndex !== undefined) {\n    index = toInteger(fromIndex);\n    index = index < 0 ? nativeMax(length + index, 0) : nativeMin(index, length - 1);\n  }\n  return value === value\n    ? strictLastIndexOf(array, value, index)\n    : baseFindIndex(array, baseIsNaN, index, true);\n}\n\nexport default lastIndexOf;\n", "import createCompounder from './_createCompounder.js';\n\n/**\n * Converts `string`, as space separated words, to lower case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the lower cased string.\n * @example\n *\n * _.lowerCase('--Foo-Bar--');\n * // => 'foo bar'\n *\n * _.lowerCase('fooBar');\n * // => 'foo bar'\n *\n * _.lowerCase('__FOO_BAR__');\n * // => 'foo bar'\n */\nvar lowerCase = createCompounder(function(result, word, index) {\n  return result + (index ? ' ' : '') + word.toLowerCase();\n});\n\nexport default lowerCase;\n", "import createCaseFirst from './_createCaseFirst.js';\n\n/**\n * Converts the first character of `string` to lower case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.lowerFirst('Fred');\n * // => 'fred'\n *\n * _.lowerFirst('FRED');\n * // => 'fRED'\n */\nvar lowerFirst = createCaseFirst('toLowerCase');\n\nexport default lowerFirst;\n", "/**\n * The base implementation of `_.lt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than `other`,\n *  else `false`.\n */\nfunction baseLt(value, other) {\n  return value < other;\n}\n\nexport default baseLt;\n", "import baseLt from './_baseLt.js';\nimport createRelationalOperation from './_createRelationalOperation.js';\n\n/**\n * Checks if `value` is less than `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than `other`,\n *  else `false`.\n * @see _.gt\n * @example\n *\n * _.lt(1, 3);\n * // => true\n *\n * _.lt(3, 3);\n * // => false\n *\n * _.lt(3, 1);\n * // => false\n */\nvar lt = createRelationalOperation(baseLt);\n\nexport default lt;\n", "import createRelationalOperation from './_createRelationalOperation.js';\n\n/**\n * Checks if `value` is less than or equal to `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than or equal to\n *  `other`, else `false`.\n * @see _.gte\n * @example\n *\n * _.lte(1, 3);\n * // => true\n *\n * _.lte(3, 3);\n * // => true\n *\n * _.lte(3, 1);\n * // => false\n */\nvar lte = createRelationalOperation(function(value, other) {\n  return value <= other;\n});\n\nexport default lte;\n", "import baseAssignValue from './_baseAssignValue.js';\nimport baseForOwn from './_baseForOwn.js';\nimport baseIteratee from './_baseIteratee.js';\n\n/**\n * The opposite of `_.mapValues`; this method creates an object with the\n * same values as `object` and keys generated by running each own enumerable\n * string keyed property of `object` thru `iteratee`. The iteratee is invoked\n * with three arguments: (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapValues\n * @example\n *\n * _.mapKeys({ 'a': 1, 'b': 2 }, function(value, key) {\n *   return key + value;\n * });\n * // => { 'a1': 1, 'b2': 2 }\n */\nfunction mapKeys(object, iteratee) {\n  var result = {};\n  iteratee = baseIteratee(iteratee, 3);\n\n  baseForOwn(object, function(value, key, object) {\n    baseAssignValue(result, iteratee(value, key, object), value);\n  });\n  return result;\n}\n\nexport default mapKeys;\n", "import baseAssignValue from './_baseAssignValue.js';\nimport baseForOwn from './_baseForOwn.js';\nimport baseIteratee from './_baseIteratee.js';\n\n/**\n * Creates an object with the same keys as `object` and values generated\n * by running each own enumerable string keyed property of `object` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapKeys\n * @example\n *\n * var users = {\n *   'fred':    { 'user': 'fred',    'age': 40 },\n *   'pebbles': { 'user': 'pebbles', 'age': 1 }\n * };\n *\n * _.mapValues(users, function(o) { return o.age; });\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n *\n * // The `_.property` iteratee shorthand.\n * _.mapValues(users, 'age');\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n */\nfunction mapValues(object, iteratee) {\n  var result = {};\n  iteratee = baseIteratee(iteratee, 3);\n\n  baseForOwn(object, function(value, key, object) {\n    baseAssignValue(result, key, iteratee(value, key, object));\n  });\n  return result;\n}\n\nexport default mapValues;\n", "import baseClone from './_baseClone.js';\nimport baseMatches from './_baseMatches.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1;\n\n/**\n * Creates a function that performs a partial deep comparison between a given\n * object and `source`, returning `true` if the given object has equivalent\n * property values, else `false`.\n *\n * **Note:** The created function is equivalent to `_.isMatch` with `source`\n * partially applied.\n *\n * Partial comparisons will match empty array and empty object `source`\n * values against any array or object value, respectively. See `_.isEqual`\n * for a list of supported value comparisons.\n *\n * **Note:** Multiple values can be checked by combining several matchers\n * using `_.overSome`\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Util\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n * @example\n *\n * var objects = [\n *   { 'a': 1, 'b': 2, 'c': 3 },\n *   { 'a': 4, 'b': 5, 'c': 6 }\n * ];\n *\n * _.filter(objects, _.matches({ 'a': 4, 'c': 6 }));\n * // => [{ 'a': 4, 'b': 5, 'c': 6 }]\n *\n * // Checking for several possible values\n * _.filter(objects, _.overSome([_.matches({ 'a': 1 }), _.matches({ 'a': 4 })]));\n * // => [{ 'a': 1, 'b': 2, 'c': 3 }, { 'a': 4, 'b': 5, 'c': 6 }]\n */\nfunction matches(source) {\n  return baseMatches(baseClone(source, CLONE_DEEP_FLAG));\n}\n\nexport default matches;\n", "import baseClone from './_baseClone.js';\nimport baseMatchesProperty from './_baseMatchesProperty.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1;\n\n/**\n * Creates a function that performs a partial deep comparison between the\n * value at `path` of a given object to `srcValue`, returning `true` if the\n * object value is equivalent, else `false`.\n *\n * **Note:** Partial comparisons will match empty array and empty object\n * `srcValue` values against any array or object value, respectively. See\n * `_.isEqual` for a list of supported value comparisons.\n *\n * **Note:** Multiple values can be checked by combining several matchers\n * using `_.overSome`\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Util\n * @param {Array|string} path The path of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n * @example\n *\n * var objects = [\n *   { 'a': 1, 'b': 2, 'c': 3 },\n *   { 'a': 4, 'b': 5, 'c': 6 }\n * ];\n *\n * _.find(objects, _.matchesProperty('a', 4));\n * // => { 'a': 4, 'b': 5, 'c': 6 }\n *\n * // Checking for several possible values\n * _.filter(objects, _.overSome([_.matchesProperty('a', 1), _.matchesProperty('a', 4)]));\n * // => [{ 'a': 1, 'b': 2, 'c': 3 }, { 'a': 4, 'b': 5, 'c': 6 }]\n */\nfunction matchesProperty(path, srcValue) {\n  return baseMatchesProperty(path, baseClone(srcValue, CLONE_DEEP_FLAG));\n}\n\nexport default matchesProperty;\n", "import isSymbol from './isSymbol.js';\n\n/**\n * The base implementation of methods like `_.max` and `_.min` which accepts a\n * `comparator` to determine the extremum value.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The iteratee invoked per iteration.\n * @param {Function} comparator The comparator used to compare values.\n * @returns {*} Returns the extremum value.\n */\nfunction baseExtremum(array, iteratee, comparator) {\n  var index = -1,\n      length = array.length;\n\n  while (++index < length) {\n    var value = array[index],\n        current = iteratee(value);\n\n    if (current != null && (computed === undefined\n          ? (current === current && !isSymbol(current))\n          : comparator(current, computed)\n        )) {\n      var computed = current,\n          result = value;\n    }\n  }\n  return result;\n}\n\nexport default baseExtremum;\n", "import baseExtremum from './_baseExtremum.js';\nimport baseGt from './_baseGt.js';\nimport identity from './identity.js';\n\n/**\n * Computes the maximum value of `array`. If `array` is empty or falsey,\n * `undefined` is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Math\n * @param {Array} array The array to iterate over.\n * @returns {*} Returns the maximum value.\n * @example\n *\n * _.max([4, 2, 8, 6]);\n * // => 8\n *\n * _.max([]);\n * // => undefined\n */\nfunction max(array) {\n  return (array && array.length)\n    ? baseExtremum(array, identity, baseGt)\n    : undefined;\n}\n\nexport default max;\n", "import baseExtremum from './_baseExtremum.js';\nimport baseGt from './_baseGt.js';\nimport baseIteratee from './_baseIteratee.js';\n\n/**\n * This method is like `_.max` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the criterion by which\n * the value is ranked. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {*} Returns the maximum value.\n * @example\n *\n * var objects = [{ 'n': 1 }, { 'n': 2 }];\n *\n * _.maxBy(objects, function(o) { return o.n; });\n * // => { 'n': 2 }\n *\n * // The `_.property` iteratee shorthand.\n * _.maxBy(objects, 'n');\n * // => { 'n': 2 }\n */\nfunction maxBy(array, iteratee) {\n  return (array && array.length)\n    ? baseExtremum(array, baseIteratee(iteratee, 2), baseGt)\n    : undefined;\n}\n\nexport default maxBy;\n", "/**\n * The base implementation of `_.sum` and `_.sumBy` without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {number} Returns the sum.\n */\nfunction baseSum(array, iteratee) {\n  var result,\n      index = -1,\n      length = array.length;\n\n  while (++index < length) {\n    var current = iteratee(array[index]);\n    if (current !== undefined) {\n      result = result === undefined ? current : (result + current);\n    }\n  }\n  return result;\n}\n\nexport default baseSum;\n", "import baseSum from './_baseSum.js';\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/**\n * The base implementation of `_.mean` and `_.meanBy` without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {number} Returns the mean.\n */\nfunction baseMean(array, iteratee) {\n  var length = array == null ? 0 : array.length;\n  return length ? (baseSum(array, iteratee) / length) : NAN;\n}\n\nexport default baseMean;\n", "import baseMean from './_baseMean.js';\nimport identity from './identity.js';\n\n/**\n * Computes the mean of the values in `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @returns {number} Returns the mean.\n * @example\n *\n * _.mean([4, 2, 8, 6]);\n * // => 5\n */\nfunction mean(array) {\n  return baseMean(array, identity);\n}\n\nexport default mean;\n", "import baseIteratee from './_baseIteratee.js';\nimport baseMean from './_baseMean.js';\n\n/**\n * This method is like `_.mean` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the value to be averaged.\n * The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the mean.\n * @example\n *\n * var objects = [{ 'n': 4 }, { 'n': 2 }, { 'n': 8 }, { 'n': 6 }];\n *\n * _.meanBy(objects, function(o) { return o.n; });\n * // => 5\n *\n * // The `_.property` iteratee shorthand.\n * _.meanBy(objects, 'n');\n * // => 5\n */\nfunction meanBy(array, iteratee) {\n  return baseMean(array, baseIteratee(iteratee, 2));\n}\n\nexport default meanBy;\n", "import baseMerge from './_baseMerge.js';\nimport createAssigner from './_createAssigner.js';\n\n/**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable string keyed properties of source objects into the\n * destination object. Source properties that resolve to `undefined` are\n * skipped if a destination value exists. Array and plain object properties\n * are merged recursively. Other objects and value types are overridden by\n * assignment. Source objects are applied from left to right. Subsequent\n * sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {\n *   'a': [{ 'b': 2 }, { 'd': 4 }]\n * };\n *\n * var other = {\n *   'a': [{ 'c': 3 }, { 'e': 5 }]\n * };\n *\n * _.merge(object, other);\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\n */\nvar merge = createAssigner(function(object, source, srcIndex) {\n  baseMerge(object, source, srcIndex);\n});\n\nexport default merge;\n", "import baseInvoke from './_baseInvoke.js';\nimport baseRest from './_baseRest.js';\n\n/**\n * Creates a function that invokes the method at `path` of a given object.\n * Any additional arguments are provided to the invoked method.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Util\n * @param {Array|string} path The path of the method to invoke.\n * @param {...*} [args] The arguments to invoke the method with.\n * @returns {Function} Returns the new invoker function.\n * @example\n *\n * var objects = [\n *   { 'a': { 'b': _.constant(2) } },\n *   { 'a': { 'b': _.constant(1) } }\n * ];\n *\n * _.map(objects, _.method('a.b'));\n * // => [2, 1]\n *\n * _.map(objects, _.method(['a', 'b']));\n * // => [2, 1]\n */\nvar method = baseRest(function(path, args) {\n  return function(object) {\n    return baseInvoke(object, path, args);\n  };\n});\n\nexport default method;\n", "import baseInvoke from './_baseInvoke.js';\nimport baseRest from './_baseRest.js';\n\n/**\n * The opposite of `_.method`; this method creates a function that invokes\n * the method at a given path of `object`. Any additional arguments are\n * provided to the invoked method.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Util\n * @param {Object} object The object to query.\n * @param {...*} [args] The arguments to invoke the method with.\n * @returns {Function} Returns the new invoker function.\n * @example\n *\n * var array = _.times(3, _.constant),\n *     object = { 'a': array, 'b': array, 'c': array };\n *\n * _.map(['a[2]', 'c[0]'], _.methodOf(object));\n * // => [2, 0]\n *\n * _.map([['a', '2'], ['c', '0']], _.methodOf(object));\n * // => [2, 0]\n */\nvar methodOf = baseRest(function(object, args) {\n  return function(path) {\n    return baseInvoke(object, path, args);\n  };\n});\n\nexport default methodOf;\n", "import baseExtremum from './_baseExtremum.js';\nimport baseLt from './_baseLt.js';\nimport identity from './identity.js';\n\n/**\n * Computes the minimum value of `array`. If `array` is empty or falsey,\n * `undefined` is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Math\n * @param {Array} array The array to iterate over.\n * @returns {*} Returns the minimum value.\n * @example\n *\n * _.min([4, 2, 8, 6]);\n * // => 2\n *\n * _.min([]);\n * // => undefined\n */\nfunction min(array) {\n  return (array && array.length)\n    ? baseExtremum(array, identity, baseLt)\n    : undefined;\n}\n\nexport default min;\n", "import baseExtremum from './_baseExtremum.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseLt from './_baseLt.js';\n\n/**\n * This method is like `_.min` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the criterion by which\n * the value is ranked. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {*} Returns the minimum value.\n * @example\n *\n * var objects = [{ 'n': 1 }, { 'n': 2 }];\n *\n * _.minBy(objects, function(o) { return o.n; });\n * // => { 'n': 1 }\n *\n * // The `_.property` iteratee shorthand.\n * _.minBy(objects, 'n');\n * // => { 'n': 1 }\n */\nfunction minBy(array, iteratee) {\n  return (array && array.length)\n    ? baseExtremum(array, baseIteratee(iteratee, 2), baseLt)\n    : undefined;\n}\n\nexport default minBy;\n", "import arrayEach from './_arrayEach.js';\nimport arrayPush from './_arrayPush.js';\nimport baseFunctions from './_baseFunctions.js';\nimport copyArray from './_copyArray.js';\nimport isFunction from './isFunction.js';\nimport isObject from './isObject.js';\nimport keys from './keys.js';\n\n/**\n * Adds all own enumerable string keyed function properties of a source\n * object to the destination object. If `object` is a function, then methods\n * are added to its prototype as well.\n *\n * **Note:** Use `_.runInContext` to create a pristine `lodash` function to\n * avoid conflicts caused by modifying the original.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {Function|Object} [object=lodash] The destination object.\n * @param {Object} source The object of functions to add.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.chain=true] Specify whether mixins are chainable.\n * @returns {Function|Object} Returns `object`.\n * @example\n *\n * function vowels(string) {\n *   return _.filter(string, function(v) {\n *     return /[aeiou]/i.test(v);\n *   });\n * }\n *\n * _.mixin({ 'vowels': vowels });\n * _.vowels('fred');\n * // => ['e']\n *\n * _('fred').vowels().value();\n * // => ['e']\n *\n * _.mixin({ 'vowels': vowels }, { 'chain': false });\n * _('fred').vowels();\n * // => ['e']\n */\nfunction mixin(object, source, options) {\n  var props = keys(source),\n      methodNames = baseFunctions(source, props);\n\n  var chain = !(isObject(options) && 'chain' in options) || !!options.chain,\n      isFunc = isFunction(object);\n\n  arrayEach(methodNames, function(methodName) {\n    var func = source[methodName];\n    object[methodName] = func;\n    if (isFunc) {\n      object.prototype[methodName] = function() {\n        var chainAll = this.__chain__;\n        if (chain || chainAll) {\n          var result = object(this.__wrapped__),\n              actions = result.__actions__ = copyArray(this.__actions__);\n\n          actions.push({ 'func': func, 'args': arguments, 'thisArg': object });\n          result.__chain__ = chainAll;\n          return result;\n        }\n        return func.apply(object, arrayPush([this.value()], arguments));\n      };\n    }\n  });\n\n  return object;\n}\n\nexport default mixin;\n", "import createMathOperation from './_createMathOperation.js';\n\n/**\n * Multiply two numbers.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Math\n * @param {number} multiplier The first number in a multiplication.\n * @param {number} multiplicand The second number in a multiplication.\n * @returns {number} Returns the product.\n * @example\n *\n * _.multiply(6, 4);\n * // => 24\n */\nvar multiply = createMathOperation(function(multiplier, multiplicand) {\n  return multiplier * multiplicand;\n}, 1);\n\nexport default multiply;\n", "/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that negates the result of the predicate `func`. The\n * `func` predicate is invoked with the `this` binding and arguments of the\n * created function.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} predicate The predicate to negate.\n * @returns {Function} Returns the new negated function.\n * @example\n *\n * function isEven(n) {\n *   return n % 2 == 0;\n * }\n *\n * _.filter([1, 2, 3, 4, 5, 6], _.negate(isEven));\n * // => [1, 3, 5]\n */\nfunction negate(predicate) {\n  if (typeof predicate != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  return function() {\n    var args = arguments;\n    switch (args.length) {\n      case 0: return !predicate.call(this);\n      case 1: return !predicate.call(this, args[0]);\n      case 2: return !predicate.call(this, args[0], args[1]);\n      case 3: return !predicate.call(this, args[0], args[1], args[2]);\n    }\n    return !predicate.apply(this, args);\n  };\n}\n\nexport default negate;\n", "/**\n * Converts `iterator` to an array.\n *\n * @private\n * @param {Object} iterator The iterator to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction iteratorToArray(iterator) {\n  var data,\n      result = [];\n\n  while (!(data = iterator.next()).done) {\n    result.push(data.value);\n  }\n  return result;\n}\n\nexport default iteratorToArray;\n", "import Symbol from './_Symbol.js';\nimport copyArray from './_copyArray.js';\nimport getTag from './_getTag.js';\nimport isArrayLike from './isArrayLike.js';\nimport isString from './isString.js';\nimport iteratorToArray from './_iteratorToArray.js';\nimport mapToArray from './_mapToArray.js';\nimport setToArray from './_setToArray.js';\nimport stringToArray from './_stringToArray.js';\nimport values from './values.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n    setTag = '[object Set]';\n\n/** Built-in value references. */\nvar symIterator = Symbol ? Symbol.iterator : undefined;\n\n/**\n * Converts `value` to an array.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Array} Returns the converted array.\n * @example\n *\n * _.toArray({ 'a': 1, 'b': 2 });\n * // => [1, 2]\n *\n * _.toArray('abc');\n * // => ['a', 'b', 'c']\n *\n * _.toArray(1);\n * // => []\n *\n * _.toArray(null);\n * // => []\n */\nfunction toArray(value) {\n  if (!value) {\n    return [];\n  }\n  if (isArrayLike(value)) {\n    return isString(value) ? stringToArray(value) : copyArray(value);\n  }\n  if (symIterator && value[symIterator]) {\n    return iteratorToArray(value[symIterator]());\n  }\n  var tag = getTag(value),\n      func = tag == mapTag ? mapToArray : (tag == setTag ? setToArray : values);\n\n  return func(value);\n}\n\nexport default toArray;\n", "import toArray from './toArray.js';\n\n/**\n * Gets the next value on a wrapped object following the\n * [iterator protocol](https://mdn.io/iteration_protocols#iterator).\n *\n * @name next\n * @memberOf _\n * @since 4.0.0\n * @category Seq\n * @returns {Object} Returns the next iterator value.\n * @example\n *\n * var wrapped = _([1, 2]);\n *\n * wrapped.next();\n * // => { 'done': false, 'value': 1 }\n *\n * wrapped.next();\n * // => { 'done': false, 'value': 2 }\n *\n * wrapped.next();\n * // => { 'done': true, 'value': undefined }\n */\nfunction wrapperNext() {\n  if (this.__values__ === undefined) {\n    this.__values__ = toArray(this.value());\n  }\n  var done = this.__index__ >= this.__values__.length,\n      value = done ? undefined : this.__values__[this.__index__++];\n\n  return { 'done': done, 'value': value };\n}\n\nexport default wrapperNext;\n", "import isIndex from './_isIndex.js';\n\n/**\n * The base implementation of `_.nth` which doesn't coerce arguments.\n *\n * @private\n * @param {Array} array The array to query.\n * @param {number} n The index of the element to return.\n * @returns {*} Returns the nth element of `array`.\n */\nfunction baseNth(array, n) {\n  var length = array.length;\n  if (!length) {\n    return;\n  }\n  n += n < 0 ? length : 0;\n  return isIndex(n, length) ? array[n] : undefined;\n}\n\nexport default baseNth;\n", "import baseNth from './_baseNth.js';\nimport toInteger from './toInteger.js';\n\n/**\n * Gets the element at index `n` of `array`. If `n` is negative, the nth\n * element from the end is returned.\n *\n * @static\n * @memberOf _\n * @since 4.11.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=0] The index of the element to return.\n * @returns {*} Returns the nth element of `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'd'];\n *\n * _.nth(array, 1);\n * // => 'b'\n *\n * _.nth(array, -2);\n * // => 'c';\n */\nfunction nth(array, n) {\n  return (array && array.length) ? baseNth(array, toInteger(n)) : undefined;\n}\n\nexport default nth;\n", "import baseNth from './_baseNth.js';\nimport baseRest from './_baseRest.js';\nimport toInteger from './toInteger.js';\n\n/**\n * Creates a function that gets the argument at index `n`. If `n` is negative,\n * the nth argument from the end is returned.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {number} [n=0] The index of the argument to return.\n * @returns {Function} Returns the new pass-thru function.\n * @example\n *\n * var func = _.nthArg(1);\n * func('a', 'b', 'c', 'd');\n * // => 'b'\n *\n * var func = _.nthArg(-2);\n * func('a', 'b', 'c', 'd');\n * // => 'c'\n */\nfunction nthArg(n) {\n  n = toInteger(n);\n  return baseRest(function(args) {\n    return baseNth(args, n);\n  });\n}\n\nexport default nthArg;\n", "import castPath from './_castPath.js';\nimport last from './last.js';\nimport parent from './_parent.js';\nimport toKey from './_toKey.js';\n\n/**\n * The base implementation of `_.unset`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The property path to unset.\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\n */\nfunction baseUnset(object, path) {\n  path = castPath(path, object);\n  object = parent(object, path);\n  return object == null || delete object[toKey(last(path))];\n}\n\nexport default baseUnset;\n", "import isPlainObject from './isPlainObject.js';\n\n/**\n * Used by `_.omit` to customize its `_.cloneDeep` use to only clone plain\n * objects.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {string} key The key of the property to inspect.\n * @returns {*} Returns the uncloned value or `undefined` to defer cloning to `_.cloneDeep`.\n */\nfunction customOmitClone(value) {\n  return isPlainObject(value) ? undefined : value;\n}\n\nexport default customOmitClone;\n", "import arrayMap from './_arrayMap.js';\nimport baseClone from './_baseClone.js';\nimport baseUnset from './_baseUnset.js';\nimport castPath from './_castPath.js';\nimport copyObject from './_copyObject.js';\nimport customOmitClone from './_customOmitClone.js';\nimport flatRest from './_flatRest.js';\nimport getAllKeysIn from './_getAllKeysIn.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n    CLONE_FLAT_FLAG = 2,\n    CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * The opposite of `_.pick`; this method creates an object composed of the\n * own and inherited enumerable property paths of `object` that are not omitted.\n *\n * **Note:** This method is considerably slower than `_.pick`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to omit.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.omit(object, ['a', 'c']);\n * // => { 'b': '2' }\n */\nvar omit = flatRest(function(object, paths) {\n  var result = {};\n  if (object == null) {\n    return result;\n  }\n  var isDeep = false;\n  paths = arrayMap(paths, function(path) {\n    path = castPath(path, object);\n    isDeep || (isDeep = path.length > 1);\n    return path;\n  });\n  copyObject(object, getAllKeysIn(object), result);\n  if (isDeep) {\n    result = baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone);\n  }\n  var length = paths.length;\n  while (length--) {\n    baseUnset(result, paths[length]);\n  }\n  return result;\n});\n\nexport default omit;\n", "import assignValue from './_assignValue.js';\nimport castPath from './_castPath.js';\nimport isIndex from './_isIndex.js';\nimport isObject from './isObject.js';\nimport toKey from './_toKey.js';\n\n/**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\nfunction baseSet(object, path, value, customizer) {\n  if (!isObject(object)) {\n    return object;\n  }\n  path = castPath(path, object);\n\n  var index = -1,\n      length = path.length,\n      lastIndex = length - 1,\n      nested = object;\n\n  while (nested != null && ++index < length) {\n    var key = toKey(path[index]),\n        newValue = value;\n\n    if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n      return object;\n    }\n\n    if (index != lastIndex) {\n      var objValue = nested[key];\n      newValue = customizer ? customizer(objValue, key, nested) : undefined;\n      if (newValue === undefined) {\n        newValue = isObject(objValue)\n          ? objValue\n          : (isIndex(path[index + 1]) ? [] : {});\n      }\n    }\n    assignValue(nested, key, newValue);\n    nested = nested[key];\n  }\n  return object;\n}\n\nexport default baseSet;\n", "import baseGet from './_baseGet.js';\nimport baseSet from './_baseSet.js';\nimport castPath from './_castPath.js';\n\n/**\n * The base implementation of  `_.pickBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @param {Function} predicate The function invoked per property.\n * @returns {Object} Returns the new object.\n */\nfunction basePickBy(object, paths, predicate) {\n  var index = -1,\n      length = paths.length,\n      result = {};\n\n  while (++index < length) {\n    var path = paths[index],\n        value = baseGet(object, path);\n\n    if (predicate(value, path)) {\n      baseSet(result, castPath(path, object), value);\n    }\n  }\n  return result;\n}\n\nexport default basePickBy;\n", "import arrayMap from './_arrayMap.js';\nimport baseIteratee from './_baseIteratee.js';\nimport basePickBy from './_basePickBy.js';\nimport getAllKeysIn from './_getAllKeysIn.js';\n\n/**\n * Creates an object composed of the `object` properties `predicate` returns\n * truthy for. The predicate is invoked with two arguments: (value, key).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The source object.\n * @param {Function} [predicate=_.identity] The function invoked per property.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pickBy(object, _.isNumber);\n * // => { 'a': 1, 'c': 3 }\n */\nfunction pickBy(object, predicate) {\n  if (object == null) {\n    return {};\n  }\n  var props = arrayMap(getAllKeysIn(object), function(prop) {\n    return [prop];\n  });\n  predicate = baseIteratee(predicate);\n  return basePickBy(object, props, function(value, path) {\n    return predicate(value, path[0]);\n  });\n}\n\nexport default pickBy;\n", "import baseIteratee from './_baseIteratee.js';\nimport negate from './negate.js';\nimport pickBy from './pickBy.js';\n\n/**\n * The opposite of `_.pickBy`; this method creates an object composed of\n * the own and inherited enumerable string keyed properties of `object` that\n * `predicate` doesn't return truthy for. The predicate is invoked with two\n * arguments: (value, key).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The source object.\n * @param {Function} [predicate=_.identity] The function invoked per property.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.omitBy(object, _.isNumber);\n * // => { 'b': '2' }\n */\nfunction omitBy(object, predicate) {\n  return pickBy(object, negate(baseIteratee(predicate)));\n}\n\nexport default omitBy;\n", "import before from './before.js';\n\n/**\n * Creates a function that is restricted to invoking `func` once. Repeat calls\n * to the function return the value of the first invocation. The `func` is\n * invoked with the `this` binding and arguments of the created function.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * var initialize = _.once(createApplication);\n * initialize();\n * initialize();\n * // => `createApplication` is invoked once\n */\nfunction once(func) {\n  return before(2, func);\n}\n\nexport default once;\n", "/**\n * The base implementation of `_.sortBy` which uses `comparer` to define the\n * sort order of `array` and replaces criteria objects with their corresponding\n * values.\n *\n * @private\n * @param {Array} array The array to sort.\n * @param {Function} comparer The function to define sort order.\n * @returns {Array} Returns `array`.\n */\nfunction baseSortBy(array, comparer) {\n  var length = array.length;\n\n  array.sort(comparer);\n  while (length--) {\n    array[length] = array[length].value;\n  }\n  return array;\n}\n\nexport default baseSortBy;\n", "import isSymbol from './isSymbol.js';\n\n/**\n * Compares values to sort them in ascending order.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {number} Returns the sort order indicator for `value`.\n */\nfunction compareAscending(value, other) {\n  if (value !== other) {\n    var valIsDefined = value !== undefined,\n        valIsNull = value === null,\n        valIsReflexive = value === value,\n        valIsSymbol = isSymbol(value);\n\n    var othIsDefined = other !== undefined,\n        othIsNull = other === null,\n        othIsReflexive = other === other,\n        othIsSymbol = isSymbol(other);\n\n    if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) ||\n        (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) ||\n        (valIsNull && othIsDefined && othIsReflexive) ||\n        (!valIsDefined && othIsReflexive) ||\n        !valIsReflexive) {\n      return 1;\n    }\n    if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) ||\n        (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) ||\n        (othIsNull && valIsDefined && valIsReflexive) ||\n        (!othIsDefined && valIsReflexive) ||\n        !othIsReflexive) {\n      return -1;\n    }\n  }\n  return 0;\n}\n\nexport default compareAscending;\n", "import compareAscending from './_compareAscending.js';\n\n/**\n * Used by `_.orderBy` to compare multiple properties of a value to another\n * and stable sort them.\n *\n * If `orders` is unspecified, all values are sorted in ascending order. Otherwise,\n * specify an order of \"desc\" for descending or \"asc\" for ascending sort order\n * of corresponding values.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {boolean[]|string[]} orders The order to sort by for each property.\n * @returns {number} Returns the sort order indicator for `object`.\n */\nfunction compareMultiple(object, other, orders) {\n  var index = -1,\n      objCriteria = object.criteria,\n      othCriteria = other.criteria,\n      length = objCriteria.length,\n      ordersLength = orders.length;\n\n  while (++index < length) {\n    var result = compareAscending(objCriteria[index], othCriteria[index]);\n    if (result) {\n      if (index >= ordersLength) {\n        return result;\n      }\n      var order = orders[index];\n      return result * (order == 'desc' ? -1 : 1);\n    }\n  }\n  // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications\n  // that causes it, under certain circumstances, to provide the same value for\n  // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247\n  // for more details.\n  //\n  // This also ensures a stable sort in V8 and other engines.\n  // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details.\n  return object.index - other.index;\n}\n\nexport default compareMultiple;\n", "import arrayMap from './_arrayMap.js';\nimport baseGet from './_baseGet.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseMap from './_baseMap.js';\nimport baseSortBy from './_baseSortBy.js';\nimport baseUnary from './_baseUnary.js';\nimport compareMultiple from './_compareMultiple.js';\nimport identity from './identity.js';\nimport isArray from './isArray.js';\n\n/**\n * The base implementation of `_.orderBy` without param guards.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by.\n * @param {string[]} orders The sort orders of `iteratees`.\n * @returns {Array} Returns the new sorted array.\n */\nfunction baseOrderBy(collection, iteratees, orders) {\n  if (iteratees.length) {\n    iteratees = arrayMap(iteratees, function(iteratee) {\n      if (isArray(iteratee)) {\n        return function(value) {\n          return baseGet(value, iteratee.length === 1 ? iteratee[0] : iteratee);\n        }\n      }\n      return iteratee;\n    });\n  } else {\n    iteratees = [identity];\n  }\n\n  var index = -1;\n  iteratees = arrayMap(iteratees, baseUnary(baseIteratee));\n\n  var result = baseMap(collection, function(value, key, collection) {\n    var criteria = arrayMap(iteratees, function(iteratee) {\n      return iteratee(value);\n    });\n    return { 'criteria': criteria, 'index': ++index, 'value': value };\n  });\n\n  return baseSortBy(result, function(object, other) {\n    return compareMultiple(object, other, orders);\n  });\n}\n\nexport default baseOrderBy;\n", "import baseOrderBy from './_baseOrderBy.js';\nimport isArray from './isArray.js';\n\n/**\n * This method is like `_.sortBy` except that it allows specifying the sort\n * orders of the iteratees to sort by. If `orders` is unspecified, all values\n * are sorted in ascending order. Otherwise, specify an order of \"desc\" for\n * descending or \"asc\" for ascending sort order of corresponding values.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Array[]|Function[]|Object[]|string[]} [iteratees=[_.identity]]\n *  The iteratees to sort by.\n * @param {string[]} [orders] The sort orders of `iteratees`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.\n * @returns {Array} Returns the new sorted array.\n * @example\n *\n * var users = [\n *   { 'user': 'fred',   'age': 48 },\n *   { 'user': 'barney', 'age': 34 },\n *   { 'user': 'fred',   'age': 40 },\n *   { 'user': 'barney', 'age': 36 }\n * ];\n *\n * // Sort by `user` in ascending order and by `age` in descending order.\n * _.orderBy(users, ['user', 'age'], ['asc', 'desc']);\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]]\n */\nfunction orderBy(collection, iteratees, orders, guard) {\n  if (collection == null) {\n    return [];\n  }\n  if (!isArray(iteratees)) {\n    iteratees = iteratees == null ? [] : [iteratees];\n  }\n  orders = guard ? undefined : orders;\n  if (!isArray(orders)) {\n    orders = orders == null ? [] : [orders];\n  }\n  return baseOrderBy(collection, iteratees, orders);\n}\n\nexport default orderBy;\n", "import apply from './_apply.js';\nimport arrayMap from './_arrayMap.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseRest from './_baseRest.js';\nimport baseUnary from './_baseUnary.js';\nimport flatRest from './_flatRest.js';\n\n/**\n * Creates a function like `_.over`.\n *\n * @private\n * @param {Function} arrayFunc The function to iterate over iteratees.\n * @returns {Function} Returns the new over function.\n */\nfunction createOver(arrayFunc) {\n  return flatRest(function(iteratees) {\n    iteratees = arrayMap(iteratees, baseUnary(baseIteratee));\n    return baseRest(function(args) {\n      var thisArg = this;\n      return arrayFunc(iteratees, function(iteratee) {\n        return apply(iteratee, thisArg, args);\n      });\n    });\n  });\n}\n\nexport default createOver;\n", "import arrayMap from './_arrayMap.js';\nimport createOver from './_createOver.js';\n\n/**\n * Creates a function that invokes `iteratees` with the arguments it receives\n * and returns their results.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {...(Function|Function[])} [iteratees=[_.identity]]\n *  The iteratees to invoke.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var func = _.over([Math.max, Math.min]);\n *\n * func(1, 2, 3, 4);\n * // => [4, 1]\n */\nvar over = createOver(arrayMap);\n\nexport default over;\n", "import baseRest from './_baseRest.js';\n\n/**\n * A `baseRest` alias which can be replaced with `identity` by module\n * replacement plugins.\n *\n * @private\n * @type {Function}\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\nvar castRest = baseRest;\n\nexport default castRest;\n", "import apply from './_apply.js';\nimport arrayMap from './_arrayMap.js';\nimport baseFlatten from './_baseFlatten.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseRest from './_baseRest.js';\nimport baseUnary from './_baseUnary.js';\nimport castRest from './_castRest.js';\nimport isArray from './isArray.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMin = Math.min;\n\n/**\n * Creates a function that invokes `func` with its arguments transformed.\n *\n * @static\n * @since 4.0.0\n * @memberOf _\n * @category Function\n * @param {Function} func The function to wrap.\n * @param {...(Function|Function[])} [transforms=[_.identity]]\n *  The argument transforms.\n * @returns {Function} Returns the new function.\n * @example\n *\n * function doubled(n) {\n *   return n * 2;\n * }\n *\n * function square(n) {\n *   return n * n;\n * }\n *\n * var func = _.overArgs(function(x, y) {\n *   return [x, y];\n * }, [square, doubled]);\n *\n * func(9, 3);\n * // => [81, 6]\n *\n * func(10, 5);\n * // => [100, 10]\n */\nvar overArgs = castRest(function(func, transforms) {\n  transforms = (transforms.length == 1 && isArray(transforms[0]))\n    ? arrayMap(transforms[0], baseUnary(baseIteratee))\n    : arrayMap(baseFlatten(transforms, 1), baseUnary(baseIteratee));\n\n  var funcsLength = transforms.length;\n  return baseRest(function(args) {\n    var index = -1,\n        length = nativeMin(args.length, funcsLength);\n\n    while (++index < length) {\n      args[index] = transforms[index].call(this, args[index]);\n    }\n    return apply(func, this, args);\n  });\n});\n\nexport default overArgs;\n", "import arrayEvery from './_arrayEvery.js';\nimport createOver from './_createOver.js';\n\n/**\n * Creates a function that checks if **all** of the `predicates` return\n * truthy when invoked with the arguments it receives.\n *\n * Following shorthands are possible for providing predicates.\n * Pass an `Object` and it will be used as an parameter for `_.matches` to create the predicate.\n * Pass an `Array` of parameters for `_.matchesProperty` and the predicate will be created using them.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {...(Function|Function[])} [predicates=[_.identity]]\n *  The predicates to check.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var func = _.overEvery([Boolean, isFinite]);\n *\n * func('1');\n * // => true\n *\n * func(null);\n * // => false\n *\n * func(NaN);\n * // => false\n */\nvar overEvery = createOver(arrayEvery);\n\nexport default overEvery;\n", "import arraySome from './_arraySome.js';\nimport createOver from './_createOver.js';\n\n/**\n * Creates a function that checks if **any** of the `predicates` return\n * truthy when invoked with the arguments it receives.\n *\n * Following shorthands are possible for providing predicates.\n * Pass an `Object` and it will be used as an parameter for `_.matches` to create the predicate.\n * Pass an `Array` of parameters for `_.matchesProperty` and the predicate will be created using them.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {...(Function|Function[])} [predicates=[_.identity]]\n *  The predicates to check.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var func = _.overSome([Boolean, isFinite]);\n *\n * func('1');\n * // => true\n *\n * func(null);\n * // => true\n *\n * func(NaN);\n * // => false\n *\n * var matchesFunc = _.overSome([{ 'a': 1 }, { 'a': 2 }])\n * var matchesPropertyFunc = _.overSome([['a', 1], ['a', 2]])\n */\nvar overSome = createOver(arraySome);\n\nexport default overSome;\n", "/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeFloor = Math.floor;\n\n/**\n * The base implementation of `_.repeat` which doesn't coerce arguments.\n *\n * @private\n * @param {string} string The string to repeat.\n * @param {number} n The number of times to repeat the string.\n * @returns {string} Returns the repeated string.\n */\nfunction baseRepeat(string, n) {\n  var result = '';\n  if (!string || n < 1 || n > MAX_SAFE_INTEGER) {\n    return result;\n  }\n  // Leverage the exponentiation by squaring algorithm for a faster repeat.\n  // See https://en.wikipedia.org/wiki/Exponentiation_by_squaring for more details.\n  do {\n    if (n % 2) {\n      result += string;\n    }\n    n = nativeFloor(n / 2);\n    if (n) {\n      string += string;\n    }\n  } while (n);\n\n  return result;\n}\n\nexport default baseRepeat;\n", "import baseProperty from './_baseProperty.js';\n\n/**\n * Gets the size of an ASCII `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\nvar asciiSize = baseProperty('length');\n\nexport default asciiSize;\n", "/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n    rsComboMarksRange = '\\\\u0300-\\\\u036f',\n    reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n    rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n    rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n    rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsAstral = '[' + rsAstralRange + ']',\n    rsCombo = '[' + rsComboRange + ']',\n    rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n    rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n    rsNonAstral = '[^' + rsAstralRange + ']',\n    rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n    rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n    rsZWJ = '\\\\u200d';\n\n/** Used to compose unicode regexes. */\nvar reOptMod = rsModifier + '?',\n    rsOptVar = '[' + rsVarRange + ']?',\n    rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n    rsSeq = rsOptVar + reOptMod + rsOptJoin,\n    rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\n/** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\nvar reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n\n/**\n * Gets the size of a Unicode `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\nfunction unicodeSize(string) {\n  var result = reUnicode.lastIndex = 0;\n  while (reUnicode.test(string)) {\n    ++result;\n  }\n  return result;\n}\n\nexport default unicodeSize;\n", "import asciiSize from './_asciiSize.js';\nimport hasUnicode from './_hasUnicode.js';\nimport unicodeSize from './_unicodeSize.js';\n\n/**\n * Gets the number of symbols in `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the string size.\n */\nfunction stringSize(string) {\n  return hasUnicode(string)\n    ? unicodeSize(string)\n    : asciiSize(string);\n}\n\nexport default stringSize;\n", "import baseRepeat from './_baseRepeat.js';\nimport baseToString from './_baseToString.js';\nimport castSlice from './_castSlice.js';\nimport hasUnicode from './_hasUnicode.js';\nimport stringSize from './_stringSize.js';\nimport stringToArray from './_stringToArray.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeCeil = Math.ceil;\n\n/**\n * Creates the padding for `string` based on `length`. The `chars` string\n * is truncated if the number of characters exceeds `length`.\n *\n * @private\n * @param {number} length The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padding for `string`.\n */\nfunction createPadding(length, chars) {\n  chars = chars === undefined ? ' ' : baseToString(chars);\n\n  var charsLength = chars.length;\n  if (charsLength < 2) {\n    return charsLength ? baseRepeat(chars, length) : chars;\n  }\n  var result = baseRepeat(chars, nativeCeil(length / stringSize(chars)));\n  return hasUnicode(chars)\n    ? castSlice(stringToArray(result), 0, length).join('')\n    : result.slice(0, length);\n}\n\nexport default createPadding;\n", "import createPadding from './_createPadding.js';\nimport stringSize from './_stringSize.js';\nimport toInteger from './toInteger.js';\nimport toString from './toString.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeCeil = Math.ceil,\n    nativeFloor = Math.floor;\n\n/**\n * Pads `string` on the left and right sides if it's shorter than `length`.\n * Padding characters are truncated if they can't be evenly divided by `length`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.pad('abc', 8);\n * // => '  abc   '\n *\n * _.pad('abc', 8, '_-');\n * // => '_-abc_-_'\n *\n * _.pad('abc', 3);\n * // => 'abc'\n */\nfunction pad(string, length, chars) {\n  string = toString(string);\n  length = toInteger(length);\n\n  var strLength = length ? stringSize(string) : 0;\n  if (!length || strLength >= length) {\n    return string;\n  }\n  var mid = (length - strLength) / 2;\n  return (\n    createPadding(nativeFloor(mid), chars) +\n    string +\n    createPadding(nativeCeil(mid), chars)\n  );\n}\n\nexport default pad;\n", "import createPadding from './_createPadding.js';\nimport stringSize from './_stringSize.js';\nimport toInteger from './toInteger.js';\nimport toString from './toString.js';\n\n/**\n * Pads `string` on the right side if it's shorter than `length`. Padding\n * characters are truncated if they exceed `length`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.padEnd('abc', 6);\n * // => 'abc   '\n *\n * _.padEnd('abc', 6, '_-');\n * // => 'abc_-_'\n *\n * _.padEnd('abc', 3);\n * // => 'abc'\n */\nfunction padEnd(string, length, chars) {\n  string = toString(string);\n  length = toInteger(length);\n\n  var strLength = length ? stringSize(string) : 0;\n  return (length && strLength < length)\n    ? (string + createPadding(length - strLength, chars))\n    : string;\n}\n\nexport default padEnd;\n", "import createPadding from './_createPadding.js';\nimport stringSize from './_stringSize.js';\nimport toInteger from './toInteger.js';\nimport toString from './toString.js';\n\n/**\n * Pads `string` on the left side if it's shorter than `length`. Padding\n * characters are truncated if they exceed `length`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.padStart('abc', 6);\n * // => '   abc'\n *\n * _.padStart('abc', 6, '_-');\n * // => '_-_abc'\n *\n * _.padStart('abc', 3);\n * // => 'abc'\n */\nfunction padStart(string, length, chars) {\n  string = toString(string);\n  length = toInteger(length);\n\n  var strLength = length ? stringSize(string) : 0;\n  return (length && strLength < length)\n    ? (createPadding(length - strLength, chars) + string)\n    : string;\n}\n\nexport default padStart;\n", "import root from './_root.js';\nimport toString from './toString.js';\n\n/** Used to match leading whitespace. */\nvar reTrimStart = /^\\s+/;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeParseInt = root.parseInt;\n\n/**\n * Converts `string` to an integer of the specified radix. If `radix` is\n * `undefined` or `0`, a `radix` of `10` is used unless `value` is a\n * hexadecimal, in which case a `radix` of `16` is used.\n *\n * **Note:** This method aligns with the\n * [ES5 implementation](https://es5.github.io/#x15.1.2.2) of `parseInt`.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category String\n * @param {string} string The string to convert.\n * @param {number} [radix=10] The radix to interpret `value` by.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.parseInt('08');\n * // => 8\n *\n * _.map(['6', '08', '10'], _.parseInt);\n * // => [6, 8, 10]\n */\nfunction parseInt(string, radix, guard) {\n  if (guard || radix == null) {\n    radix = 0;\n  } else if (radix) {\n    radix = +radix;\n  }\n  return nativeParseInt(toString(string).replace(reTrimStart, ''), radix || 0);\n}\n\nexport default parseInt;\n", "import baseRest from './_baseRest.js';\nimport createWrap from './_createWrap.js';\nimport getHolder from './_getHolder.js';\nimport replaceHolders from './_replaceHolders.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_PARTIAL_FLAG = 32;\n\n/**\n * Creates a function that invokes `func` with `partials` prepended to the\n * arguments it receives. This method is like `_.bind` except it does **not**\n * alter the `this` binding.\n *\n * The `_.partial.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of partially\n * applied functions.\n *\n * @static\n * @memberOf _\n * @since 0.2.0\n * @category Function\n * @param {Function} func The function to partially apply arguments to.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new partially applied function.\n * @example\n *\n * function greet(greeting, name) {\n *   return greeting + ' ' + name;\n * }\n *\n * var sayHelloTo = _.partial(greet, 'hello');\n * sayHelloTo('fred');\n * // => 'hello fred'\n *\n * // Partially applied with placeholders.\n * var greetFred = _.partial(greet, _, 'fred');\n * greetFred('hi');\n * // => 'hi fred'\n */\nvar partial = baseRest(function(func, partials) {\n  var holders = replaceHolders(partials, getHolder(partial));\n  return createWrap(func, WRAP_PARTIAL_FLAG, undefined, partials, holders);\n});\n\n// Assign default placeholders.\npartial.placeholder = {};\n\nexport default partial;\n", "import baseRest from './_baseRest.js';\nimport createWrap from './_createWrap.js';\nimport getHolder from './_getHolder.js';\nimport replaceHolders from './_replaceHolders.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_PARTIAL_RIGHT_FLAG = 64;\n\n/**\n * This method is like `_.partial` except that partially applied arguments\n * are appended to the arguments it receives.\n *\n * The `_.partialRight.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of partially\n * applied functions.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Function\n * @param {Function} func The function to partially apply arguments to.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new partially applied function.\n * @example\n *\n * function greet(greeting, name) {\n *   return greeting + ' ' + name;\n * }\n *\n * var greetFred = _.partialRight(greet, 'fred');\n * greetFred('hi');\n * // => 'hi fred'\n *\n * // Partially applied with placeholders.\n * var sayHelloTo = _.partialRight(greet, 'hello', _);\n * sayHelloTo('fred');\n * // => 'hello fred'\n */\nvar partialRight = baseRest(function(func, partials) {\n  var holders = replaceHolders(partials, getHolder(partialRight));\n  return createWrap(func, WRAP_PARTIAL_RIGHT_FLAG, undefined, partials, holders);\n});\n\n// Assign default placeholders.\npartialRight.placeholder = {};\n\nexport default partialRight;\n", "import createAggregator from './_createAggregator.js';\n\n/**\n * Creates an array of elements split into two groups, the first of which\n * contains elements `predicate` returns truthy for, the second of which\n * contains elements `predicate` returns falsey for. The predicate is\n * invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the array of grouped elements.\n * @example\n *\n * var users = [\n *   { 'user': 'barney',  'age': 36, 'active': false },\n *   { 'user': 'fred',    'age': 40, 'active': true },\n *   { 'user': 'pebbles', 'age': 1,  'active': false }\n * ];\n *\n * _.partition(users, function(o) { return o.active; });\n * // => objects for [['fred'], ['barney', 'pebbles']]\n *\n * // The `_.matches` iteratee shorthand.\n * _.partition(users, { 'age': 1, 'active': false });\n * // => objects for [['pebbles'], ['barney', 'fred']]\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.partition(users, ['active', false]);\n * // => objects for [['barney', 'pebbles'], ['fred']]\n *\n * // The `_.property` iteratee shorthand.\n * _.partition(users, 'active');\n * // => objects for [['fred'], ['barney', 'pebbles']]\n */\nvar partition = createAggregator(function(result, value, key) {\n  result[key ? 0 : 1].push(value);\n}, function() { return [[], []]; });\n\nexport default partition;\n", "import basePickBy from './_basePickBy.js';\nimport hasIn from './hasIn.js';\n\n/**\n * The base implementation of `_.pick` without support for individual\n * property identifiers.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @returns {Object} Returns the new object.\n */\nfunction basePick(object, paths) {\n  return basePickBy(object, paths, function(value, path) {\n    return hasIn(object, path);\n  });\n}\n\nexport default basePick;\n", "import basePick from './_basePick.js';\nimport flatRest from './_flatRest.js';\n\n/**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pick(object, ['a', 'c']);\n * // => { 'a': 1, 'c': 3 }\n */\nvar pick = flatRest(function(object, paths) {\n  return object == null ? {} : basePick(object, paths);\n});\n\nexport default pick;\n", "import baseLodash from './_baseLodash.js';\nimport wrapperClone from './_wrapperClone.js';\n\n/**\n * Creates a clone of the chain sequence planting `value` as the wrapped value.\n *\n * @name plant\n * @memberOf _\n * @since 3.2.0\n * @category Seq\n * @param {*} value The value to plant.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * function square(n) {\n *   return n * n;\n * }\n *\n * var wrapped = _([1, 2]).map(square);\n * var other = wrapped.plant([3, 4]);\n *\n * other.value();\n * // => [9, 16]\n *\n * wrapped.value();\n * // => [1, 4]\n */\nfunction wrapperPlant(value) {\n  var result,\n      parent = this;\n\n  while (parent instanceof baseLodash) {\n    var clone = wrapperClone(parent);\n    clone.__index__ = 0;\n    clone.__values__ = undefined;\n    if (result) {\n      previous.__wrapped__ = clone;\n    } else {\n      result = clone;\n    }\n    var previous = clone;\n    parent = parent.__wrapped__;\n  }\n  previous.__wrapped__ = value;\n  return result;\n}\n\nexport default wrapperPlant;\n", "import baseGet from './_baseGet.js';\n\n/**\n * The opposite of `_.property`; this method creates a function that returns\n * the value at a given path of `object`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Util\n * @param {Object} object The object to query.\n * @returns {Function} Returns the new accessor function.\n * @example\n *\n * var array = [0, 1, 2],\n *     object = { 'a': array, 'b': array, 'c': array };\n *\n * _.map(['a[2]', 'c[0]'], _.propertyOf(object));\n * // => [2, 0]\n *\n * _.map([['a', '2'], ['c', '0']], _.propertyOf(object));\n * // => [2, 0]\n */\nfunction propertyOf(object) {\n  return function(path) {\n    return object == null ? undefined : baseGet(object, path);\n  };\n}\n\nexport default propertyOf;\n", "/**\n * This function is like `baseIndexOf` except that it accepts a comparator.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @param {Function} comparator The comparator invoked per element.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseIndexOfWith(array, value, fromIndex, comparator) {\n  var index = fromIndex - 1,\n      length = array.length;\n\n  while (++index < length) {\n    if (comparator(array[index], value)) {\n      return index;\n    }\n  }\n  return -1;\n}\n\nexport default baseIndexOfWith;\n", "import arrayMap from './_arrayMap.js';\nimport baseIndexOf from './_baseIndexOf.js';\nimport baseIndexOfWith from './_baseIndexOfWith.js';\nimport baseUnary from './_baseUnary.js';\nimport copyArray from './_copyArray.js';\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * The base implementation of `_.pullAllBy` without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns `array`.\n */\nfunction basePullAll(array, values, iteratee, comparator) {\n  var indexOf = comparator ? baseIndexOfWith : baseIndexOf,\n      index = -1,\n      length = values.length,\n      seen = array;\n\n  if (array === values) {\n    values = copyArray(values);\n  }\n  if (iteratee) {\n    seen = arrayMap(array, baseUnary(iteratee));\n  }\n  while (++index < length) {\n    var fromIndex = 0,\n        value = values[index],\n        computed = iteratee ? iteratee(value) : value;\n\n    while ((fromIndex = indexOf(seen, computed, fromIndex, comparator)) > -1) {\n      if (seen !== array) {\n        splice.call(seen, fromIndex, 1);\n      }\n      splice.call(array, fromIndex, 1);\n    }\n  }\n  return array;\n}\n\nexport default basePullAll;\n", "import basePullAll from './_basePullAll.js';\n\n/**\n * This method is like `_.pull` except that it accepts an array of values to remove.\n *\n * **Note:** Unlike `_.difference`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'a', 'b', 'c'];\n *\n * _.pullAll(array, ['a', 'c']);\n * console.log(array);\n * // => ['b', 'b']\n */\nfunction pullAll(array, values) {\n  return (array && array.length && values && values.length)\n    ? basePullAll(array, values)\n    : array;\n}\n\nexport default pullAll;\n", "import baseRest from './_baseRest.js';\nimport pullAll from './pullAll.js';\n\n/**\n * Removes all given values from `array` using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * **Note:** Unlike `_.without`, this method mutates `array`. Use `_.remove`\n * to remove elements from an array by predicate.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {...*} [values] The values to remove.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'a', 'b', 'c'];\n *\n * _.pull(array, 'a', 'c');\n * console.log(array);\n * // => ['b', 'b']\n */\nvar pull = baseRest(pullAll);\n\nexport default pull;\n", "import baseIteratee from './_baseIteratee.js';\nimport basePullAll from './_basePullAll.js';\n\n/**\n * This method is like `_.pullAll` except that it accepts `iteratee` which is\n * invoked for each element of `array` and `values` to generate the criterion\n * by which they're compared. The iteratee is invoked with one argument: (value).\n *\n * **Note:** Unlike `_.differenceBy`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [{ 'x': 1 }, { 'x': 2 }, { 'x': 3 }, { 'x': 1 }];\n *\n * _.pullAllBy(array, [{ 'x': 1 }, { 'x': 3 }], 'x');\n * console.log(array);\n * // => [{ 'x': 2 }]\n */\nfunction pullAllBy(array, values, iteratee) {\n  return (array && array.length && values && values.length)\n    ? basePullAll(array, values, baseIteratee(iteratee, 2))\n    : array;\n}\n\nexport default pullAllBy;\n", "import basePullAll from './_basePullAll.js';\n\n/**\n * This method is like `_.pullAll` except that it accepts `comparator` which\n * is invoked to compare elements of `array` to `values`. The comparator is\n * invoked with two arguments: (arrVal, othVal).\n *\n * **Note:** Unlike `_.differenceWith`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [{ 'x': 1, 'y': 2 }, { 'x': 3, 'y': 4 }, { 'x': 5, 'y': 6 }];\n *\n * _.pullAllWith(array, [{ 'x': 3, 'y': 4 }], _.isEqual);\n * console.log(array);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 5, 'y': 6 }]\n */\nfunction pullAllWith(array, values, comparator) {\n  return (array && array.length && values && values.length)\n    ? basePullAll(array, values, undefined, comparator)\n    : array;\n}\n\nexport default pullAllWith;\n", "import baseUnset from './_baseUnset.js';\nimport isIndex from './_isIndex.js';\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * The base implementation of `_.pullAt` without support for individual\n * indexes or capturing the removed elements.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {number[]} indexes The indexes of elements to remove.\n * @returns {Array} Returns `array`.\n */\nfunction basePullAt(array, indexes) {\n  var length = array ? indexes.length : 0,\n      lastIndex = length - 1;\n\n  while (length--) {\n    var index = indexes[length];\n    if (length == lastIndex || index !== previous) {\n      var previous = index;\n      if (isIndex(index)) {\n        splice.call(array, index, 1);\n      } else {\n        baseUnset(array, index);\n      }\n    }\n  }\n  return array;\n}\n\nexport default basePullAt;\n", "import arrayMap from './_arrayMap.js';\nimport baseAt from './_baseAt.js';\nimport basePullAt from './_basePullAt.js';\nimport compareAscending from './_compareAscending.js';\nimport flatRest from './_flatRest.js';\nimport isIndex from './_isIndex.js';\n\n/**\n * Removes elements from `array` corresponding to `indexes` and returns an\n * array of removed elements.\n *\n * **Note:** Unlike `_.at`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {...(number|number[])} [indexes] The indexes of elements to remove.\n * @returns {Array} Returns the new array of removed elements.\n * @example\n *\n * var array = ['a', 'b', 'c', 'd'];\n * var pulled = _.pullAt(array, [1, 3]);\n *\n * console.log(array);\n * // => ['a', 'c']\n *\n * console.log(pulled);\n * // => ['b', 'd']\n */\nvar pullAt = flatRest(function(array, indexes) {\n  var length = array == null ? 0 : array.length,\n      result = baseAt(array, indexes);\n\n  basePullAt(array, arrayMap(indexes, function(index) {\n    return isIndex(index, length) ? +index : index;\n  }).sort(compareAscending));\n\n  return result;\n});\n\nexport default pullAt;\n", "/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeFloor = Math.floor,\n    nativeRandom = Math.random;\n\n/**\n * The base implementation of `_.random` without support for returning\n * floating-point numbers.\n *\n * @private\n * @param {number} lower The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the random number.\n */\nfunction baseRandom(lower, upper) {\n  return lower + nativeFloor(nativeRandom() * (upper - lower + 1));\n}\n\nexport default baseRandom;\n", "import baseRandom from './_baseRandom.js';\nimport isIterateeCall from './_isIterateeCall.js';\nimport toFinite from './toFinite.js';\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseFloat = parseFloat;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMin = Math.min,\n    nativeRandom = Math.random;\n\n/**\n * Produces a random number between the inclusive `lower` and `upper` bounds.\n * If only one argument is provided a number between `0` and the given number\n * is returned. If `floating` is `true`, or either `lower` or `upper` are\n * floats, a floating-point number is returned instead of an integer.\n *\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\n * floating-point values which can produce unexpected results.\n *\n * @static\n * @memberOf _\n * @since 0.7.0\n * @category Number\n * @param {number} [lower=0] The lower bound.\n * @param {number} [upper=1] The upper bound.\n * @param {boolean} [floating] Specify returning a floating-point number.\n * @returns {number} Returns the random number.\n * @example\n *\n * _.random(0, 5);\n * // => an integer between 0 and 5\n *\n * _.random(5);\n * // => also an integer between 0 and 5\n *\n * _.random(5, true);\n * // => a floating-point number between 0 and 5\n *\n * _.random(1.2, 5.2);\n * // => a floating-point number between 1.2 and 5.2\n */\nfunction random(lower, upper, floating) {\n  if (floating && typeof floating != 'boolean' && isIterateeCall(lower, upper, floating)) {\n    upper = floating = undefined;\n  }\n  if (floating === undefined) {\n    if (typeof upper == 'boolean') {\n      floating = upper;\n      upper = undefined;\n    }\n    else if (typeof lower == 'boolean') {\n      floating = lower;\n      lower = undefined;\n    }\n  }\n  if (lower === undefined && upper === undefined) {\n    lower = 0;\n    upper = 1;\n  }\n  else {\n    lower = toFinite(lower);\n    if (upper === undefined) {\n      upper = lower;\n      lower = 0;\n    } else {\n      upper = toFinite(upper);\n    }\n  }\n  if (lower > upper) {\n    var temp = lower;\n    lower = upper;\n    upper = temp;\n  }\n  if (floating || lower % 1 || upper % 1) {\n    var rand = nativeRandom();\n    return nativeMin(lower + (rand * (upper - lower + freeParseFloat('1e-' + ((rand + '').length - 1)))), upper);\n  }\n  return baseRandom(lower, upper);\n}\n\nexport default random;\n", "/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeCeil = Math.ceil,\n    nativeMax = Math.max;\n\n/**\n * The base implementation of `_.range` and `_.rangeRight` which doesn't\n * coerce arguments.\n *\n * @private\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @param {number} step The value to increment or decrement by.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the range of numbers.\n */\nfunction baseRange(start, end, step, fromRight) {\n  var index = -1,\n      length = nativeMax(nativeCeil((end - start) / (step || 1)), 0),\n      result = Array(length);\n\n  while (length--) {\n    result[fromRight ? length : ++index] = start;\n    start += step;\n  }\n  return result;\n}\n\nexport default baseRange;\n", "import baseRange from './_baseRange.js';\nimport isIterateeCall from './_isIterateeCall.js';\nimport toFinite from './toFinite.js';\n\n/**\n * Creates a `_.range` or `_.rangeRight` function.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new range function.\n */\nfunction createRange(fromRight) {\n  return function(start, end, step) {\n    if (step && typeof step != 'number' && isIterateeCall(start, end, step)) {\n      end = step = undefined;\n    }\n    // Ensure the sign of `-0` is preserved.\n    start = toFinite(start);\n    if (end === undefined) {\n      end = start;\n      start = 0;\n    } else {\n      end = toFinite(end);\n    }\n    step = step === undefined ? (start < end ? 1 : -1) : toFinite(step);\n    return baseRange(start, end, step, fromRight);\n  };\n}\n\nexport default createRange;\n", "import createRange from './_createRange.js';\n\n/**\n * Creates an array of numbers (positive and/or negative) progressing from\n * `start` up to, but not including, `end`. A step of `-1` is used if a negative\n * `start` is specified without an `end` or `step`. If `end` is not specified,\n * it's set to `start` with `start` then set to `0`.\n *\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\n * floating-point values which can produce unexpected results.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {number} [start=0] The start of the range.\n * @param {number} end The end of the range.\n * @param {number} [step=1] The value to increment or decrement by.\n * @returns {Array} Returns the range of numbers.\n * @see _.inRange, _.rangeRight\n * @example\n *\n * _.range(4);\n * // => [0, 1, 2, 3]\n *\n * _.range(-4);\n * // => [0, -1, -2, -3]\n *\n * _.range(1, 5);\n * // => [1, 2, 3, 4]\n *\n * _.range(0, 20, 5);\n * // => [0, 5, 10, 15]\n *\n * _.range(0, -4, -1);\n * // => [0, -1, -2, -3]\n *\n * _.range(1, 4, 0);\n * // => [1, 1, 1]\n *\n * _.range(0);\n * // => []\n */\nvar range = createRange();\n\nexport default range;\n", "import createRange from './_createRange.js';\n\n/**\n * This method is like `_.range` except that it populates values in\n * descending order.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {number} [start=0] The start of the range.\n * @param {number} end The end of the range.\n * @param {number} [step=1] The value to increment or decrement by.\n * @returns {Array} Returns the range of numbers.\n * @see _.inRange, _.range\n * @example\n *\n * _.rangeRight(4);\n * // => [3, 2, 1, 0]\n *\n * _.rangeRight(-4);\n * // => [-3, -2, -1, 0]\n *\n * _.rangeRight(1, 5);\n * // => [4, 3, 2, 1]\n *\n * _.rangeRight(0, 20, 5);\n * // => [15, 10, 5, 0]\n *\n * _.rangeRight(0, -4, -1);\n * // => [-3, -2, -1, 0]\n *\n * _.rangeRight(1, 4, 0);\n * // => [1, 1, 1]\n *\n * _.rangeRight(0);\n * // => []\n */\nvar rangeRight = createRange(true);\n\nexport default rangeRight;\n", "import createWrap from './_createWrap.js';\nimport flatRest from './_flatRest.js';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_REARG_FLAG = 256;\n\n/**\n * Creates a function that invokes `func` with arguments arranged according\n * to the specified `indexes` where the argument value at the first index is\n * provided as the first argument, the argument value at the second index is\n * provided as the second argument, and so on.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to rearrange arguments for.\n * @param {...(number|number[])} indexes The arranged argument indexes.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var rearged = _.rearg(function(a, b, c) {\n *   return [a, b, c];\n * }, [2, 0, 1]);\n *\n * rearged('b', 'c', 'a')\n * // => ['a', 'b', 'c']\n */\nvar rearg = flatRest(function(func, indexes) {\n  return createWrap(func, WRAP_REARG_FLAG, undefined, undefined, undefined, indexes);\n});\n\nexport default rearg;\n", "/**\n * The base implementation of `_.reduce` and `_.reduceRight`, without support\n * for iteratee shorthands, which iterates over `collection` using `eachFunc`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} accumulator The initial value.\n * @param {boolean} initAccum Specify using the first or last element of\n *  `collection` as the initial value.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @returns {*} Returns the accumulated value.\n */\nfunction baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) {\n  eachFunc(collection, function(value, index, collection) {\n    accumulator = initAccum\n      ? (initAccum = false, value)\n      : iteratee(accumulator, value, index, collection);\n  });\n  return accumulator;\n}\n\nexport default baseReduce;\n", "import arrayReduce from './_arrayReduce.js';\nimport baseEach from './_baseEach.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseReduce from './_baseReduce.js';\nimport isArray from './isArray.js';\n\n/**\n * Reduces `collection` to a value which is the accumulated result of running\n * each element in `collection` thru `iteratee`, where each successive\n * invocation is supplied the return value of the previous. If `accumulator`\n * is not given, the first element of `collection` is used as the initial\n * value. The iteratee is invoked with four arguments:\n * (accumulator, value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.reduce`, `_.reduceRight`, and `_.transform`.\n *\n * The guarded methods are:\n * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`,\n * and `sortBy`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @returns {*} Returns the accumulated value.\n * @see _.reduceRight\n * @example\n *\n * _.reduce([1, 2], function(sum, n) {\n *   return sum + n;\n * }, 0);\n * // => 3\n *\n * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n *   (result[value] || (result[value] = [])).push(key);\n *   return result;\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed)\n */\nfunction reduce(collection, iteratee, accumulator) {\n  var func = isArray(collection) ? arrayReduce : baseReduce,\n      initAccum = arguments.length < 3;\n\n  return func(collection, baseIteratee(iteratee, 4), accumulator, initAccum, baseEach);\n}\n\nexport default reduce;\n", "/**\n * A specialized version of `_.reduceRight` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the last element of `array` as\n *  the initial value.\n * @returns {*} Returns the accumulated value.\n */\nfunction arrayReduceRight(array, iteratee, accumulator, initAccum) {\n  var length = array == null ? 0 : array.length;\n  if (initAccum && length) {\n    accumulator = array[--length];\n  }\n  while (length--) {\n    accumulator = iteratee(accumulator, array[length], length, array);\n  }\n  return accumulator;\n}\n\nexport default arrayReduceRight;\n", "import arrayReduceRight from './_arrayReduceRight.js';\nimport baseEachRight from './_baseEachRight.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseReduce from './_baseReduce.js';\nimport isArray from './isArray.js';\n\n/**\n * This method is like `_.reduce` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @returns {*} Returns the accumulated value.\n * @see _.reduce\n * @example\n *\n * var array = [[0, 1], [2, 3], [4, 5]];\n *\n * _.reduceRight(array, function(flattened, other) {\n *   return flattened.concat(other);\n * }, []);\n * // => [4, 5, 2, 3, 0, 1]\n */\nfunction reduceRight(collection, iteratee, accumulator) {\n  var func = isArray(collection) ? arrayReduceRight : baseReduce,\n      initAccum = arguments.length < 3;\n\n  return func(collection, baseIteratee(iteratee, 4), accumulator, initAccum, baseEachRight);\n}\n\nexport default reduceRight;\n", "import arrayFilter from './_arrayFilter.js';\nimport baseFilter from './_baseFilter.js';\nimport baseIteratee from './_baseIteratee.js';\nimport isArray from './isArray.js';\nimport negate from './negate.js';\n\n/**\n * The opposite of `_.filter`; this method returns the elements of `collection`\n * that `predicate` does **not** return truthy for.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.filter\n * @example\n *\n * var users = [\n *   { 'user': 'barney', 'age': 36, 'active': false },\n *   { 'user': 'fred',   'age': 40, 'active': true }\n * ];\n *\n * _.reject(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.reject(users, { 'age': 40, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.reject(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.reject(users, 'active');\n * // => objects for ['barney']\n */\nfunction reject(collection, predicate) {\n  var func = isArray(collection) ? arrayFilter : baseFilter;\n  return func(collection, negate(baseIteratee(predicate, 3)));\n}\n\nexport default reject;\n", "import baseIteratee from './_baseIteratee.js';\nimport basePullAt from './_basePullAt.js';\n\n/**\n * Removes all elements from `array` that `predicate` returns truthy for\n * and returns an array of the removed elements. The predicate is invoked\n * with three arguments: (value, index, array).\n *\n * **Note:** Unlike `_.filter`, this method mutates `array`. Use `_.pull`\n * to pull elements from an array by value.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new array of removed elements.\n * @example\n *\n * var array = [1, 2, 3, 4];\n * var evens = _.remove(array, function(n) {\n *   return n % 2 == 0;\n * });\n *\n * console.log(array);\n * // => [1, 3]\n *\n * console.log(evens);\n * // => [2, 4]\n */\nfunction remove(array, predicate) {\n  var result = [];\n  if (!(array && array.length)) {\n    return result;\n  }\n  var index = -1,\n      indexes = [],\n      length = array.length;\n\n  predicate = baseIteratee(predicate, 3);\n  while (++index < length) {\n    var value = array[index];\n    if (predicate(value, index, array)) {\n      result.push(value);\n      indexes.push(index);\n    }\n  }\n  basePullAt(array, indexes);\n  return result;\n}\n\nexport default remove;\n", "import baseRepeat from './_baseRepeat.js';\nimport isIterateeCall from './_isIterateeCall.js';\nimport toInteger from './toInteger.js';\nimport toString from './toString.js';\n\n/**\n * Repeats the given string `n` times.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to repeat.\n * @param {number} [n=1] The number of times to repeat the string.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {string} Returns the repeated string.\n * @example\n *\n * _.repeat('*', 3);\n * // => '***'\n *\n * _.repeat('abc', 2);\n * // => 'abcabc'\n *\n * _.repeat('abc', 0);\n * // => ''\n */\nfunction repeat(string, n, guard) {\n  if ((guard ? isIterateeCall(string, n, guard) : n === undefined)) {\n    n = 1;\n  } else {\n    n = toInteger(n);\n  }\n  return baseRepeat(toString(string), n);\n}\n\nexport default repeat;\n", "import toString from './toString.js';\n\n/**\n * Replaces matches for `pattern` in `string` with `replacement`.\n *\n * **Note:** This method is based on\n * [`String#replace`](https://mdn.io/String/replace).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to modify.\n * @param {RegExp|string} pattern The pattern to replace.\n * @param {Function|string} replacement The match replacement.\n * @returns {string} Returns the modified string.\n * @example\n *\n * _.replace('Hi Fred', 'Fred', 'Barney');\n * // => 'Hi Barney'\n */\nfunction replace() {\n  var args = arguments,\n      string = toString(args[0]);\n\n  return args.length < 3 ? string : string.replace(args[1], args[2]);\n}\n\nexport default replace;\n", "import baseRest from './_baseRest.js';\nimport toInteger from './toInteger.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that invokes `func` with the `this` binding of the\n * created function and arguments from `start` and beyond provided as\n * an array.\n *\n * **Note:** This method is based on the\n * [rest parameter](https://mdn.io/rest_parameters).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var say = _.rest(function(what, names) {\n *   return what + ' ' + _.initial(names).join(', ') +\n *     (_.size(names) > 1 ? ', & ' : '') + _.last(names);\n * });\n *\n * say('hello', 'fred', 'barney', 'pebbles');\n * // => 'hello fred, barney, & pebbles'\n */\nfunction rest(func, start) {\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  start = start === undefined ? start : toInteger(start);\n  return baseRest(func, start);\n}\n\nexport default rest;\n", "import castPath from './_castPath.js';\nimport isFunction from './isFunction.js';\nimport toKey from './_toKey.js';\n\n/**\n * This method is like `_.get` except that if the resolved value is a\n * function it's invoked with the `this` binding of its parent object and\n * its result is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to resolve.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c1': 3, 'c2': _.constant(4) } }] };\n *\n * _.result(object, 'a[0].b.c1');\n * // => 3\n *\n * _.result(object, 'a[0].b.c2');\n * // => 4\n *\n * _.result(object, 'a[0].b.c3', 'default');\n * // => 'default'\n *\n * _.result(object, 'a[0].b.c3', _.constant('default'));\n * // => 'default'\n */\nfunction result(object, path, defaultValue) {\n  path = castPath(path, object);\n\n  var index = -1,\n      length = path.length;\n\n  // Ensure the loop is entered when path is empty.\n  if (!length) {\n    length = 1;\n    object = undefined;\n  }\n  while (++index < length) {\n    var value = object == null ? undefined : object[toKey(path[index])];\n    if (value === undefined) {\n      index = length;\n      value = defaultValue;\n    }\n    object = isFunction(value) ? value.call(object) : value;\n  }\n  return object;\n}\n\nexport default result;\n", "/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeReverse = arrayProto.reverse;\n\n/**\n * Reverses `array` so that the first element becomes the last, the second\n * element becomes the second to last, and so on.\n *\n * **Note:** This method mutates `array` and is based on\n * [`Array#reverse`](https://mdn.io/Array/reverse).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _.reverse(array);\n * // => [3, 2, 1]\n *\n * console.log(array);\n * // => [3, 2, 1]\n */\nfunction reverse(array) {\n  return array == null ? array : nativeReverse.call(array);\n}\n\nexport default reverse;\n", "import createRound from './_createRound.js';\n\n/**\n * Computes `number` rounded to `precision`.\n *\n * @static\n * @memberOf _\n * @since 3.10.0\n * @category Math\n * @param {number} number The number to round.\n * @param {number} [precision=0] The precision to round to.\n * @returns {number} Returns the rounded number.\n * @example\n *\n * _.round(4.006);\n * // => 4\n *\n * _.round(4.006, 2);\n * // => 4.01\n *\n * _.round(4060, -2);\n * // => 4100\n */\nvar round = createRound('round');\n\nexport default round;\n", "import baseRandom from './_baseRandom.js';\n\n/**\n * A specialized version of `_.sample` for arrays.\n *\n * @private\n * @param {Array} array The array to sample.\n * @returns {*} Returns the random element.\n */\nfunction arraySample(array) {\n  var length = array.length;\n  return length ? array[baseRandom(0, length - 1)] : undefined;\n}\n\nexport default arraySample;\n", "import arraySample from './_arraySample.js';\nimport values from './values.js';\n\n/**\n * The base implementation of `_.sample`.\n *\n * @private\n * @param {Array|Object} collection The collection to sample.\n * @returns {*} Returns the random element.\n */\nfunction baseSample(collection) {\n  return arraySample(values(collection));\n}\n\nexport default baseSample;\n", "import arraySample from './_arraySample.js';\nimport baseSample from './_baseSample.js';\nimport isArray from './isArray.js';\n\n/**\n * Gets a random element from `collection`.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to sample.\n * @returns {*} Returns the random element.\n * @example\n *\n * _.sample([1, 2, 3, 4]);\n * // => 2\n */\nfunction sample(collection) {\n  var func = isArray(collection) ? arraySample : baseSample;\n  return func(collection);\n}\n\nexport default sample;\n", "import baseRandom from './_baseRandom.js';\n\n/**\n * A specialized version of `_.shuffle` which mutates and sets the size of `array`.\n *\n * @private\n * @param {Array} array The array to shuffle.\n * @param {number} [size=array.length] The size of `array`.\n * @returns {Array} Returns `array`.\n */\nfunction shuffleSelf(array, size) {\n  var index = -1,\n      length = array.length,\n      lastIndex = length - 1;\n\n  size = size === undefined ? length : size;\n  while (++index < size) {\n    var rand = baseRandom(index, lastIndex),\n        value = array[rand];\n\n    array[rand] = array[index];\n    array[index] = value;\n  }\n  array.length = size;\n  return array;\n}\n\nexport default shuffleSelf;\n", "import baseClamp from './_baseClamp.js';\nimport copyArray from './_copyArray.js';\nimport shuffleSelf from './_shuffleSelf.js';\n\n/**\n * A specialized version of `_.sampleSize` for arrays.\n *\n * @private\n * @param {Array} array The array to sample.\n * @param {number} n The number of elements to sample.\n * @returns {Array} Returns the random elements.\n */\nfunction arraySampleSize(array, n) {\n  return shuffleSelf(copyArray(array), baseClamp(n, 0, array.length));\n}\n\nexport default arraySampleSize;\n", "import baseClamp from './_baseClamp.js';\nimport shuffleSelf from './_shuffleSelf.js';\nimport values from './values.js';\n\n/**\n * The base implementation of `_.sampleSize` without param guards.\n *\n * @private\n * @param {Array|Object} collection The collection to sample.\n * @param {number} n The number of elements to sample.\n * @returns {Array} Returns the random elements.\n */\nfunction baseSampleSize(collection, n) {\n  var array = values(collection);\n  return shuffleSelf(array, baseClamp(n, 0, array.length));\n}\n\nexport default baseSampleSize;\n", "import arraySampleSize from './_arraySampleSize.js';\nimport baseSampleSize from './_baseSampleSize.js';\nimport isArray from './isArray.js';\nimport isIterateeCall from './_isIterateeCall.js';\nimport toInteger from './toInteger.js';\n\n/**\n * Gets `n` random elements at unique keys from `collection` up to the\n * size of `collection`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to sample.\n * @param {number} [n=1] The number of elements to sample.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the random elements.\n * @example\n *\n * _.sampleSize([1, 2, 3], 2);\n * // => [3, 1]\n *\n * _.sampleSize([1, 2, 3], 4);\n * // => [2, 3, 1]\n */\nfunction sampleSize(collection, n, guard) {\n  if ((guard ? isIterateeCall(collection, n, guard) : n === undefined)) {\n    n = 1;\n  } else {\n    n = toInteger(n);\n  }\n  var func = isArray(collection) ? arraySampleSize : baseSampleSize;\n  return func(collection, n);\n}\n\nexport default sampleSize;\n", "import baseSet from './_baseSet.js';\n\n/**\n * Sets the value at `path` of `object`. If a portion of `path` doesn't exist,\n * it's created. Arrays are created for missing index properties while objects\n * are created for all other missing properties. Use `_.setWith` to customize\n * `path` creation.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.set(object, 'a[0].b.c', 4);\n * console.log(object.a[0].b.c);\n * // => 4\n *\n * _.set(object, ['x', '0', 'y', 'z'], 5);\n * console.log(object.x[0].y.z);\n * // => 5\n */\nfunction set(object, path, value) {\n  return object == null ? object : baseSet(object, path, value);\n}\n\nexport default set;\n", "import baseSet from './_baseSet.js';\n\n/**\n * This method is like `_.set` except that it accepts `customizer` which is\n * invoked to produce the objects of `path`.  If `customizer` returns `undefined`\n * path creation is handled by the method instead. The `customizer` is invoked\n * with three arguments: (nsValue, key, nsObject).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {};\n *\n * _.setWith(object, '[0][1]', 'a', Object);\n * // => { '0': { '1': 'a' } }\n */\nfunction setWith(object, path, value, customizer) {\n  customizer = typeof customizer == 'function' ? customizer : undefined;\n  return object == null ? object : baseSet(object, path, value, customizer);\n}\n\nexport default setWith;\n", "import copyArray from './_copyArray.js';\nimport shuffleSelf from './_shuffleSelf.js';\n\n/**\n * A specialized version of `_.shuffle` for arrays.\n *\n * @private\n * @param {Array} array The array to shuffle.\n * @returns {Array} Returns the new shuffled array.\n */\nfunction arrayShuffle(array) {\n  return shuffleSelf(copyArray(array));\n}\n\nexport default arrayShuffle;\n", "import shuffleSelf from './_shuffleSelf.js';\nimport values from './values.js';\n\n/**\n * The base implementation of `_.shuffle`.\n *\n * @private\n * @param {Array|Object} collection The collection to shuffle.\n * @returns {Array} Returns the new shuffled array.\n */\nfunction baseShuffle(collection) {\n  return shuffleSelf(values(collection));\n}\n\nexport default baseShuffle;\n", "import arrayShuffle from './_arrayShuffle.js';\nimport baseShuffle from './_baseShuffle.js';\nimport isArray from './isArray.js';\n\n/**\n * Creates an array of shuffled values, using a version of the\n * [Fisher-Yates shuffle](https://en.wikipedia.org/wiki/Fisher-Yates_shuffle).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to shuffle.\n * @returns {Array} Returns the new shuffled array.\n * @example\n *\n * _.shuffle([1, 2, 3, 4]);\n * // => [4, 1, 3, 2]\n */\nfunction shuffle(collection) {\n  var func = isArray(collection) ? arrayShuffle : baseShuffle;\n  return func(collection);\n}\n\nexport default shuffle;\n", "import baseKeys from './_baseKeys.js';\nimport getTag from './_getTag.js';\nimport isArrayLike from './isArrayLike.js';\nimport isString from './isString.js';\nimport stringSize from './_stringSize.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n    setTag = '[object Set]';\n\n/**\n * Gets the size of `collection` by returning its length for array-like\n * values or the number of own enumerable string keyed properties for objects.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @returns {number} Returns the collection size.\n * @example\n *\n * _.size([1, 2, 3]);\n * // => 3\n *\n * _.size({ 'a': 1, 'b': 2 });\n * // => 2\n *\n * _.size('pebbles');\n * // => 7\n */\nfunction size(collection) {\n  if (collection == null) {\n    return 0;\n  }\n  if (isArrayLike(collection)) {\n    return isString(collection) ? stringSize(collection) : collection.length;\n  }\n  var tag = getTag(collection);\n  if (tag == mapTag || tag == setTag) {\n    return collection.size;\n  }\n  return baseKeys(collection).length;\n}\n\nexport default size;\n", "import baseSlice from './_baseSlice.js';\nimport isIterateeCall from './_isIterateeCall.js';\nimport toInteger from './toInteger.js';\n\n/**\n * Creates a slice of `array` from `start` up to, but not including, `end`.\n *\n * **Note:** This method is used instead of\n * [`Array#slice`](https://mdn.io/Array/slice) to ensure dense arrays are\n * returned.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\nfunction slice(array, start, end) {\n  var length = array == null ? 0 : array.length;\n  if (!length) {\n    return [];\n  }\n  if (end && typeof end != 'number' && isIterateeCall(array, start, end)) {\n    start = 0;\n    end = length;\n  }\n  else {\n    start = start == null ? 0 : toInteger(start);\n    end = end === undefined ? length : toInteger(end);\n  }\n  return baseSlice(array, start, end);\n}\n\nexport default slice;\n", "import createCompounder from './_createCompounder.js';\n\n/**\n * Converts `string` to\n * [snake case](https://en.wikipedia.org/wiki/Snake_case).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the snake cased string.\n * @example\n *\n * _.snakeCase('Foo Bar');\n * // => 'foo_bar'\n *\n * _.snakeCase('fooBar');\n * // => 'foo_bar'\n *\n * _.snakeCase('--FOO-BAR--');\n * // => 'foo_bar'\n */\nvar snakeCase = createCompounder(function(result, word, index) {\n  return result + (index ? '_' : '') + word.toLowerCase();\n});\n\nexport default snakeCase;\n", "import baseEach from './_baseEach.js';\n\n/**\n * The base implementation of `_.some` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n *  else `false`.\n */\nfunction baseSome(collection, predicate) {\n  var result;\n\n  baseEach(collection, function(value, index, collection) {\n    result = predicate(value, index, collection);\n    return !result;\n  });\n  return !!result;\n}\n\nexport default baseSome;\n", "import arraySome from './_arraySome.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseSome from './_baseSome.js';\nimport isArray from './isArray.js';\nimport isIterateeCall from './_isIterateeCall.js';\n\n/**\n * Checks if `predicate` returns truthy for **any** element of `collection`.\n * Iteration is stopped once `predicate` returns truthy. The predicate is\n * invoked with three arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n *  else `false`.\n * @example\n *\n * _.some([null, 0, 'yes', false], Boolean);\n * // => true\n *\n * var users = [\n *   { 'user': 'barney', 'active': true },\n *   { 'user': 'fred',   'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.some(users, { 'user': 'barney', 'active': false });\n * // => false\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.some(users, ['active', false]);\n * // => true\n *\n * // The `_.property` iteratee shorthand.\n * _.some(users, 'active');\n * // => true\n */\nfunction some(collection, predicate, guard) {\n  var func = isArray(collection) ? arraySome : baseSome;\n  if (guard && isIterateeCall(collection, predicate, guard)) {\n    predicate = undefined;\n  }\n  return func(collection, baseIteratee(predicate, 3));\n}\n\nexport default some;\n", "import baseFlatten from './_baseFlatten.js';\nimport baseOrderBy from './_baseOrderBy.js';\nimport baseRest from './_baseRest.js';\nimport isIterateeCall from './_isIterateeCall.js';\n\n/**\n * Creates an array of elements, sorted in ascending order by the results of\n * running each element in a collection thru each iteratee. This method\n * performs a stable sort, that is, it preserves the original sort order of\n * equal elements. The iteratees are invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {...(Function|Function[])} [iteratees=[_.identity]]\n *  The iteratees to sort by.\n * @returns {Array} Returns the new sorted array.\n * @example\n *\n * var users = [\n *   { 'user': 'fred',   'age': 48 },\n *   { 'user': 'barney', 'age': 36 },\n *   { 'user': 'fred',   'age': 30 },\n *   { 'user': 'barney', 'age': 34 }\n * ];\n *\n * _.sortBy(users, [function(o) { return o.user; }]);\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 30]]\n *\n * _.sortBy(users, ['user', 'age']);\n * // => objects for [['barney', 34], ['barney', 36], ['fred', 30], ['fred', 48]]\n */\nvar sortBy = baseRest(function(collection, iteratees) {\n  if (collection == null) {\n    return [];\n  }\n  var length = iteratees.length;\n  if (length > 1 && isIterateeCall(collection, iteratees[0], iteratees[1])) {\n    iteratees = [];\n  } else if (length > 2 && isIterateeCall(iteratees[0], iteratees[1], iteratees[2])) {\n    iteratees = [iteratees[0]];\n  }\n  return baseOrderBy(collection, baseFlatten(iteratees, 1), []);\n});\n\nexport default sortBy;\n", "import isSymbol from './isSymbol.js';\n\n/** Used as references for the maximum length and index of an array. */\nvar MAX_ARRAY_LENGTH = 4294967295,\n    MAX_ARRAY_INDEX = MAX_ARRAY_LENGTH - 1;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeFloor = Math.floor,\n    nativeMin = Math.min;\n\n/**\n * The base implementation of `_.sortedIndexBy` and `_.sortedLastIndexBy`\n * which invokes `iteratee` for `value` and each element of `array` to compute\n * their sort ranking. The iteratee is invoked with one argument; (value).\n *\n * @private\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} iteratee The iteratee invoked per element.\n * @param {boolean} [retHighest] Specify returning the highest qualified index.\n * @returns {number} Returns the index at which `value` should be inserted\n *  into `array`.\n */\nfunction baseSortedIndexBy(array, value, iteratee, retHighest) {\n  var low = 0,\n      high = array == null ? 0 : array.length;\n  if (high === 0) {\n    return 0;\n  }\n\n  value = iteratee(value);\n  var valIsNaN = value !== value,\n      valIsNull = value === null,\n      valIsSymbol = isSymbol(value),\n      valIsUndefined = value === undefined;\n\n  while (low < high) {\n    var mid = nativeFloor((low + high) / 2),\n        computed = iteratee(array[mid]),\n        othIsDefined = computed !== undefined,\n        othIsNull = computed === null,\n        othIsReflexive = computed === computed,\n        othIsSymbol = isSymbol(computed);\n\n    if (valIsNaN) {\n      var setLow = retHighest || othIsReflexive;\n    } else if (valIsUndefined) {\n      setLow = othIsReflexive && (retHighest || othIsDefined);\n    } else if (valIsNull) {\n      setLow = othIsReflexive && othIsDefined && (retHighest || !othIsNull);\n    } else if (valIsSymbol) {\n      setLow = othIsReflexive && othIsDefined && !othIsNull && (retHighest || !othIsSymbol);\n    } else if (othIsNull || othIsSymbol) {\n      setLow = false;\n    } else {\n      setLow = retHighest ? (computed <= value) : (computed < value);\n    }\n    if (setLow) {\n      low = mid + 1;\n    } else {\n      high = mid;\n    }\n  }\n  return nativeMin(high, MAX_ARRAY_INDEX);\n}\n\nexport default baseSortedIndexBy;\n", "import baseSortedIndexBy from './_baseSortedIndexBy.js';\nimport identity from './identity.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used as references for the maximum length and index of an array. */\nvar MAX_ARRAY_LENGTH = 4294967295,\n    HALF_MAX_ARRAY_LENGTH = MAX_ARRAY_LENGTH >>> 1;\n\n/**\n * The base implementation of `_.sortedIndex` and `_.sortedLastIndex` which\n * performs a binary search of `array` to determine the index at which `value`\n * should be inserted into `array` in order to maintain its sort order.\n *\n * @private\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {boolean} [retHighest] Specify returning the highest qualified index.\n * @returns {number} Returns the index at which `value` should be inserted\n *  into `array`.\n */\nfunction baseSortedIndex(array, value, retHighest) {\n  var low = 0,\n      high = array == null ? low : array.length;\n\n  if (typeof value == 'number' && value === value && high <= HALF_MAX_ARRAY_LENGTH) {\n    while (low < high) {\n      var mid = (low + high) >>> 1,\n          computed = array[mid];\n\n      if (computed !== null && !isSymbol(computed) &&\n          (retHighest ? (computed <= value) : (computed < value))) {\n        low = mid + 1;\n      } else {\n        high = mid;\n      }\n    }\n    return high;\n  }\n  return baseSortedIndexBy(array, value, identity, retHighest);\n}\n\nexport default baseSortedIndex;\n", "import baseSortedIndex from './_baseSortedIndex.js';\n\n/**\n * Uses a binary search to determine the lowest index at which `value`\n * should be inserted into `array` in order to maintain its sort order.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @returns {number} Returns the index at which `value` should be inserted\n *  into `array`.\n * @example\n *\n * _.sortedIndex([30, 50], 40);\n * // => 1\n */\nfunction sortedIndex(array, value) {\n  return baseSortedIndex(array, value);\n}\n\nexport default sortedIndex;\n", "import baseIteratee from './_baseIteratee.js';\nimport baseSortedIndexBy from './_baseSortedIndexBy.js';\n\n/**\n * This method is like `_.sortedIndex` except that it accepts `iteratee`\n * which is invoked for `value` and each element of `array` to compute their\n * sort ranking. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the index at which `value` should be inserted\n *  into `array`.\n * @example\n *\n * var objects = [{ 'x': 4 }, { 'x': 5 }];\n *\n * _.sortedIndexBy(objects, { 'x': 4 }, function(o) { return o.x; });\n * // => 0\n *\n * // The `_.property` iteratee shorthand.\n * _.sortedIndexBy(objects, { 'x': 4 }, 'x');\n * // => 0\n */\nfunction sortedIndexBy(array, value, iteratee) {\n  return baseSortedIndexBy(array, value, baseIteratee(iteratee, 2));\n}\n\nexport default sortedIndexBy;\n", "import baseSortedIndex from './_baseSortedIndex.js';\nimport eq from './eq.js';\n\n/**\n * This method is like `_.indexOf` except that it performs a binary\n * search on a sorted `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.sortedIndexOf([4, 5, 5, 5, 6], 5);\n * // => 1\n */\nfunction sortedIndexOf(array, value) {\n  var length = array == null ? 0 : array.length;\n  if (length) {\n    var index = baseSortedIndex(array, value);\n    if (index < length && eq(array[index], value)) {\n      return index;\n    }\n  }\n  return -1;\n}\n\nexport default sortedIndexOf;\n", "import baseSortedIndex from './_baseSortedIndex.js';\n\n/**\n * This method is like `_.sortedIndex` except that it returns the highest\n * index at which `value` should be inserted into `array` in order to\n * maintain its sort order.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @returns {number} Returns the index at which `value` should be inserted\n *  into `array`.\n * @example\n *\n * _.sortedLastIndex([4, 5, 5, 5, 6], 5);\n * // => 4\n */\nfunction sortedLastIndex(array, value) {\n  return baseSortedIndex(array, value, true);\n}\n\nexport default sortedLastIndex;\n", "import baseIteratee from './_baseIteratee.js';\nimport baseSortedIndexBy from './_baseSortedIndexBy.js';\n\n/**\n * This method is like `_.sortedLastIndex` except that it accepts `iteratee`\n * which is invoked for `value` and each element of `array` to compute their\n * sort ranking. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the index at which `value` should be inserted\n *  into `array`.\n * @example\n *\n * var objects = [{ 'x': 4 }, { 'x': 5 }];\n *\n * _.sortedLastIndexBy(objects, { 'x': 4 }, function(o) { return o.x; });\n * // => 1\n *\n * // The `_.property` iteratee shorthand.\n * _.sortedLastIndexBy(objects, { 'x': 4 }, 'x');\n * // => 1\n */\nfunction sortedLastIndexBy(array, value, iteratee) {\n  return baseSortedIndexBy(array, value, baseIteratee(iteratee, 2), true);\n}\n\nexport default sortedLastIndexBy;\n", "import baseSortedIndex from './_baseSortedIndex.js';\nimport eq from './eq.js';\n\n/**\n * This method is like `_.lastIndexOf` except that it performs a binary\n * search on a sorted `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.sortedLastIndexOf([4, 5, 5, 5, 6], 5);\n * // => 3\n */\nfunction sortedLastIndexOf(array, value) {\n  var length = array == null ? 0 : array.length;\n  if (length) {\n    var index = baseSortedIndex(array, value, true) - 1;\n    if (eq(array[index], value)) {\n      return index;\n    }\n  }\n  return -1;\n}\n\nexport default sortedLastIndexOf;\n", "import eq from './eq.js';\n\n/**\n * The base implementation of `_.sortedUniq` and `_.sortedUniqBy` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n */\nfunction baseSortedUniq(array, iteratee) {\n  var index = -1,\n      length = array.length,\n      resIndex = 0,\n      result = [];\n\n  while (++index < length) {\n    var value = array[index],\n        computed = iteratee ? iteratee(value) : value;\n\n    if (!index || !eq(computed, seen)) {\n      var seen = computed;\n      result[resIndex++] = value === 0 ? 0 : value;\n    }\n  }\n  return result;\n}\n\nexport default baseSortedUniq;\n", "import baseSortedUniq from './_baseSortedUniq.js';\n\n/**\n * This method is like `_.uniq` except that it's designed and optimized\n * for sorted arrays.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.sortedUniq([1, 1, 2]);\n * // => [1, 2]\n */\nfunction sortedUniq(array) {\n  return (array && array.length)\n    ? baseSortedUniq(array)\n    : [];\n}\n\nexport default sortedUniq;\n", "import baseIteratee from './_baseIteratee.js';\nimport baseSortedUniq from './_baseSortedUniq.js';\n\n/**\n * This method is like `_.uniqBy` except that it's designed and optimized\n * for sorted arrays.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.sortedUniqBy([1.1, 1.2, 2.3, 2.4], Math.floor);\n * // => [1.1, 2.3]\n */\nfunction sortedUniqBy(array, iteratee) {\n  return (array && array.length)\n    ? baseSortedUniq(array, baseIteratee(iteratee, 2))\n    : [];\n}\n\nexport default sortedUniqBy;\n", "import baseToString from './_baseToString.js';\nimport castSlice from './_castSlice.js';\nimport hasUnicode from './_hasUnicode.js';\nimport isIterateeCall from './_isIterateeCall.js';\nimport isRegExp from './isRegExp.js';\nimport stringToArray from './_stringToArray.js';\nimport toString from './toString.js';\n\n/** Used as references for the maximum length and index of an array. */\nvar MAX_ARRAY_LENGTH = 4294967295;\n\n/**\n * Splits `string` by `separator`.\n *\n * **Note:** This method is based on\n * [`String#split`](https://mdn.io/String/split).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to split.\n * @param {RegExp|string} separator The separator pattern to split by.\n * @param {number} [limit] The length to truncate results to.\n * @returns {Array} Returns the string segments.\n * @example\n *\n * _.split('a-b-c', '-', 2);\n * // => ['a', 'b']\n */\nfunction split(string, separator, limit) {\n  if (limit && typeof limit != 'number' && isIterateeCall(string, separator, limit)) {\n    separator = limit = undefined;\n  }\n  limit = limit === undefined ? MAX_ARRAY_LENGTH : limit >>> 0;\n  if (!limit) {\n    return [];\n  }\n  string = toString(string);\n  if (string && (\n        typeof separator == 'string' ||\n        (separator != null && !isRegExp(separator))\n      )) {\n    separator = baseToString(separator);\n    if (!separator && hasUnicode(string)) {\n      return castSlice(stringToArray(string), 0, limit);\n    }\n  }\n  return string.split(separator, limit);\n}\n\nexport default split;\n", "import apply from './_apply.js';\nimport arrayPush from './_arrayPush.js';\nimport baseRest from './_baseRest.js';\nimport castSlice from './_castSlice.js';\nimport toInteger from './toInteger.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates a function that invokes `func` with the `this` binding of the\n * create function and an array of arguments much like\n * [`Function#apply`](http://www.ecma-international.org/ecma-262/7.0/#sec-function.prototype.apply).\n *\n * **Note:** This method is based on the\n * [spread operator](https://mdn.io/spread_operator).\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Function\n * @param {Function} func The function to spread arguments over.\n * @param {number} [start=0] The start position of the spread.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var say = _.spread(function(who, what) {\n *   return who + ' says ' + what;\n * });\n *\n * say(['fred', 'hello']);\n * // => 'fred says hello'\n *\n * var numbers = Promise.all([\n *   Promise.resolve(40),\n *   Promise.resolve(36)\n * ]);\n *\n * numbers.then(_.spread(function(x, y) {\n *   return x + y;\n * }));\n * // => a Promise of 76\n */\nfunction spread(func, start) {\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  start = start == null ? 0 : nativeMax(toInteger(start), 0);\n  return baseRest(function(args) {\n    var array = args[start],\n        otherArgs = castSlice(args, 0, start);\n\n    if (array) {\n      arrayPush(otherArgs, array);\n    }\n    return apply(func, this, otherArgs);\n  });\n}\n\nexport default spread;\n", "import createCompounder from './_createCompounder.js';\nimport upperFirst from './upperFirst.js';\n\n/**\n * Converts `string` to\n * [start case](https://en.wikipedia.org/wiki/Letter_case#Stylistic_or_specialised_usage).\n *\n * @static\n * @memberOf _\n * @since 3.1.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the start cased string.\n * @example\n *\n * _.startCase('--foo-bar--');\n * // => 'Foo Bar'\n *\n * _.startCase('fooBar');\n * // => 'Foo Bar'\n *\n * _.startCase('__FOO_BAR__');\n * // => 'FOO BAR'\n */\nvar startCase = createCompounder(function(result, word, index) {\n  return result + (index ? ' ' : '') + upperFirst(word);\n});\n\nexport default startCase;\n", "import baseClamp from './_baseClamp.js';\nimport baseToString from './_baseToString.js';\nimport toInteger from './toInteger.js';\nimport toString from './toString.js';\n\n/**\n * Checks if `string` starts with the given target string.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {string} [target] The string to search for.\n * @param {number} [position=0] The position to search from.\n * @returns {boolean} Returns `true` if `string` starts with `target`,\n *  else `false`.\n * @example\n *\n * _.startsWith('abc', 'a');\n * // => true\n *\n * _.startsWith('abc', 'b');\n * // => false\n *\n * _.startsWith('abc', 'b', 1);\n * // => true\n */\nfunction startsWith(string, target, position) {\n  string = toString(string);\n  position = position == null\n    ? 0\n    : baseClamp(toInteger(position), 0, string.length);\n\n  target = baseToString(target);\n  return string.slice(position, position + target.length) == target;\n}\n\nexport default startsWith;\n", "/**\n * This method returns a new empty object.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Object} Returns the new empty object.\n * @example\n *\n * var objects = _.times(2, _.stubObject);\n *\n * console.log(objects);\n * // => [{}, {}]\n *\n * console.log(objects[0] === objects[1]);\n * // => false\n */\nfunction stubObject() {\n  return {};\n}\n\nexport default stubObject;\n", "/**\n * This method returns an empty string.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {string} Returns the empty string.\n * @example\n *\n * _.times(2, _.stubString);\n * // => ['', '']\n */\nfunction stubString() {\n  return '';\n}\n\nexport default stubString;\n", "/**\n * This method returns `true`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `true`.\n * @example\n *\n * _.times(2, _.stubTrue);\n * // => [true, true]\n */\nfunction stubTrue() {\n  return true;\n}\n\nexport default stubTrue;\n", "import createMathOperation from './_createMathOperation.js';\n\n/**\n * Subtract two numbers.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Math\n * @param {number} minuend The first number in a subtraction.\n * @param {number} subtrahend The second number in a subtraction.\n * @returns {number} Returns the difference.\n * @example\n *\n * _.subtract(6, 4);\n * // => 2\n */\nvar subtract = createMathOperation(function(minuend, subtrahend) {\n  return minuend - subtrahend;\n}, 0);\n\nexport default subtract;\n", "import baseSum from './_baseSum.js';\nimport identity from './identity.js';\n\n/**\n * Computes the sum of the values in `array`.\n *\n * @static\n * @memberOf _\n * @since 3.4.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @returns {number} Returns the sum.\n * @example\n *\n * _.sum([4, 2, 8, 6]);\n * // => 20\n */\nfunction sum(array) {\n  return (array && array.length)\n    ? baseSum(array, identity)\n    : 0;\n}\n\nexport default sum;\n", "import baseIteratee from './_baseIteratee.js';\nimport baseSum from './_baseSum.js';\n\n/**\n * This method is like `_.sum` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the value to be summed.\n * The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the sum.\n * @example\n *\n * var objects = [{ 'n': 4 }, { 'n': 2 }, { 'n': 8 }, { 'n': 6 }];\n *\n * _.sumBy(objects, function(o) { return o.n; });\n * // => 20\n *\n * // The `_.property` iteratee shorthand.\n * _.sumBy(objects, 'n');\n * // => 20\n */\nfunction sumBy(array, iteratee) {\n  return (array && array.length)\n    ? baseSum(array, baseIteratee(iteratee, 2))\n    : 0;\n}\n\nexport default sumBy;\n", "import baseSlice from './_baseSlice.js';\n\n/**\n * Gets all but the first element of `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.tail([1, 2, 3]);\n * // => [2, 3]\n */\nfunction tail(array) {\n  var length = array == null ? 0 : array.length;\n  return length ? baseSlice(array, 1, length) : [];\n}\n\nexport default tail;\n", "import baseSlice from './_baseSlice.js';\nimport toInteger from './toInteger.js';\n\n/**\n * Creates a slice of `array` with `n` elements taken from the beginning.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to take.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.take([1, 2, 3]);\n * // => [1]\n *\n * _.take([1, 2, 3], 2);\n * // => [1, 2]\n *\n * _.take([1, 2, 3], 5);\n * // => [1, 2, 3]\n *\n * _.take([1, 2, 3], 0);\n * // => []\n */\nfunction take(array, n, guard) {\n  if (!(array && array.length)) {\n    return [];\n  }\n  n = (guard || n === undefined) ? 1 : toInteger(n);\n  return baseSlice(array, 0, n < 0 ? 0 : n);\n}\n\nexport default take;\n", "import baseSlice from './_baseSlice.js';\nimport toInteger from './toInteger.js';\n\n/**\n * Creates a slice of `array` with `n` elements taken from the end.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to take.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.takeRight([1, 2, 3]);\n * // => [3]\n *\n * _.takeRight([1, 2, 3], 2);\n * // => [2, 3]\n *\n * _.takeRight([1, 2, 3], 5);\n * // => [1, 2, 3]\n *\n * _.takeRight([1, 2, 3], 0);\n * // => []\n */\nfunction takeRight(array, n, guard) {\n  var length = array == null ? 0 : array.length;\n  if (!length) {\n    return [];\n  }\n  n = (guard || n === undefined) ? 1 : toInteger(n);\n  n = length - n;\n  return baseSlice(array, n < 0 ? 0 : n, length);\n}\n\nexport default takeRight;\n", "import baseIteratee from './_baseIteratee.js';\nimport baseWhile from './_baseWhile.js';\n\n/**\n * Creates a slice of `array` with elements taken from the end. Elements are\n * taken until `predicate` returns falsey. The predicate is invoked with\n * three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n *   { 'user': 'barney',  'active': true },\n *   { 'user': 'fred',    'active': false },\n *   { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.takeRightWhile(users, function(o) { return !o.active; });\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.matches` iteratee shorthand.\n * _.takeRightWhile(users, { 'user': 'pebbles', 'active': false });\n * // => objects for ['pebbles']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.takeRightWhile(users, ['active', false]);\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.property` iteratee shorthand.\n * _.takeRightWhile(users, 'active');\n * // => []\n */\nfunction takeRightWhile(array, predicate) {\n  return (array && array.length)\n    ? baseWhile(array, baseIteratee(predicate, 3), false, true)\n    : [];\n}\n\nexport default takeRightWhile;\n", "import baseIteratee from './_baseIteratee.js';\nimport baseWhile from './_baseWhile.js';\n\n/**\n * Creates a slice of `array` with elements taken from the beginning. Elements\n * are taken until `predicate` returns falsey. The predicate is invoked with\n * three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n *   { 'user': 'barney',  'active': false },\n *   { 'user': 'fred',    'active': false },\n *   { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.takeWhile(users, function(o) { return !o.active; });\n * // => objects for ['barney', 'fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.takeWhile(users, { 'user': 'barney', 'active': false });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.takeWhile(users, ['active', false]);\n * // => objects for ['barney', 'fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.takeWhile(users, 'active');\n * // => []\n */\nfunction takeWhile(array, predicate) {\n  return (array && array.length)\n    ? baseWhile(array, baseIteratee(predicate, 3))\n    : [];\n}\n\nexport default takeWhile;\n", "/**\n * This method invokes `interceptor` and returns `value`. The interceptor\n * is invoked with one argument; (value). The purpose of this method is to\n * \"tap into\" a method chain sequence in order to modify intermediate results.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @param {*} value The value to provide to `interceptor`.\n * @param {Function} interceptor The function to invoke.\n * @returns {*} Returns `value`.\n * @example\n *\n * _([1, 2, 3])\n *  .tap(function(array) {\n *    // Mutate input array.\n *    array.pop();\n *  })\n *  .reverse()\n *  .value();\n * // => [2, 1]\n */\nfunction tap(value, interceptor) {\n  interceptor(value);\n  return value;\n}\n\nexport default tap;\n", "import eq from './eq.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used by `_.defaults` to customize its `_.assignIn` use to assign properties\n * of source objects to the destination object for all destination properties\n * that resolve to `undefined`.\n *\n * @private\n * @param {*} objValue The destination value.\n * @param {*} srcValue The source value.\n * @param {string} key The key of the property to assign.\n * @param {Object} object The parent object of `objValue`.\n * @returns {*} Returns the value to assign.\n */\nfunction customDefaultsAssignIn(objValue, srcValue, key, object) {\n  if (objValue === undefined ||\n      (eq(objValue, objectProto[key]) && !hasOwnProperty.call(object, key))) {\n    return srcValue;\n  }\n  return objValue;\n}\n\nexport default customDefaultsAssignIn;\n", "/** Used to escape characters for inclusion in compiled string literals. */\nvar stringEscapes = {\n  '\\\\': '\\\\',\n  \"'\": \"'\",\n  '\\n': 'n',\n  '\\r': 'r',\n  '\\u2028': 'u2028',\n  '\\u2029': 'u2029'\n};\n\n/**\n * Used by `_.template` to escape characters for inclusion in compiled string literals.\n *\n * @private\n * @param {string} chr The matched character to escape.\n * @returns {string} Returns the escaped character.\n */\nfunction escapeStringChar(chr) {\n  return '\\\\' + stringEscapes[chr];\n}\n\nexport default escapeStringChar;\n", "/** Used to match template delimiters. */\nvar reInterpolate = /<%=([\\s\\S]+?)%>/g;\n\nexport default reInterpolate;\n", "/** Used to match template delimiters. */\nvar reEscape = /<%-([\\s\\S]+?)%>/g;\n\nexport default reEscape;\n", "/** Used to match template delimiters. */\nvar reEvaluate = /<%([\\s\\S]+?)%>/g;\n\nexport default reEvaluate;\n", "import escape from './escape.js';\nimport reEscape from './_reEscape.js';\nimport reEvaluate from './_reEvaluate.js';\nimport reInterpolate from './_reInterpolate.js';\n\n/**\n * By default, the template delimiters used by lodash are like those in\n * embedded Ruby (ERB) as well as ES2015 template strings. Change the\n * following template settings to use alternative delimiters.\n *\n * @static\n * @memberOf _\n * @type {Object}\n */\nvar templateSettings = {\n\n  /**\n   * Used to detect `data` property values to be HTML-escaped.\n   *\n   * @memberOf _.templateSettings\n   * @type {RegExp}\n   */\n  'escape': reEscape,\n\n  /**\n   * Used to detect code to be evaluated.\n   *\n   * @memberOf _.templateSettings\n   * @type {RegExp}\n   */\n  'evaluate': reEvaluate,\n\n  /**\n   * Used to detect `data` property values to inject.\n   *\n   * @memberOf _.templateSettings\n   * @type {RegExp}\n   */\n  'interpolate': reInterpolate,\n\n  /**\n   * Used to reference the data object in the template text.\n   *\n   * @memberOf _.templateSettings\n   * @type {string}\n   */\n  'variable': '',\n\n  /**\n   * Used to import variables into the compiled template.\n   *\n   * @memberOf _.templateSettings\n   * @type {Object}\n   */\n  'imports': {\n\n    /**\n     * A reference to the `lodash` function.\n     *\n     * @memberOf _.templateSettings.imports\n     * @type {Function}\n     */\n    '_': { 'escape': escape }\n  }\n};\n\nexport default templateSettings;\n", "import assignInWith from './assignInWith.js';\nimport attempt from './attempt.js';\nimport baseValues from './_baseValues.js';\nimport customDefaultsAssignIn from './_customDefaultsAssignIn.js';\nimport escapeStringChar from './_escapeStringChar.js';\nimport isError from './isError.js';\nimport isIterateeCall from './_isIterateeCall.js';\nimport keys from './keys.js';\nimport reInterpolate from './_reInterpolate.js';\nimport templateSettings from './templateSettings.js';\nimport toString from './toString.js';\n\n/** Error message constants. */\nvar INVALID_TEMPL_VAR_ERROR_TEXT = 'Invalid `variable` option passed into `_.template`';\n\n/** Used to match empty string literals in compiled template source. */\nvar reEmptyStringLeading = /\\b__p \\+= '';/g,\n    reEmptyStringMiddle = /\\b(__p \\+=) '' \\+/g,\n    reEmptyStringTrailing = /(__e\\(.*?\\)|\\b__t\\)) \\+\\n'';/g;\n\n/**\n * Used to validate the `validate` option in `_.template` variable.\n *\n * Forbids characters which could potentially change the meaning of the function argument definition:\n * - \"(),\" (modification of function parameters)\n * - \"=\" (default value)\n * - \"[]{}\" (destructuring of function parameters)\n * - \"/\" (beginning of a comment)\n * - whitespace\n */\nvar reForbiddenIdentifierChars = /[()=,{}\\[\\]\\/\\s]/;\n\n/**\n * Used to match\n * [ES template delimiters](http://ecma-international.org/ecma-262/7.0/#sec-template-literal-lexical-components).\n */\nvar reEsTemplate = /\\$\\{([^\\\\}]*(?:\\\\.[^\\\\}]*)*)\\}/g;\n\n/** Used to ensure capturing order of template delimiters. */\nvar reNoMatch = /($^)/;\n\n/** Used to match unescaped characters in compiled string literals. */\nvar reUnescapedString = /['\\n\\r\\u2028\\u2029\\\\]/g;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates a compiled template function that can interpolate data properties\n * in \"interpolate\" delimiters, HTML-escape interpolated data properties in\n * \"escape\" delimiters, and execute JavaScript in \"evaluate\" delimiters. Data\n * properties may be accessed as free variables in the template. If a setting\n * object is given, it takes precedence over `_.templateSettings` values.\n *\n * **Note:** In the development build `_.template` utilizes\n * [sourceURLs](http://www.html5rocks.com/en/tutorials/developertools/sourcemaps/#toc-sourceurl)\n * for easier debugging.\n *\n * For more information on precompiling templates see\n * [lodash's custom builds documentation](https://lodash.com/custom-builds).\n *\n * For more information on Chrome extension sandboxes see\n * [Chrome's extensions documentation](https://developer.chrome.com/extensions/sandboxingEval).\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category String\n * @param {string} [string=''] The template string.\n * @param {Object} [options={}] The options object.\n * @param {RegExp} [options.escape=_.templateSettings.escape]\n *  The HTML \"escape\" delimiter.\n * @param {RegExp} [options.evaluate=_.templateSettings.evaluate]\n *  The \"evaluate\" delimiter.\n * @param {Object} [options.imports=_.templateSettings.imports]\n *  An object to import into the template as free variables.\n * @param {RegExp} [options.interpolate=_.templateSettings.interpolate]\n *  The \"interpolate\" delimiter.\n * @param {string} [options.sourceURL='templateSources[n]']\n *  The sourceURL of the compiled template.\n * @param {string} [options.variable='obj']\n *  The data object variable name.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the compiled template function.\n * @example\n *\n * // Use the \"interpolate\" delimiter to create a compiled template.\n * var compiled = _.template('hello <%= user %>!');\n * compiled({ 'user': 'fred' });\n * // => 'hello fred!'\n *\n * // Use the HTML \"escape\" delimiter to escape data property values.\n * var compiled = _.template('<b><%- value %></b>');\n * compiled({ 'value': '<script>' });\n * // => '<b>&lt;script&gt;</b>'\n *\n * // Use the \"evaluate\" delimiter to execute JavaScript and generate HTML.\n * var compiled = _.template('<% _.forEach(users, function(user) { %><li><%- user %></li><% }); %>');\n * compiled({ 'users': ['fred', 'barney'] });\n * // => '<li>fred</li><li>barney</li>'\n *\n * // Use the internal `print` function in \"evaluate\" delimiters.\n * var compiled = _.template('<% print(\"hello \" + user); %>!');\n * compiled({ 'user': 'barney' });\n * // => 'hello barney!'\n *\n * // Use the ES template literal delimiter as an \"interpolate\" delimiter.\n * // Disable support by replacing the \"interpolate\" delimiter.\n * var compiled = _.template('hello ${ user }!');\n * compiled({ 'user': 'pebbles' });\n * // => 'hello pebbles!'\n *\n * // Use backslashes to treat delimiters as plain text.\n * var compiled = _.template('<%= \"\\\\<%- value %\\\\>\" %>');\n * compiled({ 'value': 'ignored' });\n * // => '<%- value %>'\n *\n * // Use the `imports` option to import `jQuery` as `jq`.\n * var text = '<% jq.each(users, function(user) { %><li><%- user %></li><% }); %>';\n * var compiled = _.template(text, { 'imports': { 'jq': jQuery } });\n * compiled({ 'users': ['fred', 'barney'] });\n * // => '<li>fred</li><li>barney</li>'\n *\n * // Use the `sourceURL` option to specify a custom sourceURL for the template.\n * var compiled = _.template('hello <%= user %>!', { 'sourceURL': '/basic/greeting.jst' });\n * compiled(data);\n * // => Find the source of \"greeting.jst\" under the Sources tab or Resources panel of the web inspector.\n *\n * // Use the `variable` option to ensure a with-statement isn't used in the compiled template.\n * var compiled = _.template('hi <%= data.user %>!', { 'variable': 'data' });\n * compiled.source;\n * // => function(data) {\n * //   var __t, __p = '';\n * //   __p += 'hi ' + ((__t = ( data.user )) == null ? '' : __t) + '!';\n * //   return __p;\n * // }\n *\n * // Use custom template delimiters.\n * _.templateSettings.interpolate = /{{([\\s\\S]+?)}}/g;\n * var compiled = _.template('hello {{ user }}!');\n * compiled({ 'user': 'mustache' });\n * // => 'hello mustache!'\n *\n * // Use the `source` property to inline compiled templates for meaningful\n * // line numbers in error messages and stack traces.\n * fs.writeFileSync(path.join(process.cwd(), 'jst.js'), '\\\n *   var JST = {\\\n *     \"main\": ' + _.template(mainText).source + '\\\n *   };\\\n * ');\n */\nfunction template(string, options, guard) {\n  // Based on John Resig's `tmpl` implementation\n  // (http://ejohn.org/blog/javascript-micro-templating/)\n  // and Laura Doktorova's doT.js (https://github.com/olado/doT).\n  var settings = templateSettings.imports._.templateSettings || templateSettings;\n\n  if (guard && isIterateeCall(string, options, guard)) {\n    options = undefined;\n  }\n  string = toString(string);\n  options = assignInWith({}, options, settings, customDefaultsAssignIn);\n\n  var imports = assignInWith({}, options.imports, settings.imports, customDefaultsAssignIn),\n      importsKeys = keys(imports),\n      importsValues = baseValues(imports, importsKeys);\n\n  var isEscaping,\n      isEvaluating,\n      index = 0,\n      interpolate = options.interpolate || reNoMatch,\n      source = \"__p += '\";\n\n  // Compile the regexp to match each delimiter.\n  var reDelimiters = RegExp(\n    (options.escape || reNoMatch).source + '|' +\n    interpolate.source + '|' +\n    (interpolate === reInterpolate ? reEsTemplate : reNoMatch).source + '|' +\n    (options.evaluate || reNoMatch).source + '|$'\n  , 'g');\n\n  // Use a sourceURL for easier debugging.\n  // The sourceURL gets injected into the source that's eval-ed, so be careful\n  // to normalize all kinds of whitespace, so e.g. newlines (and unicode versions of it) can't sneak in\n  // and escape the comment, thus injecting code that gets evaled.\n  var sourceURL = hasOwnProperty.call(options, 'sourceURL')\n    ? ('//# sourceURL=' +\n       (options.sourceURL + '').replace(/\\s/g, ' ') +\n       '\\n')\n    : '';\n\n  string.replace(reDelimiters, function(match, escapeValue, interpolateValue, esTemplateValue, evaluateValue, offset) {\n    interpolateValue || (interpolateValue = esTemplateValue);\n\n    // Escape characters that can't be included in string literals.\n    source += string.slice(index, offset).replace(reUnescapedString, escapeStringChar);\n\n    // Replace delimiters with snippets.\n    if (escapeValue) {\n      isEscaping = true;\n      source += \"' +\\n__e(\" + escapeValue + \") +\\n'\";\n    }\n    if (evaluateValue) {\n      isEvaluating = true;\n      source += \"';\\n\" + evaluateValue + \";\\n__p += '\";\n    }\n    if (interpolateValue) {\n      source += \"' +\\n((__t = (\" + interpolateValue + \")) == null ? '' : __t) +\\n'\";\n    }\n    index = offset + match.length;\n\n    // The JS engine embedded in Adobe products needs `match` returned in\n    // order to produce the correct `offset` value.\n    return match;\n  });\n\n  source += \"';\\n\";\n\n  // If `variable` is not specified wrap a with-statement around the generated\n  // code to add the data object to the top of the scope chain.\n  var variable = hasOwnProperty.call(options, 'variable') && options.variable;\n  if (!variable) {\n    source = 'with (obj) {\\n' + source + '\\n}\\n';\n  }\n  // Throw an error if a forbidden character was found in `variable`, to prevent\n  // potential command injection attacks.\n  else if (reForbiddenIdentifierChars.test(variable)) {\n    throw new Error(INVALID_TEMPL_VAR_ERROR_TEXT);\n  }\n\n  // Cleanup code by stripping empty strings.\n  source = (isEvaluating ? source.replace(reEmptyStringLeading, '') : source)\n    .replace(reEmptyStringMiddle, '$1')\n    .replace(reEmptyStringTrailing, '$1;');\n\n  // Frame code as the function body.\n  source = 'function(' + (variable || 'obj') + ') {\\n' +\n    (variable\n      ? ''\n      : 'obj || (obj = {});\\n'\n    ) +\n    \"var __t, __p = ''\" +\n    (isEscaping\n       ? ', __e = _.escape'\n       : ''\n    ) +\n    (isEvaluating\n      ? ', __j = Array.prototype.join;\\n' +\n        \"function print() { __p += __j.call(arguments, '') }\\n\"\n      : ';\\n'\n    ) +\n    source +\n    'return __p\\n}';\n\n  var result = attempt(function() {\n    return Function(importsKeys, sourceURL + 'return ' + source)\n      .apply(undefined, importsValues);\n  });\n\n  // Provide the compiled function's source by its `toString` method or\n  // the `source` property as a convenience for inlining compiled templates.\n  result.source = source;\n  if (isError(result)) {\n    throw result;\n  }\n  return result;\n}\n\nexport default template;\n", "import debounce from './debounce.js';\nimport isObject from './isObject.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a throttled function that only invokes `func` at most once per\n * every `wait` milliseconds. The throttled function comes with a `cancel`\n * method to cancel delayed `func` invocations and a `flush` method to\n * immediately invoke them. Provide `options` to indicate whether `func`\n * should be invoked on the leading and/or trailing edge of the `wait`\n * timeout. The `func` is invoked with the last arguments provided to the\n * throttled function. Subsequent calls to the throttled function return the\n * result of the last `func` invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the throttled function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.throttle` and `_.debounce`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to throttle.\n * @param {number} [wait=0] The number of milliseconds to throttle invocations to.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=true]\n *  Specify invoking on the leading edge of the timeout.\n * @param {boolean} [options.trailing=true]\n *  Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new throttled function.\n * @example\n *\n * // Avoid excessively updating the position while scrolling.\n * jQuery(window).on('scroll', _.throttle(updatePosition, 100));\n *\n * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.\n * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });\n * jQuery(element).on('click', throttled);\n *\n * // Cancel the trailing throttled invocation.\n * jQuery(window).on('popstate', throttled.cancel);\n */\nfunction throttle(func, wait, options) {\n  var leading = true,\n      trailing = true;\n\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  if (isObject(options)) {\n    leading = 'leading' in options ? !!options.leading : leading;\n    trailing = 'trailing' in options ? !!options.trailing : trailing;\n  }\n  return debounce(func, wait, {\n    'leading': leading,\n    'maxWait': wait,\n    'trailing': trailing\n  });\n}\n\nexport default throttle;\n", "/**\n * This method is like `_.tap` except that it returns the result of `interceptor`.\n * The purpose of this method is to \"pass thru\" values replacing intermediate\n * results in a method chain sequence.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Seq\n * @param {*} value The value to provide to `interceptor`.\n * @param {Function} interceptor The function to invoke.\n * @returns {*} Returns the result of `interceptor`.\n * @example\n *\n * _('  abc  ')\n *  .chain()\n *  .trim()\n *  .thru(function(value) {\n *    return [value];\n *  })\n *  .value();\n * // => ['abc']\n */\nfunction thru(value, interceptor) {\n  return interceptor(value);\n}\n\nexport default thru;\n", "import baseTimes from './_baseTimes.js';\nimport castFunction from './_castFunction.js';\nimport toInteger from './toInteger.js';\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used as references for the maximum length and index of an array. */\nvar MAX_ARRAY_LENGTH = 4294967295;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMin = Math.min;\n\n/**\n * Invokes the iteratee `n` times, returning an array of the results of\n * each invocation. The iteratee is invoked with one argument; (index).\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n * @example\n *\n * _.times(3, String);\n * // => ['0', '1', '2']\n *\n *  _.times(4, _.constant(0));\n * // => [0, 0, 0, 0]\n */\nfunction times(n, iteratee) {\n  n = toInteger(n);\n  if (n < 1 || n > MAX_SAFE_INTEGER) {\n    return [];\n  }\n  var index = MAX_ARRAY_LENGTH,\n      length = nativeMin(n, MAX_ARRAY_LENGTH);\n\n  iteratee = castFunction(iteratee);\n  n -= MAX_ARRAY_LENGTH;\n\n  var result = baseTimes(length, iteratee);\n  while (++index < n) {\n    iteratee(index);\n  }\n  return result;\n}\n\nexport default times;\n", "/**\n * Enables the wrapper to be iterable.\n *\n * @name Symbol.iterator\n * @memberOf _\n * @since 4.0.0\n * @category Seq\n * @returns {Object} Returns the wrapper object.\n * @example\n *\n * var wrapped = _([1, 2]);\n *\n * wrapped[Symbol.iterator]() === wrapped;\n * // => true\n *\n * Array.from(wrapped);\n * // => [1, 2]\n */\nfunction wrapperToIterator() {\n  return this;\n}\n\nexport default wrapperToIterator;\n", "import LazyWrapper from './_LazyWrapper.js';\nimport arrayPush from './_arrayPush.js';\nimport arrayReduce from './_arrayReduce.js';\n\n/**\n * The base implementation of `wrapperValue` which returns the result of\n * performing a sequence of actions on the unwrapped `value`, where each\n * successive action is supplied the return value of the previous.\n *\n * @private\n * @param {*} value The unwrapped value.\n * @param {Array} actions Actions to perform to resolve the unwrapped value.\n * @returns {*} Returns the resolved value.\n */\nfunction baseWrapperValue(value, actions) {\n  var result = value;\n  if (result instanceof LazyWrapper) {\n    result = result.value();\n  }\n  return arrayReduce(actions, function(result, action) {\n    return action.func.apply(action.thisArg, arrayPush([result], action.args));\n  }, result);\n}\n\nexport default baseWrapperValue;\n", "import baseWrapperValue from './_baseWrapperValue.js';\n\n/**\n * Executes the chain sequence to resolve the unwrapped value.\n *\n * @name value\n * @memberOf _\n * @since 0.1.0\n * @alias toJSON, valueOf\n * @category Seq\n * @returns {*} Returns the resolved unwrapped value.\n * @example\n *\n * _([1, 2, 3]).value();\n * // => [1, 2, 3]\n */\nfunction wrapperValue() {\n  return baseWrapperValue(this.__wrapped__, this.__actions__);\n}\n\nexport default wrapperValue;\n", "import toString from './toString.js';\n\n/**\n * Converts `string`, as a whole, to lower case just like\n * [String#toLowerCase](https://mdn.io/toLowerCase).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the lower cased string.\n * @example\n *\n * _.toLower('--Foo-Bar--');\n * // => '--foo-bar--'\n *\n * _.toLower('fooBar');\n * // => 'foobar'\n *\n * _.toLower('__FOO_BAR__');\n * // => '__foo_bar__'\n */\nfunction toLower(value) {\n  return toString(value).toLowerCase();\n}\n\nexport default toLower;\n", "import arrayMap from './_arrayMap.js';\nimport copyArray from './_copyArray.js';\nimport isArray from './isArray.js';\nimport isSymbol from './isSymbol.js';\nimport stringToPath from './_stringToPath.js';\nimport toKey from './_toKey.js';\nimport toString from './toString.js';\n\n/**\n * Converts `value` to a property path array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {*} value The value to convert.\n * @returns {Array} Returns the new property path array.\n * @example\n *\n * _.toPath('a.b.c');\n * // => ['a', 'b', 'c']\n *\n * _.toPath('a[0].b.c');\n * // => ['a', '0', 'b', 'c']\n */\nfunction toPath(value) {\n  if (isArray(value)) {\n    return arrayMap(value, toKey);\n  }\n  return isSymbol(value) ? [value] : copyArray(stringToPath(toString(value)));\n}\n\nexport default toPath;\n", "import baseClamp from './_baseClamp.js';\nimport toInteger from './toInteger.js';\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Converts `value` to a safe integer. A safe integer can be compared and\n * represented correctly.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toSafeInteger(3.2);\n * // => 3\n *\n * _.toSafeInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toSafeInteger(Infinity);\n * // => 9007199254740991\n *\n * _.toSafeInteger('3.2');\n * // => 3\n */\nfunction toSafeInteger(value) {\n  return value\n    ? baseClamp(toInteger(value), -MAX_SAFE_INTEGER, MAX_SAFE_INTEGER)\n    : (value === 0 ? value : 0);\n}\n\nexport default toSafeInteger;\n", "import toString from './toString.js';\n\n/**\n * Converts `string`, as a whole, to upper case just like\n * [String#toUpperCase](https://mdn.io/toUpperCase).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the upper cased string.\n * @example\n *\n * _.toUpper('--foo-bar--');\n * // => '--FOO-BAR--'\n *\n * _.toUpper('fooBar');\n * // => 'FOOBAR'\n *\n * _.toUpper('__foo_bar__');\n * // => '__FOO_BAR__'\n */\nfunction toUpper(value) {\n  return toString(value).toUpperCase();\n}\n\nexport default toUpper;\n", "import arrayEach from './_arrayEach.js';\nimport baseCreate from './_baseCreate.js';\nimport baseForOwn from './_baseForOwn.js';\nimport baseIteratee from './_baseIteratee.js';\nimport getPrototype from './_getPrototype.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isFunction from './isFunction.js';\nimport isObject from './isObject.js';\nimport isTypedArray from './isTypedArray.js';\n\n/**\n * An alternative to `_.reduce`; this method transforms `object` to a new\n * `accumulator` object which is the result of running each of its own\n * enumerable string keyed properties thru `iteratee`, with each invocation\n * potentially mutating the `accumulator` object. If `accumulator` is not\n * provided, a new object with the same `[[Prototype]]` will be used. The\n * iteratee is invoked with four arguments: (accumulator, value, key, object).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 1.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The custom accumulator value.\n * @returns {*} Returns the accumulated value.\n * @example\n *\n * _.transform([2, 3, 4], function(result, n) {\n *   result.push(n *= n);\n *   return n % 2 == 0;\n * }, []);\n * // => [4, 9]\n *\n * _.transform({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n *   (result[value] || (result[value] = [])).push(key);\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] }\n */\nfunction transform(object, iteratee, accumulator) {\n  var isArr = isArray(object),\n      isArrLike = isArr || isBuffer(object) || isTypedArray(object);\n\n  iteratee = baseIteratee(iteratee, 4);\n  if (accumulator == null) {\n    var Ctor = object && object.constructor;\n    if (isArrLike) {\n      accumulator = isArr ? new Ctor : [];\n    }\n    else if (isObject(object)) {\n      accumulator = isFunction(Ctor) ? baseCreate(getPrototype(object)) : {};\n    }\n    else {\n      accumulator = {};\n    }\n  }\n  (isArrLike ? arrayEach : baseForOwn)(object, function(value, index, object) {\n    return iteratee(accumulator, value, index, object);\n  });\n  return accumulator;\n}\n\nexport default transform;\n", "import baseIndexOf from './_baseIndexOf.js';\n\n/**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last string symbol\n * that is not found in the character symbols.\n *\n * @private\n * @param {Array} strSymbols The string symbols to inspect.\n * @param {Array} chrSymbols The character symbols to find.\n * @returns {number} Returns the index of the last unmatched string symbol.\n */\nfunction charsEndIndex(strSymbols, chrSymbols) {\n  var index = strSymbols.length;\n\n  while (index-- && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\n  return index;\n}\n\nexport default charsEndIndex;\n", "import baseIndexOf from './_baseIndexOf.js';\n\n/**\n * Used by `_.trim` and `_.trimStart` to get the index of the first string symbol\n * that is not found in the character symbols.\n *\n * @private\n * @param {Array} strSymbols The string symbols to inspect.\n * @param {Array} chrSymbols The character symbols to find.\n * @returns {number} Returns the index of the first unmatched string symbol.\n */\nfunction charsStartIndex(strSymbols, chrSymbols) {\n  var index = -1,\n      length = strSymbols.length;\n\n  while (++index < length && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\n  return index;\n}\n\nexport default charsStartIndex;\n", "import baseToString from './_baseToString.js';\nimport baseTrim from './_baseTrim.js';\nimport castSlice from './_castSlice.js';\nimport charsEndIndex from './_charsEndIndex.js';\nimport charsStartIndex from './_charsStartIndex.js';\nimport stringToArray from './_stringToArray.js';\nimport toString from './toString.js';\n\n/**\n * Removes leading and trailing whitespace or specified characters from `string`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to trim.\n * @param {string} [chars=whitespace] The characters to trim.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {string} Returns the trimmed string.\n * @example\n *\n * _.trim('  abc  ');\n * // => 'abc'\n *\n * _.trim('-_-abc-_-', '_-');\n * // => 'abc'\n *\n * _.map(['  foo  ', '  bar  '], _.trim);\n * // => ['foo', 'bar']\n */\nfunction trim(string, chars, guard) {\n  string = toString(string);\n  if (string && (guard || chars === undefined)) {\n    return baseTrim(string);\n  }\n  if (!string || !(chars = baseToString(chars))) {\n    return string;\n  }\n  var strSymbols = stringToArray(string),\n      chrSymbols = stringToArray(chars),\n      start = charsStartIndex(strSymbols, chrSymbols),\n      end = charsEndIndex(strSymbols, chrSymbols) + 1;\n\n  return castSlice(strSymbols, start, end).join('');\n}\n\nexport default trim;\n", "import baseToString from './_baseToString.js';\nimport castSlice from './_castSlice.js';\nimport charsEndIndex from './_charsEndIndex.js';\nimport stringToArray from './_stringToArray.js';\nimport toString from './toString.js';\nimport trimmedEndIndex from './_trimmedEndIndex.js';\n\n/**\n * Removes trailing whitespace or specified characters from `string`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to trim.\n * @param {string} [chars=whitespace] The characters to trim.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {string} Returns the trimmed string.\n * @example\n *\n * _.trimEnd('  abc  ');\n * // => '  abc'\n *\n * _.trimEnd('-_-abc-_-', '_-');\n * // => '-_-abc'\n */\nfunction trimEnd(string, chars, guard) {\n  string = toString(string);\n  if (string && (guard || chars === undefined)) {\n    return string.slice(0, trimmedEndIndex(string) + 1);\n  }\n  if (!string || !(chars = baseToString(chars))) {\n    return string;\n  }\n  var strSymbols = stringToArray(string),\n      end = charsEndIndex(strSymbols, stringToArray(chars)) + 1;\n\n  return castSlice(strSymbols, 0, end).join('');\n}\n\nexport default trimEnd;\n", "import baseToString from './_baseToString.js';\nimport castSlice from './_castSlice.js';\nimport charsStartIndex from './_charsStartIndex.js';\nimport stringToArray from './_stringToArray.js';\nimport toString from './toString.js';\n\n/** Used to match leading whitespace. */\nvar reTrimStart = /^\\s+/;\n\n/**\n * Removes leading whitespace or specified characters from `string`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to trim.\n * @param {string} [chars=whitespace] The characters to trim.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {string} Returns the trimmed string.\n * @example\n *\n * _.trimStart('  abc  ');\n * // => 'abc  '\n *\n * _.trimStart('-_-abc-_-', '_-');\n * // => 'abc-_-'\n */\nfunction trimStart(string, chars, guard) {\n  string = toString(string);\n  if (string && (guard || chars === undefined)) {\n    return string.replace(reTrimStart, '');\n  }\n  if (!string || !(chars = baseToString(chars))) {\n    return string;\n  }\n  var strSymbols = stringToArray(string),\n      start = charsStartIndex(strSymbols, stringToArray(chars));\n\n  return castSlice(strSymbols, start).join('');\n}\n\nexport default trimStart;\n", "import baseToString from './_baseToString.js';\nimport castSlice from './_castSlice.js';\nimport hasUnicode from './_hasUnicode.js';\nimport isObject from './isObject.js';\nimport isRegExp from './isRegExp.js';\nimport stringSize from './_stringSize.js';\nimport stringToArray from './_stringToArray.js';\nimport toInteger from './toInteger.js';\nimport toString from './toString.js';\n\n/** Used as default options for `_.truncate`. */\nvar DEFAULT_TRUNC_LENGTH = 30,\n    DEFAULT_TRUNC_OMISSION = '...';\n\n/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/**\n * Truncates `string` if it's longer than the given maximum string length.\n * The last characters of the truncated string are replaced with the omission\n * string which defaults to \"...\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to truncate.\n * @param {Object} [options={}] The options object.\n * @param {number} [options.length=30] The maximum string length.\n * @param {string} [options.omission='...'] The string to indicate text is omitted.\n * @param {RegExp|string} [options.separator] The separator pattern to truncate to.\n * @returns {string} Returns the truncated string.\n * @example\n *\n * _.truncate('hi-diddly-ho there, neighborino');\n * // => 'hi-diddly-ho there, neighbo...'\n *\n * _.truncate('hi-diddly-ho there, neighborino', {\n *   'length': 24,\n *   'separator': ' '\n * });\n * // => 'hi-diddly-ho there,...'\n *\n * _.truncate('hi-diddly-ho there, neighborino', {\n *   'length': 24,\n *   'separator': /,? +/\n * });\n * // => 'hi-diddly-ho there...'\n *\n * _.truncate('hi-diddly-ho there, neighborino', {\n *   'omission': ' [...]'\n * });\n * // => 'hi-diddly-ho there, neig [...]'\n */\nfunction truncate(string, options) {\n  var length = DEFAULT_TRUNC_LENGTH,\n      omission = DEFAULT_TRUNC_OMISSION;\n\n  if (isObject(options)) {\n    var separator = 'separator' in options ? options.separator : separator;\n    length = 'length' in options ? toInteger(options.length) : length;\n    omission = 'omission' in options ? baseToString(options.omission) : omission;\n  }\n  string = toString(string);\n\n  var strLength = string.length;\n  if (hasUnicode(string)) {\n    var strSymbols = stringToArray(string);\n    strLength = strSymbols.length;\n  }\n  if (length >= strLength) {\n    return string;\n  }\n  var end = length - stringSize(omission);\n  if (end < 1) {\n    return omission;\n  }\n  var result = strSymbols\n    ? castSlice(strSymbols, 0, end).join('')\n    : string.slice(0, end);\n\n  if (separator === undefined) {\n    return result + omission;\n  }\n  if (strSymbols) {\n    end += (result.length - end);\n  }\n  if (isRegExp(separator)) {\n    if (string.slice(end).search(separator)) {\n      var match,\n          substring = result;\n\n      if (!separator.global) {\n        separator = RegExp(separator.source, toString(reFlags.exec(separator)) + 'g');\n      }\n      separator.lastIndex = 0;\n      while ((match = separator.exec(substring))) {\n        var newEnd = match.index;\n      }\n      result = result.slice(0, newEnd === undefined ? end : newEnd);\n    }\n  } else if (string.indexOf(baseToString(separator), end) != end) {\n    var index = result.lastIndexOf(separator);\n    if (index > -1) {\n      result = result.slice(0, index);\n    }\n  }\n  return result + omission;\n}\n\nexport default truncate;\n", "import ary from './ary.js';\n\n/**\n * Creates a function that accepts up to one argument, ignoring any\n * additional arguments.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n * @example\n *\n * _.map(['6', '8', '10'], _.unary(parseInt));\n * // => [6, 8, 10]\n */\nfunction unary(func) {\n  return ary(func, 1);\n}\n\nexport default unary;\n", "import basePropertyOf from './_basePropertyOf.js';\n\n/** Used to map HTML entities to characters. */\nvar htmlUnescapes = {\n  '&amp;': '&',\n  '&lt;': '<',\n  '&gt;': '>',\n  '&quot;': '\"',\n  '&#39;': \"'\"\n};\n\n/**\n * Used by `_.unescape` to convert HTML entities to characters.\n *\n * @private\n * @param {string} chr The matched character to unescape.\n * @returns {string} Returns the unescaped character.\n */\nvar unescapeHtmlChar = basePropertyOf(htmlUnescapes);\n\nexport default unescapeHtmlChar;\n", "import toString from './toString.js';\nimport unescapeHtmlChar from './_unescapeHtmlChar.js';\n\n/** Used to match HTML entities and HTML characters. */\nvar reEscapedHtml = /&(?:amp|lt|gt|quot|#39);/g,\n    reHasEscapedHtml = RegExp(reEscapedHtml.source);\n\n/**\n * The inverse of `_.escape`; this method converts the HTML entities\n * `&amp;`, `&lt;`, `&gt;`, `&quot;`, and `&#39;` in `string` to\n * their corresponding characters.\n *\n * **Note:** No other HTML entities are unescaped. To unescape additional\n * HTML entities use a third-party library like [_he_](https://mths.be/he).\n *\n * @static\n * @memberOf _\n * @since 0.6.0\n * @category String\n * @param {string} [string=''] The string to unescape.\n * @returns {string} Returns the unescaped string.\n * @example\n *\n * _.unescape('fred, barney, &amp; pebbles');\n * // => 'fred, barney, & pebbles'\n */\nfunction unescape(string) {\n  string = toString(string);\n  return (string && reHasEscapedHtml.test(string))\n    ? string.replace(reEscapedHtml, unescapeHtmlChar)\n    : string;\n}\n\nexport default unescape;\n", "import Set from './_Set.js';\nimport noop from './noop.js';\nimport setToArray from './_setToArray.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Creates a set object of `values`.\n *\n * @private\n * @param {Array} values The values to add to the set.\n * @returns {Object} Returns the new set.\n */\nvar createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) {\n  return new Set(values);\n};\n\nexport default createSet;\n", "import SetCache from './_SetCache.js';\nimport arrayIncludes from './_arrayIncludes.js';\nimport arrayIncludesWith from './_arrayIncludesWith.js';\nimport cacheHas from './_cacheHas.js';\nimport createSet from './_createSet.js';\nimport setToArray from './_setToArray.js';\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * The base implementation of `_.uniqBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n */\nfunction baseUniq(array, iteratee, comparator) {\n  var index = -1,\n      includes = arrayIncludes,\n      length = array.length,\n      isCommon = true,\n      result = [],\n      seen = result;\n\n  if (comparator) {\n    isCommon = false;\n    includes = arrayIncludesWith;\n  }\n  else if (length >= LARGE_ARRAY_SIZE) {\n    var set = iteratee ? null : createSet(array);\n    if (set) {\n      return setToArray(set);\n    }\n    isCommon = false;\n    includes = cacheHas;\n    seen = new SetCache;\n  }\n  else {\n    seen = iteratee ? [] : result;\n  }\n  outer:\n  while (++index < length) {\n    var value = array[index],\n        computed = iteratee ? iteratee(value) : value;\n\n    value = (comparator || value !== 0) ? value : 0;\n    if (isCommon && computed === computed) {\n      var seenIndex = seen.length;\n      while (seenIndex--) {\n        if (seen[seenIndex] === computed) {\n          continue outer;\n        }\n      }\n      if (iteratee) {\n        seen.push(computed);\n      }\n      result.push(value);\n    }\n    else if (!includes(seen, computed, comparator)) {\n      if (seen !== result) {\n        seen.push(computed);\n      }\n      result.push(value);\n    }\n  }\n  return result;\n}\n\nexport default baseUniq;\n", "import baseFlatten from './_baseFlatten.js';\nimport baseRest from './_baseRest.js';\nimport baseUniq from './_baseUniq.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\n\n/**\n * Creates an array of unique values, in order, from all given arrays using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * _.union([2], [1, 2]);\n * // => [2, 1]\n */\nvar union = baseRest(function(arrays) {\n  return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true));\n});\n\nexport default union;\n", "import baseFlatten from './_baseFlatten.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseRest from './_baseRest.js';\nimport baseUniq from './_baseUniq.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\nimport last from './last.js';\n\n/**\n * This method is like `_.union` except that it accepts `iteratee` which is\n * invoked for each element of each `arrays` to generate the criterion by\n * which uniqueness is computed. Result values are chosen from the first\n * array in which the value occurs. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * _.unionBy([2.1], [1.2, 2.3], Math.floor);\n * // => [2.1, 1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.unionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }, { 'x': 2 }]\n */\nvar unionBy = baseRest(function(arrays) {\n  var iteratee = last(arrays);\n  if (isArrayLikeObject(iteratee)) {\n    iteratee = undefined;\n  }\n  return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), baseIteratee(iteratee, 2));\n});\n\nexport default unionBy;\n", "import baseFlatten from './_baseFlatten.js';\nimport baseRest from './_baseRest.js';\nimport baseUniq from './_baseUniq.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\nimport last from './last.js';\n\n/**\n * This method is like `_.union` except that it accepts `comparator` which\n * is invoked to compare elements of `arrays`. Result values are chosen from\n * the first array in which the value occurs. The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.unionWith(objects, others, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]\n */\nvar unionWith = baseRest(function(arrays) {\n  var comparator = last(arrays);\n  comparator = typeof comparator == 'function' ? comparator : undefined;\n  return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), undefined, comparator);\n});\n\nexport default unionWith;\n", "import baseUniq from './_baseUniq.js';\n\n/**\n * Creates a duplicate-free version of an array, using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons, in which only the first occurrence of each element\n * is kept. The order of result values is determined by the order they occur\n * in the array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.uniq([2, 1, 2]);\n * // => [2, 1]\n */\nfunction uniq(array) {\n  return (array && array.length) ? baseUniq(array) : [];\n}\n\nexport default uniq;\n", "import baseIteratee from './_baseIteratee.js';\nimport baseUniq from './_baseUniq.js';\n\n/**\n * This method is like `_.uniq` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the criterion by which\n * uniqueness is computed. The order of result values is determined by the\n * order they occur in the array. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.uniqBy([2.1, 1.2, 2.3], Math.floor);\n * // => [2.1, 1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.uniqBy([{ 'x': 1 }, { 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }, { 'x': 2 }]\n */\nfunction uniqBy(array, iteratee) {\n  return (array && array.length) ? baseUniq(array, baseIteratee(iteratee, 2)) : [];\n}\n\nexport default uniqBy;\n", "import baseUniq from './_baseUniq.js';\n\n/**\n * This method is like `_.uniq` except that it accepts `comparator` which\n * is invoked to compare elements of `array`. The order of result values is\n * determined by the order they occur in the array.The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.uniqWith(objects, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]\n */\nfunction uniqWith(array, comparator) {\n  comparator = typeof comparator == 'function' ? comparator : undefined;\n  return (array && array.length) ? baseUniq(array, undefined, comparator) : [];\n}\n\nexport default uniqWith;\n", "import toString from './toString.js';\n\n/** Used to generate unique IDs. */\nvar idCounter = 0;\n\n/**\n * Generates a unique ID. If `prefix` is given, the ID is appended to it.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {string} [prefix=''] The value to prefix the ID with.\n * @returns {string} Returns the unique ID.\n * @example\n *\n * _.uniqueId('contact_');\n * // => 'contact_104'\n *\n * _.uniqueId();\n * // => '105'\n */\nfunction uniqueId(prefix) {\n  var id = ++idCounter;\n  return toString(prefix) + id;\n}\n\nexport default uniqueId;\n", "import baseUnset from './_baseUnset.js';\n\n/**\n * Removes the property at `path` of `object`.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to unset.\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 7 } }] };\n * _.unset(object, 'a[0].b.c');\n * // => true\n *\n * console.log(object);\n * // => { 'a': [{ 'b': {} }] };\n *\n * _.unset(object, ['a', '0', 'b', 'c']);\n * // => true\n *\n * console.log(object);\n * // => { 'a': [{ 'b': {} }] };\n */\nfunction unset(object, path) {\n  return object == null ? true : baseUnset(object, path);\n}\n\nexport default unset;\n", "import arrayFilter from './_arrayFilter.js';\nimport arrayMap from './_arrayMap.js';\nimport baseProperty from './_baseProperty.js';\nimport baseTimes from './_baseTimes.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * This method is like `_.zip` except that it accepts an array of grouped\n * elements and creates an array regrouping the elements to their pre-zip\n * configuration.\n *\n * @static\n * @memberOf _\n * @since 1.2.0\n * @category Array\n * @param {Array} array The array of grouped elements to process.\n * @returns {Array} Returns the new array of regrouped elements.\n * @example\n *\n * var zipped = _.zip(['a', 'b'], [1, 2], [true, false]);\n * // => [['a', 1, true], ['b', 2, false]]\n *\n * _.unzip(zipped);\n * // => [['a', 'b'], [1, 2], [true, false]]\n */\nfunction unzip(array) {\n  if (!(array && array.length)) {\n    return [];\n  }\n  var length = 0;\n  array = arrayFilter(array, function(group) {\n    if (isArrayLikeObject(group)) {\n      length = nativeMax(group.length, length);\n      return true;\n    }\n  });\n  return baseTimes(length, function(index) {\n    return arrayMap(array, baseProperty(index));\n  });\n}\n\nexport default unzip;\n", "import apply from './_apply.js';\nimport arrayMap from './_arrayMap.js';\nimport unzip from './unzip.js';\n\n/**\n * This method is like `_.unzip` except that it accepts `iteratee` to specify\n * how regrouped values should be combined. The iteratee is invoked with the\n * elements of each group: (...group).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Array\n * @param {Array} array The array of grouped elements to process.\n * @param {Function} [iteratee=_.identity] The function to combine\n *  regrouped values.\n * @returns {Array} Returns the new array of regrouped elements.\n * @example\n *\n * var zipped = _.zip([1, 2], [10, 20], [100, 200]);\n * // => [[1, 10, 100], [2, 20, 200]]\n *\n * _.unzipWith(zipped, _.add);\n * // => [3, 30, 300]\n */\nfunction unzipWith(array, iteratee) {\n  if (!(array && array.length)) {\n    return [];\n  }\n  var result = unzip(array);\n  if (iteratee == null) {\n    return result;\n  }\n  return arrayMap(result, function(group) {\n    return apply(iteratee, undefined, group);\n  });\n}\n\nexport default unzipWith;\n", "import baseGet from './_baseGet.js';\nimport baseSet from './_baseSet.js';\n\n/**\n * The base implementation of `_.update`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to update.\n * @param {Function} updater The function to produce the updated value.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\nfunction baseUpdate(object, path, updater, customizer) {\n  return baseSet(object, path, updater(baseGet(object, path)), customizer);\n}\n\nexport default baseUpdate;\n", "import baseUpdate from './_baseUpdate.js';\nimport castFunction from './_castFunction.js';\n\n/**\n * This method is like `_.set` except that accepts `updater` to produce the\n * value to set. Use `_.updateWith` to customize `path` creation. The `updater`\n * is invoked with one argument: (value).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {Function} updater The function to produce the updated value.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.update(object, 'a[0].b.c', function(n) { return n * n; });\n * console.log(object.a[0].b.c);\n * // => 9\n *\n * _.update(object, 'x[0].y.z', function(n) { return n ? n + 1 : 0; });\n * console.log(object.x[0].y.z);\n * // => 0\n */\nfunction update(object, path, updater) {\n  return object == null ? object : baseUpdate(object, path, castFunction(updater));\n}\n\nexport default update;\n", "import baseUpdate from './_baseUpdate.js';\nimport castFunction from './_castFunction.js';\n\n/**\n * This method is like `_.update` except that it accepts `customizer` which is\n * invoked to produce the objects of `path`.  If `customizer` returns `undefined`\n * path creation is handled by the method instead. The `customizer` is invoked\n * with three arguments: (nsValue, key, nsObject).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {Function} updater The function to produce the updated value.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {};\n *\n * _.updateWith(object, '[0][1]', _.constant('a'), Object);\n * // => { '0': { '1': 'a' } }\n */\nfunction updateWith(object, path, updater, customizer) {\n  customizer = typeof customizer == 'function' ? customizer : undefined;\n  return object == null ? object : baseUpdate(object, path, castFunction(updater), customizer);\n}\n\nexport default updateWith;\n", "import createCompounder from './_createCompounder.js';\n\n/**\n * Converts `string`, as space separated words, to upper case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the upper cased string.\n * @example\n *\n * _.upperCase('--foo-bar');\n * // => 'FOO BAR'\n *\n * _.upperCase('fooBar');\n * // => 'FOO BAR'\n *\n * _.upperCase('__foo_bar__');\n * // => 'FOO BAR'\n */\nvar upperCase = createCompounder(function(result, word, index) {\n  return result + (index ? ' ' : '') + word.toUpperCase();\n});\n\nexport default upperCase;\n", "import baseValues from './_baseValues.js';\nimport keysIn from './keysIn.js';\n\n/**\n * Creates an array of the own and inherited enumerable string keyed property\n * values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.valuesIn(new Foo);\n * // => [1, 2, 3] (iteration order is not guaranteed)\n */\nfunction valuesIn(object) {\n  return object == null ? [] : baseValues(object, keysIn(object));\n}\n\nexport default valuesIn;\n", "import baseDifference from './_baseDifference.js';\nimport baseRest from './_baseRest.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\n\n/**\n * Creates an array excluding all given values using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * **Note:** Unlike `_.pull`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...*} [values] The values to exclude.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.difference, _.xor\n * @example\n *\n * _.without([2, 1, 2, 3], 1, 2);\n * // => [3]\n */\nvar without = baseRest(function(array, values) {\n  return isArrayLikeObject(array)\n    ? baseDifference(array, values)\n    : [];\n});\n\nexport default without;\n", "import castFunction from './_castFunction.js';\nimport partial from './partial.js';\n\n/**\n * Creates a function that provides `value` to `wrapper` as its first\n * argument. Any additional arguments provided to the function are appended\n * to those provided to the `wrapper`. The wrapper is invoked with the `this`\n * binding of the created function.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {*} value The value to wrap.\n * @param {Function} [wrapper=identity] The wrapper function.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var p = _.wrap(_.escape, function(func, text) {\n *   return '<p>' + func(text) + '</p>';\n * });\n *\n * p('fred, barney, & pebbles');\n * // => '<p>fred, barney, &amp; pebbles</p>'\n */\nfunction wrap(value, wrapper) {\n  return partial(castFunction(wrapper), value);\n}\n\nexport default wrap;\n", "import LazyWrapper from './_LazyWrapper.js';\nimport LodashWrapper from './_LodashWrapper.js';\nimport baseAt from './_baseAt.js';\nimport flatRest from './_flatRest.js';\nimport isIndex from './_isIndex.js';\nimport thru from './thru.js';\n\n/**\n * This method is the wrapper version of `_.at`.\n *\n * @name at\n * @memberOf _\n * @since 1.0.0\n * @category Seq\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };\n *\n * _(object).at(['a[0].b.c', 'a[1]']).value();\n * // => [3, 4]\n */\nvar wrapperAt = flatRest(function(paths) {\n  var length = paths.length,\n      start = length ? paths[0] : 0,\n      value = this.__wrapped__,\n      interceptor = function(object) { return baseAt(object, paths); };\n\n  if (length > 1 || this.__actions__.length ||\n      !(value instanceof LazyWrapper) || !isIndex(start)) {\n    return this.thru(interceptor);\n  }\n  value = value.slice(start, +start + (length ? 1 : 0));\n  value.__actions__.push({\n    'func': thru,\n    'args': [interceptor],\n    'thisArg': undefined\n  });\n  return new LodashWrapper(value, this.__chain__).thru(function(array) {\n    if (length && !array.length) {\n      array.push(undefined);\n    }\n    return array;\n  });\n});\n\nexport default wrapperAt;\n", "import chain from './chain.js';\n\n/**\n * Creates a `lodash` wrapper instance with explicit method chain sequences enabled.\n *\n * @name chain\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var users = [\n *   { 'user': 'barney', 'age': 36 },\n *   { 'user': 'fred',   'age': 40 }\n * ];\n *\n * // A sequence without explicit chaining.\n * _(users).head();\n * // => { 'user': 'barney', 'age': 36 }\n *\n * // A sequence with explicit chaining.\n * _(users)\n *   .chain()\n *   .head()\n *   .pick('user')\n *   .value();\n * // => { 'user': 'barney' }\n */\nfunction wrapperChain() {\n  return chain(this);\n}\n\nexport default wrapperChain;\n", "import LazyWrapper from './_LazyWrapper.js';\nimport LodashWrapper from './_LodashWrapper.js';\nimport reverse from './reverse.js';\nimport thru from './thru.js';\n\n/**\n * This method is the wrapper version of `_.reverse`.\n *\n * **Note:** This method mutates the wrapped array.\n *\n * @name reverse\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _(array).reverse().value()\n * // => [3, 2, 1]\n *\n * console.log(array);\n * // => [3, 2, 1]\n */\nfunction wrapperReverse() {\n  var value = this.__wrapped__;\n  if (value instanceof LazyWrapper) {\n    var wrapped = value;\n    if (this.__actions__.length) {\n      wrapped = new LazyWrapper(this);\n    }\n    wrapped = wrapped.reverse();\n    wrapped.__actions__.push({\n      'func': thru,\n      'args': [reverse],\n      'thisArg': undefined\n    });\n    return new LodashWrapper(wrapped, this.__chain__);\n  }\n  return this.thru(reverse);\n}\n\nexport default wrapperReverse;\n", "import baseDifference from './_baseDifference.js';\nimport baseFlatten from './_baseFlatten.js';\nimport baseUniq from './_baseUniq.js';\n\n/**\n * The base implementation of methods like `_.xor`, without support for\n * iteratee shorthands, that accepts an array of arrays to inspect.\n *\n * @private\n * @param {Array} arrays The arrays to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of values.\n */\nfunction baseXor(arrays, iteratee, comparator) {\n  var length = arrays.length;\n  if (length < 2) {\n    return length ? baseUniq(arrays[0]) : [];\n  }\n  var index = -1,\n      result = Array(length);\n\n  while (++index < length) {\n    var array = arrays[index],\n        othIndex = -1;\n\n    while (++othIndex < length) {\n      if (othIndex != index) {\n        result[index] = baseDifference(result[index] || array, arrays[othIndex], iteratee, comparator);\n      }\n    }\n  }\n  return baseUniq(baseFlatten(result, 1), iteratee, comparator);\n}\n\nexport default baseXor;\n", "import arrayFilter from './_arrayFilter.js';\nimport baseRest from './_baseRest.js';\nimport baseXor from './_baseXor.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\n\n/**\n * Creates an array of unique values that is the\n * [symmetric difference](https://en.wikipedia.org/wiki/Symmetric_difference)\n * of the given arrays. The order of result values is determined by the order\n * they occur in the arrays.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.difference, _.without\n * @example\n *\n * _.xor([2, 1], [2, 3]);\n * // => [1, 3]\n */\nvar xor = baseRest(function(arrays) {\n  return baseXor(arrayFilter(arrays, isArrayLikeObject));\n});\n\nexport default xor;\n", "import arrayFilter from './_arrayFilter.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseRest from './_baseRest.js';\nimport baseXor from './_baseXor.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\nimport last from './last.js';\n\n/**\n * This method is like `_.xor` except that it accepts `iteratee` which is\n * invoked for each element of each `arrays` to generate the criterion by\n * which by which they're compared. The order of result values is determined\n * by the order they occur in the arrays. The iteratee is invoked with one\n * argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.xorBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [1.2, 3.4]\n *\n * // The `_.property` iteratee shorthand.\n * _.xorBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 2 }]\n */\nvar xorBy = baseRest(function(arrays) {\n  var iteratee = last(arrays);\n  if (isArrayLikeObject(iteratee)) {\n    iteratee = undefined;\n  }\n  return baseXor(arrayFilter(arrays, isArrayLikeObject), baseIteratee(iteratee, 2));\n});\n\nexport default xorBy;\n", "import arrayFilter from './_arrayFilter.js';\nimport baseRest from './_baseRest.js';\nimport baseXor from './_baseXor.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\nimport last from './last.js';\n\n/**\n * This method is like `_.xor` except that it accepts `comparator` which is\n * invoked to compare elements of `arrays`. The order of result values is\n * determined by the order they occur in the arrays. The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.xorWith(objects, others, _.isEqual);\n * // => [{ 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]\n */\nvar xorWith = baseRest(function(arrays) {\n  var comparator = last(arrays);\n  comparator = typeof comparator == 'function' ? comparator : undefined;\n  return baseXor(arrayFilter(arrays, isArrayLikeObject), undefined, comparator);\n});\n\nexport default xorWith;\n", "import baseRest from './_baseRest.js';\nimport unzip from './unzip.js';\n\n/**\n * Creates an array of grouped elements, the first of which contains the\n * first elements of the given arrays, the second of which contains the\n * second elements of the given arrays, and so on.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to process.\n * @returns {Array} Returns the new array of grouped elements.\n * @example\n *\n * _.zip(['a', 'b'], [1, 2], [true, false]);\n * // => [['a', 1, true], ['b', 2, false]]\n */\nvar zip = baseRest(unzip);\n\nexport default zip;\n", "/**\n * This base implementation of `_.zipObject` which assigns values using `assignFunc`.\n *\n * @private\n * @param {Array} props The property identifiers.\n * @param {Array} values The property values.\n * @param {Function} assignFunc The function to assign values.\n * @returns {Object} Returns the new object.\n */\nfunction baseZipObject(props, values, assignFunc) {\n  var index = -1,\n      length = props.length,\n      valsLength = values.length,\n      result = {};\n\n  while (++index < length) {\n    var value = index < valsLength ? values[index] : undefined;\n    assignFunc(result, props[index], value);\n  }\n  return result;\n}\n\nexport default baseZipObject;\n", "import assignValue from './_assignValue.js';\nimport baseZipObject from './_baseZipObject.js';\n\n/**\n * This method is like `_.fromPairs` except that it accepts two arrays,\n * one of property identifiers and one of corresponding values.\n *\n * @static\n * @memberOf _\n * @since 0.4.0\n * @category Array\n * @param {Array} [props=[]] The property identifiers.\n * @param {Array} [values=[]] The property values.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.zipObject(['a', 'b'], [1, 2]);\n * // => { 'a': 1, 'b': 2 }\n */\nfunction zipObject(props, values) {\n  return baseZipObject(props || [], values || [], assignValue);\n}\n\nexport default zipObject;\n", "import baseSet from './_baseSet.js';\nimport baseZipObject from './_baseZipObject.js';\n\n/**\n * This method is like `_.zipObject` except that it supports property paths.\n *\n * @static\n * @memberOf _\n * @since 4.1.0\n * @category Array\n * @param {Array} [props=[]] The property identifiers.\n * @param {Array} [values=[]] The property values.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.zipObjectDeep(['a.b[0].c', 'a.b[1].d'], [1, 2]);\n * // => { 'a': { 'b': [{ 'c': 1 }, { 'd': 2 }] } }\n */\nfunction zipObjectDeep(props, values) {\n  return baseZipObject(props || [], values || [], baseSet);\n}\n\nexport default zipObjectDeep;\n", "import baseRest from './_baseRest.js';\nimport unzipWith from './unzipWith.js';\n\n/**\n * This method is like `_.zip` except that it accepts `iteratee` to specify\n * how grouped values should be combined. The iteratee is invoked with the\n * elements of each group: (...group).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Array\n * @param {...Array} [arrays] The arrays to process.\n * @param {Function} [iteratee=_.identity] The function to combine\n *  grouped values.\n * @returns {Array} Returns the new array of grouped elements.\n * @example\n *\n * _.zipWith([1, 2], [10, 20], [100, 200], function(a, b, c) {\n *   return a + b + c;\n * });\n * // => [111, 222]\n */\nvar zipWith = baseRest(function(arrays) {\n  var length = arrays.length,\n      iteratee = length > 1 ? arrays[length - 1] : undefined;\n\n  iteratee = typeof iteratee == 'function' ? (arrays.pop(), iteratee) : undefined;\n  return unzipWith(arrays, iteratee);\n});\n\nexport default zipWith;\n", "import chunk from './chunk.js';\nimport compact from './compact.js';\nimport concat from './concat.js';\nimport difference from './difference.js';\nimport differenceBy from './differenceBy.js';\nimport differenceWith from './differenceWith.js';\nimport drop from './drop.js';\nimport dropRight from './dropRight.js';\nimport dropRightWhile from './dropRightWhile.js';\nimport dropWhile from './dropWhile.js';\nimport fill from './fill.js';\nimport findIndex from './findIndex.js';\nimport findLastIndex from './findLastIndex.js';\nimport first from './first.js';\nimport flatten from './flatten.js';\nimport flattenDeep from './flattenDeep.js';\nimport flattenDepth from './flattenDepth.js';\nimport fromPairs from './fromPairs.js';\nimport head from './head.js';\nimport indexOf from './indexOf.js';\nimport initial from './initial.js';\nimport intersection from './intersection.js';\nimport intersectionBy from './intersectionBy.js';\nimport intersectionWith from './intersectionWith.js';\nimport join from './join.js';\nimport last from './last.js';\nimport lastIndexOf from './lastIndexOf.js';\nimport nth from './nth.js';\nimport pull from './pull.js';\nimport pullAll from './pullAll.js';\nimport pullAllBy from './pullAllBy.js';\nimport pullAllWith from './pullAllWith.js';\nimport pullAt from './pullAt.js';\nimport remove from './remove.js';\nimport reverse from './reverse.js';\nimport slice from './slice.js';\nimport sortedIndex from './sortedIndex.js';\nimport sortedIndexBy from './sortedIndexBy.js';\nimport sortedIndexOf from './sortedIndexOf.js';\nimport sortedLastIndex from './sortedLastIndex.js';\nimport sortedLastIndexBy from './sortedLastIndexBy.js';\nimport sortedLastIndexOf from './sortedLastIndexOf.js';\nimport sortedUniq from './sortedUniq.js';\nimport sortedUniqBy from './sortedUniqBy.js';\nimport tail from './tail.js';\nimport take from './take.js';\nimport takeRight from './takeRight.js';\nimport takeRightWhile from './takeRightWhile.js';\nimport takeWhile from './takeWhile.js';\nimport union from './union.js';\nimport unionBy from './unionBy.js';\nimport unionWith from './unionWith.js';\nimport uniq from './uniq.js';\nimport uniqBy from './uniqBy.js';\nimport uniqWith from './uniqWith.js';\nimport unzip from './unzip.js';\nimport unzipWith from './unzipWith.js';\nimport without from './without.js';\nimport xor from './xor.js';\nimport xorBy from './xorBy.js';\nimport xorWith from './xorWith.js';\nimport zip from './zip.js';\nimport zipObject from './zipObject.js';\nimport zipObjectDeep from './zipObjectDeep.js';\nimport zipWith from './zipWith.js';\n\nexport default {\n  chunk, compact, concat, difference, differenceBy,\n  differenceWith, drop, dropRight, dropRightWhile, dropWhile,\n  fill, findIndex, findLastIndex, first, flatten,\n  flattenDeep, flattenDepth, fromPairs, head, indexOf,\n  initial, intersection, intersectionBy, intersectionWith, join,\n  last, lastIndexOf, nth, pull, pullAll,\n  pullAllBy, pullAllWith, pullAt, remove, reverse,\n  slice, sortedIndex, sortedIndexBy, sortedIndexOf, sortedLastIndex,\n  sortedLastIndexBy, sortedLastIndexOf, sortedUniq, sortedUniqBy, tail,\n  take, takeRight, takeRightWhile, takeWhile, union,\n  unionBy, unionWith, uniq, uniqBy, uniqWith,\n  unzip, unzipWith, without, xor, xorBy,\n  xorWith, zip, zipObject, zipObjectDeep, zipWith\n};\n", "import countBy from './countBy.js';\nimport each from './each.js';\nimport eachRight from './eachRight.js';\nimport every from './every.js';\nimport filter from './filter.js';\nimport find from './find.js';\nimport findLast from './findLast.js';\nimport flatMap from './flatMap.js';\nimport flatMapDeep from './flatMapDeep.js';\nimport flatMapDepth from './flatMapDepth.js';\nimport forEach from './forEach.js';\nimport forEachRight from './forEachRight.js';\nimport groupBy from './groupBy.js';\nimport includes from './includes.js';\nimport invokeMap from './invokeMap.js';\nimport keyBy from './keyBy.js';\nimport map from './map.js';\nimport orderBy from './orderBy.js';\nimport partition from './partition.js';\nimport reduce from './reduce.js';\nimport reduceRight from './reduceRight.js';\nimport reject from './reject.js';\nimport sample from './sample.js';\nimport sampleSize from './sampleSize.js';\nimport shuffle from './shuffle.js';\nimport size from './size.js';\nimport some from './some.js';\nimport sortBy from './sortBy.js';\n\nexport default {\n  countBy, each, eachRight, every, filter,\n  find, findLast, flatMap, flatMapDeep, flatMapDepth,\n  forEach, forEachRight, groupBy, includes, invokeMap,\n  keyBy, map, orderBy, partition, reduce,\n  reduceRight, reject, sample, sampleSize, shuffle,\n  size, some, sortBy\n};\n", "import now from './now.js';\n\nexport default {\n  now\n};\n", "import after from './after.js';\nimport ary from './ary.js';\nimport before from './before.js';\nimport bind from './bind.js';\nimport bindKey from './bindKey.js';\nimport curry from './curry.js';\nimport curryRight from './curryRight.js';\nimport debounce from './debounce.js';\nimport defer from './defer.js';\nimport delay from './delay.js';\nimport flip from './flip.js';\nimport memoize from './memoize.js';\nimport negate from './negate.js';\nimport once from './once.js';\nimport overArgs from './overArgs.js';\nimport partial from './partial.js';\nimport partialRight from './partialRight.js';\nimport rearg from './rearg.js';\nimport rest from './rest.js';\nimport spread from './spread.js';\nimport throttle from './throttle.js';\nimport unary from './unary.js';\nimport wrap from './wrap.js';\n\nexport default {\n  after, ary, before, bind, bindKey,\n  curry, curryRight, debounce, defer, delay,\n  flip, memoize, negate, once, overArgs,\n  partial, partialRight, rearg, rest, spread,\n  throttle, unary, wrap\n};\n", "import castArray from './castArray.js';\nimport clone from './clone.js';\nimport cloneDeep from './cloneDeep.js';\nimport cloneDeepWith from './cloneDeepWith.js';\nimport cloneWith from './cloneWith.js';\nimport conformsTo from './conformsTo.js';\nimport eq from './eq.js';\nimport gt from './gt.js';\nimport gte from './gte.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isArrayBuffer from './isArrayBuffer.js';\nimport isArrayLike from './isArrayLike.js';\nimport isArrayLikeObject from './isArrayLikeObject.js';\nimport isBoolean from './isBoolean.js';\nimport isBuffer from './isBuffer.js';\nimport isDate from './isDate.js';\nimport isElement from './isElement.js';\nimport isEmpty from './isEmpty.js';\nimport isEqual from './isEqual.js';\nimport isEqualWith from './isEqualWith.js';\nimport isError from './isError.js';\nimport isFinite from './isFinite.js';\nimport isFunction from './isFunction.js';\nimport isInteger from './isInteger.js';\nimport isLength from './isLength.js';\nimport isMap from './isMap.js';\nimport isMatch from './isMatch.js';\nimport isMatchWith from './isMatchWith.js';\nimport isNaN from './isNaN.js';\nimport isNative from './isNative.js';\nimport isNil from './isNil.js';\nimport isNull from './isNull.js';\nimport isNumber from './isNumber.js';\nimport isObject from './isObject.js';\nimport isObjectLike from './isObjectLike.js';\nimport isPlainObject from './isPlainObject.js';\nimport isRegExp from './isRegExp.js';\nimport isSafeInteger from './isSafeInteger.js';\nimport isSet from './isSet.js';\nimport isString from './isString.js';\nimport isSymbol from './isSymbol.js';\nimport isTypedArray from './isTypedArray.js';\nimport isUndefined from './isUndefined.js';\nimport isWeakMap from './isWeakMap.js';\nimport isWeakSet from './isWeakSet.js';\nimport lt from './lt.js';\nimport lte from './lte.js';\nimport toArray from './toArray.js';\nimport toFinite from './toFinite.js';\nimport toInteger from './toInteger.js';\nimport toLength from './toLength.js';\nimport toNumber from './toNumber.js';\nimport toPlainObject from './toPlainObject.js';\nimport toSafeInteger from './toSafeInteger.js';\nimport toString from './toString.js';\n\nexport default {\n  castArray, clone, cloneDeep, cloneDeepWith, cloneWith,\n  conformsTo, eq, gt, gte, isArguments,\n  isArray, isArrayBuffer, isArrayLike, isArrayLikeObject, isBoolean,\n  isBuffer, isDate, isElement, isEmpty, isEqual,\n  isEqualWith, isError, isFinite, isFunction, isInteger,\n  isLength, isMap, isMatch, isMatchWith, isNaN,\n  isNative, isNil, isNull, isNumber, isObject,\n  isObjectLike, isPlainObject, isRegExp, isSafeInteger, isSet,\n  isString, isSymbol, isTypedArray, isUndefined, isWeakMap,\n  isWeakSet, lt, lte, toArray, toFinite,\n  toInteger, toLength, toNumber, toPlainObject, toSafeInteger,\n  toString\n};\n", "import add from './add.js';\nimport ceil from './ceil.js';\nimport divide from './divide.js';\nimport floor from './floor.js';\nimport max from './max.js';\nimport maxBy from './maxBy.js';\nimport mean from './mean.js';\nimport meanBy from './meanBy.js';\nimport min from './min.js';\nimport minBy from './minBy.js';\nimport multiply from './multiply.js';\nimport round from './round.js';\nimport subtract from './subtract.js';\nimport sum from './sum.js';\nimport sumBy from './sumBy.js';\n\nexport default {\n  add, ceil, divide, floor, max,\n  maxBy, mean, meanBy, min, minBy,\n  multiply, round, subtract, sum, sumBy\n};\n", "import clamp from './clamp.js';\nimport inRange from './inRange.js';\nimport random from './random.js';\n\nexport default {\n  clamp, inRange, random\n};\n", "import assign from './assign.js';\nimport assignIn from './assignIn.js';\nimport assignInWith from './assignInWith.js';\nimport assignWith from './assignWith.js';\nimport at from './at.js';\nimport create from './create.js';\nimport defaults from './defaults.js';\nimport defaultsDeep from './defaultsDeep.js';\nimport entries from './entries.js';\nimport entriesIn from './entriesIn.js';\nimport extend from './extend.js';\nimport extendWith from './extendWith.js';\nimport findKey from './findKey.js';\nimport findLastKey from './findLastKey.js';\nimport forIn from './forIn.js';\nimport forInRight from './forInRight.js';\nimport forOwn from './forOwn.js';\nimport forOwnRight from './forOwnRight.js';\nimport functions from './functions.js';\nimport functionsIn from './functionsIn.js';\nimport get from './get.js';\nimport has from './has.js';\nimport hasIn from './hasIn.js';\nimport invert from './invert.js';\nimport invertBy from './invertBy.js';\nimport invoke from './invoke.js';\nimport keys from './keys.js';\nimport keysIn from './keysIn.js';\nimport mapKeys from './mapKeys.js';\nimport mapValues from './mapValues.js';\nimport merge from './merge.js';\nimport mergeWith from './mergeWith.js';\nimport omit from './omit.js';\nimport omitBy from './omitBy.js';\nimport pick from './pick.js';\nimport pickBy from './pickBy.js';\nimport result from './result.js';\nimport set from './set.js';\nimport setWith from './setWith.js';\nimport toPairs from './toPairs.js';\nimport toPairsIn from './toPairsIn.js';\nimport transform from './transform.js';\nimport unset from './unset.js';\nimport update from './update.js';\nimport updateWith from './updateWith.js';\nimport values from './values.js';\nimport valuesIn from './valuesIn.js';\n\nexport default {\n  assign, assignIn, assignInWith, assignWith, at,\n  create, defaults, defaultsDeep, entries, entriesIn,\n  extend, extendWith, findKey, findLastKey, forIn,\n  forInRight, forOwn, forOwnRight, functions, functionsIn,\n  get, has, hasIn, invert, invertBy,\n  invoke, keys, keysIn, mapKeys, mapValues,\n  merge, mergeWith, omit, omitBy, pick,\n  pickBy, result, set, setWith, toPairs,\n  toPairsIn, transform, unset, update, updateWith,\n  values, valuesIn\n};\n", "import at from './wrapperAt.js';\nimport chain from './chain.js';\nimport commit from './commit.js';\nimport lodash from './wrapperLodash.js';\nimport next from './next.js';\nimport plant from './plant.js';\nimport reverse from './wrapperReverse.js';\nimport tap from './tap.js';\nimport thru from './thru.js';\nimport toIterator from './toIterator.js';\nimport toJSON from './toJSON.js';\nimport value from './wrapperValue.js';\nimport valueOf from './valueOf.js';\nimport wrapperChain from './wrapperChain.js';\n\nexport default {\n  at, chain, commit, lodash, next,\n  plant, reverse, tap, thru, toIterator,\n  toJSON, value, valueOf, wrapperChain\n};\n", "import camelCase from './camelCase.js';\nimport capitalize from './capitalize.js';\nimport deburr from './deburr.js';\nimport endsWith from './endsWith.js';\nimport escape from './escape.js';\nimport escapeRegExp from './escapeRegExp.js';\nimport kebabCase from './kebabCase.js';\nimport lowerCase from './lowerCase.js';\nimport lowerFirst from './lowerFirst.js';\nimport pad from './pad.js';\nimport padEnd from './padEnd.js';\nimport padStart from './padStart.js';\nimport parseInt from './parseInt.js';\nimport repeat from './repeat.js';\nimport replace from './replace.js';\nimport snakeCase from './snakeCase.js';\nimport split from './split.js';\nimport startCase from './startCase.js';\nimport startsWith from './startsWith.js';\nimport template from './template.js';\nimport templateSettings from './templateSettings.js';\nimport toLower from './toLower.js';\nimport toUpper from './toUpper.js';\nimport trim from './trim.js';\nimport trimEnd from './trimEnd.js';\nimport trimStart from './trimStart.js';\nimport truncate from './truncate.js';\nimport unescape from './unescape.js';\nimport upperCase from './upperCase.js';\nimport upperFirst from './upperFirst.js';\nimport words from './words.js';\n\nexport default {\n  camelCase, capitalize, deburr, endsWith, escape,\n  escapeRegExp, kebabCase, lowerCase, lowerFirst, pad,\n  padEnd, padStart, parseInt, repeat, replace,\n  snakeCase, split, startCase, startsWith, template,\n  templateSettings, toLower, toUpper, trim, trimEnd,\n  trimStart, truncate, unescape, upperCase, upperFirst,\n  words\n};\n", "import attempt from './attempt.js';\nimport bindAll from './bindAll.js';\nimport cond from './cond.js';\nimport conforms from './conforms.js';\nimport constant from './constant.js';\nimport defaultTo from './defaultTo.js';\nimport flow from './flow.js';\nimport flowRight from './flowRight.js';\nimport identity from './identity.js';\nimport iteratee from './iteratee.js';\nimport matches from './matches.js';\nimport matchesProperty from './matchesProperty.js';\nimport method from './method.js';\nimport methodOf from './methodOf.js';\nimport mixin from './mixin.js';\nimport noop from './noop.js';\nimport nthArg from './nthArg.js';\nimport over from './over.js';\nimport overEvery from './overEvery.js';\nimport overSome from './overSome.js';\nimport property from './property.js';\nimport propertyOf from './propertyOf.js';\nimport range from './range.js';\nimport rangeRight from './rangeRight.js';\nimport stubArray from './stubArray.js';\nimport stubFalse from './stubFalse.js';\nimport stubObject from './stubObject.js';\nimport stubString from './stubString.js';\nimport stubTrue from './stubTrue.js';\nimport times from './times.js';\nimport toPath from './toPath.js';\nimport uniqueId from './uniqueId.js';\n\nexport default {\n  attempt, bindAll, cond, conforms, constant,\n  defaultTo, flow, flowRight, identity, iteratee,\n  matches, matchesProperty, method, methodOf, mixin,\n  noop, nthArg, over, overEvery, overSome,\n  property, propertyOf, range, rangeRight, stubArray,\n  stubFalse, stubObject, stubString, stubTrue, times,\n  toPath, uniqueId\n};\n", "import LazyWrapper from './_LazyWrapper.js';\nimport copyArray from './_copyArray.js';\n\n/**\n * Creates a clone of the lazy wrapper object.\n *\n * @private\n * @name clone\n * @memberOf LazyWrapper\n * @returns {Object} Returns the cloned `LazyWrapper` object.\n */\nfunction lazyClone() {\n  var result = new LazyWrapper(this.__wrapped__);\n  result.__actions__ = copyArray(this.__actions__);\n  result.__dir__ = this.__dir__;\n  result.__filtered__ = this.__filtered__;\n  result.__iteratees__ = copyArray(this.__iteratees__);\n  result.__takeCount__ = this.__takeCount__;\n  result.__views__ = copyArray(this.__views__);\n  return result;\n}\n\nexport default lazyClone;\n", "import LazyWrapper from './_LazyWrapper.js';\n\n/**\n * Reverses the direction of lazy iteration.\n *\n * @private\n * @name reverse\n * @memberOf LazyWrapper\n * @returns {Object} Returns the new reversed `LazyWrapper` object.\n */\nfunction lazyReverse() {\n  if (this.__filtered__) {\n    var result = new LazyWrapper(this);\n    result.__dir__ = -1;\n    result.__filtered__ = true;\n  } else {\n    result = this.clone();\n    result.__dir__ *= -1;\n  }\n  return result;\n}\n\nexport default lazyReverse;\n", "/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n    nativeMin = Math.min;\n\n/**\n * Gets the view, applying any `transforms` to the `start` and `end` positions.\n *\n * @private\n * @param {number} start The start of the view.\n * @param {number} end The end of the view.\n * @param {Array} transforms The transformations to apply to the view.\n * @returns {Object} Returns an object containing the `start` and `end`\n *  positions of the view.\n */\nfunction getView(start, end, transforms) {\n  var index = -1,\n      length = transforms.length;\n\n  while (++index < length) {\n    var data = transforms[index],\n        size = data.size;\n\n    switch (data.type) {\n      case 'drop':      start += size; break;\n      case 'dropRight': end -= size; break;\n      case 'take':      end = nativeMin(end, start + size); break;\n      case 'takeRight': start = nativeMax(start, end - size); break;\n    }\n  }\n  return { 'start': start, 'end': end };\n}\n\nexport default getView;\n", "import baseWrapperValue from './_baseWrapperValue.js';\nimport getView from './_getView.js';\nimport isArray from './isArray.js';\n\n/** Used to indicate the type of lazy iteratees. */\nvar LAZY_FILTER_FLAG = 1,\n    LAZY_MAP_FLAG = 2;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMin = Math.min;\n\n/**\n * Extracts the unwrapped value from its lazy wrapper.\n *\n * @private\n * @name value\n * @memberOf LazyWrapper\n * @returns {*} Returns the unwrapped value.\n */\nfunction lazyValue() {\n  var array = this.__wrapped__.value(),\n      dir = this.__dir__,\n      isArr = isArray(array),\n      isRight = dir < 0,\n      arrLength = isArr ? array.length : 0,\n      view = getView(0, arrLength, this.__views__),\n      start = view.start,\n      end = view.end,\n      length = end - start,\n      index = isRight ? end : (start - 1),\n      iteratees = this.__iteratees__,\n      iterLength = iteratees.length,\n      resIndex = 0,\n      takeCount = nativeMin(length, this.__takeCount__);\n\n  if (!isArr || (!isRight && arrLength == length && takeCount == length)) {\n    return baseWrapperValue(array, this.__actions__);\n  }\n  var result = [];\n\n  outer:\n  while (length-- && resIndex < takeCount) {\n    index += dir;\n\n    var iterIndex = -1,\n        value = array[index];\n\n    while (++iterIndex < iterLength) {\n      var data = iteratees[iterIndex],\n          iteratee = data.iteratee,\n          type = data.type,\n          computed = iteratee(value);\n\n      if (type == LAZY_MAP_FLAG) {\n        value = computed;\n      } else if (!computed) {\n        if (type == LAZY_FILTER_FLAG) {\n          continue outer;\n        } else {\n          break outer;\n        }\n      }\n    }\n    result[resIndex++] = value;\n  }\n  return result;\n}\n\nexport default lazyValue;\n", "/**\n * @license\n * Lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"es\" -o ./`\n * Copyright OpenJS Foundation and other contributors <https://openjsf.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\nimport array from './array.js';\nimport collection from './collection.js';\nimport date from './date.js';\nimport func from './function.js';\nimport lang from './lang.js';\nimport math from './math.js';\nimport number from './number.js';\nimport object from './object.js';\nimport seq from './seq.js';\nimport string from './string.js';\nimport util from './util.js';\nimport LazyWrapper from './_LazyWrapper.js';\nimport LodashWrapper from './_LodashWrapper.js';\nimport Symbol from './_Symbol.js';\nimport arrayEach from './_arrayEach.js';\nimport arrayPush from './_arrayPush.js';\nimport baseForOwn from './_baseForOwn.js';\nimport baseFunctions from './_baseFunctions.js';\nimport baseInvoke from './_baseInvoke.js';\nimport baseIteratee from './_baseIteratee.js';\nimport baseRest from './_baseRest.js';\nimport createHybrid from './_createHybrid.js';\nimport identity from './identity.js';\nimport isArray from './isArray.js';\nimport isObject from './isObject.js';\nimport keys from './keys.js';\nimport last from './last.js';\nimport lazyClone from './_lazyClone.js';\nimport lazyReverse from './_lazyReverse.js';\nimport lazyValue from './_lazyValue.js';\nimport _mixin from './mixin.js';\nimport negate from './negate.js';\nimport realNames from './_realNames.js';\nimport thru from './thru.js';\nimport toInteger from './toInteger.js';\nimport lodash from './wrapperLodash.js';\n\n/** Used as the semantic version number. */\nvar VERSION = '4.17.21';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_KEY_FLAG = 2;\n\n/** Used to indicate the type of lazy iteratees. */\nvar LAZY_FILTER_FLAG = 1,\n    LAZY_WHILE_FLAG = 3;\n\n/** Used as references for the maximum length and index of an array. */\nvar MAX_ARRAY_LENGTH = 4294967295;\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n    objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar symIterator = Symbol ? Symbol.iterator : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n    nativeMin = Math.min;\n\n// wrap `_.mixin` so it works when provided only one argument\nvar mixin = (function(func) {\n  return function(object, source, options) {\n    if (options == null) {\n      var isObj = isObject(source),\n          props = isObj && keys(source),\n          methodNames = props && props.length && baseFunctions(source, props);\n\n      if (!(methodNames ? methodNames.length : isObj)) {\n        options = source;\n        source = object;\n        object = this;\n      }\n    }\n    return func(object, source, options);\n  };\n}(_mixin));\n\n// Add methods that return wrapped values in chain sequences.\nlodash.after = func.after;\nlodash.ary = func.ary;\nlodash.assign = object.assign;\nlodash.assignIn = object.assignIn;\nlodash.assignInWith = object.assignInWith;\nlodash.assignWith = object.assignWith;\nlodash.at = object.at;\nlodash.before = func.before;\nlodash.bind = func.bind;\nlodash.bindAll = util.bindAll;\nlodash.bindKey = func.bindKey;\nlodash.castArray = lang.castArray;\nlodash.chain = seq.chain;\nlodash.chunk = array.chunk;\nlodash.compact = array.compact;\nlodash.concat = array.concat;\nlodash.cond = util.cond;\nlodash.conforms = util.conforms;\nlodash.constant = util.constant;\nlodash.countBy = collection.countBy;\nlodash.create = object.create;\nlodash.curry = func.curry;\nlodash.curryRight = func.curryRight;\nlodash.debounce = func.debounce;\nlodash.defaults = object.defaults;\nlodash.defaultsDeep = object.defaultsDeep;\nlodash.defer = func.defer;\nlodash.delay = func.delay;\nlodash.difference = array.difference;\nlodash.differenceBy = array.differenceBy;\nlodash.differenceWith = array.differenceWith;\nlodash.drop = array.drop;\nlodash.dropRight = array.dropRight;\nlodash.dropRightWhile = array.dropRightWhile;\nlodash.dropWhile = array.dropWhile;\nlodash.fill = array.fill;\nlodash.filter = collection.filter;\nlodash.flatMap = collection.flatMap;\nlodash.flatMapDeep = collection.flatMapDeep;\nlodash.flatMapDepth = collection.flatMapDepth;\nlodash.flatten = array.flatten;\nlodash.flattenDeep = array.flattenDeep;\nlodash.flattenDepth = array.flattenDepth;\nlodash.flip = func.flip;\nlodash.flow = util.flow;\nlodash.flowRight = util.flowRight;\nlodash.fromPairs = array.fromPairs;\nlodash.functions = object.functions;\nlodash.functionsIn = object.functionsIn;\nlodash.groupBy = collection.groupBy;\nlodash.initial = array.initial;\nlodash.intersection = array.intersection;\nlodash.intersectionBy = array.intersectionBy;\nlodash.intersectionWith = array.intersectionWith;\nlodash.invert = object.invert;\nlodash.invertBy = object.invertBy;\nlodash.invokeMap = collection.invokeMap;\nlodash.iteratee = util.iteratee;\nlodash.keyBy = collection.keyBy;\nlodash.keys = keys;\nlodash.keysIn = object.keysIn;\nlodash.map = collection.map;\nlodash.mapKeys = object.mapKeys;\nlodash.mapValues = object.mapValues;\nlodash.matches = util.matches;\nlodash.matchesProperty = util.matchesProperty;\nlodash.memoize = func.memoize;\nlodash.merge = object.merge;\nlodash.mergeWith = object.mergeWith;\nlodash.method = util.method;\nlodash.methodOf = util.methodOf;\nlodash.mixin = mixin;\nlodash.negate = negate;\nlodash.nthArg = util.nthArg;\nlodash.omit = object.omit;\nlodash.omitBy = object.omitBy;\nlodash.once = func.once;\nlodash.orderBy = collection.orderBy;\nlodash.over = util.over;\nlodash.overArgs = func.overArgs;\nlodash.overEvery = util.overEvery;\nlodash.overSome = util.overSome;\nlodash.partial = func.partial;\nlodash.partialRight = func.partialRight;\nlodash.partition = collection.partition;\nlodash.pick = object.pick;\nlodash.pickBy = object.pickBy;\nlodash.property = util.property;\nlodash.propertyOf = util.propertyOf;\nlodash.pull = array.pull;\nlodash.pullAll = array.pullAll;\nlodash.pullAllBy = array.pullAllBy;\nlodash.pullAllWith = array.pullAllWith;\nlodash.pullAt = array.pullAt;\nlodash.range = util.range;\nlodash.rangeRight = util.rangeRight;\nlodash.rearg = func.rearg;\nlodash.reject = collection.reject;\nlodash.remove = array.remove;\nlodash.rest = func.rest;\nlodash.reverse = array.reverse;\nlodash.sampleSize = collection.sampleSize;\nlodash.set = object.set;\nlodash.setWith = object.setWith;\nlodash.shuffle = collection.shuffle;\nlodash.slice = array.slice;\nlodash.sortBy = collection.sortBy;\nlodash.sortedUniq = array.sortedUniq;\nlodash.sortedUniqBy = array.sortedUniqBy;\nlodash.split = string.split;\nlodash.spread = func.spread;\nlodash.tail = array.tail;\nlodash.take = array.take;\nlodash.takeRight = array.takeRight;\nlodash.takeRightWhile = array.takeRightWhile;\nlodash.takeWhile = array.takeWhile;\nlodash.tap = seq.tap;\nlodash.throttle = func.throttle;\nlodash.thru = thru;\nlodash.toArray = lang.toArray;\nlodash.toPairs = object.toPairs;\nlodash.toPairsIn = object.toPairsIn;\nlodash.toPath = util.toPath;\nlodash.toPlainObject = lang.toPlainObject;\nlodash.transform = object.transform;\nlodash.unary = func.unary;\nlodash.union = array.union;\nlodash.unionBy = array.unionBy;\nlodash.unionWith = array.unionWith;\nlodash.uniq = array.uniq;\nlodash.uniqBy = array.uniqBy;\nlodash.uniqWith = array.uniqWith;\nlodash.unset = object.unset;\nlodash.unzip = array.unzip;\nlodash.unzipWith = array.unzipWith;\nlodash.update = object.update;\nlodash.updateWith = object.updateWith;\nlodash.values = object.values;\nlodash.valuesIn = object.valuesIn;\nlodash.without = array.without;\nlodash.words = string.words;\nlodash.wrap = func.wrap;\nlodash.xor = array.xor;\nlodash.xorBy = array.xorBy;\nlodash.xorWith = array.xorWith;\nlodash.zip = array.zip;\nlodash.zipObject = array.zipObject;\nlodash.zipObjectDeep = array.zipObjectDeep;\nlodash.zipWith = array.zipWith;\n\n// Add aliases.\nlodash.entries = object.toPairs;\nlodash.entriesIn = object.toPairsIn;\nlodash.extend = object.assignIn;\nlodash.extendWith = object.assignInWith;\n\n// Add methods to `lodash.prototype`.\nmixin(lodash, lodash);\n\n// Add methods that return unwrapped values in chain sequences.\nlodash.add = math.add;\nlodash.attempt = util.attempt;\nlodash.camelCase = string.camelCase;\nlodash.capitalize = string.capitalize;\nlodash.ceil = math.ceil;\nlodash.clamp = number.clamp;\nlodash.clone = lang.clone;\nlodash.cloneDeep = lang.cloneDeep;\nlodash.cloneDeepWith = lang.cloneDeepWith;\nlodash.cloneWith = lang.cloneWith;\nlodash.conformsTo = lang.conformsTo;\nlodash.deburr = string.deburr;\nlodash.defaultTo = util.defaultTo;\nlodash.divide = math.divide;\nlodash.endsWith = string.endsWith;\nlodash.eq = lang.eq;\nlodash.escape = string.escape;\nlodash.escapeRegExp = string.escapeRegExp;\nlodash.every = collection.every;\nlodash.find = collection.find;\nlodash.findIndex = array.findIndex;\nlodash.findKey = object.findKey;\nlodash.findLast = collection.findLast;\nlodash.findLastIndex = array.findLastIndex;\nlodash.findLastKey = object.findLastKey;\nlodash.floor = math.floor;\nlodash.forEach = collection.forEach;\nlodash.forEachRight = collection.forEachRight;\nlodash.forIn = object.forIn;\nlodash.forInRight = object.forInRight;\nlodash.forOwn = object.forOwn;\nlodash.forOwnRight = object.forOwnRight;\nlodash.get = object.get;\nlodash.gt = lang.gt;\nlodash.gte = lang.gte;\nlodash.has = object.has;\nlodash.hasIn = object.hasIn;\nlodash.head = array.head;\nlodash.identity = identity;\nlodash.includes = collection.includes;\nlodash.indexOf = array.indexOf;\nlodash.inRange = number.inRange;\nlodash.invoke = object.invoke;\nlodash.isArguments = lang.isArguments;\nlodash.isArray = isArray;\nlodash.isArrayBuffer = lang.isArrayBuffer;\nlodash.isArrayLike = lang.isArrayLike;\nlodash.isArrayLikeObject = lang.isArrayLikeObject;\nlodash.isBoolean = lang.isBoolean;\nlodash.isBuffer = lang.isBuffer;\nlodash.isDate = lang.isDate;\nlodash.isElement = lang.isElement;\nlodash.isEmpty = lang.isEmpty;\nlodash.isEqual = lang.isEqual;\nlodash.isEqualWith = lang.isEqualWith;\nlodash.isError = lang.isError;\nlodash.isFinite = lang.isFinite;\nlodash.isFunction = lang.isFunction;\nlodash.isInteger = lang.isInteger;\nlodash.isLength = lang.isLength;\nlodash.isMap = lang.isMap;\nlodash.isMatch = lang.isMatch;\nlodash.isMatchWith = lang.isMatchWith;\nlodash.isNaN = lang.isNaN;\nlodash.isNative = lang.isNative;\nlodash.isNil = lang.isNil;\nlodash.isNull = lang.isNull;\nlodash.isNumber = lang.isNumber;\nlodash.isObject = isObject;\nlodash.isObjectLike = lang.isObjectLike;\nlodash.isPlainObject = lang.isPlainObject;\nlodash.isRegExp = lang.isRegExp;\nlodash.isSafeInteger = lang.isSafeInteger;\nlodash.isSet = lang.isSet;\nlodash.isString = lang.isString;\nlodash.isSymbol = lang.isSymbol;\nlodash.isTypedArray = lang.isTypedArray;\nlodash.isUndefined = lang.isUndefined;\nlodash.isWeakMap = lang.isWeakMap;\nlodash.isWeakSet = lang.isWeakSet;\nlodash.join = array.join;\nlodash.kebabCase = string.kebabCase;\nlodash.last = last;\nlodash.lastIndexOf = array.lastIndexOf;\nlodash.lowerCase = string.lowerCase;\nlodash.lowerFirst = string.lowerFirst;\nlodash.lt = lang.lt;\nlodash.lte = lang.lte;\nlodash.max = math.max;\nlodash.maxBy = math.maxBy;\nlodash.mean = math.mean;\nlodash.meanBy = math.meanBy;\nlodash.min = math.min;\nlodash.minBy = math.minBy;\nlodash.stubArray = util.stubArray;\nlodash.stubFalse = util.stubFalse;\nlodash.stubObject = util.stubObject;\nlodash.stubString = util.stubString;\nlodash.stubTrue = util.stubTrue;\nlodash.multiply = math.multiply;\nlodash.nth = array.nth;\nlodash.noop = util.noop;\nlodash.now = date.now;\nlodash.pad = string.pad;\nlodash.padEnd = string.padEnd;\nlodash.padStart = string.padStart;\nlodash.parseInt = string.parseInt;\nlodash.random = number.random;\nlodash.reduce = collection.reduce;\nlodash.reduceRight = collection.reduceRight;\nlodash.repeat = string.repeat;\nlodash.replace = string.replace;\nlodash.result = object.result;\nlodash.round = math.round;\nlodash.sample = collection.sample;\nlodash.size = collection.size;\nlodash.snakeCase = string.snakeCase;\nlodash.some = collection.some;\nlodash.sortedIndex = array.sortedIndex;\nlodash.sortedIndexBy = array.sortedIndexBy;\nlodash.sortedIndexOf = array.sortedIndexOf;\nlodash.sortedLastIndex = array.sortedLastIndex;\nlodash.sortedLastIndexBy = array.sortedLastIndexBy;\nlodash.sortedLastIndexOf = array.sortedLastIndexOf;\nlodash.startCase = string.startCase;\nlodash.startsWith = string.startsWith;\nlodash.subtract = math.subtract;\nlodash.sum = math.sum;\nlodash.sumBy = math.sumBy;\nlodash.template = string.template;\nlodash.times = util.times;\nlodash.toFinite = lang.toFinite;\nlodash.toInteger = toInteger;\nlodash.toLength = lang.toLength;\nlodash.toLower = string.toLower;\nlodash.toNumber = lang.toNumber;\nlodash.toSafeInteger = lang.toSafeInteger;\nlodash.toString = lang.toString;\nlodash.toUpper = string.toUpper;\nlodash.trim = string.trim;\nlodash.trimEnd = string.trimEnd;\nlodash.trimStart = string.trimStart;\nlodash.truncate = string.truncate;\nlodash.unescape = string.unescape;\nlodash.uniqueId = util.uniqueId;\nlodash.upperCase = string.upperCase;\nlodash.upperFirst = string.upperFirst;\n\n// Add aliases.\nlodash.each = collection.forEach;\nlodash.eachRight = collection.forEachRight;\nlodash.first = array.head;\n\nmixin(lodash, (function() {\n  var source = {};\n  baseForOwn(lodash, function(func, methodName) {\n    if (!hasOwnProperty.call(lodash.prototype, methodName)) {\n      source[methodName] = func;\n    }\n  });\n  return source;\n}()), { 'chain': false });\n\n/**\n * The semantic version number.\n *\n * @static\n * @memberOf _\n * @type {string}\n */\nlodash.VERSION = VERSION;\n(lodash.templateSettings = string.templateSettings).imports._ = lodash;\n\n// Assign default placeholders.\narrayEach(['bind', 'bindKey', 'curry', 'curryRight', 'partial', 'partialRight'], function(methodName) {\n  lodash[methodName].placeholder = lodash;\n});\n\n// Add `LazyWrapper` methods for `_.drop` and `_.take` variants.\narrayEach(['drop', 'take'], function(methodName, index) {\n  LazyWrapper.prototype[methodName] = function(n) {\n    n = n === undefined ? 1 : nativeMax(toInteger(n), 0);\n\n    var result = (this.__filtered__ && !index)\n      ? new LazyWrapper(this)\n      : this.clone();\n\n    if (result.__filtered__) {\n      result.__takeCount__ = nativeMin(n, result.__takeCount__);\n    } else {\n      result.__views__.push({\n        'size': nativeMin(n, MAX_ARRAY_LENGTH),\n        'type': methodName + (result.__dir__ < 0 ? 'Right' : '')\n      });\n    }\n    return result;\n  };\n\n  LazyWrapper.prototype[methodName + 'Right'] = function(n) {\n    return this.reverse()[methodName](n).reverse();\n  };\n});\n\n// Add `LazyWrapper` methods that accept an `iteratee` value.\narrayEach(['filter', 'map', 'takeWhile'], function(methodName, index) {\n  var type = index + 1,\n      isFilter = type == LAZY_FILTER_FLAG || type == LAZY_WHILE_FLAG;\n\n  LazyWrapper.prototype[methodName] = function(iteratee) {\n    var result = this.clone();\n    result.__iteratees__.push({\n      'iteratee': baseIteratee(iteratee, 3),\n      'type': type\n    });\n    result.__filtered__ = result.__filtered__ || isFilter;\n    return result;\n  };\n});\n\n// Add `LazyWrapper` methods for `_.head` and `_.last`.\narrayEach(['head', 'last'], function(methodName, index) {\n  var takeName = 'take' + (index ? 'Right' : '');\n\n  LazyWrapper.prototype[methodName] = function() {\n    return this[takeName](1).value()[0];\n  };\n});\n\n// Add `LazyWrapper` methods for `_.initial` and `_.tail`.\narrayEach(['initial', 'tail'], function(methodName, index) {\n  var dropName = 'drop' + (index ? '' : 'Right');\n\n  LazyWrapper.prototype[methodName] = function() {\n    return this.__filtered__ ? new LazyWrapper(this) : this[dropName](1);\n  };\n});\n\nLazyWrapper.prototype.compact = function() {\n  return this.filter(identity);\n};\n\nLazyWrapper.prototype.find = function(predicate) {\n  return this.filter(predicate).head();\n};\n\nLazyWrapper.prototype.findLast = function(predicate) {\n  return this.reverse().find(predicate);\n};\n\nLazyWrapper.prototype.invokeMap = baseRest(function(path, args) {\n  if (typeof path == 'function') {\n    return new LazyWrapper(this);\n  }\n  return this.map(function(value) {\n    return baseInvoke(value, path, args);\n  });\n});\n\nLazyWrapper.prototype.reject = function(predicate) {\n  return this.filter(negate(baseIteratee(predicate)));\n};\n\nLazyWrapper.prototype.slice = function(start, end) {\n  start = toInteger(start);\n\n  var result = this;\n  if (result.__filtered__ && (start > 0 || end < 0)) {\n    return new LazyWrapper(result);\n  }\n  if (start < 0) {\n    result = result.takeRight(-start);\n  } else if (start) {\n    result = result.drop(start);\n  }\n  if (end !== undefined) {\n    end = toInteger(end);\n    result = end < 0 ? result.dropRight(-end) : result.take(end - start);\n  }\n  return result;\n};\n\nLazyWrapper.prototype.takeRightWhile = function(predicate) {\n  return this.reverse().takeWhile(predicate).reverse();\n};\n\nLazyWrapper.prototype.toArray = function() {\n  return this.take(MAX_ARRAY_LENGTH);\n};\n\n// Add `LazyWrapper` methods to `lodash.prototype`.\nbaseForOwn(LazyWrapper.prototype, function(func, methodName) {\n  var checkIteratee = /^(?:filter|find|map|reject)|While$/.test(methodName),\n      isTaker = /^(?:head|last)$/.test(methodName),\n      lodashFunc = lodash[isTaker ? ('take' + (methodName == 'last' ? 'Right' : '')) : methodName],\n      retUnwrapped = isTaker || /^find/.test(methodName);\n\n  if (!lodashFunc) {\n    return;\n  }\n  lodash.prototype[methodName] = function() {\n    var value = this.__wrapped__,\n        args = isTaker ? [1] : arguments,\n        isLazy = value instanceof LazyWrapper,\n        iteratee = args[0],\n        useLazy = isLazy || isArray(value);\n\n    var interceptor = function(value) {\n      var result = lodashFunc.apply(lodash, arrayPush([value], args));\n      return (isTaker && chainAll) ? result[0] : result;\n    };\n\n    if (useLazy && checkIteratee && typeof iteratee == 'function' && iteratee.length != 1) {\n      // Avoid lazy use if the iteratee has a \"length\" value other than `1`.\n      isLazy = useLazy = false;\n    }\n    var chainAll = this.__chain__,\n        isHybrid = !!this.__actions__.length,\n        isUnwrapped = retUnwrapped && !chainAll,\n        onlyLazy = isLazy && !isHybrid;\n\n    if (!retUnwrapped && useLazy) {\n      value = onlyLazy ? value : new LazyWrapper(this);\n      var result = func.apply(value, args);\n      result.__actions__.push({ 'func': thru, 'args': [interceptor], 'thisArg': undefined });\n      return new LodashWrapper(result, chainAll);\n    }\n    if (isUnwrapped && onlyLazy) {\n      return func.apply(this, args);\n    }\n    result = this.thru(interceptor);\n    return isUnwrapped ? (isTaker ? result.value()[0] : result.value()) : result;\n  };\n});\n\n// Add `Array` methods to `lodash.prototype`.\narrayEach(['pop', 'push', 'shift', 'sort', 'splice', 'unshift'], function(methodName) {\n  var func = arrayProto[methodName],\n      chainName = /^(?:push|sort|unshift)$/.test(methodName) ? 'tap' : 'thru',\n      retUnwrapped = /^(?:pop|shift)$/.test(methodName);\n\n  lodash.prototype[methodName] = function() {\n    var args = arguments;\n    if (retUnwrapped && !this.__chain__) {\n      var value = this.value();\n      return func.apply(isArray(value) ? value : [], args);\n    }\n    return this[chainName](function(value) {\n      return func.apply(isArray(value) ? value : [], args);\n    });\n  };\n});\n\n// Map minified method names to their real names.\nbaseForOwn(LazyWrapper.prototype, function(func, methodName) {\n  var lodashFunc = lodash[methodName];\n  if (lodashFunc) {\n    var key = lodashFunc.name + '';\n    if (!hasOwnProperty.call(realNames, key)) {\n      realNames[key] = [];\n    }\n    realNames[key].push({ 'name': methodName, 'func': lodashFunc });\n  }\n});\n\nrealNames[createHybrid(undefined, WRAP_BIND_KEY_FLAG).name] = [{\n  'name': 'wrapper',\n  'func': undefined\n}];\n\n// Add methods to `LazyWrapper`.\nLazyWrapper.prototype.clone = lazyClone;\nLazyWrapper.prototype.reverse = lazyReverse;\nLazyWrapper.prototype.value = lazyValue;\n\n// Add chain sequence methods to the `lodash` wrapper.\nlodash.prototype.at = seq.at;\nlodash.prototype.chain = seq.wrapperChain;\nlodash.prototype.commit = seq.commit;\nlodash.prototype.next = seq.next;\nlodash.prototype.plant = seq.plant;\nlodash.prototype.reverse = seq.reverse;\nlodash.prototype.toJSON = lodash.prototype.valueOf = lodash.prototype.value = seq.value;\n\n// Add lazy aliases.\nlodash.prototype.first = lodash.prototype.head;\n\nif (symIterator) {\n  lodash.prototype[symIterator] = seq.toIterator;\n}\n\nexport default lodash;\n", "import { isArray, isObject, isString } from '@vue/shared'\nimport { isNil } from 'lodash-unified'\n\nexport {\n  isArray,\n  isFunction,\n  isObject,\n  isString,\n  isDate,\n  isPromise,\n  isSymbol,\n  isPlainObject,\n} from '@vue/shared'\nexport { isVNode } from 'vue'\n\nexport const isUndefined = (val: any): val is undefined => val === undefined\nexport const isBoolean = (val: any): val is boolean => typeof val === 'boolean'\nexport const isNumber = (val: any): val is number => typeof val === 'number'\n\nexport const isEmpty = (val: unknown) =>\n  (!val && val !== 0) ||\n  (isArray(val) && val.length === 0) ||\n  (isObject(val) && !Object.keys(val).length)\n\nexport const isElement = (e: unknown): e is Element => {\n  if (typeof Element === 'undefined') return false\n  return e instanceof Element\n}\n\nexport const isPropAbsent = (prop: unknown): prop is null | undefined => {\n  return isNil(prop)\n}\n\nexport const isStringNumber = (val: string): boolean => {\n  if (!isString(val)) {\n    return false\n  }\n  return !Number.isNaN(Number(val))\n}\n\nexport const isWindow = (val: unknown): val is Window => {\n  return val === window\n}\n", "import { isClient } from './browser'\n\nexport const rAF = (fn: () => void) =>\n  isClient\n    ? window.requestAnimationFrame(fn)\n    : (setTimeout(fn, 16) as unknown as number)\n\nexport const cAF = (handle: number) =>\n  isClient ? window.cancelAnimationFrame(handle) : clearTimeout(handle)\n", "import { capitalize as toCapitalize } from '@vue/shared'\nexport {\n  camelize,\n  hyphenate,\n  hyphenate as kebabCase, // alias\n} from '@vue/shared'\n\n/**\n * fork from {@link https://github.com/sindresorhus/escape-string-regexp}\n */\nexport const escapeStringRegexp = (string = '') =>\n  string.replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&').replace(/-/g, '\\\\x2d')\n\n// NOTE: improve capitalize types. Restore previous code after the [PR](https://github.com/vuejs/core/pull/6212) merge\nexport const capitalize = <T extends string>(str: T) =>\n  toCapitalize(str) as Capitalize<T>\n", "import { get, set } from 'lodash-unified'\nimport type { Entries } from 'type-fest'\nimport type { Arrayable } from '.'\n\nexport const keysOf = <T>(arr: T) => Object.keys(arr) as Array<keyof T>\nexport const entriesOf = <T>(arr: T) => Object.entries(arr) as Entries<T>\nexport { hasOwn } from '@vue/shared'\n\nexport const getProp = <T = any>(\n  obj: Record<string, any>,\n  path: Arrayable<string>,\n  defaultValue?: any\n): { value: T } => {\n  return {\n    get value() {\n      return get(obj, path, defaultValue)\n    },\n    set value(val: any) {\n      set(obj, path, val)\n    },\n  }\n}\n", "import { isString } from './types'\n\nclass ElementPlusError extends Error {\n  constructor(m: string) {\n    super(m)\n    this.name = 'ElementPlusError'\n  }\n}\n\nexport function throwError(scope: string, m: string): never {\n  throw new ElementPlusError(`[${scope}] ${m}`)\n}\n\nexport function debugWarn(err: Error): void\nexport function debugWarn(scope: string, message: string): void\nexport function debugWarn(scope: string | Error, message?: string): void {\n  if (process.env.NODE_ENV !== 'production') {\n    const error: Error = isString(scope)\n      ? new ElementPlusError(`[${scope}] ${message}`)\n      : scope\n    // eslint-disable-next-line no-console\n    console.warn(error)\n  }\n}\n", "import { isNumber, isObject, isString, isStringNumber } from '../types'\nimport { isClient } from '../browser'\nimport { camelize } from '../strings'\nimport { entriesOf, keysOf } from '../objects'\nimport { debugWarn } from '../error'\nimport type { CSSProperties } from 'vue'\n\nconst SCOPE = 'utils/dom/style'\n\nexport const classNameToArray = (cls = '') =>\n  cls.split(' ').filter((item) => !!item.trim())\n\nexport const hasClass = (el: Element, cls: string): boolean => {\n  if (!el || !cls) return false\n  if (cls.includes(' ')) throw new Error('className should not contain space.')\n  return el.classList.contains(cls)\n}\n\nexport const addClass = (el: Element, cls: string) => {\n  if (!el || !cls.trim()) return\n  el.classList.add(...classNameToArray(cls))\n}\n\nexport const removeClass = (el: Element, cls: string) => {\n  if (!el || !cls.trim()) return\n  el.classList.remove(...classNameToArray(cls))\n}\n\nexport const getStyle = (\n  element: HTMLElement,\n  styleName: keyof CSSProperties\n): string => {\n  if (!isClient || !element || !styleName) return ''\n\n  let key = camelize(styleName)\n  if (key === 'float') key = 'cssFloat'\n  try {\n    const style = (element.style as any)[key]\n    if (style) return style\n    const computed: any = document.defaultView?.getComputedStyle(element, '')\n    return computed ? computed[key] : ''\n  } catch {\n    return (element.style as any)[key]\n  }\n}\n\nexport const setStyle = (\n  element: HTMLElement,\n  styleName: CSSProperties | keyof CSSProperties,\n  value?: string | number\n) => {\n  if (!element || !styleName) return\n\n  if (isObject(styleName)) {\n    entriesOf(styleName).forEach(([prop, value]) =>\n      setStyle(element, prop, value)\n    )\n  } else {\n    const key: any = camelize(styleName)\n    element.style[key] = value as any\n  }\n}\n\nexport const removeStyle = (\n  element: HTMLElement,\n  style: CSSProperties | keyof CSSProperties\n) => {\n  if (!element || !style) return\n\n  if (isObject(style)) {\n    keysOf(style).forEach((prop) => removeStyle(element, prop))\n  } else {\n    setStyle(element, style, '')\n  }\n}\n\nexport function addUnit(value?: string | number, defaultUnit = 'px') {\n  if (!value) return ''\n  if (isNumber(value) || isStringNumber(value)) {\n    return `${value}${defaultUnit}`\n  } else if (isString(value)) {\n    return value\n  }\n  debugWarn(SCOPE, 'binding value must be a string or number')\n}\n", "import { isClient } from '../browser'\nimport { easeInOutCubic } from '../easings'\nimport { isWindow } from '../types'\nimport { cAF, rAF } from '../raf'\nimport { getStyle } from './style'\n\nexport const isScroll = (el: HTMLElement, isVertical?: boolean): boolean => {\n  if (!isClient) return false\n\n  const key = (\n    {\n      undefined: 'overflow',\n      true: 'overflow-y',\n      false: 'overflow-x',\n    } as const\n  )[String(isVertical)]!\n  const overflow = getStyle(el, key)\n  return ['scroll', 'auto', 'overlay'].some((s) => overflow.includes(s))\n}\n\nexport const getScrollContainer = (\n  el: HTMLElement,\n  isVertical?: boolean\n): Window | HTMLElement | undefined => {\n  if (!isClient) return\n\n  let parent: HTMLElement = el\n  while (parent) {\n    if ([window, document, document.documentElement].includes(parent))\n      return window\n\n    if (isScroll(parent, isVertical)) return parent\n\n    parent = parent.parentNode as HTMLElement\n  }\n\n  return parent\n}\n\nlet scrollBarWidth: number\nexport const getScrollBarWidth = (namespace: string): number => {\n  if (!isClient) return 0\n  if (scrollBarWidth !== undefined) return scrollBarWidth\n\n  const outer = document.createElement('div')\n  outer.className = `${namespace}-scrollbar__wrap`\n  outer.style.visibility = 'hidden'\n  outer.style.width = '100px'\n  outer.style.position = 'absolute'\n  outer.style.top = '-9999px'\n  document.body.appendChild(outer)\n\n  const widthNoScroll = outer.offsetWidth\n  outer.style.overflow = 'scroll'\n\n  const inner = document.createElement('div')\n  inner.style.width = '100%'\n  outer.appendChild(inner)\n\n  const widthWithScroll = inner.offsetWidth\n  outer.parentNode?.removeChild(outer)\n  scrollBarWidth = widthNoScroll - widthWithScroll\n\n  return scrollBarWidth\n}\n\n/**\n * Scroll with in the container element, positioning the **selected** element at the top\n * of the container\n */\nexport function scrollIntoView(\n  container: HTMLElement,\n  selected: HTMLElement\n): void {\n  if (!isClient) return\n\n  if (!selected) {\n    container.scrollTop = 0\n    return\n  }\n\n  const offsetParents: HTMLElement[] = []\n  let pointer = selected.offsetParent\n  while (\n    pointer !== null &&\n    container !== pointer &&\n    container.contains(pointer)\n  ) {\n    offsetParents.push(pointer as HTMLElement)\n    pointer = (pointer as HTMLElement).offsetParent\n  }\n  const top =\n    selected.offsetTop +\n    offsetParents.reduce((prev, curr) => prev + curr.offsetTop, 0)\n  const bottom = top + selected.offsetHeight\n  const viewRectTop = container.scrollTop\n  const viewRectBottom = viewRectTop + container.clientHeight\n\n  if (top < viewRectTop) {\n    container.scrollTop = top\n  } else if (bottom > viewRectBottom) {\n    container.scrollTop = bottom - container.clientHeight\n  }\n}\n\nexport function animateScrollTo(\n  container: HTMLElement | Window,\n  from: number,\n  to: number,\n  duration: number,\n  callback?: unknown\n) {\n  const startTime = Date.now()\n\n  let handle: number | undefined\n  const scroll = () => {\n    const timestamp = Date.now()\n    const time = timestamp - startTime\n    const nextScrollTop = easeInOutCubic(\n      time > duration ? duration : time,\n      from,\n      to,\n      duration\n    )\n\n    if (isWindow(container)) {\n      container.scrollTo(window.pageXOffset, nextScrollTop)\n    } else {\n      container.scrollTop = nextScrollTop\n    }\n    if (time < duration) {\n      handle = rAF(scroll)\n    } else if (typeof callback === 'function') {\n      callback()\n    }\n  }\n\n  scroll()\n\n  return () => {\n    handle && cAF(handle)\n  }\n}\n\nexport const getScrollElement = (\n  target: HTMLElement,\n  container: HTMLElement | Window\n) => {\n  if (isWindow(container)) {\n    return target.ownerDocument.documentElement\n  }\n  return container\n}\n\nexport const getScrollTop = (container: HTMLElement | Window) => {\n  if (isWindow(container)) {\n    return window.scrollY\n  }\n  return container.scrollTop\n}\n", "import { isString } from '../types'\nimport { isClient } from '../browser'\n\ntype GetElement = <T extends string | HTMLElement | Window | null | undefined>(\n  target: T\n) => T extends string ? HTMLElement | null : T\n\nexport const getElement = ((\n  target: string | HTMLElement | Window | null | undefined\n) => {\n  if (!isClient || target === '') return null\n  if (isString(target)) {\n    try {\n      return document.querySelector<HTMLElement>(target)\n    } catch {\n      return null\n    }\n  }\n  return target\n}) as GetElement\n", "import { isClient } from '../browser'\n\nconst globalNodes: HTMLElement[] = []\nlet target: HTMLElement | undefined = !isClient ? undefined : document.body\n\nexport function createGlobalNode(id?: string) {\n  const el = document.createElement('div')\n  if (id !== undefined) {\n    el.setAttribute('id', id)\n  }\n\n  if (target) {\n    target.appendChild(el)\n    globalNodes.push(el)\n  }\n\n  return el\n}\n\nexport function removeGlobalNode(el: HTMLElement) {\n  globalNodes.splice(globalNodes.indexOf(el), 1)\n  el.remove()\n}\n\nexport function changeGlobalNodesTarget(el: HTMLElement) {\n  if (el === target) return\n\n  target = el\n  globalNodes.forEach((el) => {\n    if (target && !el.contains(target)) {\n      target.appendChild(el)\n    }\n  })\n}\n", "import { warn } from 'vue'\nimport { fromPairs } from 'lodash-unified'\nimport { isObject } from '../../types'\nimport { hasOwn } from '../../objects'\n\nimport type { PropType } from 'vue'\nimport type {\n  EpProp,\n  EpPropConvert,\n  EpPropFinalized,\n  EpPropInput,\n  EpPropMergeType,\n  IfEpProp,\n  IfNativePropType,\n  NativePropType,\n} from './types'\n\nexport const epPropKey = '__epPropKey'\n\nexport const definePropType = <T>(val: any): PropType<T> => val\n\nexport const isEpProp = (val: unknown): val is EpProp<any, any, any> =>\n  isObject(val) && !!(val as any)[epPropKey]\n\n/**\n * @description Build prop. It can better optimize prop types\n * @description 生成 prop,能更好地优化类型\n * @example\n  // limited options\n  // the type will be PropType<'light' | 'dark'>\n  buildProp({\n    type: String,\n    values: ['light', 'dark'],\n  } as const)\n  * @example\n  // limited options and other types\n  // the type will be PropType<'small' | 'large' | number>\n  buildProp({\n    type: [String, Number],\n    values: ['small', 'large'],\n    validator: (val: unknown): val is number => typeof val === 'number',\n  } as const)\n  @link see more: https://github.com/element-plus/element-plus/pull/3341\n */\nexport const buildProp = <\n  Type = never,\n  Value = never,\n  Validator = never,\n  Default extends EpPropMergeType<Type, Value, Validator> = never,\n  Required extends boolean = false\n>(\n  prop: EpPropInput<Type, Value, Validator, Default, Required>,\n  key?: string\n): EpPropFinalized<Type, Value, Validator, Default, Required> => {\n  // filter native prop type and nested prop, e.g `null`, `undefined` (from `buildProps`)\n  if (!isObject(prop) || isEpProp(prop)) return prop as any\n\n  const { values, required, default: defaultValue, type, validator } = prop\n\n  const _validator =\n    values || validator\n      ? (val: unknown) => {\n          let valid = false\n          let allowedValues: unknown[] = []\n\n          if (values) {\n            allowedValues = Array.from(values)\n            if (hasOwn(prop, 'default')) {\n              allowedValues.push(defaultValue)\n            }\n            valid ||= allowedValues.includes(val)\n          }\n          if (validator) valid ||= validator(val)\n\n          if (!valid && allowedValues.length > 0) {\n            const allowValuesText = [...new Set(allowedValues)]\n              .map((value) => JSON.stringify(value))\n              .join(', ')\n            warn(\n              `Invalid prop: validation failed${\n                key ? ` for prop \"${key}\"` : ''\n              }. Expected one of [${allowValuesText}], got value ${JSON.stringify(\n                val\n              )}.`\n            )\n          }\n          return valid\n        }\n      : undefined\n\n  const epProp: any = {\n    type,\n    required: !!required,\n    validator: _validator,\n    [epPropKey]: true,\n  }\n  if (hasOwn(prop, 'default')) epProp.default = defaultValue\n  return epProp\n}\n\nexport const buildProps = <\n  Props extends Record<\n    string,\n    | { [epPropKey]: true }\n    | NativePropType\n    | EpPropInput<any, any, any, any, any>\n  >\n>(\n  props: Props\n): {\n  [K in keyof Props]: IfEpProp<\n    Props[K],\n    Props[K],\n    IfNativePropType<Props[K], Props[K], EpPropConvert<Props[K]>>\n  >\n} =>\n  fromPairs(\n    Object.entries(props).map(([key, option]) => [\n      key,\n      buildProp(option as any, key),\n    ])\n  ) as any\n", "import {\n  CircleCheck,\n  CircleClose,\n  CircleCloseFilled,\n  Close,\n  InfoFilled,\n  Loading,\n  SuccessFilled,\n  WarningFilled,\n} from '@element-plus/icons-vue'\nimport { definePropType } from './props'\n\nimport type { Component } from 'vue'\n\nexport const iconPropType = definePropType<string | Component>([\n  String,\n  Object,\n  Function,\n])\n\nexport const CloseComponents = {\n  Close,\n}\n\nexport const TypeComponents = {\n  Close,\n  SuccessFilled,\n  InfoFilled,\n  WarningFilled,\n  CircleCloseFilled,\n}\n\nexport const TypeComponentsMap = {\n  success: SuccessFilled,\n  warning: WarningFilled,\n  error: CircleCloseFilled,\n  info: InfoFilled,\n}\n\nexport const ValidateComponentsMap = {\n  validating: Loading,\n  success: CircleCheck,\n  error: CircleClose,\n}\n", "import { NOOP } from '../functions'\n\nimport type { App, Directive } from 'vue'\nimport type { SFCInstallWithContext, SFCWithInstall } from './typescript'\n\nexport const withInstall = <T, E extends Record<string, any>>(\n  main: T,\n  extra?: E\n) => {\n  ;(main as SFCWithInstall<T>).install = (app): void => {\n    for (const comp of [main, ...Object.values(extra ?? {})]) {\n      app.component(comp.name, comp)\n    }\n  }\n\n  if (extra) {\n    for (const [key, comp] of Object.entries(extra)) {\n      ;(main as any)[key] = comp\n    }\n  }\n  return main as SFCWithInstall<T> & E\n}\n\nexport const withInstallFunction = <T>(fn: T, name: string) => {\n  ;(fn as SFCWithInstall<T>).install = (app: App) => {\n    ;(fn as SFCInstallWithContext<T>)._context = app._context\n    app.config.globalProperties[name] = fn\n  }\n\n  return fn as SFCInstallWithContext<T>\n}\n\nexport const withInstallDirective = <T extends Directive>(\n  directive: T,\n  name: string\n) => {\n  ;(directive as SFCWithInstall<T>).install = (app: App): void => {\n    app.directive(name, directive)\n  }\n\n  return directive as SFCWithInstall<T>\n}\n\nexport const withNoopInstall = <T>(component: T) => {\n  ;(component as SFCWithInstall<T>).install = NOOP\n\n  return component as SFCWithInstall<T>\n}\n", "import { isFunction } from '../types'\n\nimport type { ComponentPublicInstance, Ref } from 'vue'\n\nexport type RefSetter = (\n  el: Element | ComponentPublicInstance | undefined\n) => void\n\nexport const composeRefs = (\n  ...refs: (Ref<HTMLElement | undefined> | RefSetter)[]\n) => {\n  return (el: Element | ComponentPublicInstance | null) => {\n    refs.forEach((ref) => {\n      if (isFunction(ref)) {\n        ref(el as Element | ComponentPublicInstance)\n      } else {\n        ref.value = el as HTMLElement | undefined\n      }\n    })\n  }\n}\n", "export const EVENT_CODE = {\n  tab: 'Tab',\n  enter: 'Enter',\n  space: 'Space',\n  left: 'ArrowLeft', // 37\n  up: 'ArrowUp', // 38\n  right: 'ArrowRight', // 39\n  down: 'ArrowDown', // 40\n  esc: 'Escape',\n  delete: 'Delete',\n  backspace: 'Backspace',\n  numpadEnter: 'NumpadEnter',\n  pageUp: 'PageUp',\n  pageDown: 'PageDown',\n  home: 'Home',\n  end: 'End',\n}\n", "export const datePickTypes = [\n  'year',\n  'years',\n  'month',\n  'months',\n  'date',\n  'dates',\n  'week',\n  'datetime',\n  'datetimerange',\n  'daterange',\n  'monthrange',\n  'yearrange',\n] as const\n\nexport const WEEK_DAYS = [\n  'sun',\n  'mon',\n  'tue',\n  'wed',\n  'thu',\n  'fri',\n  'sat',\n] as const\n\nexport type DatePickType = typeof datePickTypes[number]\n", "export const UPDATE_MODEL_EVENT = 'update:modelValue'\nexport const CHANGE_EVENT = 'change'\nexport const INPUT_EVENT = 'input'\n", "export const INSTALLED_KEY = Symbol('INSTALLED_KEY')\n", "export const componentSizes = ['', 'default', 'small', 'large'] as const\n\nexport type ComponentSize = typeof componentSizes[number]\n\nexport const componentSizeMap = {\n  large: 40,\n  default: 32,\n  small: 24,\n} as const\n", "import { componentSizes, datePickTypes } from '@element-plus/constants'\nimport type { ComponentSize, DatePickType } from '@element-plus/constants'\n\nexport const isValidComponentSize = (val: string): val is ComponentSize | '' =>\n  ['', ...componentSizes].includes(val)\n\nexport const isValidDatePickType = (val: string): val is DatePickType =>\n  ([...datePickTypes] as string[]).includes(val)\n", "import {\n  Comment,\n  Fragment,\n  Text,\n  createBlock,\n  createCommentVNode,\n  isVNode,\n  openBlock,\n} from 'vue'\nimport { camelize } from '../strings'\nimport { isArray } from '../types'\nimport { hasOwn } from '../objects'\nimport { debugWarn } from '../error'\nimport type {\n  VNode,\n  VNodeArrayChildren,\n  VNodeChild,\n  VNodeNormalizedChildren,\n} from 'vue'\n\nconst SCOPE = 'utils/vue/vnode'\n\nexport enum PatchFlags {\n  TEXT = 1,\n  CLASS = 2,\n  STYLE = 4,\n  PROPS = 8,\n  FULL_PROPS = 16,\n  HYDRATE_EVENTS = 32,\n  STABLE_FRAGMENT = 64,\n  KEYED_FRAGMENT = 128,\n  UNKEYED_FRAGMENT = 256,\n  NEED_PATCH = 512,\n  DYNAMIC_SLOTS = 1024,\n  HOISTED = -1,\n  BAIL = -2,\n}\n\nexport type VNodeChildAtom = Exclude<VNodeChild, Array<any>>\nexport type RawSlots = Exclude<\n  VNodeNormalizedChildren,\n  Array<any> | null | string\n>\n\nexport function isFragment(node: VNode): boolean\nexport function isFragment(node: unknown): node is VNode\nexport function isFragment(node: unknown): node is VNode {\n  return isVNode(node) && node.type === Fragment\n}\n\nexport function isText(node: VNode): boolean\nexport function isText(node: unknown): node is VNode\nexport function isText(node: unknown): node is VNode {\n  return isVNode(node) && node.type === Text\n}\n\nexport function isComment(node: VNode): boolean\nexport function isComment(node: unknown): node is VNode\nexport function isComment(node: unknown): node is VNode {\n  return isVNode(node) && node.type === Comment\n}\n\nconst TEMPLATE = 'template'\nexport function isTemplate(node: VNode): boolean\nexport function isTemplate(node: unknown): node is VNode\nexport function isTemplate(node: unknown): node is VNode {\n  return isVNode(node) && node.type === TEMPLATE\n}\n\n/**\n * determine if the element is a valid element type rather than fragments and comment e.g. <template> v-if\n * @param node {VNode} node to be tested\n */\nexport function isValidElementNode(node: VNode): boolean\nexport function isValidElementNode(node: unknown): node is VNode\nexport function isValidElementNode(node: unknown): node is VNode {\n  return isVNode(node) && !isFragment(node) && !isComment(node)\n}\n\n/**\n * get a valid child node (not fragment nor comment)\n * @param node {VNode} node to be searched\n * @param depth {number} depth to be searched\n */\nfunction getChildren(\n  node: VNodeNormalizedChildren | VNodeChild,\n  depth: number\n): VNodeNormalizedChildren | VNodeChild {\n  if (isComment(node)) return\n  if (isFragment(node) || isTemplate(node)) {\n    return depth > 0 ? getFirstValidNode(node.children, depth - 1) : undefined\n  }\n  return node\n}\n\nexport const getFirstValidNode = (\n  nodes: VNodeNormalizedChildren,\n  maxDepth = 3\n) => {\n  if (Array.isArray(nodes)) {\n    return getChildren(nodes[0], maxDepth)\n  } else {\n    return getChildren(nodes, maxDepth)\n  }\n}\n\nexport function renderIf(\n  condition: boolean,\n  ...args: Parameters<typeof createBlock>\n) {\n  return condition ? renderBlock(...args) : createCommentVNode('v-if', true)\n}\n\nexport function renderBlock(...args: Parameters<typeof createBlock>) {\n  return openBlock(), createBlock(...args)\n}\n\nexport const getNormalizedProps = (node: VNode) => {\n  if (!isVNode(node)) {\n    debugWarn(SCOPE, '[getNormalizedProps] must be a VNode')\n    return {}\n  }\n\n  const raw = node.props || {}\n  const type = (isVNode(node.type) ? node.type.props : undefined) || {}\n  const props: Record<string, any> = {}\n\n  Object.keys(type).forEach((key) => {\n    if (hasOwn(type[key], 'default')) {\n      props[key] = type[key].default\n    }\n  })\n\n  Object.keys(raw).forEach((key) => {\n    props[camelize(key)] = raw[key]\n  })\n\n  return props\n}\n\nexport const ensureOnlyChild = (children: VNodeArrayChildren | undefined) => {\n  if (!isArray(children) || children.length > 1) {\n    throw new Error('expect to receive a single Vue element child')\n  }\n  return children[0]\n}\n\nexport type FlattenVNodes = Array<VNodeChildAtom | RawSlots>\n\nexport const flattedChildren = (\n  children: FlattenVNodes | VNode | VNodeNormalizedChildren\n): FlattenVNodes => {\n  const vNodes = isArray(children) ? children : [children]\n  const result: FlattenVNodes = []\n\n  vNodes.forEach((child) => {\n    if (isArray(child)) {\n      result.push(...flattedChildren(child))\n    } else if (isVNode(child) && isArray(child.children)) {\n      result.push(...flattedChildren(child.children))\n    } else {\n      result.push(child)\n      if (isVNode(child) && child.component?.subTree) {\n        result.push(...flattedChildren(child.component.subTree))\n      }\n    }\n  })\n  return result\n}\n", "export const unique = <T>(arr: T[]) => [...new Set(arr)]\n\ntype Many<T> = T | ReadonlyArray<T>\n// TODO: rename to `ensureArray`\n/** like `_.castArray`, except falsy value returns empty array. */\nexport const castArray = <T>(arr: Many<T>): T[] => {\n  if (!arr && (arr as any) !== 0) return []\n  return Array.isArray(arr) ? arr : [arr]\n}\n\n// TODO: remove import alias\n// avoid naming conflicts\nexport { castArray as ensureArray } from 'lodash-unified'\n", "export const isKorean = (text: string) =>\n  /([\\uAC00-\\uD7AF\\u3130-\\u318F])+/gi.test(text)\n", "export const mutable = <T extends readonly any[] | Record<string, unknown>>(\n  val: T\n) => val as Mutable<typeof val>\nexport type Mutable<T> = { -readonly [P in keyof T]: T[P] }\n\nexport type HTMLElementCustomized<T> = HTMLElement & T\n\n/**\n * @deprecated stop to use null\n * @see {@link https://github.com/sindresorhus/meta/discussions/7}\n */\nexport type Nullable<T> = T | null\n\nexport type Arrayable<T> = T | T[]\nexport type Awaitable<T> = Promise<T> | T\n", "import { cAF, rAF } from './raf'\n\nexport function throttleByRaf(cb: (...args: any[]) => void) {\n  let timer = 0\n\n  const throttle = (...args: any[]): void => {\n    if (timer) {\n      cAF(timer)\n    }\n    timer = rAF(() => {\n      cb(...args)\n      timer = 0\n    })\n  }\n\n  throttle.cancel = () => {\n    cAF(timer)\n    timer = 0\n  }\n\n  return throttle\n}\n", "import { computed, getCurrentInstance } from 'vue'\nimport { fromPairs } from 'lodash-unified'\nimport { debugWarn } from '@element-plus/utils'\n\nimport type { ComputedRef } from 'vue'\n\ninterface Params {\n  excludeListeners?: boolean\n  excludeKeys?: ComputedRef<string[]>\n}\n\nconst DEFAULT_EXCLUDE_KEYS = ['class', 'style']\nconst LISTENER_PREFIX = /^on[A-Z]/\n\nexport const useAttrs = (\n  params: Params = {}\n): ComputedRef<Record<string, unknown>> => {\n  const { excludeListeners = false, excludeKeys } = params\n  const allExcludeKeys = computed<string[]>(() => {\n    return (excludeKeys?.value || []).concat(DEFAULT_EXCLUDE_KEYS)\n  })\n\n  const instance = getCurrentInstance()\n  if (!instance) {\n    debugWarn(\n      'use-attrs',\n      'getCurrentInstance() returned null. useAttrs() must be called at the top of a setup function'\n    )\n    return computed(() => ({}))\n  }\n\n  return computed(() =>\n    fromPairs(\n      Object.entries(instance.proxy?.$attrs!).filter(\n        ([key]) =>\n          !allExcludeKeys.value.includes(key) &&\n          !(excludeListeners && LISTENER_PREFIX.test(key))\n      )\n    )\n  )\n}\n", "import { unref, watch } from 'vue'\nimport { debugWarn } from '@element-plus/utils'\n\nimport type { MaybeRef } from '@vueuse/core'\n\ntype DeprecationParam = {\n  from: string\n  replacement: string\n  scope: string\n  version: string\n  ref: string\n  type?: 'API' | 'Attribute' | 'Event' | 'Slot'\n}\n\nexport const useDeprecated = (\n  { from, replacement, scope, version, ref, type = 'API' }: DeprecationParam,\n  condition: MaybeRef<boolean>\n) => {\n  watch(\n    () => unref(condition),\n    (val) => {\n      if (val) {\n        debugWarn(\n          scope,\n          `[${type}] ${from} is about to be deprecated in version ${version}, please use ${replacement} instead.\nFor more detail, please visit: ${ref}\n`\n        )\n      }\n    },\n    {\n      immediate: true,\n    }\n  )\n}\n", "import { onBeforeUnmount, onMounted, watchEffect } from 'vue'\nimport { addUnit } from '@element-plus/utils'\nimport type { ComputedRef, Ref } from 'vue'\n\nexport const useDraggable = (\n  targetRef: Ref<HTMLElement | undefined>,\n  dragRef: Ref<HTMLElement | undefined>,\n  draggable: ComputedRef<boolean>,\n  overflow?: ComputedRef<boolean>\n) => {\n  let transform = {\n    offsetX: 0,\n    offsetY: 0,\n  }\n\n  const onMousedown = (e: MouseEvent) => {\n    const downX = e.clientX\n    const downY = e.clientY\n    const { offsetX, offsetY } = transform\n\n    const targetRect = targetRef.value!.getBoundingClientRect()\n    const targetLeft = targetRect.left\n    const targetTop = targetRect.top\n    const targetWidth = targetRect.width\n    const targetHeight = targetRect.height\n\n    const clientWidth = document.documentElement.clientWidth\n    const clientHeight = document.documentElement.clientHeight\n\n    const minLeft = -targetLeft + offsetX\n    const minTop = -targetTop + offsetY\n    const maxLeft = clientWidth - targetLeft - targetWidth + offsetX\n    const maxTop = clientHeight - targetTop - targetHeight + offsetY\n\n    const onMousemove = (e: MouseEvent) => {\n      let moveX = offsetX + e.clientX - downX\n      let moveY = offsetY + e.clientY - downY\n\n      if (!overflow?.value) {\n        moveX = Math.min(Math.max(moveX, minLeft), maxLeft)\n        moveY = Math.min(Math.max(moveY, minTop), maxTop)\n      }\n\n      transform = {\n        offsetX: moveX,\n        offsetY: moveY,\n      }\n\n      if (targetRef.value) {\n        targetRef.value.style.transform = `translate(${addUnit(\n          moveX\n        )}, ${addUnit(moveY)})`\n      }\n    }\n\n    const onMouseup = () => {\n      document.removeEventListener('mousemove', onMousemove)\n      document.removeEventListener('mouseup', onMouseup)\n    }\n\n    document.addEventListener('mousemove', onMousemove)\n    document.addEventListener('mouseup', onMouseup)\n  }\n\n  const onDraggable = () => {\n    if (dragRef.value && targetRef.value) {\n      dragRef.value.addEventListener('mousedown', onMousedown)\n    }\n  }\n\n  const offDraggable = () => {\n    if (dragRef.value && targetRef.value) {\n      dragRef.value.removeEventListener('mousedown', onMousedown)\n    }\n  }\n\n  const resetPosition = () => {\n    transform = {\n      offsetX: 0,\n      offsetY: 0,\n    }\n    if (targetRef.value) {\n      targetRef.value.style.transform = 'none'\n    }\n  }\n\n  onMounted(() => {\n    watchEffect(() => {\n      if (draggable.value) {\n        onDraggable()\n      } else {\n        offDraggable()\n      }\n    })\n  })\n\n  onBeforeUnmount(() => {\n    offDraggable()\n  })\n\n  return {\n    resetPosition,\n  }\n}\n", "import type { Ref } from 'vue'\n\nexport const useFocus = (\n  el: Ref<{\n    focus: () => void\n  } | null>\n) => {\n  return {\n    focus: () => {\n      el.value?.focus?.()\n    },\n  }\n}\n", "export default {\n  name: 'en',\n  el: {\n    breadcrumb: {\n      label: 'Breadcrumb', // to be translated\n    },\n    colorpicker: {\n      confirm: 'OK',\n      clear: 'Clear',\n      defaultLabel: 'color picker',\n      description:\n        'current color is {color}. press enter to select a new color.',\n      alphaLabel: 'pick alpha value',\n    },\n    datepicker: {\n      now: 'Now',\n      today: 'Today',\n      cancel: 'Cancel',\n      clear: 'Clear',\n      confirm: 'OK',\n      dateTablePrompt:\n        'Use the arrow keys and enter to select the day of the month',\n      monthTablePrompt: 'Use the arrow keys and enter to select the month',\n      yearTablePrompt: 'Use the arrow keys and enter to select the year',\n      selectedDate: 'Selected date',\n      selectDate: 'Select date',\n      selectTime: 'Select time',\n      startDate: 'Start Date',\n      startTime: 'Start Time',\n      endDate: 'End Date',\n      endTime: 'End Time',\n      prevYear: 'Previous Year',\n      nextYear: 'Next Year',\n      prevMonth: 'Previous Month',\n      nextMonth: 'Next Month',\n      year: '',\n      month1: 'January',\n      month2: 'February',\n      month3: 'March',\n      month4: 'April',\n      month5: 'May',\n      month6: 'June',\n      month7: 'July',\n      month8: 'August',\n      month9: 'September',\n      month10: 'October',\n      month11: 'November',\n      month12: 'December',\n      week: 'week',\n      weeks: {\n        sun: 'Sun',\n        mon: 'Mon',\n        tue: 'Tue',\n        wed: 'Wed',\n        thu: 'Thu',\n        fri: 'Fri',\n        sat: 'Sat',\n      },\n      weeksFull: {\n        sun: 'Sunday',\n        mon: 'Monday',\n        tue: 'Tuesday',\n        wed: 'Wednesday',\n        thu: 'Thursday',\n        fri: 'Friday',\n        sat: 'Saturday',\n      },\n      months: {\n        jan: 'Jan',\n        feb: 'Feb',\n        mar: 'Mar',\n        apr: 'Apr',\n        may: 'May',\n        jun: 'Jun',\n        jul: 'Jul',\n        aug: 'Aug',\n        sep: 'Sep',\n        oct: 'Oct',\n        nov: 'Nov',\n        dec: 'Dec',\n      },\n    },\n    inputNumber: {\n      decrease: 'decrease number',\n      increase: 'increase number',\n    },\n    select: {\n      loading: 'Loading',\n      noMatch: 'No matching data',\n      noData: 'No data',\n      placeholder: 'Select',\n    },\n    mention: {\n      loading: 'Loading',\n    },\n    dropdown: {\n      toggleDropdown: 'Toggle Dropdown',\n    },\n    cascader: {\n      noMatch: 'No matching data',\n      loading: 'Loading',\n      placeholder: 'Select',\n      noData: 'No data',\n    },\n    pagination: {\n      goto: 'Go to',\n      pagesize: '/page',\n      total: 'Total {total}',\n      pageClassifier: '',\n      page: 'Page',\n      prev: 'Go to previous page',\n      next: 'Go to next page',\n      currentPage: 'page {pager}',\n      prevPages: 'Previous {pager} pages',\n      nextPages: 'Next {pager} pages',\n      deprecationWarning:\n        'Deprecated usages detected, please refer to the el-pagination documentation for more details',\n    },\n    dialog: {\n      close: 'Close this dialog',\n    },\n    drawer: {\n      close: 'Close this dialog',\n    },\n    messagebox: {\n      title: 'Message',\n      confirm: 'OK',\n      cancel: 'Cancel',\n      error: 'Illegal input',\n      close: 'Close this dialog',\n    },\n    upload: {\n      deleteTip: 'press delete to remove',\n      delete: 'Delete',\n      preview: 'Preview',\n      continue: 'Continue',\n    },\n    slider: {\n      defaultLabel: 'slider between {min} and {max}',\n      defaultRangeStartLabel: 'pick start value',\n      defaultRangeEndLabel: 'pick end value',\n    },\n    table: {\n      emptyText: 'No Data',\n      confirmFilter: 'Confirm',\n      resetFilter: 'Reset',\n      clearFilter: 'All',\n      sumText: 'Sum',\n    },\n    tour: {\n      next: 'Next',\n      previous: 'Previous',\n      finish: 'Finish',\n    },\n    tree: {\n      emptyText: 'No Data',\n    },\n    transfer: {\n      noMatch: 'No matching data',\n      noData: 'No data',\n      titles: ['List 1', 'List 2'], // to be translated\n      filterPlaceholder: 'Enter keyword', // to be translated\n      noCheckedFormat: '{total} items', // to be translated\n      hasCheckedFormat: '{checked}/{total} checked', // to be translated\n    },\n    image: {\n      error: 'FAILED',\n    },\n    pageHeader: {\n      title: 'Back', // to be translated\n    },\n    popconfirm: {\n      confirmButtonText: 'Yes',\n      cancelButtonText: 'No',\n    },\n    carousel: {\n      leftArrow: 'Carousel arrow left',\n      rightArrow: 'Carousel arrow right',\n      indicator: 'Carousel switch to index {index}',\n    },\n  },\n}\n", "import { computed, inject, isRef, ref, unref } from 'vue'\nimport { get } from 'lodash-unified'\nimport English from '@element-plus/locale/lang/en'\n\nimport type { MaybeRef } from '@vueuse/core'\nimport type { InjectionKey, Ref } from 'vue'\nimport type { Language } from '@element-plus/locale'\n\nexport type TranslatorOption = Record<string, string | number>\nexport type Translator = (path: string, option?: TranslatorOption) => string\nexport type LocaleContext = {\n  locale: Ref<Language>\n  lang: Ref<string>\n  t: Translator\n}\n\nexport const buildTranslator =\n  (locale: MaybeRef<Language>): Translator =>\n  (path, option) =>\n    translate(path, option, unref(locale))\n\nexport const translate = (\n  path: string,\n  option: undefined | TranslatorOption,\n  locale: Language\n): string =>\n  (get(locale, path, path) as string).replace(\n    /\\{(\\w+)\\}/g,\n    (_, key) => `${option?.[key] ?? `{${key}}`}`\n  )\n\nexport const buildLocaleContext = (\n  locale: MaybeRef<Language>\n): LocaleContext => {\n  const lang = computed(() => unref(locale).name)\n  const localeRef = isRef(locale) ? locale : ref(locale)\n  return {\n    lang,\n    locale: localeRef,\n    t: buildTranslator(locale),\n  }\n}\n\nexport const localeContextKey: InjectionKey<Ref<Language | undefined>> =\n  Symbol('localeContextKey')\n\nexport const useLocale = (localeOverrides?: Ref<Language | undefined>) => {\n  const locale = localeOverrides || inject(localeContextKey, ref())!\n  return buildLocaleContext(computed(() => locale.value || English))\n}\n", "import { computed, getCurrentInstance, inject, ref, unref } from 'vue'\n\nimport type { InjectionKey, Ref } from 'vue'\n\nexport const defaultNamespace = 'el'\nconst statePrefix = 'is-'\n\nconst _bem = (\n  namespace: string,\n  block: string,\n  blockSuffix: string,\n  element: string,\n  modifier: string\n) => {\n  let cls = `${namespace}-${block}`\n  if (blockSuffix) {\n    cls += `-${blockSuffix}`\n  }\n  if (element) {\n    cls += `__${element}`\n  }\n  if (modifier) {\n    cls += `--${modifier}`\n  }\n  return cls\n}\n\nexport const namespaceContextKey: InjectionKey<Ref<string | undefined>> =\n  Symbol('namespaceContextKey')\n\nexport const useGetDerivedNamespace = (\n  namespaceOverrides?: Ref<string | undefined>\n) => {\n  const derivedNamespace =\n    namespaceOverrides ||\n    (getCurrentInstance()\n      ? inject(namespaceContextKey, ref(defaultNamespace))\n      : ref(defaultNamespace))\n  const namespace = computed(() => {\n    return unref(derivedNamespace) || defaultNamespace\n  })\n  return namespace\n}\n\nexport const useNamespace = (\n  block: string,\n  namespaceOverrides?: Ref<string | undefined>\n) => {\n  const namespace = useGetDerivedNamespace(namespaceOverrides)\n  const b = (blockSuffix = '') =>\n    _bem(namespace.value, block, blockSuffix, '', '')\n  const e = (element?: string) =>\n    element ? _bem(namespace.value, block, '', element, '') : ''\n  const m = (modifier?: string) =>\n    modifier ? _bem(namespace.value, block, '', '', modifier) : ''\n  const be = (blockSuffix?: string, element?: string) =>\n    blockSuffix && element\n      ? _bem(namespace.value, block, blockSuffix, element, '')\n      : ''\n  const em = (element?: string, modifier?: string) =>\n    element && modifier\n      ? _bem(namespace.value, block, '', element, modifier)\n      : ''\n  const bm = (blockSuffix?: string, modifier?: string) =>\n    blockSuffix && modifier\n      ? _bem(namespace.value, block, blockSuffix, '', modifier)\n      : ''\n  const bem = (blockSuffix?: string, element?: string, modifier?: string) =>\n    blockSuffix && element && modifier\n      ? _bem(namespace.value, block, blockSuffix, element, modifier)\n      : ''\n  const is: {\n    (name: string, state: boolean | undefined): string\n    (name: string): string\n  } = (name: string, ...args: [boolean | undefined] | []) => {\n    const state = args.length >= 1 ? args[0]! : true\n    return name && state ? `${statePrefix}${name}` : ''\n  }\n\n  // for css var\n  // --el-xxx: value;\n  const cssVar = (object: Record<string, string>) => {\n    const styles: Record<string, string> = {}\n    for (const key in object) {\n      if (object[key]) {\n        styles[`--${namespace.value}-${key}`] = object[key]\n      }\n    }\n    return styles\n  }\n  // with block\n  const cssVarBlock = (object: Record<string, string>) => {\n    const styles: Record<string, string> = {}\n    for (const key in object) {\n      if (object[key]) {\n        styles[`--${namespace.value}-${block}-${key}`] = object[key]\n      }\n    }\n    return styles\n  }\n\n  const cssVarName = (name: string) => `--${namespace.value}-${name}`\n  const cssVarBlockName = (name: string) =>\n    `--${namespace.value}-${block}-${name}`\n\n  return {\n    namespace,\n    b,\n    e,\n    m,\n    be,\n    em,\n    bm,\n    bem,\n    is,\n    // css\n    cssVar,\n    cssVarName,\n    cssVarBlock,\n    cssVarBlockName,\n  }\n}\n\nexport type UseNamespaceReturn = ReturnType<typeof useNamespace>\n", "import { computed, isRef, onScopeDispose, watch } from 'vue'\nimport {\n  addClass,\n  getScrollBarWidth,\n  getStyle,\n  hasClass,\n  isClient,\n  removeClass,\n  throwError,\n} from '@element-plus/utils'\nimport { useNamespace } from '../use-namespace'\n\nimport type { Ref } from 'vue'\nimport type { UseNamespaceReturn } from '../use-namespace'\n\nexport type UseLockScreenOptions = {\n  ns?: UseNamespaceReturn\n  // shouldLock?: MaybeRef<boolean>\n}\n\n/**\n * Hook that monitoring the ref value to lock or unlock the screen.\n * When the trigger became true, it assumes modal is now opened and vice versa.\n * @param trigger {Ref<boolean>}\n */\nexport const useLockscreen = (\n  trigger: Ref<boolean>,\n  options: UseLockScreenOptions = {}\n) => {\n  if (!isRef(trigger)) {\n    throwError(\n      '[useLockscreen]',\n      'You need to pass a ref param to this function'\n    )\n  }\n\n  const ns = options.ns || useNamespace('popup')\n\n  const hiddenCls = computed(() => ns.bm('parent', 'hidden'))\n\n  if (!isClient || hasClass(document.body, hiddenCls.value)) {\n    return\n  }\n\n  let scrollBarWidth = 0\n  let withoutHiddenClass = false\n  let bodyWidth = '0'\n\n  const cleanup = () => {\n    setTimeout(() => {\n      removeClass(document?.body, hiddenCls.value)\n      if (withoutHiddenClass && document) {\n        document.body.style.width = bodyWidth\n      }\n    }, 200)\n  }\n  watch(trigger, (val) => {\n    if (!val) {\n      cleanup()\n      return\n    }\n\n    withoutHiddenClass = !hasClass(document.body, hiddenCls.value)\n    if (withoutHiddenClass) {\n      bodyWidth = document.body.style.width\n    }\n    scrollBarWidth = getScrollBarWidth(ns.namespace.value)\n    const bodyHasOverflow =\n      document.documentElement.clientHeight < document.body.scrollHeight\n    const bodyOverflowY = getStyle(document.body, 'overflowY')\n    if (\n      scrollBarWidth > 0 &&\n      (bodyHasOverflow || bodyOverflowY === 'scroll') &&\n      withoutHiddenClass\n    ) {\n      document.body.style.width = `calc(100% - ${scrollBarWidth}px)`\n    }\n    addClass(document.body, hiddenCls.value)\n  })\n  onScopeDispose(() => cleanup())\n}\n", "import { watch } from 'vue'\nimport { isClient, useEventListener } from '@vueuse/core'\nimport { EVENT_CODE } from '@element-plus/constants'\n\nimport type { Ref } from 'vue'\n\ntype ModalInstance = {\n  handleClose: () => void\n}\n\nconst modalStack: ModalInstance[] = []\n\nconst closeModal = (e: KeyboardEvent) => {\n  if (modalStack.length === 0) return\n  if (e.code === EVENT_CODE.esc) {\n    e.stopPropagation()\n    const topModal = modalStack[modalStack.length - 1]\n    topModal.handleClose()\n  }\n}\n\nexport const useModal = (instance: ModalInstance, visibleRef: Ref<boolean>) => {\n  watch(visibleRef, (val) => {\n    if (val) {\n      modalStack.push(instance)\n    } else {\n      modalStack.splice(modalStack.indexOf(instance), 1)\n    }\n  })\n}\n\nif (isClient) useEventListener(document, 'keydown', closeModal)\n", "import { computed, getCurrentInstance, onMounted, watch } from 'vue'\nimport {\n  buildProp,\n  definePropType,\n  isBoolean,\n  isClient,\n  isFunction,\n} from '@element-plus/utils'\nimport type { ExtractPropType } from '@element-plus/utils'\nimport type { RouteLocationNormalizedLoaded } from 'vue-router'\n\nimport type { ComponentPublicInstance, ExtractPropTypes, Ref } from 'vue'\n\nconst _prop = buildProp({\n  type: definePropType<boolean | null>(Boolean),\n  default: null,\n} as const)\nconst _event = buildProp({\n  type: definePropType<(val: boolean) => void>(Function),\n} as const)\n\nexport type UseModelTogglePropsRaw<T extends string> = {\n  [K in T]: typeof _prop\n} & {\n  [K in `onUpdate:${T}`]: typeof _event\n}\n\nexport type UseModelTogglePropsGeneric<T extends string> = {\n  [K in T]: ExtractPropType<typeof _prop>\n} & {\n  [K in `onUpdate:${T}`]: ExtractPropType<typeof _event>\n}\n\nexport const createModelToggleComposable = <T extends string>(name: T) => {\n  const updateEventKey = `update:${name}` as const\n  const updateEventKeyRaw = `onUpdate:${name}` as const\n  const useModelToggleEmits = [updateEventKey]\n\n  const useModelToggleProps = {\n    [name]: _prop,\n    [updateEventKeyRaw]: _event,\n  } as UseModelTogglePropsRaw<T>\n\n  const useModelToggle = ({\n    indicator,\n    toggleReason,\n    shouldHideWhenRouteChanges,\n    shouldProceed,\n    onShow,\n    onHide,\n  }: ModelToggleParams) => {\n    const instance = getCurrentInstance()!\n    const { emit } = instance\n    const props = instance.props as UseModelTogglePropsGeneric<T> & {\n      disabled: boolean\n    }\n    const hasUpdateHandler = computed(() =>\n      isFunction(props[updateEventKeyRaw])\n    )\n    // when it matches the default value we say this is absent\n    // though this could be mistakenly passed from the user but we need to rule out that\n    // condition\n    const isModelBindingAbsent = computed(() => props[name] === null)\n\n    const doShow = (event?: Event) => {\n      if (indicator.value === true) {\n        return\n      }\n\n      indicator.value = true\n      if (toggleReason) {\n        toggleReason.value = event\n      }\n      if (isFunction(onShow)) {\n        onShow(event)\n      }\n    }\n\n    const doHide = (event?: Event) => {\n      if (indicator.value === false) {\n        return\n      }\n\n      indicator.value = false\n      if (toggleReason) {\n        toggleReason.value = event\n      }\n      if (isFunction(onHide)) {\n        onHide(event)\n      }\n    }\n\n    const show = (event?: Event) => {\n      if (\n        props.disabled === true ||\n        (isFunction(shouldProceed) && !shouldProceed())\n      )\n        return\n\n      const shouldEmit = hasUpdateHandler.value && isClient\n\n      if (shouldEmit) {\n        emit(updateEventKey, true)\n      }\n\n      if (isModelBindingAbsent.value || !shouldEmit) {\n        doShow(event)\n      }\n    }\n\n    const hide = (event?: Event) => {\n      if (props.disabled === true || !isClient) return\n\n      const shouldEmit = hasUpdateHandler.value && isClient\n\n      if (shouldEmit) {\n        emit(updateEventKey, false)\n      }\n\n      if (isModelBindingAbsent.value || !shouldEmit) {\n        doHide(event)\n      }\n    }\n\n    const onChange = (val: boolean) => {\n      if (!isBoolean(val)) return\n      if (props.disabled && val) {\n        if (hasUpdateHandler.value) {\n          emit(updateEventKey, false)\n        }\n      } else if (indicator.value !== val) {\n        if (val) {\n          doShow()\n        } else {\n          doHide()\n        }\n      }\n    }\n\n    const toggle = () => {\n      if (indicator.value) {\n        hide()\n      } else {\n        show()\n      }\n    }\n\n    watch(() => props[name], onChange)\n\n    if (\n      shouldHideWhenRouteChanges &&\n      instance.appContext.config.globalProperties.$route !== undefined\n    ) {\n      watch(\n        () => ({\n          ...(\n            instance.proxy as ComponentPublicInstance<{\n              $route: RouteLocationNormalizedLoaded\n            }>\n          ).$route,\n        }),\n        () => {\n          if (shouldHideWhenRouteChanges.value && indicator.value) {\n            hide()\n          }\n        }\n      )\n    }\n\n    onMounted(() => {\n      onChange(props[name])\n    })\n\n    return {\n      hide,\n      show,\n      toggle,\n      hasUpdateHandler,\n    }\n  }\n\n  return {\n    useModelToggle,\n    useModelToggleProps,\n    useModelToggleEmits,\n  }\n}\n\nconst { useModelToggle, useModelToggleProps, useModelToggleEmits } =\n  createModelToggleComposable('modelValue')\n\nexport { useModelToggle, useModelToggleEmits, useModelToggleProps }\n\nexport type UseModelToggleProps = ExtractPropTypes<typeof useModelToggleProps>\n\nexport type ModelToggleParams = {\n  indicator: Ref<boolean>\n  toggleReason?: Ref<Event | undefined>\n  shouldHideWhenRouteChanges?: Ref<boolean>\n  shouldProceed?: () => boolean\n  onShow?: (event?: Event) => void\n  onHide?: (event?: Event) => void\n}\n", "import { watch } from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport type { Ref } from 'vue'\n\nexport const usePreventGlobal = <E extends keyof DocumentEventMap>(\n  indicator: Ref<boolean>,\n  evt: E,\n  cb: (e: DocumentEventMap[E]) => boolean\n) => {\n  const prevent = (e: DocumentEventMap[E]) => {\n    if (cb(e)) e.stopImmediatePropagation()\n  }\n  let stop: (() => void) | undefined = undefined\n  watch(\n    () => indicator.value,\n    (val) => {\n      if (val) {\n        stop = useEventListener(document, evt, prevent, true)\n      } else {\n        stop?.()\n      }\n    },\n    { immediate: true }\n  )\n}\n", "import { computed, getCurrentInstance } from 'vue'\nimport type { ComputedRef } from 'vue'\n\nexport const useProp = <T>(name: string): ComputedRef<T | undefined> => {\n  const vm = getCurrentInstance()\n  return computed(() => (vm?.proxy?.$props as any)?.[name])\n}\n", "var E=\"top\",R=\"bottom\",W=\"right\",P=\"left\",me=\"auto\",G=[E,R,W,P],U=\"start\",J=\"end\",Xe=\"clippingParents\",je=\"viewport\",K=\"popper\",Ye=\"reference\",De=G.reduce(function(t,e){return t.concat([e+\"-\"+U,e+\"-\"+J])},[]),Ee=[].concat(G,[me]).reduce(function(t,e){return t.concat([e,e+\"-\"+U,e+\"-\"+J])},[]),Ge=\"beforeRead\",Je=\"read\",Ke=\"afterRead\",Qe=\"beforeMain\",Ze=\"main\",et=\"afterMain\",tt=\"beforeWrite\",nt=\"write\",rt=\"afterWrite\",ot=[Ge,Je,Ke,Qe,Ze,et,tt,nt,rt];function C(t){return t?(t.nodeName||\"\").toLowerCase():null}function H(t){if(t==null)return window;if(t.toString()!==\"[object Window]\"){var e=t.ownerDocument;return e&&e.defaultView||window}return t}function Q(t){var e=H(t).Element;return t instanceof e||t instanceof Element}function B(t){var e=H(t).HTMLElement;return t instanceof e||t instanceof HTMLElement}function Pe(t){if(typeof ShadowRoot==\"undefined\")return!1;var e=H(t).ShadowRoot;return t instanceof e||t instanceof ShadowRoot}function Mt(t){var e=t.state;Object.keys(e.elements).forEach(function(n){var r=e.styles[n]||{},o=e.attributes[n]||{},i=e.elements[n];!B(i)||!C(i)||(Object.assign(i.style,r),Object.keys(o).forEach(function(a){var s=o[a];s===!1?i.removeAttribute(a):i.setAttribute(a,s===!0?\"\":s)}))})}function Rt(t){var e=t.state,n={popper:{position:e.options.strategy,left:\"0\",top:\"0\",margin:\"0\"},arrow:{position:\"absolute\"},reference:{}};return Object.assign(e.elements.popper.style,n.popper),e.styles=n,e.elements.arrow&&Object.assign(e.elements.arrow.style,n.arrow),function(){Object.keys(e.elements).forEach(function(r){var o=e.elements[r],i=e.attributes[r]||{},a=Object.keys(e.styles.hasOwnProperty(r)?e.styles[r]:n[r]),s=a.reduce(function(f,c){return f[c]=\"\",f},{});!B(o)||!C(o)||(Object.assign(o.style,s),Object.keys(i).forEach(function(f){o.removeAttribute(f)}))})}}var Ae={name:\"applyStyles\",enabled:!0,phase:\"write\",fn:Mt,effect:Rt,requires:[\"computeStyles\"]};function q(t){return t.split(\"-\")[0]}var X=Math.max,ve=Math.min,Z=Math.round;function ee(t,e){e===void 0&&(e=!1);var n=t.getBoundingClientRect(),r=1,o=1;if(B(t)&&e){var i=t.offsetHeight,a=t.offsetWidth;a>0&&(r=Z(n.width)/a||1),i>0&&(o=Z(n.height)/i||1)}return{width:n.width/r,height:n.height/o,top:n.top/o,right:n.right/r,bottom:n.bottom/o,left:n.left/r,x:n.left/r,y:n.top/o}}function ke(t){var e=ee(t),n=t.offsetWidth,r=t.offsetHeight;return Math.abs(e.width-n)<=1&&(n=e.width),Math.abs(e.height-r)<=1&&(r=e.height),{x:t.offsetLeft,y:t.offsetTop,width:n,height:r}}function it(t,e){var n=e.getRootNode&&e.getRootNode();if(t.contains(e))return!0;if(n&&Pe(n)){var r=e;do{if(r&&t.isSameNode(r))return!0;r=r.parentNode||r.host}while(r)}return!1}function N(t){return H(t).getComputedStyle(t)}function Wt(t){return[\"table\",\"td\",\"th\"].indexOf(C(t))>=0}function I(t){return((Q(t)?t.ownerDocument:t.document)||window.document).documentElement}function ge(t){return C(t)===\"html\"?t:t.assignedSlot||t.parentNode||(Pe(t)?t.host:null)||I(t)}function at(t){return!B(t)||N(t).position===\"fixed\"?null:t.offsetParent}function Bt(t){var e=navigator.userAgent.toLowerCase().indexOf(\"firefox\")!==-1,n=navigator.userAgent.indexOf(\"Trident\")!==-1;if(n&&B(t)){var r=N(t);if(r.position===\"fixed\")return null}var o=ge(t);for(Pe(o)&&(o=o.host);B(o)&&[\"html\",\"body\"].indexOf(C(o))<0;){var i=N(o);if(i.transform!==\"none\"||i.perspective!==\"none\"||i.contain===\"paint\"||[\"transform\",\"perspective\"].indexOf(i.willChange)!==-1||e&&i.willChange===\"filter\"||e&&i.filter&&i.filter!==\"none\")return o;o=o.parentNode}return null}function se(t){for(var e=H(t),n=at(t);n&&Wt(n)&&N(n).position===\"static\";)n=at(n);return n&&(C(n)===\"html\"||C(n)===\"body\"&&N(n).position===\"static\")?e:n||Bt(t)||e}function Le(t){return[\"top\",\"bottom\"].indexOf(t)>=0?\"x\":\"y\"}function fe(t,e,n){return X(t,ve(e,n))}function St(t,e,n){var r=fe(t,e,n);return r>n?n:r}function st(){return{top:0,right:0,bottom:0,left:0}}function ft(t){return Object.assign({},st(),t)}function ct(t,e){return e.reduce(function(n,r){return n[r]=t,n},{})}var Tt=function(t,e){return t=typeof t==\"function\"?t(Object.assign({},e.rects,{placement:e.placement})):t,ft(typeof t!=\"number\"?t:ct(t,G))};function Ht(t){var e,n=t.state,r=t.name,o=t.options,i=n.elements.arrow,a=n.modifiersData.popperOffsets,s=q(n.placement),f=Le(s),c=[P,W].indexOf(s)>=0,u=c?\"height\":\"width\";if(!(!i||!a)){var m=Tt(o.padding,n),v=ke(i),l=f===\"y\"?E:P,h=f===\"y\"?R:W,p=n.rects.reference[u]+n.rects.reference[f]-a[f]-n.rects.popper[u],g=a[f]-n.rects.reference[f],x=se(i),y=x?f===\"y\"?x.clientHeight||0:x.clientWidth||0:0,$=p/2-g/2,d=m[l],b=y-v[u]-m[h],w=y/2-v[u]/2+$,O=fe(d,w,b),j=f;n.modifiersData[r]=(e={},e[j]=O,e.centerOffset=O-w,e)}}function Ct(t){var e=t.state,n=t.options,r=n.element,o=r===void 0?\"[data-popper-arrow]\":r;o!=null&&(typeof o==\"string\"&&(o=e.elements.popper.querySelector(o),!o)||!it(e.elements.popper,o)||(e.elements.arrow=o))}var pt={name:\"arrow\",enabled:!0,phase:\"main\",fn:Ht,effect:Ct,requires:[\"popperOffsets\"],requiresIfExists:[\"preventOverflow\"]};function te(t){return t.split(\"-\")[1]}var qt={top:\"auto\",right:\"auto\",bottom:\"auto\",left:\"auto\"};function Vt(t){var e=t.x,n=t.y,r=window,o=r.devicePixelRatio||1;return{x:Z(e*o)/o||0,y:Z(n*o)/o||0}}function ut(t){var e,n=t.popper,r=t.popperRect,o=t.placement,i=t.variation,a=t.offsets,s=t.position,f=t.gpuAcceleration,c=t.adaptive,u=t.roundOffsets,m=t.isFixed,v=a.x,l=v===void 0?0:v,h=a.y,p=h===void 0?0:h,g=typeof u==\"function\"?u({x:l,y:p}):{x:l,y:p};l=g.x,p=g.y;var x=a.hasOwnProperty(\"x\"),y=a.hasOwnProperty(\"y\"),$=P,d=E,b=window;if(c){var w=se(n),O=\"clientHeight\",j=\"clientWidth\";if(w===H(n)&&(w=I(n),N(w).position!==\"static\"&&s===\"absolute\"&&(O=\"scrollHeight\",j=\"scrollWidth\")),w=w,o===E||(o===P||o===W)&&i===J){d=R;var A=m&&w===b&&b.visualViewport?b.visualViewport.height:w[O];p-=A-r.height,p*=f?1:-1}if(o===P||(o===E||o===R)&&i===J){$=W;var k=m&&w===b&&b.visualViewport?b.visualViewport.width:w[j];l-=k-r.width,l*=f?1:-1}}var D=Object.assign({position:s},c&&qt),S=u===!0?Vt({x:l,y:p}):{x:l,y:p};if(l=S.x,p=S.y,f){var L;return Object.assign({},D,(L={},L[d]=y?\"0\":\"\",L[$]=x?\"0\":\"\",L.transform=(b.devicePixelRatio||1)<=1?\"translate(\"+l+\"px, \"+p+\"px)\":\"translate3d(\"+l+\"px, \"+p+\"px, 0)\",L))}return Object.assign({},D,(e={},e[d]=y?p+\"px\":\"\",e[$]=x?l+\"px\":\"\",e.transform=\"\",e))}function Nt(t){var e=t.state,n=t.options,r=n.gpuAcceleration,o=r===void 0?!0:r,i=n.adaptive,a=i===void 0?!0:i,s=n.roundOffsets,f=s===void 0?!0:s,c={placement:q(e.placement),variation:te(e.placement),popper:e.elements.popper,popperRect:e.rects.popper,gpuAcceleration:o,isFixed:e.options.strategy===\"fixed\"};e.modifiersData.popperOffsets!=null&&(e.styles.popper=Object.assign({},e.styles.popper,ut(Object.assign({},c,{offsets:e.modifiersData.popperOffsets,position:e.options.strategy,adaptive:a,roundOffsets:f})))),e.modifiersData.arrow!=null&&(e.styles.arrow=Object.assign({},e.styles.arrow,ut(Object.assign({},c,{offsets:e.modifiersData.arrow,position:\"absolute\",adaptive:!1,roundOffsets:f})))),e.attributes.popper=Object.assign({},e.attributes.popper,{\"data-popper-placement\":e.placement})}var Me={name:\"computeStyles\",enabled:!0,phase:\"beforeWrite\",fn:Nt,data:{}},ye={passive:!0};function It(t){var e=t.state,n=t.instance,r=t.options,o=r.scroll,i=o===void 0?!0:o,a=r.resize,s=a===void 0?!0:a,f=H(e.elements.popper),c=[].concat(e.scrollParents.reference,e.scrollParents.popper);return i&&c.forEach(function(u){u.addEventListener(\"scroll\",n.update,ye)}),s&&f.addEventListener(\"resize\",n.update,ye),function(){i&&c.forEach(function(u){u.removeEventListener(\"scroll\",n.update,ye)}),s&&f.removeEventListener(\"resize\",n.update,ye)}}var Re={name:\"eventListeners\",enabled:!0,phase:\"write\",fn:function(){},effect:It,data:{}},_t={left:\"right\",right:\"left\",bottom:\"top\",top:\"bottom\"};function be(t){return t.replace(/left|right|bottom|top/g,function(e){return _t[e]})}var zt={start:\"end\",end:\"start\"};function lt(t){return t.replace(/start|end/g,function(e){return zt[e]})}function We(t){var e=H(t),n=e.pageXOffset,r=e.pageYOffset;return{scrollLeft:n,scrollTop:r}}function Be(t){return ee(I(t)).left+We(t).scrollLeft}function Ft(t){var e=H(t),n=I(t),r=e.visualViewport,o=n.clientWidth,i=n.clientHeight,a=0,s=0;return r&&(o=r.width,i=r.height,/^((?!chrome|android).)*safari/i.test(navigator.userAgent)||(a=r.offsetLeft,s=r.offsetTop)),{width:o,height:i,x:a+Be(t),y:s}}function Ut(t){var e,n=I(t),r=We(t),o=(e=t.ownerDocument)==null?void 0:e.body,i=X(n.scrollWidth,n.clientWidth,o?o.scrollWidth:0,o?o.clientWidth:0),a=X(n.scrollHeight,n.clientHeight,o?o.scrollHeight:0,o?o.clientHeight:0),s=-r.scrollLeft+Be(t),f=-r.scrollTop;return N(o||n).direction===\"rtl\"&&(s+=X(n.clientWidth,o?o.clientWidth:0)-i),{width:i,height:a,x:s,y:f}}function Se(t){var e=N(t),n=e.overflow,r=e.overflowX,o=e.overflowY;return/auto|scroll|overlay|hidden/.test(n+o+r)}function dt(t){return[\"html\",\"body\",\"#document\"].indexOf(C(t))>=0?t.ownerDocument.body:B(t)&&Se(t)?t:dt(ge(t))}function ce(t,e){var n;e===void 0&&(e=[]);var r=dt(t),o=r===((n=t.ownerDocument)==null?void 0:n.body),i=H(r),a=o?[i].concat(i.visualViewport||[],Se(r)?r:[]):r,s=e.concat(a);return o?s:s.concat(ce(ge(a)))}function Te(t){return Object.assign({},t,{left:t.x,top:t.y,right:t.x+t.width,bottom:t.y+t.height})}function Xt(t){var e=ee(t);return e.top=e.top+t.clientTop,e.left=e.left+t.clientLeft,e.bottom=e.top+t.clientHeight,e.right=e.left+t.clientWidth,e.width=t.clientWidth,e.height=t.clientHeight,e.x=e.left,e.y=e.top,e}function ht(t,e){return e===je?Te(Ft(t)):Q(e)?Xt(e):Te(Ut(I(t)))}function Yt(t){var e=ce(ge(t)),n=[\"absolute\",\"fixed\"].indexOf(N(t).position)>=0,r=n&&B(t)?se(t):t;return Q(r)?e.filter(function(o){return Q(o)&&it(o,r)&&C(o)!==\"body\"}):[]}function Gt(t,e,n){var r=e===\"clippingParents\"?Yt(t):[].concat(e),o=[].concat(r,[n]),i=o[0],a=o.reduce(function(s,f){var c=ht(t,f);return s.top=X(c.top,s.top),s.right=ve(c.right,s.right),s.bottom=ve(c.bottom,s.bottom),s.left=X(c.left,s.left),s},ht(t,i));return a.width=a.right-a.left,a.height=a.bottom-a.top,a.x=a.left,a.y=a.top,a}function mt(t){var e=t.reference,n=t.element,r=t.placement,o=r?q(r):null,i=r?te(r):null,a=e.x+e.width/2-n.width/2,s=e.y+e.height/2-n.height/2,f;switch(o){case E:f={x:a,y:e.y-n.height};break;case R:f={x:a,y:e.y+e.height};break;case W:f={x:e.x+e.width,y:s};break;case P:f={x:e.x-n.width,y:s};break;default:f={x:e.x,y:e.y}}var c=o?Le(o):null;if(c!=null){var u=c===\"y\"?\"height\":\"width\";switch(i){case U:f[c]=f[c]-(e[u]/2-n[u]/2);break;case J:f[c]=f[c]+(e[u]/2-n[u]/2);break}}return f}function ne(t,e){e===void 0&&(e={});var n=e,r=n.placement,o=r===void 0?t.placement:r,i=n.boundary,a=i===void 0?Xe:i,s=n.rootBoundary,f=s===void 0?je:s,c=n.elementContext,u=c===void 0?K:c,m=n.altBoundary,v=m===void 0?!1:m,l=n.padding,h=l===void 0?0:l,p=ft(typeof h!=\"number\"?h:ct(h,G)),g=u===K?Ye:K,x=t.rects.popper,y=t.elements[v?g:u],$=Gt(Q(y)?y:y.contextElement||I(t.elements.popper),a,f),d=ee(t.elements.reference),b=mt({reference:d,element:x,strategy:\"absolute\",placement:o}),w=Te(Object.assign({},x,b)),O=u===K?w:d,j={top:$.top-O.top+p.top,bottom:O.bottom-$.bottom+p.bottom,left:$.left-O.left+p.left,right:O.right-$.right+p.right},A=t.modifiersData.offset;if(u===K&&A){var k=A[o];Object.keys(j).forEach(function(D){var S=[W,R].indexOf(D)>=0?1:-1,L=[E,R].indexOf(D)>=0?\"y\":\"x\";j[D]+=k[L]*S})}return j}function Jt(t,e){e===void 0&&(e={});var n=e,r=n.placement,o=n.boundary,i=n.rootBoundary,a=n.padding,s=n.flipVariations,f=n.allowedAutoPlacements,c=f===void 0?Ee:f,u=te(r),m=u?s?De:De.filter(function(h){return te(h)===u}):G,v=m.filter(function(h){return c.indexOf(h)>=0});v.length===0&&(v=m);var l=v.reduce(function(h,p){return h[p]=ne(t,{placement:p,boundary:o,rootBoundary:i,padding:a})[q(p)],h},{});return Object.keys(l).sort(function(h,p){return l[h]-l[p]})}function Kt(t){if(q(t)===me)return[];var e=be(t);return[lt(t),e,lt(e)]}function Qt(t){var e=t.state,n=t.options,r=t.name;if(!e.modifiersData[r]._skip){for(var o=n.mainAxis,i=o===void 0?!0:o,a=n.altAxis,s=a===void 0?!0:a,f=n.fallbackPlacements,c=n.padding,u=n.boundary,m=n.rootBoundary,v=n.altBoundary,l=n.flipVariations,h=l===void 0?!0:l,p=n.allowedAutoPlacements,g=e.options.placement,x=q(g),y=x===g,$=f||(y||!h?[be(g)]:Kt(g)),d=[g].concat($).reduce(function(z,V){return z.concat(q(V)===me?Jt(e,{placement:V,boundary:u,rootBoundary:m,padding:c,flipVariations:h,allowedAutoPlacements:p}):V)},[]),b=e.rects.reference,w=e.rects.popper,O=new Map,j=!0,A=d[0],k=0;k<d.length;k++){var D=d[k],S=q(D),L=te(D)===U,re=[E,R].indexOf(S)>=0,oe=re?\"width\":\"height\",M=ne(e,{placement:D,boundary:u,rootBoundary:m,altBoundary:v,padding:c}),T=re?L?W:P:L?R:E;b[oe]>w[oe]&&(T=be(T));var pe=be(T),_=[];if(i&&_.push(M[S]<=0),s&&_.push(M[T]<=0,M[pe]<=0),_.every(function(z){return z})){A=D,j=!1;break}O.set(D,_)}if(j)for(var ue=h?3:1,xe=function(z){var V=d.find(function(de){var ae=O.get(de);if(ae)return ae.slice(0,z).every(function(Y){return Y})});if(V)return A=V,\"break\"},ie=ue;ie>0;ie--){var le=xe(ie);if(le===\"break\")break}e.placement!==A&&(e.modifiersData[r]._skip=!0,e.placement=A,e.reset=!0)}}var vt={name:\"flip\",enabled:!0,phase:\"main\",fn:Qt,requiresIfExists:[\"offset\"],data:{_skip:!1}};function gt(t,e,n){return n===void 0&&(n={x:0,y:0}),{top:t.top-e.height-n.y,right:t.right-e.width+n.x,bottom:t.bottom-e.height+n.y,left:t.left-e.width-n.x}}function yt(t){return[E,W,R,P].some(function(e){return t[e]>=0})}function Zt(t){var e=t.state,n=t.name,r=e.rects.reference,o=e.rects.popper,i=e.modifiersData.preventOverflow,a=ne(e,{elementContext:\"reference\"}),s=ne(e,{altBoundary:!0}),f=gt(a,r),c=gt(s,o,i),u=yt(f),m=yt(c);e.modifiersData[n]={referenceClippingOffsets:f,popperEscapeOffsets:c,isReferenceHidden:u,hasPopperEscaped:m},e.attributes.popper=Object.assign({},e.attributes.popper,{\"data-popper-reference-hidden\":u,\"data-popper-escaped\":m})}var bt={name:\"hide\",enabled:!0,phase:\"main\",requiresIfExists:[\"preventOverflow\"],fn:Zt};function en(t,e,n){var r=q(t),o=[P,E].indexOf(r)>=0?-1:1,i=typeof n==\"function\"?n(Object.assign({},e,{placement:t})):n,a=i[0],s=i[1];return a=a||0,s=(s||0)*o,[P,W].indexOf(r)>=0?{x:s,y:a}:{x:a,y:s}}function tn(t){var e=t.state,n=t.options,r=t.name,o=n.offset,i=o===void 0?[0,0]:o,a=Ee.reduce(function(u,m){return u[m]=en(m,e.rects,i),u},{}),s=a[e.placement],f=s.x,c=s.y;e.modifiersData.popperOffsets!=null&&(e.modifiersData.popperOffsets.x+=f,e.modifiersData.popperOffsets.y+=c),e.modifiersData[r]=a}var wt={name:\"offset\",enabled:!0,phase:\"main\",requires:[\"popperOffsets\"],fn:tn};function nn(t){var e=t.state,n=t.name;e.modifiersData[n]=mt({reference:e.rects.reference,element:e.rects.popper,strategy:\"absolute\",placement:e.placement})}var He={name:\"popperOffsets\",enabled:!0,phase:\"read\",fn:nn,data:{}};function rn(t){return t===\"x\"?\"y\":\"x\"}function on(t){var e=t.state,n=t.options,r=t.name,o=n.mainAxis,i=o===void 0?!0:o,a=n.altAxis,s=a===void 0?!1:a,f=n.boundary,c=n.rootBoundary,u=n.altBoundary,m=n.padding,v=n.tether,l=v===void 0?!0:v,h=n.tetherOffset,p=h===void 0?0:h,g=ne(e,{boundary:f,rootBoundary:c,padding:m,altBoundary:u}),x=q(e.placement),y=te(e.placement),$=!y,d=Le(x),b=rn(d),w=e.modifiersData.popperOffsets,O=e.rects.reference,j=e.rects.popper,A=typeof p==\"function\"?p(Object.assign({},e.rects,{placement:e.placement})):p,k=typeof A==\"number\"?{mainAxis:A,altAxis:A}:Object.assign({mainAxis:0,altAxis:0},A),D=e.modifiersData.offset?e.modifiersData.offset[e.placement]:null,S={x:0,y:0};if(w){if(i){var L,re=d===\"y\"?E:P,oe=d===\"y\"?R:W,M=d===\"y\"?\"height\":\"width\",T=w[d],pe=T+g[re],_=T-g[oe],ue=l?-j[M]/2:0,xe=y===U?O[M]:j[M],ie=y===U?-j[M]:-O[M],le=e.elements.arrow,z=l&&le?ke(le):{width:0,height:0},V=e.modifiersData[\"arrow#persistent\"]?e.modifiersData[\"arrow#persistent\"].padding:st(),de=V[re],ae=V[oe],Y=fe(0,O[M],z[M]),jt=$?O[M]/2-ue-Y-de-k.mainAxis:xe-Y-de-k.mainAxis,Dt=$?-O[M]/2+ue+Y+ae+k.mainAxis:ie+Y+ae+k.mainAxis,Oe=e.elements.arrow&&se(e.elements.arrow),Et=Oe?d===\"y\"?Oe.clientTop||0:Oe.clientLeft||0:0,Ce=(L=D==null?void 0:D[d])!=null?L:0,Pt=T+jt-Ce-Et,At=T+Dt-Ce,qe=fe(l?ve(pe,Pt):pe,T,l?X(_,At):_);w[d]=qe,S[d]=qe-T}if(s){var Ve,kt=d===\"x\"?E:P,Lt=d===\"x\"?R:W,F=w[b],he=b===\"y\"?\"height\":\"width\",Ne=F+g[kt],Ie=F-g[Lt],$e=[E,P].indexOf(x)!==-1,_e=(Ve=D==null?void 0:D[b])!=null?Ve:0,ze=$e?Ne:F-O[he]-j[he]-_e+k.altAxis,Fe=$e?F+O[he]+j[he]-_e-k.altAxis:Ie,Ue=l&&$e?St(ze,F,Fe):fe(l?ze:Ne,F,l?Fe:Ie);w[b]=Ue,S[b]=Ue-F}e.modifiersData[r]=S}}var xt={name:\"preventOverflow\",enabled:!0,phase:\"main\",fn:on,requiresIfExists:[\"offset\"]};function an(t){return{scrollLeft:t.scrollLeft,scrollTop:t.scrollTop}}function sn(t){return t===H(t)||!B(t)?We(t):an(t)}function fn(t){var e=t.getBoundingClientRect(),n=Z(e.width)/t.offsetWidth||1,r=Z(e.height)/t.offsetHeight||1;return n!==1||r!==1}function cn(t,e,n){n===void 0&&(n=!1);var r=B(e),o=B(e)&&fn(e),i=I(e),a=ee(t,o),s={scrollLeft:0,scrollTop:0},f={x:0,y:0};return(r||!r&&!n)&&((C(e)!==\"body\"||Se(i))&&(s=sn(e)),B(e)?(f=ee(e,!0),f.x+=e.clientLeft,f.y+=e.clientTop):i&&(f.x=Be(i))),{x:a.left+s.scrollLeft-f.x,y:a.top+s.scrollTop-f.y,width:a.width,height:a.height}}function pn(t){var e=new Map,n=new Set,r=[];t.forEach(function(i){e.set(i.name,i)});function o(i){n.add(i.name);var a=[].concat(i.requires||[],i.requiresIfExists||[]);a.forEach(function(s){if(!n.has(s)){var f=e.get(s);f&&o(f)}}),r.push(i)}return t.forEach(function(i){n.has(i.name)||o(i)}),r}function un(t){var e=pn(t);return ot.reduce(function(n,r){return n.concat(e.filter(function(o){return o.phase===r}))},[])}function ln(t){var e;return function(){return e||(e=new Promise(function(n){Promise.resolve().then(function(){e=void 0,n(t())})})),e}}function dn(t){var e=t.reduce(function(n,r){var o=n[r.name];return n[r.name]=o?Object.assign({},o,r,{options:Object.assign({},o.options,r.options),data:Object.assign({},o.data,r.data)}):r,n},{});return Object.keys(e).map(function(n){return e[n]})}var Ot={placement:\"bottom\",modifiers:[],strategy:\"absolute\"};function $t(){for(var t=arguments.length,e=new Array(t),n=0;n<t;n++)e[n]=arguments[n];return!e.some(function(r){return!(r&&typeof r.getBoundingClientRect==\"function\")})}function we(t){t===void 0&&(t={});var e=t,n=e.defaultModifiers,r=n===void 0?[]:n,o=e.defaultOptions,i=o===void 0?Ot:o;return function(a,s,f){f===void 0&&(f=i);var c={placement:\"bottom\",orderedModifiers:[],options:Object.assign({},Ot,i),modifiersData:{},elements:{reference:a,popper:s},attributes:{},styles:{}},u=[],m=!1,v={state:c,setOptions:function(p){var g=typeof p==\"function\"?p(c.options):p;h(),c.options=Object.assign({},i,c.options,g),c.scrollParents={reference:Q(a)?ce(a):a.contextElement?ce(a.contextElement):[],popper:ce(s)};var x=un(dn([].concat(r,c.options.modifiers)));return c.orderedModifiers=x.filter(function(y){return y.enabled}),l(),v.update()},forceUpdate:function(){if(!m){var p=c.elements,g=p.reference,x=p.popper;if($t(g,x)){c.rects={reference:cn(g,se(x),c.options.strategy===\"fixed\"),popper:ke(x)},c.reset=!1,c.placement=c.options.placement,c.orderedModifiers.forEach(function(j){return c.modifiersData[j.name]=Object.assign({},j.data)});for(var y=0;y<c.orderedModifiers.length;y++){if(c.reset===!0){c.reset=!1,y=-1;continue}var $=c.orderedModifiers[y],d=$.fn,b=$.options,w=b===void 0?{}:b,O=$.name;typeof d==\"function\"&&(c=d({state:c,options:w,name:O,instance:v})||c)}}}},update:ln(function(){return new Promise(function(p){v.forceUpdate(),p(c)})}),destroy:function(){h(),m=!0}};if(!$t(a,s))return v;v.setOptions(f).then(function(p){!m&&f.onFirstUpdate&&f.onFirstUpdate(p)});function l(){c.orderedModifiers.forEach(function(p){var g=p.name,x=p.options,y=x===void 0?{}:x,$=p.effect;if(typeof $==\"function\"){var d=$({state:c,name:g,instance:v,options:y}),b=function(){};u.push(d||b)}})}function h(){u.forEach(function(p){return p()}),u=[]}return v}}var hn=we(),mn=[Re,He,Me,Ae],vn=we({defaultModifiers:mn}),gn=[Re,He,Me,Ae,wt,vt,xt,pt,bt],yn=we({defaultModifiers:gn});export{et as afterMain,Ke as afterRead,rt as afterWrite,Ae as applyStyles,pt as arrow,me as auto,G as basePlacements,Qe as beforeMain,Ge as beforeRead,tt as beforeWrite,R as bottom,Xe as clippingParents,Me as computeStyles,yn as createPopper,hn as createPopperBase,vn as createPopperLite,ne as detectOverflow,J as end,Re as eventListeners,vt as flip,bt as hide,P as left,Ze as main,ot as modifierPhases,wt as offset,Ee as placements,K as popper,we as popperGenerator,He as popperOffsets,xt as preventOverflow,Je as read,Ye as reference,W as right,U as start,E as top,De as variationPlacements,je as viewport,nt as write};\n", "import { computed, onBeforeUnmount, ref, shallowRef, unref, watch } from 'vue'\nimport { createPopper } from '@popperjs/core'\nimport { fromPairs } from 'lodash-unified'\n\nimport type { Ref } from 'vue'\nimport type {\n  Instance,\n  Modifier,\n  Options,\n  State,\n  VirtualElement,\n} from '@popperjs/core'\n\ntype ElementType = HTMLElement | undefined\ntype ReferenceElement = ElementType | VirtualElement\nexport type PartialOptions = Partial<Options>\n\nexport const usePopper = (\n  referenceElementRef: Ref<ReferenceElement>,\n  popperElementRef: Ref<ElementType>,\n  opts: Ref<PartialOptions> | PartialOptions = {} as PartialOptions\n) => {\n  const stateUpdater = {\n    name: 'updateState',\n    enabled: true,\n    phase: 'write',\n    fn: ({ state }) => {\n      const derivedState = deriveState(state)\n\n      Object.assign(states.value, derivedState)\n    },\n    requires: ['computeStyles'],\n  } as Modifier<'updateState', any>\n\n  const options = computed<Options>(() => {\n    const { onFirstUpdate, placement, strategy, modifiers } = unref(opts)\n\n    return {\n      onFirstUpdate,\n      placement: placement || 'bottom',\n      strategy: strategy || 'absolute',\n      modifiers: [\n        ...(modifiers || []),\n        stateUpdater,\n        { name: 'applyStyles', enabled: false },\n      ],\n    }\n  })\n\n  const instanceRef = shallowRef<Instance | undefined>()\n  const states = ref<Pick<State, 'styles' | 'attributes'>>({\n    styles: {\n      popper: {\n        position: unref(options).strategy,\n        left: '0',\n        top: '0',\n      },\n      arrow: {\n        position: 'absolute',\n      },\n    },\n    attributes: {},\n  })\n\n  const destroy = () => {\n    if (!instanceRef.value) return\n\n    instanceRef.value.destroy()\n    instanceRef.value = undefined\n  }\n\n  watch(\n    options,\n    (newOptions) => {\n      const instance = unref(instanceRef)\n      if (instance) {\n        instance.setOptions(newOptions)\n      }\n    },\n    {\n      deep: true,\n    }\n  )\n\n  watch(\n    [referenceElementRef, popperElementRef],\n    ([referenceElement, popperElement]) => {\n      destroy()\n      if (!referenceElement || !popperElement) return\n\n      instanceRef.value = createPopper(\n        referenceElement,\n        popperElement,\n        unref(options)\n      )\n    }\n  )\n\n  onBeforeUnmount(() => {\n    destroy()\n  })\n\n  return {\n    state: computed(() => ({ ...(unref(instanceRef)?.state || {}) })),\n    styles: computed(() => unref(states).styles),\n    attributes: computed(() => unref(states).attributes),\n    update: () => unref(instanceRef)?.update(),\n    forceUpdate: () => unref(instanceRef)?.forceUpdate(),\n    // Preventing end users from modifying the instance.\n    instanceRef: computed(() => unref(instanceRef)),\n  }\n}\n\nfunction deriveState(state: State) {\n  const elements = Object.keys(state.elements) as unknown as Array<\n    keyof State['elements']\n  >\n\n  const styles = fromPairs(\n    elements.map(\n      (element) =>\n        [element, state.styles[element] || {}] as [\n          string,\n          State['styles'][keyof State['styles']]\n        ]\n    )\n  )\n\n  const attributes = fromPairs(\n    elements.map(\n      (element) =>\n        [element, state.attributes[element]] as [\n          string,\n          State['attributes'][keyof State['attributes']]\n        ]\n    )\n  )\n\n  return {\n    styles,\n    attributes,\n  }\n}\n\nexport type UsePopperReturn = ReturnType<typeof usePopper>\n", "import { NOOP } from '@element-plus/utils'\n\nexport const useSameTarget = (handleClick?: (e: MouseEvent) => void) => {\n  if (!handleClick) {\n    return { onClick: NOOP, onMousedown: NOOP, onMouseup: NOOP }\n  }\n\n  let mousedownTarget = false\n  let mouseupTarget = false\n  // refer to this https://javascript.info/mouse-events-basics\n  // events fired in the order: mousedown -> mouseup -> click\n  // we need to set the mousedown handle to false after click fired.\n  const onClick = (e: MouseEvent) => {\n    // if and only if\n    if (mousedownTarget && mouseupTarget) {\n      handleClick(e)\n    }\n    mousedownTarget = mouseupTarget = false\n  }\n\n  const onMousedown = (e: MouseEvent) => {\n    // marking current mousedown target.\n    mousedownTarget = e.target === e.currentTarget\n  }\n  const onMouseup = (e: MouseEvent) => {\n    // marking current mouseup target.\n    mouseupTarget = e.target === e.currentTarget\n  }\n\n  return { onClick, onMousedown, onMouseup }\n}\n", "import { Teleport, h, onUnmounted, ref } from 'vue'\nimport {\n  NOOP,\n  createGlobalNode,\n  isClient,\n  removeGlobalNode,\n} from '@element-plus/utils'\n\nimport type { Ref, VNode } from 'vue'\n\nexport const useTeleport = (\n  contentRenderer: () => VNode,\n  appendToBody: Ref<boolean>\n) => {\n  const isTeleportVisible = ref(false)\n\n  if (!isClient) {\n    return {\n      isTeleportVisible,\n      showTeleport: NOOP,\n      hideTeleport: NOOP,\n      renderTeleport: NOOP,\n    }\n  }\n\n  let $el: HTMLElement | null = null\n\n  const showTeleport = () => {\n    isTeleportVisible.value = true\n    // this allows the delayed showing strategy since the the content itself could be enterable\n    // e.g. el-popper\n    if ($el !== null) return\n\n    $el = createGlobalNode()\n  }\n\n  const hideTeleport = () => {\n    isTeleportVisible.value = false\n    if ($el !== null) {\n      removeGlobalNode($el)\n      $el = null\n    }\n  }\n\n  const renderTeleport = () => {\n    return appendToBody.value !== true\n      ? contentRenderer()\n      : isTeleportVisible.value\n      ? [h(Teleport, { to: $el }, contentRenderer())]\n      : undefined\n  }\n\n  onUnmounted(hideTeleport)\n\n  return {\n    isTeleportVisible,\n    showTeleport,\n    hideTeleport,\n    renderTeleport,\n  }\n}\n", "import { onMounted, ref, watch } from 'vue'\n\nimport type { Ref } from 'vue'\n\nexport const useThrottleRender = (loading: Ref<boolean>, throttle = 0) => {\n  if (throttle === 0) return loading\n  const throttled = ref(false)\n  let timeoutHandle: ReturnType<typeof setTimeout> | null = null\n\n  const dispatchThrottling = () => {\n    if (timeoutHandle) {\n      clearTimeout(timeoutHandle)\n    }\n    timeoutHandle = setTimeout(() => {\n      throttled.value = loading.value\n    }, throttle)\n  }\n  onMounted(dispatchThrottling)\n\n  watch(\n    () => loading.value,\n    (val) => {\n      if (val) {\n        dispatchThrottling()\n      } else {\n        throttled.value = val\n      }\n    }\n  )\n  return throttled\n}\n", "import { tryOnScopeDispose } from '@vueuse/core'\n\nexport function useTimeout() {\n  let timeoutHandle: number\n\n  const registerTimeout = (fn: (...args: any[]) => any, delay: number) => {\n    cancelTimeout()\n    timeoutHandle = window.setTimeout(fn, delay)\n  }\n  const cancelTimeout = () => window.clearTimeout(timeoutHandle)\n\n  tryOnScopeDispose(() => cancelTimeout())\n\n  return {\n    registerTimeout,\n    cancelTimeout,\n  }\n}\n", "/* istanbul ignore file */\nimport { getCurrentInstance } from 'vue'\n\nconst AFTER_APPEAR = 'after-appear'\nconst AFTER_ENTER = 'after-enter'\nconst AFTER_LEAVE = 'after-leave'\nconst APPEAR = 'appear'\nconst APPEAR_CANCELLED = 'appear-cancelled'\nconst BEFORE_ENTER = 'before-enter'\nconst BEFORE_LEAVE = 'before-leave'\nconst ENTER = 'enter'\nconst ENTER_CANCELLED = 'enter-cancelled'\nconst LEAVE = 'leave'\nconst LEAVE_CANCELLED = 'leave-cancelled'\n\nexport const useTransitionFallthroughEmits = [\n  AFTER_APPEAR,\n  AFTER_ENTER,\n  AFTER_LEAVE,\n  APPEAR,\n  APPEAR_CANCELLED,\n  BEFORE_ENTER,\n  BEFORE_LEAVE,\n  ENTER,\n  ENTER_CANCELLED,\n  LEAVE,\n  LEAVE_CANCELLED,\n] as const\n\n// Sometimes we want to delegate the transition emitted event\n// we have to right the function locally, which is not a good\n// approach to this, so we created this hook for the event\n// fallthrough\n\n/**\n * NOTE:\n * This is only a delegator for delegating transition callbacks.\n * Use this at your need.\n */\n\n/**\n * Simple usage\n *\n * In your setups:\n *\n * setup() {\n *   const fallthroughMethods = useTransitionFallthrough()\n *   return fallthrough\n * }\n *\n * In your template:\n *\n * <template>\n *  <transition name=\"whatever\" v-bind=\"fallthrough\">\n *    <slot />\n *  </transition>\n * </template>\n *\n */\n\nexport const useTransitionFallthrough = () => {\n  const { emit } = getCurrentInstance()!\n\n  return {\n    onAfterAppear: () => {\n      emit(AFTER_APPEAR)\n    },\n    onAfterEnter: () => {\n      emit(AFTER_ENTER)\n    },\n    onAfterLeave: () => {\n      emit(AFTER_LEAVE)\n    },\n    onAppearCancelled: () => {\n      emit(APPEAR_CANCELLED)\n    },\n    onBeforeEnter: () => {\n      emit(BEFORE_ENTER)\n    },\n    onBeforeLeave: () => {\n      emit(BEFORE_LEAVE)\n    },\n    onEnter: () => {\n      emit(ENTER)\n    },\n    onEnterCancelled: () => {\n      emit(ENTER_CANCELLED)\n    },\n    onLeave: () => {\n      emit(LEAVE)\n    },\n    onLeaveCancelled: () => {\n      emit(LEAVE_CANCELLED)\n    },\n  }\n}\n", "import { computed, getCurrentInstance, inject, unref } from 'vue'\nimport { debugWarn, isClient } from '@element-plus/utils'\nimport { useGetDerivedNamespace } from '../use-namespace'\n\nimport type { InjectionKey, Ref } from 'vue'\nimport type { MaybeRef } from '@vueuse/core'\n\nexport type ElIdInjectionContext = {\n  prefix: number\n  current: number\n}\n\nconst defaultIdInjection = {\n  prefix: Math.floor(Math.random() * 10000),\n  current: 0,\n}\n\nexport const ID_INJECTION_KEY: InjectionKey<ElIdInjectionContext> =\n  Symbol('elIdInjection')\n\nexport const useIdInjection = (): ElIdInjectionContext => {\n  return getCurrentInstance()\n    ? inject(ID_INJECTION_KEY, defaultIdInjection)\n    : defaultIdInjection\n}\n\nexport const useId = (deterministicId?: MaybeRef<string>): Ref<string> => {\n  const idInjection = useIdInjection()\n  if (!isClient && idInjection === defaultIdInjection) {\n    debugWarn(\n      'IdInjection',\n      `Looks like you are using server rendering, you must provide a id provider to ensure the hydration process to be succeed\nusage: app.provide(ID_INJECTION_KEY, {\n  prefix: number,\n  current: number,\n})`\n    )\n  }\n\n  const namespace = useGetDerivedNamespace()\n  const idRef = computed(\n    () =>\n      unref(deterministicId) ||\n      `${namespace.value}-id-${idInjection.prefix}-${idInjection.current++}`\n  )\n\n  return idRef\n}\n", "import { onBeforeUnmount, onMounted } from 'vue'\nimport { isClient } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\n\nlet registeredEscapeHandlers: ((e: KeyboardEvent) => void)[] = []\n\nconst cachedHandler = (e: Event) => {\n  const event = e as KeyboardEvent\n  if (event.key === EVENT_CODE.esc) {\n    registeredEscapeHandlers.forEach((registeredHandler) =>\n      registeredHandler(event)\n    )\n  }\n}\n\nexport const useEscapeKeydown = (handler: (e: KeyboardEvent) => void) => {\n  onMounted(() => {\n    if (registeredEscapeHandlers.length === 0) {\n      document.addEventListener('keydown', cachedHandler)\n    }\n    if (isClient) registeredEscapeHandlers.push(handler)\n  })\n\n  onBeforeUnmount(() => {\n    registeredEscapeHandlers = registeredEscapeHandlers.filter(\n      (registeredHandler) => registeredHandler !== handler\n    )\n    if (registeredEscapeHandlers.length === 0) {\n      if (isClient) document.removeEventListener('keydown', cachedHandler)\n    }\n  })\n}\n", "import { computed, onBeforeMount } from 'vue'\nimport { isClient } from '@element-plus/utils'\nimport { useGetDerivedNamespace } from '../use-namespace'\nimport { useIdInjection } from '../use-id'\n\nlet cachedContainer: HTMLElement\n\nexport const usePopperContainerId = () => {\n  const namespace = useGetDerivedNamespace()\n  const idInjection = useIdInjection()\n\n  const id = computed(() => {\n    return `${namespace.value}-popper-container-${idInjection.prefix}`\n  })\n  const selector = computed(() => `#${id.value}`)\n\n  return {\n    id,\n    selector,\n  }\n}\n\nconst createContainer = (id: string) => {\n  const container = document.createElement('div')\n  container.id = id\n  document.body.appendChild(container)\n  return container\n}\n\nexport const usePopperContainer = () => {\n  const { id, selector } = usePopperContainerId()\n  onBeforeMount(() => {\n    if (!isClient) return\n\n    // This is for bypassing the error that when under testing env, we often encounter\n    // document.body.innerHTML = '' situation\n    // for this we need to disable the caching since it's not really needed\n    if (\n      process.env.NODE_ENV === 'test' ||\n      !cachedContainer ||\n      !document.body.querySelector(selector.value)\n    ) {\n      cachedContainer = createContainer(id.value)\n    }\n  })\n\n  return {\n    id,\n    selector,\n  }\n}\n", "import { nextTick, unref, watch } from 'vue'\n\nimport type { Ref } from 'vue'\n\nexport type UseDelayedRenderProps = {\n  indicator: Ref<boolean>\n  intermediateIndicator: Ref<boolean>\n  shouldSetIntermediate?: (step: 'show' | 'hide') => boolean\n  beforeShow?: () => void\n  beforeHide?: () => void\n  afterShow?: () => void\n  afterHide?: () => void\n}\n\nexport const useDelayedRender = ({\n  indicator,\n  intermediateIndicator,\n  shouldSetIntermediate = () => true,\n  beforeShow,\n  afterShow,\n  afterHide,\n  beforeHide,\n}: UseDelayedRenderProps) => {\n  watch(\n    () => unref(indicator),\n    (val) => {\n      if (val) {\n        beforeShow?.()\n        nextTick(() => {\n          if (!unref(indicator)) return\n          if (shouldSetIntermediate('show')) {\n            intermediateIndicator.value = true\n          }\n        })\n      } else {\n        beforeHide?.()\n        nextTick(() => {\n          if (unref(indicator)) return\n\n          if (shouldSetIntermediate('hide')) {\n            intermediateIndicator.value = false\n          }\n        })\n      }\n    }\n  )\n\n  // because we don't always set the value ourselves, so that we\n  // simply watch the value's state, then invoke the corresponding hook.\n  watch(\n    () => intermediateIndicator.value,\n    (val) => {\n      if (val) {\n        afterShow?.()\n      } else {\n        afterHide?.()\n      }\n    }\n  )\n}\n", "import { unref } from 'vue'\nimport { buildProps, isNumber } from '@element-plus/utils'\nimport { useTimeout } from '../use-timeout'\n\nimport type { ExtractPropTypes, ToRefs } from 'vue'\n\nexport const useDelayedToggleProps = buildProps({\n  /**\n   * @description delay of appearance, in millisecond\n   */\n  showAfter: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description delay of disappear, in millisecond\n   */\n  hideAfter: {\n    type: Number,\n    default: 200,\n  },\n  /**\n   * @description disappear automatically, in millisecond\n   */\n  autoClose: {\n    type: Number,\n    default: 0,\n  },\n} as const)\n\nexport type UseDelayedToggleProps = {\n  open: (event?: Event) => void\n  close: (event?: Event) => void\n} & ToRefs<ExtractPropTypes<typeof useDelayedToggleProps>>\n\nexport const useDelayedToggle = ({\n  showAfter,\n  hideAfter,\n  autoClose,\n  open,\n  close,\n}: UseDelayedToggleProps) => {\n  const { registerTimeout } = useTimeout()\n  const {\n    registerTimeout: registerTimeoutForAutoClose,\n    cancelTimeout: cancelTimeoutForAutoClose,\n  } = useTimeout()\n\n  const onOpen = (event?: Event) => {\n    registerTimeout(() => {\n      open(event)\n\n      const _autoClose = unref(autoClose)\n      if (isNumber(_autoClose) && _autoClose > 0) {\n        registerTimeoutForAutoClose(() => {\n          close(event)\n        }, _autoClose)\n      }\n    }, unref(showAfter))\n  }\n\n  const onClose = (event?: Event) => {\n    cancelTimeoutForAutoClose()\n\n    registerTimeout(() => {\n      close(event)\n    }, unref(hideAfter))\n  }\n\n  return {\n    onOpen,\n    onClose,\n  }\n}\n", "import { provide } from 'vue'\n\nimport type { InjectionKey, ObjectDirective, Ref } from 'vue'\n\ntype ForwardRefSetter = <T>(el: T) => void\n\nexport type ForwardRefInjectionContext = {\n  setForwardRef: ForwardRefSetter\n}\n\nexport const FORWARD_REF_INJECTION_KEY: InjectionKey<ForwardRefInjectionContext> =\n  Symbol('elForwardRef')\n\nexport const useForwardRef = <T>(forwardRef: Ref<T | null>) => {\n  const setForwardRef = (el: T) => {\n    forwardRef.value = el\n  }\n\n  provide(FORWARD_REF_INJECTION_KEY, {\n    setForwardRef,\n  })\n}\n\nexport const useForwardRefDirective = (\n  setForwardRef: ForwardRefSetter\n): ObjectDirective => {\n  return {\n    mounted(el) {\n      setForwardRef(el)\n    },\n    updated(el) {\n      setForwardRef(el)\n    },\n    unmounted() {\n      setForwardRef(null)\n    },\n  }\n}\n", "import { computed, getCurrentInstance, inject, ref, unref } from 'vue'\nimport { debugWarn, isClient, isNumber } from '@element-plus/utils'\n\nimport type { InjectionKey, Ref } from 'vue'\n\nexport interface ElZIndexInjectionContext {\n  current: number\n}\n\nconst initial: ElZIndexInjectionContext = {\n  current: 0,\n}\n\nconst zIndex = ref(0)\n\nexport const defaultInitialZIndex = 2000\n\n// For SSR\nexport const ZINDEX_INJECTION_KEY: InjectionKey<ElZIndexInjectionContext> =\n  Symbol('elZIndexContextKey')\n\nexport const zIndexContextKey: InjectionKey<Ref<number | undefined>> =\n  Symbol('zIndexContextKey')\n\nexport const useZIndex = (zIndexOverrides?: Ref<number>) => {\n  const increasingInjection = getCurrentInstance()\n    ? inject(ZINDEX_INJECTION_KEY, initial)\n    : initial\n\n  const zIndexInjection =\n    zIndexOverrides ||\n    (getCurrentInstance() ? inject(zIndexContextKey, undefined) : undefined)\n\n  const initialZIndex = computed(() => {\n    const zIndexFromInjection = unref(zIndexInjection)\n    return isNumber(zIndexFromInjection)\n      ? zIndexFromInjection\n      : defaultInitialZIndex\n  })\n\n  const currentZIndex = computed(() => initialZIndex.value + zIndex.value)\n\n  const nextZIndex = () => {\n    increasingInjection.current++\n    zIndex.value = increasingInjection.current\n    return currentZIndex.value\n  }\n\n  if (!isClient && !inject(ZINDEX_INJECTION_KEY)) {\n    debugWarn(\n      'ZIndexInjection',\n      `Looks like you are using server rendering, you must provide a z-index provider to ensure the hydration process to be succeed\nusage: app.provide(ZINDEX_INJECTION_KEY, { current: 0 })`\n    )\n  }\n\n  return {\n    initialZIndex,\n    currentZIndex,\n    nextZIndex,\n  }\n}\n\nexport type UseZIndexReturn = ReturnType<typeof useZIndex>\n", "/**\n * Custom positioning reference element.\n * @see https://floating-ui.com/docs/virtual-elements\n */\n\nconst sides = ['top', 'right', 'bottom', 'left'];\nconst alignments = ['start', 'end'];\nconst placements = /*#__PURE__*/sides.reduce((acc, side) => acc.concat(side, side + \"-\" + alignments[0], side + \"-\" + alignments[1]), []);\nconst min = Math.min;\nconst max = Math.max;\nconst round = Math.round;\nconst floor = Math.floor;\nconst createCoords = v => ({\n  x: v,\n  y: v\n});\nconst oppositeSideMap = {\n  left: 'right',\n  right: 'left',\n  bottom: 'top',\n  top: 'bottom'\n};\nconst oppositeAlignmentMap = {\n  start: 'end',\n  end: 'start'\n};\nfunction clamp(start, value, end) {\n  return max(start, min(value, end));\n}\nfunction evaluate(value, param) {\n  return typeof value === 'function' ? value(param) : value;\n}\nfunction getSide(placement) {\n  return placement.split('-')[0];\n}\nfunction getAlignment(placement) {\n  return placement.split('-')[1];\n}\nfunction getOppositeAxis(axis) {\n  return axis === 'x' ? 'y' : 'x';\n}\nfunction getAxisLength(axis) {\n  return axis === 'y' ? 'height' : 'width';\n}\nfunction getSideAxis(placement) {\n  return ['top', 'bottom'].includes(getSide(placement)) ? 'y' : 'x';\n}\nfunction getAlignmentAxis(placement) {\n  return getOppositeAxis(getSideAxis(placement));\n}\nfunction getAlignmentSides(placement, rects, rtl) {\n  if (rtl === void 0) {\n    rtl = false;\n  }\n  const alignment = getAlignment(placement);\n  const alignmentAxis = getAlignmentAxis(placement);\n  const length = getAxisLength(alignmentAxis);\n  let mainAlignmentSide = alignmentAxis === 'x' ? alignment === (rtl ? 'end' : 'start') ? 'right' : 'left' : alignment === 'start' ? 'bottom' : 'top';\n  if (rects.reference[length] > rects.floating[length]) {\n    mainAlignmentSide = getOppositePlacement(mainAlignmentSide);\n  }\n  return [mainAlignmentSide, getOppositePlacement(mainAlignmentSide)];\n}\nfunction getExpandedPlacements(placement) {\n  const oppositePlacement = getOppositePlacement(placement);\n  return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)];\n}\nfunction getOppositeAlignmentPlacement(placement) {\n  return placement.replace(/start|end/g, alignment => oppositeAlignmentMap[alignment]);\n}\nfunction getSideList(side, isStart, rtl) {\n  const lr = ['left', 'right'];\n  const rl = ['right', 'left'];\n  const tb = ['top', 'bottom'];\n  const bt = ['bottom', 'top'];\n  switch (side) {\n    case 'top':\n    case 'bottom':\n      if (rtl) return isStart ? rl : lr;\n      return isStart ? lr : rl;\n    case 'left':\n    case 'right':\n      return isStart ? tb : bt;\n    default:\n      return [];\n  }\n}\nfunction getOppositeAxisPlacements(placement, flipAlignment, direction, rtl) {\n  const alignment = getAlignment(placement);\n  let list = getSideList(getSide(placement), direction === 'start', rtl);\n  if (alignment) {\n    list = list.map(side => side + \"-\" + alignment);\n    if (flipAlignment) {\n      list = list.concat(list.map(getOppositeAlignmentPlacement));\n    }\n  }\n  return list;\n}\nfunction getOppositePlacement(placement) {\n  return placement.replace(/left|right|bottom|top/g, side => oppositeSideMap[side]);\n}\nfunction expandPaddingObject(padding) {\n  return {\n    top: 0,\n    right: 0,\n    bottom: 0,\n    left: 0,\n    ...padding\n  };\n}\nfunction getPaddingObject(padding) {\n  return typeof padding !== 'number' ? expandPaddingObject(padding) : {\n    top: padding,\n    right: padding,\n    bottom: padding,\n    left: padding\n  };\n}\nfunction rectToClientRect(rect) {\n  return {\n    ...rect,\n    top: rect.y,\n    left: rect.x,\n    right: rect.x + rect.width,\n    bottom: rect.y + rect.height\n  };\n}\n\nexport { alignments, clamp, createCoords, evaluate, expandPaddingObject, floor, getAlignment, getAlignmentAxis, getAlignmentSides, getAxisLength, getExpandedPlacements, getOppositeAlignmentPlacement, getOppositeAxis, getOppositeAxisPlacements, getOppositePlacement, getPaddingObject, getSide, getSideAxis, max, min, placements, rectToClientRect, round, sides };\n", "import { getSideAxis, getAlignmentAxis, getAxisLength, getSide, getAlignment, evaluate, getPaddingObject, rectToClientRect, min, clamp, placements, getAlignmentSides, getOppositeAlignmentPlacement, getOppositePlacement, getExpandedPlacements, getOppositeAxisPlacements, sides, max, getOppositeAxis } from '@floating-ui/utils';\nexport { rectToClientRect } from '@floating-ui/utils';\n\nfunction computeCoordsFromPlacement(_ref, placement, rtl) {\n  let {\n    reference,\n    floating\n  } = _ref;\n  const sideAxis = getSideAxis(placement);\n  const alignmentAxis = getAlignmentAxis(placement);\n  const alignLength = getAxisLength(alignmentAxis);\n  const side = getSide(placement);\n  const isVertical = sideAxis === 'y';\n  const commonX = reference.x + reference.width / 2 - floating.width / 2;\n  const commonY = reference.y + reference.height / 2 - floating.height / 2;\n  const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2;\n  let coords;\n  switch (side) {\n    case 'top':\n      coords = {\n        x: commonX,\n        y: reference.y - floating.height\n      };\n      break;\n    case 'bottom':\n      coords = {\n        x: commonX,\n        y: reference.y + reference.height\n      };\n      break;\n    case 'right':\n      coords = {\n        x: reference.x + reference.width,\n        y: commonY\n      };\n      break;\n    case 'left':\n      coords = {\n        x: reference.x - floating.width,\n        y: commonY\n      };\n      break;\n    default:\n      coords = {\n        x: reference.x,\n        y: reference.y\n      };\n  }\n  switch (getAlignment(placement)) {\n    case 'start':\n      coords[alignmentAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);\n      break;\n    case 'end':\n      coords[alignmentAxis] += commonAlign * (rtl && isVertical ? -1 : 1);\n      break;\n  }\n  return coords;\n}\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a given reference element.\n *\n * This export does not have any `platform` interface logic. You will need to\n * write one for the platform you are using Floating UI with.\n */\nconst computePosition = async (reference, floating, config) => {\n  const {\n    placement = 'bottom',\n    strategy = 'absolute',\n    middleware = [],\n    platform\n  } = config;\n  const validMiddleware = middleware.filter(Boolean);\n  const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));\n  let rects = await platform.getElementRects({\n    reference,\n    floating,\n    strategy\n  });\n  let {\n    x,\n    y\n  } = computeCoordsFromPlacement(rects, placement, rtl);\n  let statefulPlacement = placement;\n  let middlewareData = {};\n  let resetCount = 0;\n  for (let i = 0; i < validMiddleware.length; i++) {\n    const {\n      name,\n      fn\n    } = validMiddleware[i];\n    const {\n      x: nextX,\n      y: nextY,\n      data,\n      reset\n    } = await fn({\n      x,\n      y,\n      initialPlacement: placement,\n      placement: statefulPlacement,\n      strategy,\n      middlewareData,\n      rects,\n      platform,\n      elements: {\n        reference,\n        floating\n      }\n    });\n    x = nextX != null ? nextX : x;\n    y = nextY != null ? nextY : y;\n    middlewareData = {\n      ...middlewareData,\n      [name]: {\n        ...middlewareData[name],\n        ...data\n      }\n    };\n    if (reset && resetCount <= 50) {\n      resetCount++;\n      if (typeof reset === 'object') {\n        if (reset.placement) {\n          statefulPlacement = reset.placement;\n        }\n        if (reset.rects) {\n          rects = reset.rects === true ? await platform.getElementRects({\n            reference,\n            floating,\n            strategy\n          }) : reset.rects;\n        }\n        ({\n          x,\n          y\n        } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));\n      }\n      i = -1;\n    }\n  }\n  return {\n    x,\n    y,\n    placement: statefulPlacement,\n    strategy,\n    middlewareData\n  };\n};\n\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */\nasync function detectOverflow(state, options) {\n  var _await$platform$isEle;\n  if (options === void 0) {\n    options = {};\n  }\n  const {\n    x,\n    y,\n    platform,\n    rects,\n    elements,\n    strategy\n  } = state;\n  const {\n    boundary = 'clippingAncestors',\n    rootBoundary = 'viewport',\n    elementContext = 'floating',\n    altBoundary = false,\n    padding = 0\n  } = evaluate(options, state);\n  const paddingObject = getPaddingObject(padding);\n  const altContext = elementContext === 'floating' ? 'reference' : 'floating';\n  const element = elements[altBoundary ? altContext : elementContext];\n  const clippingClientRect = rectToClientRect(await platform.getClippingRect({\n    element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || (await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating))),\n    boundary,\n    rootBoundary,\n    strategy\n  }));\n  const rect = elementContext === 'floating' ? {\n    ...rects.floating,\n    x,\n    y\n  } : rects.reference;\n  const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));\n  const offsetScale = (await (platform.isElement == null ? void 0 : platform.isElement(offsetParent))) ? (await (platform.getScale == null ? void 0 : platform.getScale(offsetParent))) || {\n    x: 1,\n    y: 1\n  } : {\n    x: 1,\n    y: 1\n  };\n  const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({\n    elements,\n    rect,\n    offsetParent,\n    strategy\n  }) : rect);\n  return {\n    top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,\n    bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,\n    left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,\n    right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x\n  };\n}\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = options => ({\n  name: 'arrow',\n  options,\n  async fn(state) {\n    const {\n      x,\n      y,\n      placement,\n      rects,\n      platform,\n      elements,\n      middlewareData\n    } = state;\n    // Since `element` is required, we don't Partial<> the type.\n    const {\n      element,\n      padding = 0\n    } = evaluate(options, state) || {};\n    if (element == null) {\n      return {};\n    }\n    const paddingObject = getPaddingObject(padding);\n    const coords = {\n      x,\n      y\n    };\n    const axis = getAlignmentAxis(placement);\n    const length = getAxisLength(axis);\n    const arrowDimensions = await platform.getDimensions(element);\n    const isYAxis = axis === 'y';\n    const minProp = isYAxis ? 'top' : 'left';\n    const maxProp = isYAxis ? 'bottom' : 'right';\n    const clientProp = isYAxis ? 'clientHeight' : 'clientWidth';\n    const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];\n    const startDiff = coords[axis] - rects.reference[axis];\n    const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));\n    let clientSize = arrowOffsetParent ? arrowOffsetParent[clientProp] : 0;\n\n    // DOM platform can return `window` as the `offsetParent`.\n    if (!clientSize || !(await (platform.isElement == null ? void 0 : platform.isElement(arrowOffsetParent)))) {\n      clientSize = elements.floating[clientProp] || rects.floating[length];\n    }\n    const centerToReference = endDiff / 2 - startDiff / 2;\n\n    // If the padding is large enough that it causes the arrow to no longer be\n    // centered, modify the padding so that it is centered.\n    const largestPossiblePadding = clientSize / 2 - arrowDimensions[length] / 2 - 1;\n    const minPadding = min(paddingObject[minProp], largestPossiblePadding);\n    const maxPadding = min(paddingObject[maxProp], largestPossiblePadding);\n\n    // Make sure the arrow doesn't overflow the floating element if the center\n    // point is outside the floating element's bounds.\n    const min$1 = minPadding;\n    const max = clientSize - arrowDimensions[length] - maxPadding;\n    const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;\n    const offset = clamp(min$1, center, max);\n\n    // If the reference is small enough that the arrow's padding causes it to\n    // to point to nothing for an aligned placement, adjust the offset of the\n    // floating element itself. To ensure `shift()` continues to take action,\n    // a single reset is performed when this is true.\n    const shouldAddOffset = !middlewareData.arrow && getAlignment(placement) != null && center !== offset && rects.reference[length] / 2 - (center < min$1 ? minPadding : maxPadding) - arrowDimensions[length] / 2 < 0;\n    const alignmentOffset = shouldAddOffset ? center < min$1 ? center - min$1 : center - max : 0;\n    return {\n      [axis]: coords[axis] + alignmentOffset,\n      data: {\n        [axis]: offset,\n        centerOffset: center - offset - alignmentOffset,\n        ...(shouldAddOffset && {\n          alignmentOffset\n        })\n      },\n      reset: shouldAddOffset\n    };\n  }\n});\n\nfunction getPlacementList(alignment, autoAlignment, allowedPlacements) {\n  const allowedPlacementsSortedByAlignment = alignment ? [...allowedPlacements.filter(placement => getAlignment(placement) === alignment), ...allowedPlacements.filter(placement => getAlignment(placement) !== alignment)] : allowedPlacements.filter(placement => getSide(placement) === placement);\n  return allowedPlacementsSortedByAlignment.filter(placement => {\n    if (alignment) {\n      return getAlignment(placement) === alignment || (autoAlignment ? getOppositeAlignmentPlacement(placement) !== placement : false);\n    }\n    return true;\n  });\n}\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'autoPlacement',\n    options,\n    async fn(state) {\n      var _middlewareData$autoP, _middlewareData$autoP2, _placementsThatFitOnE;\n      const {\n        rects,\n        middlewareData,\n        placement,\n        platform,\n        elements\n      } = state;\n      const {\n        crossAxis = false,\n        alignment,\n        allowedPlacements = placements,\n        autoAlignment = true,\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const placements$1 = alignment !== undefined || allowedPlacements === placements ? getPlacementList(alignment || null, autoAlignment, allowedPlacements) : allowedPlacements;\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const currentIndex = ((_middlewareData$autoP = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP.index) || 0;\n      const currentPlacement = placements$1[currentIndex];\n      if (currentPlacement == null) {\n        return {};\n      }\n      const alignmentSides = getAlignmentSides(currentPlacement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));\n\n      // Make `computeCoords` start from the right place.\n      if (placement !== currentPlacement) {\n        return {\n          reset: {\n            placement: placements$1[0]\n          }\n        };\n      }\n      const currentOverflows = [overflow[getSide(currentPlacement)], overflow[alignmentSides[0]], overflow[alignmentSides[1]]];\n      const allOverflows = [...(((_middlewareData$autoP2 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP2.overflows) || []), {\n        placement: currentPlacement,\n        overflows: currentOverflows\n      }];\n      const nextPlacement = placements$1[currentIndex + 1];\n\n      // There are more placements to check.\n      if (nextPlacement) {\n        return {\n          data: {\n            index: currentIndex + 1,\n            overflows: allOverflows\n          },\n          reset: {\n            placement: nextPlacement\n          }\n        };\n      }\n      const placementsSortedByMostSpace = allOverflows.map(d => {\n        const alignment = getAlignment(d.placement);\n        return [d.placement, alignment && crossAxis ?\n        // Check along the mainAxis and main crossAxis side.\n        d.overflows.slice(0, 2).reduce((acc, v) => acc + v, 0) :\n        // Check only the mainAxis.\n        d.overflows[0], d.overflows];\n      }).sort((a, b) => a[1] - b[1]);\n      const placementsThatFitOnEachSide = placementsSortedByMostSpace.filter(d => d[2].slice(0,\n      // Aligned placements should not check their opposite crossAxis\n      // side.\n      getAlignment(d[0]) ? 2 : 3).every(v => v <= 0));\n      const resetPlacement = ((_placementsThatFitOnE = placementsThatFitOnEachSide[0]) == null ? void 0 : _placementsThatFitOnE[0]) || placementsSortedByMostSpace[0][0];\n      if (resetPlacement !== placement) {\n        return {\n          data: {\n            index: currentIndex + 1,\n            overflows: allOverflows\n          },\n          reset: {\n            placement: resetPlacement\n          }\n        };\n      }\n      return {};\n    }\n  };\n};\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'flip',\n    options,\n    async fn(state) {\n      var _middlewareData$arrow, _middlewareData$flip;\n      const {\n        placement,\n        middlewareData,\n        rects,\n        initialPlacement,\n        platform,\n        elements\n      } = state;\n      const {\n        mainAxis: checkMainAxis = true,\n        crossAxis: checkCrossAxis = true,\n        fallbackPlacements: specifiedFallbackPlacements,\n        fallbackStrategy = 'bestFit',\n        fallbackAxisSideDirection = 'none',\n        flipAlignment = true,\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n\n      // If a reset by the arrow was caused due to an alignment offset being\n      // added, we should skip any logic now since `flip()` has already done its\n      // work.\n      // https://github.com/floating-ui/floating-ui/issues/2549#issuecomment-1719601643\n      if ((_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n        return {};\n      }\n      const side = getSide(placement);\n      const isBasePlacement = getSide(initialPlacement) === initialPlacement;\n      const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n      const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));\n      if (!specifiedFallbackPlacements && fallbackAxisSideDirection !== 'none') {\n        fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));\n      }\n      const placements = [initialPlacement, ...fallbackPlacements];\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const overflows = [];\n      let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];\n      if (checkMainAxis) {\n        overflows.push(overflow[side]);\n      }\n      if (checkCrossAxis) {\n        const sides = getAlignmentSides(placement, rects, rtl);\n        overflows.push(overflow[sides[0]], overflow[sides[1]]);\n      }\n      overflowsData = [...overflowsData, {\n        placement,\n        overflows\n      }];\n\n      // One or more sides is overflowing.\n      if (!overflows.every(side => side <= 0)) {\n        var _middlewareData$flip2, _overflowsData$filter;\n        const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;\n        const nextPlacement = placements[nextIndex];\n        if (nextPlacement) {\n          // Try next placement and re-run the lifecycle.\n          return {\n            data: {\n              index: nextIndex,\n              overflows: overflowsData\n            },\n            reset: {\n              placement: nextPlacement\n            }\n          };\n        }\n\n        // First, find the candidates that fit on the mainAxis side of overflow,\n        // then find the placement that fits the best on the main crossAxis side.\n        let resetPlacement = (_overflowsData$filter = overflowsData.filter(d => d.overflows[0] <= 0).sort((a, b) => a.overflows[1] - b.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement;\n\n        // Otherwise fallback.\n        if (!resetPlacement) {\n          switch (fallbackStrategy) {\n            case 'bestFit':\n              {\n                var _overflowsData$map$so;\n                const placement = (_overflowsData$map$so = overflowsData.map(d => [d.placement, d.overflows.filter(overflow => overflow > 0).reduce((acc, overflow) => acc + overflow, 0)]).sort((a, b) => a[1] - b[1])[0]) == null ? void 0 : _overflowsData$map$so[0];\n                if (placement) {\n                  resetPlacement = placement;\n                }\n                break;\n              }\n            case 'initialPlacement':\n              resetPlacement = initialPlacement;\n              break;\n          }\n        }\n        if (placement !== resetPlacement) {\n          return {\n            reset: {\n              placement: resetPlacement\n            }\n          };\n        }\n      }\n      return {};\n    }\n  };\n};\n\nfunction getSideOffsets(overflow, rect) {\n  return {\n    top: overflow.top - rect.height,\n    right: overflow.right - rect.width,\n    bottom: overflow.bottom - rect.height,\n    left: overflow.left - rect.width\n  };\n}\nfunction isAnySideFullyClipped(overflow) {\n  return sides.some(side => overflow[side] >= 0);\n}\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'hide',\n    options,\n    async fn(state) {\n      const {\n        rects\n      } = state;\n      const {\n        strategy = 'referenceHidden',\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      switch (strategy) {\n        case 'referenceHidden':\n          {\n            const overflow = await detectOverflow(state, {\n              ...detectOverflowOptions,\n              elementContext: 'reference'\n            });\n            const offsets = getSideOffsets(overflow, rects.reference);\n            return {\n              data: {\n                referenceHiddenOffsets: offsets,\n                referenceHidden: isAnySideFullyClipped(offsets)\n              }\n            };\n          }\n        case 'escaped':\n          {\n            const overflow = await detectOverflow(state, {\n              ...detectOverflowOptions,\n              altBoundary: true\n            });\n            const offsets = getSideOffsets(overflow, rects.floating);\n            return {\n              data: {\n                escapedOffsets: offsets,\n                escaped: isAnySideFullyClipped(offsets)\n              }\n            };\n          }\n        default:\n          {\n            return {};\n          }\n      }\n    }\n  };\n};\n\nfunction getBoundingRect(rects) {\n  const minX = min(...rects.map(rect => rect.left));\n  const minY = min(...rects.map(rect => rect.top));\n  const maxX = max(...rects.map(rect => rect.right));\n  const maxY = max(...rects.map(rect => rect.bottom));\n  return {\n    x: minX,\n    y: minY,\n    width: maxX - minX,\n    height: maxY - minY\n  };\n}\nfunction getRectsByLine(rects) {\n  const sortedRects = rects.slice().sort((a, b) => a.y - b.y);\n  const groups = [];\n  let prevRect = null;\n  for (let i = 0; i < sortedRects.length; i++) {\n    const rect = sortedRects[i];\n    if (!prevRect || rect.y - prevRect.y > prevRect.height / 2) {\n      groups.push([rect]);\n    } else {\n      groups[groups.length - 1].push(rect);\n    }\n    prevRect = rect;\n  }\n  return groups.map(rect => rectToClientRect(getBoundingRect(rect)));\n}\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'inline',\n    options,\n    async fn(state) {\n      const {\n        placement,\n        elements,\n        rects,\n        platform,\n        strategy\n      } = state;\n      // A MouseEvent's client{X,Y} coords can be up to 2 pixels off a\n      // ClientRect's bounds, despite the event listener being triggered. A\n      // padding of 2 seems to handle this issue.\n      const {\n        padding = 2,\n        x,\n        y\n      } = evaluate(options, state);\n      const nativeClientRects = Array.from((await (platform.getClientRects == null ? void 0 : platform.getClientRects(elements.reference))) || []);\n      const clientRects = getRectsByLine(nativeClientRects);\n      const fallback = rectToClientRect(getBoundingRect(nativeClientRects));\n      const paddingObject = getPaddingObject(padding);\n      function getBoundingClientRect() {\n        // There are two rects and they are disjoined.\n        if (clientRects.length === 2 && clientRects[0].left > clientRects[1].right && x != null && y != null) {\n          // Find the first rect in which the point is fully inside.\n          return clientRects.find(rect => x > rect.left - paddingObject.left && x < rect.right + paddingObject.right && y > rect.top - paddingObject.top && y < rect.bottom + paddingObject.bottom) || fallback;\n        }\n\n        // There are 2 or more connected rects.\n        if (clientRects.length >= 2) {\n          if (getSideAxis(placement) === 'y') {\n            const firstRect = clientRects[0];\n            const lastRect = clientRects[clientRects.length - 1];\n            const isTop = getSide(placement) === 'top';\n            const top = firstRect.top;\n            const bottom = lastRect.bottom;\n            const left = isTop ? firstRect.left : lastRect.left;\n            const right = isTop ? firstRect.right : lastRect.right;\n            const width = right - left;\n            const height = bottom - top;\n            return {\n              top,\n              bottom,\n              left,\n              right,\n              width,\n              height,\n              x: left,\n              y: top\n            };\n          }\n          const isLeftSide = getSide(placement) === 'left';\n          const maxRight = max(...clientRects.map(rect => rect.right));\n          const minLeft = min(...clientRects.map(rect => rect.left));\n          const measureRects = clientRects.filter(rect => isLeftSide ? rect.left === minLeft : rect.right === maxRight);\n          const top = measureRects[0].top;\n          const bottom = measureRects[measureRects.length - 1].bottom;\n          const left = minLeft;\n          const right = maxRight;\n          const width = right - left;\n          const height = bottom - top;\n          return {\n            top,\n            bottom,\n            left,\n            right,\n            width,\n            height,\n            x: left,\n            y: top\n          };\n        }\n        return fallback;\n      }\n      const resetRects = await platform.getElementRects({\n        reference: {\n          getBoundingClientRect\n        },\n        floating: elements.floating,\n        strategy\n      });\n      if (rects.reference.x !== resetRects.reference.x || rects.reference.y !== resetRects.reference.y || rects.reference.width !== resetRects.reference.width || rects.reference.height !== resetRects.reference.height) {\n        return {\n          reset: {\n            rects: resetRects\n          }\n        };\n      }\n      return {};\n    }\n  };\n};\n\n// For type backwards-compatibility, the `OffsetOptions` type was also\n// Derivable.\n\nasync function convertValueToCoords(state, options) {\n  const {\n    placement,\n    platform,\n    elements\n  } = state;\n  const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n  const side = getSide(placement);\n  const alignment = getAlignment(placement);\n  const isVertical = getSideAxis(placement) === 'y';\n  const mainAxisMulti = ['left', 'top'].includes(side) ? -1 : 1;\n  const crossAxisMulti = rtl && isVertical ? -1 : 1;\n  const rawValue = evaluate(options, state);\n  let {\n    mainAxis,\n    crossAxis,\n    alignmentAxis\n  } = typeof rawValue === 'number' ? {\n    mainAxis: rawValue,\n    crossAxis: 0,\n    alignmentAxis: null\n  } : {\n    mainAxis: 0,\n    crossAxis: 0,\n    alignmentAxis: null,\n    ...rawValue\n  };\n  if (alignment && typeof alignmentAxis === 'number') {\n    crossAxis = alignment === 'end' ? alignmentAxis * -1 : alignmentAxis;\n  }\n  return isVertical ? {\n    x: crossAxis * crossAxisMulti,\n    y: mainAxis * mainAxisMulti\n  } : {\n    x: mainAxis * mainAxisMulti,\n    y: crossAxis * crossAxisMulti\n  };\n}\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = function (options) {\n  if (options === void 0) {\n    options = 0;\n  }\n  return {\n    name: 'offset',\n    options,\n    async fn(state) {\n      var _middlewareData$offse, _middlewareData$arrow;\n      const {\n        x,\n        y,\n        placement,\n        middlewareData\n      } = state;\n      const diffCoords = await convertValueToCoords(state, options);\n\n      // If the placement is the same and the arrow caused an alignment offset\n      // then we don't need to change the positioning coordinates.\n      if (placement === ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse.placement) && (_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n        return {};\n      }\n      return {\n        x: x + diffCoords.x,\n        y: y + diffCoords.y,\n        data: {\n          ...diffCoords,\n          placement\n        }\n      };\n    }\n  };\n};\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'shift',\n    options,\n    async fn(state) {\n      const {\n        x,\n        y,\n        placement\n      } = state;\n      const {\n        mainAxis: checkMainAxis = true,\n        crossAxis: checkCrossAxis = false,\n        limiter = {\n          fn: _ref => {\n            let {\n              x,\n              y\n            } = _ref;\n            return {\n              x,\n              y\n            };\n          }\n        },\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const coords = {\n        x,\n        y\n      };\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const crossAxis = getSideAxis(getSide(placement));\n      const mainAxis = getOppositeAxis(crossAxis);\n      let mainAxisCoord = coords[mainAxis];\n      let crossAxisCoord = coords[crossAxis];\n      if (checkMainAxis) {\n        const minSide = mainAxis === 'y' ? 'top' : 'left';\n        const maxSide = mainAxis === 'y' ? 'bottom' : 'right';\n        const min = mainAxisCoord + overflow[minSide];\n        const max = mainAxisCoord - overflow[maxSide];\n        mainAxisCoord = clamp(min, mainAxisCoord, max);\n      }\n      if (checkCrossAxis) {\n        const minSide = crossAxis === 'y' ? 'top' : 'left';\n        const maxSide = crossAxis === 'y' ? 'bottom' : 'right';\n        const min = crossAxisCoord + overflow[minSide];\n        const max = crossAxisCoord - overflow[maxSide];\n        crossAxisCoord = clamp(min, crossAxisCoord, max);\n      }\n      const limitedCoords = limiter.fn({\n        ...state,\n        [mainAxis]: mainAxisCoord,\n        [crossAxis]: crossAxisCoord\n      });\n      return {\n        ...limitedCoords,\n        data: {\n          x: limitedCoords.x - x,\n          y: limitedCoords.y - y\n        }\n      };\n    }\n  };\n};\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    options,\n    fn(state) {\n      const {\n        x,\n        y,\n        placement,\n        rects,\n        middlewareData\n      } = state;\n      const {\n        offset = 0,\n        mainAxis: checkMainAxis = true,\n        crossAxis: checkCrossAxis = true\n      } = evaluate(options, state);\n      const coords = {\n        x,\n        y\n      };\n      const crossAxis = getSideAxis(placement);\n      const mainAxis = getOppositeAxis(crossAxis);\n      let mainAxisCoord = coords[mainAxis];\n      let crossAxisCoord = coords[crossAxis];\n      const rawOffset = evaluate(offset, state);\n      const computedOffset = typeof rawOffset === 'number' ? {\n        mainAxis: rawOffset,\n        crossAxis: 0\n      } : {\n        mainAxis: 0,\n        crossAxis: 0,\n        ...rawOffset\n      };\n      if (checkMainAxis) {\n        const len = mainAxis === 'y' ? 'height' : 'width';\n        const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;\n        const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;\n        if (mainAxisCoord < limitMin) {\n          mainAxisCoord = limitMin;\n        } else if (mainAxisCoord > limitMax) {\n          mainAxisCoord = limitMax;\n        }\n      }\n      if (checkCrossAxis) {\n        var _middlewareData$offse, _middlewareData$offse2;\n        const len = mainAxis === 'y' ? 'width' : 'height';\n        const isOriginSide = ['top', 'left'].includes(getSide(placement));\n        const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse[crossAxis]) || 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);\n        const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : ((_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) || 0) - (isOriginSide ? computedOffset.crossAxis : 0);\n        if (crossAxisCoord < limitMin) {\n          crossAxisCoord = limitMin;\n        } else if (crossAxisCoord > limitMax) {\n          crossAxisCoord = limitMax;\n        }\n      }\n      return {\n        [mainAxis]: mainAxisCoord,\n        [crossAxis]: crossAxisCoord\n      };\n    }\n  };\n};\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'size',\n    options,\n    async fn(state) {\n      const {\n        placement,\n        rects,\n        platform,\n        elements\n      } = state;\n      const {\n        apply = () => {},\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const side = getSide(placement);\n      const alignment = getAlignment(placement);\n      const isYAxis = getSideAxis(placement) === 'y';\n      const {\n        width,\n        height\n      } = rects.floating;\n      let heightSide;\n      let widthSide;\n      if (side === 'top' || side === 'bottom') {\n        heightSide = side;\n        widthSide = alignment === ((await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating))) ? 'start' : 'end') ? 'left' : 'right';\n      } else {\n        widthSide = side;\n        heightSide = alignment === 'end' ? 'top' : 'bottom';\n      }\n      const overflowAvailableHeight = height - overflow[heightSide];\n      const overflowAvailableWidth = width - overflow[widthSide];\n      const noShift = !state.middlewareData.shift;\n      let availableHeight = overflowAvailableHeight;\n      let availableWidth = overflowAvailableWidth;\n      if (isYAxis) {\n        const maximumClippingWidth = width - overflow.left - overflow.right;\n        availableWidth = alignment || noShift ? min(overflowAvailableWidth, maximumClippingWidth) : maximumClippingWidth;\n      } else {\n        const maximumClippingHeight = height - overflow.top - overflow.bottom;\n        availableHeight = alignment || noShift ? min(overflowAvailableHeight, maximumClippingHeight) : maximumClippingHeight;\n      }\n      if (noShift && !alignment) {\n        const xMin = max(overflow.left, 0);\n        const xMax = max(overflow.right, 0);\n        const yMin = max(overflow.top, 0);\n        const yMax = max(overflow.bottom, 0);\n        if (isYAxis) {\n          availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right));\n        } else {\n          availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom));\n        }\n      }\n      await apply({\n        ...state,\n        availableWidth,\n        availableHeight\n      });\n      const nextDimensions = await platform.getDimensions(elements.floating);\n      if (width !== nextDimensions.width || height !== nextDimensions.height) {\n        return {\n          reset: {\n            rects: true\n          }\n        };\n      }\n      return {};\n    }\n  };\n};\n\nexport { arrow, autoPlacement, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, shift, size };\n", "function getNodeName(node) {\n  if (isNode(node)) {\n    return (node.nodeName || '').toLowerCase();\n  }\n  // Mocked nodes in testing environments may not be instances of Node. By\n  // returning `#document` an infinite loop won't occur.\n  // https://github.com/floating-ui/floating-ui/issues/2317\n  return '#document';\n}\nfunction getWindow(node) {\n  var _node$ownerDocument;\n  return (node == null || (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;\n}\nfunction getDocumentElement(node) {\n  var _ref;\n  return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;\n}\nfunction isNode(value) {\n  return value instanceof Node || value instanceof getWindow(value).Node;\n}\nfunction isElement(value) {\n  return value instanceof Element || value instanceof getWindow(value).Element;\n}\nfunction isHTMLElement(value) {\n  return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;\n}\nfunction isShadowRoot(value) {\n  // Browsers without `ShadowRoot` support.\n  if (typeof ShadowRoot === 'undefined') {\n    return false;\n  }\n  return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;\n}\nfunction isOverflowElement(element) {\n  const {\n    overflow,\n    overflowX,\n    overflowY,\n    display\n  } = getComputedStyle(element);\n  return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !['inline', 'contents'].includes(display);\n}\nfunction isTableElement(element) {\n  return ['table', 'td', 'th'].includes(getNodeName(element));\n}\nfunction isContainingBlock(element) {\n  const webkit = isWebKit();\n  const css = getComputedStyle(element);\n\n  // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n  return css.transform !== 'none' || css.perspective !== 'none' || (css.containerType ? css.containerType !== 'normal' : false) || !webkit && (css.backdropFilter ? css.backdropFilter !== 'none' : false) || !webkit && (css.filter ? css.filter !== 'none' : false) || ['transform', 'perspective', 'filter'].some(value => (css.willChange || '').includes(value)) || ['paint', 'layout', 'strict', 'content'].some(value => (css.contain || '').includes(value));\n}\nfunction getContainingBlock(element) {\n  let currentNode = getParentNode(element);\n  while (isHTMLElement(currentNode) && !isLastTraversableNode(currentNode)) {\n    if (isContainingBlock(currentNode)) {\n      return currentNode;\n    } else {\n      currentNode = getParentNode(currentNode);\n    }\n  }\n  return null;\n}\nfunction isWebKit() {\n  if (typeof CSS === 'undefined' || !CSS.supports) return false;\n  return CSS.supports('-webkit-backdrop-filter', 'none');\n}\nfunction isLastTraversableNode(node) {\n  return ['html', 'body', '#document'].includes(getNodeName(node));\n}\nfunction getComputedStyle(element) {\n  return getWindow(element).getComputedStyle(element);\n}\nfunction getNodeScroll(element) {\n  if (isElement(element)) {\n    return {\n      scrollLeft: element.scrollLeft,\n      scrollTop: element.scrollTop\n    };\n  }\n  return {\n    scrollLeft: element.pageXOffset,\n    scrollTop: element.pageYOffset\n  };\n}\nfunction getParentNode(node) {\n  if (getNodeName(node) === 'html') {\n    return node;\n  }\n  const result =\n  // Step into the shadow DOM of the parent of a slotted node.\n  node.assignedSlot ||\n  // DOM Element detected.\n  node.parentNode ||\n  // ShadowRoot detected.\n  isShadowRoot(node) && node.host ||\n  // Fallback.\n  getDocumentElement(node);\n  return isShadowRoot(result) ? result.host : result;\n}\nfunction getNearestOverflowAncestor(node) {\n  const parentNode = getParentNode(node);\n  if (isLastTraversableNode(parentNode)) {\n    return node.ownerDocument ? node.ownerDocument.body : node.body;\n  }\n  if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {\n    return parentNode;\n  }\n  return getNearestOverflowAncestor(parentNode);\n}\nfunction getOverflowAncestors(node, list, traverseIframes) {\n  var _node$ownerDocument2;\n  if (list === void 0) {\n    list = [];\n  }\n  if (traverseIframes === void 0) {\n    traverseIframes = true;\n  }\n  const scrollableAncestor = getNearestOverflowAncestor(node);\n  const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);\n  const win = getWindow(scrollableAncestor);\n  if (isBody) {\n    return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], win.frameElement && traverseIframes ? getOverflowAncestors(win.frameElement) : []);\n  }\n  return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes));\n}\n\nexport { getComputedStyle, getContainingBlock, getDocumentElement, getNearestOverflowAncestor, getNodeName, getNodeScroll, getOverflowAncestors, getParentNode, getWindow, isContainingBlock, isElement, isHTMLElement, isLastTraversableNode, isNode, isOverflowElement, isShadowRoot, isTableElement, isWebKit };\n", "import { rectToClientRect, autoPlacement as autoPlacement$1, shift as shift$1, flip as flip$1, size as size$1, hide as hide$1, arrow as arrow$1, inline as inline$1, limitShift as limitShift$1, computePosition as computePosition$1 } from '@floating-ui/core';\nexport { detectOverflow, offset } from '@floating-ui/core';\nimport { round, createCoords, max, min, floor } from '@floating-ui/utils';\nimport { getComputedStyle, isHTMLElement, isElement, getWindow, isWebKit, getContainingBlock, getDocumentElement, getNodeName, isOverflowElement, getNodeScroll, getOverflowAncestors, getParentNode, isLastTraversableNode, isContainingBlock, isTableElement } from '@floating-ui/utils/dom';\nexport { getOverflowAncestors } from '@floating-ui/utils/dom';\n\nfunction getCssDimensions(element) {\n  const css = getComputedStyle(element);\n  // In testing environments, the `width` and `height` properties are empty\n  // strings for SVG elements, returning NaN. Fallback to `0` in this case.\n  let width = parseFloat(css.width) || 0;\n  let height = parseFloat(css.height) || 0;\n  const hasOffset = isHTMLElement(element);\n  const offsetWidth = hasOffset ? element.offsetWidth : width;\n  const offsetHeight = hasOffset ? element.offsetHeight : height;\n  const shouldFallback = round(width) !== offsetWidth || round(height) !== offsetHeight;\n  if (shouldFallback) {\n    width = offsetWidth;\n    height = offsetHeight;\n  }\n  return {\n    width,\n    height,\n    $: shouldFallback\n  };\n}\n\nfunction unwrapElement(element) {\n  return !isElement(element) ? element.contextElement : element;\n}\n\nfunction getScale(element) {\n  const domElement = unwrapElement(element);\n  if (!isHTMLElement(domElement)) {\n    return createCoords(1);\n  }\n  const rect = domElement.getBoundingClientRect();\n  const {\n    width,\n    height,\n    $\n  } = getCssDimensions(domElement);\n  let x = ($ ? round(rect.width) : rect.width) / width;\n  let y = ($ ? round(rect.height) : rect.height) / height;\n\n  // 0, NaN, or Infinity should always fallback to 1.\n\n  if (!x || !Number.isFinite(x)) {\n    x = 1;\n  }\n  if (!y || !Number.isFinite(y)) {\n    y = 1;\n  }\n  return {\n    x,\n    y\n  };\n}\n\nconst noOffsets = /*#__PURE__*/createCoords(0);\nfunction getVisualOffsets(element) {\n  const win = getWindow(element);\n  if (!isWebKit() || !win.visualViewport) {\n    return noOffsets;\n  }\n  return {\n    x: win.visualViewport.offsetLeft,\n    y: win.visualViewport.offsetTop\n  };\n}\nfunction shouldAddVisualOffsets(element, isFixed, floatingOffsetParent) {\n  if (isFixed === void 0) {\n    isFixed = false;\n  }\n  if (!floatingOffsetParent || isFixed && floatingOffsetParent !== getWindow(element)) {\n    return false;\n  }\n  return isFixed;\n}\n\nfunction getBoundingClientRect(element, includeScale, isFixedStrategy, offsetParent) {\n  if (includeScale === void 0) {\n    includeScale = false;\n  }\n  if (isFixedStrategy === void 0) {\n    isFixedStrategy = false;\n  }\n  const clientRect = element.getBoundingClientRect();\n  const domElement = unwrapElement(element);\n  let scale = createCoords(1);\n  if (includeScale) {\n    if (offsetParent) {\n      if (isElement(offsetParent)) {\n        scale = getScale(offsetParent);\n      }\n    } else {\n      scale = getScale(element);\n    }\n  }\n  const visualOffsets = shouldAddVisualOffsets(domElement, isFixedStrategy, offsetParent) ? getVisualOffsets(domElement) : createCoords(0);\n  let x = (clientRect.left + visualOffsets.x) / scale.x;\n  let y = (clientRect.top + visualOffsets.y) / scale.y;\n  let width = clientRect.width / scale.x;\n  let height = clientRect.height / scale.y;\n  if (domElement) {\n    const win = getWindow(domElement);\n    const offsetWin = offsetParent && isElement(offsetParent) ? getWindow(offsetParent) : offsetParent;\n    let currentIFrame = win.frameElement;\n    while (currentIFrame && offsetParent && offsetWin !== win) {\n      const iframeScale = getScale(currentIFrame);\n      const iframeRect = currentIFrame.getBoundingClientRect();\n      const css = getComputedStyle(currentIFrame);\n      const left = iframeRect.left + (currentIFrame.clientLeft + parseFloat(css.paddingLeft)) * iframeScale.x;\n      const top = iframeRect.top + (currentIFrame.clientTop + parseFloat(css.paddingTop)) * iframeScale.y;\n      x *= iframeScale.x;\n      y *= iframeScale.y;\n      width *= iframeScale.x;\n      height *= iframeScale.y;\n      x += left;\n      y += top;\n      currentIFrame = getWindow(currentIFrame).frameElement;\n    }\n  }\n  return rectToClientRect({\n    width,\n    height,\n    x,\n    y\n  });\n}\n\nconst topLayerSelectors = [':popover-open', ':modal'];\nfunction topLayer(floating) {\n  let isTopLayer = false;\n  let x = 0;\n  let y = 0;\n  function setIsTopLayer(selector) {\n    try {\n      isTopLayer = isTopLayer || floating.matches(selector);\n    } catch (e) {}\n  }\n  topLayerSelectors.forEach(selector => {\n    setIsTopLayer(selector);\n  });\n  if (isTopLayer) {\n    const containingBlock = getContainingBlock(floating);\n    if (containingBlock) {\n      const rect = containingBlock.getBoundingClientRect();\n      x = rect.x;\n      y = rect.y;\n    }\n  }\n  return [isTopLayer, x, y];\n}\n\nfunction convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {\n  let {\n    elements,\n    rect,\n    offsetParent,\n    strategy\n  } = _ref;\n  const documentElement = getDocumentElement(offsetParent);\n  const [isTopLayer] = elements ? topLayer(elements.floating) : [false];\n  if (offsetParent === documentElement || isTopLayer) {\n    return rect;\n  }\n  let scroll = {\n    scrollLeft: 0,\n    scrollTop: 0\n  };\n  let scale = createCoords(1);\n  const offsets = createCoords(0);\n  const isOffsetParentAnElement = isHTMLElement(offsetParent);\n  if (isOffsetParentAnElement || !isOffsetParentAnElement && strategy !== 'fixed') {\n    if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n      scroll = getNodeScroll(offsetParent);\n    }\n    if (isHTMLElement(offsetParent)) {\n      const offsetRect = getBoundingClientRect(offsetParent);\n      scale = getScale(offsetParent);\n      offsets.x = offsetRect.x + offsetParent.clientLeft;\n      offsets.y = offsetRect.y + offsetParent.clientTop;\n    }\n  }\n  return {\n    width: rect.width * scale.x,\n    height: rect.height * scale.y,\n    x: rect.x * scale.x - scroll.scrollLeft * scale.x + offsets.x,\n    y: rect.y * scale.y - scroll.scrollTop * scale.y + offsets.y\n  };\n}\n\nfunction getClientRects(element) {\n  return Array.from(element.getClientRects());\n}\n\nfunction getWindowScrollBarX(element) {\n  // If <html> has a CSS width greater than the viewport, then this will be\n  // incorrect for RTL.\n  return getBoundingClientRect(getDocumentElement(element)).left + getNodeScroll(element).scrollLeft;\n}\n\n// Gets the entire size of the scrollable document area, even extending outside\n// of the `<html>` and `<body>` rect bounds if horizontally scrollable.\nfunction getDocumentRect(element) {\n  const html = getDocumentElement(element);\n  const scroll = getNodeScroll(element);\n  const body = element.ownerDocument.body;\n  const width = max(html.scrollWidth, html.clientWidth, body.scrollWidth, body.clientWidth);\n  const height = max(html.scrollHeight, html.clientHeight, body.scrollHeight, body.clientHeight);\n  let x = -scroll.scrollLeft + getWindowScrollBarX(element);\n  const y = -scroll.scrollTop;\n  if (getComputedStyle(body).direction === 'rtl') {\n    x += max(html.clientWidth, body.clientWidth) - width;\n  }\n  return {\n    width,\n    height,\n    x,\n    y\n  };\n}\n\nfunction getViewportRect(element, strategy) {\n  const win = getWindow(element);\n  const html = getDocumentElement(element);\n  const visualViewport = win.visualViewport;\n  let width = html.clientWidth;\n  let height = html.clientHeight;\n  let x = 0;\n  let y = 0;\n  if (visualViewport) {\n    width = visualViewport.width;\n    height = visualViewport.height;\n    const visualViewportBased = isWebKit();\n    if (!visualViewportBased || visualViewportBased && strategy === 'fixed') {\n      x = visualViewport.offsetLeft;\n      y = visualViewport.offsetTop;\n    }\n  }\n  return {\n    width,\n    height,\n    x,\n    y\n  };\n}\n\n// Returns the inner client rect, subtracting scrollbars if present.\nfunction getInnerBoundingClientRect(element, strategy) {\n  const clientRect = getBoundingClientRect(element, true, strategy === 'fixed');\n  const top = clientRect.top + element.clientTop;\n  const left = clientRect.left + element.clientLeft;\n  const scale = isHTMLElement(element) ? getScale(element) : createCoords(1);\n  const width = element.clientWidth * scale.x;\n  const height = element.clientHeight * scale.y;\n  const x = left * scale.x;\n  const y = top * scale.y;\n  return {\n    width,\n    height,\n    x,\n    y\n  };\n}\nfunction getClientRectFromClippingAncestor(element, clippingAncestor, strategy) {\n  let rect;\n  if (clippingAncestor === 'viewport') {\n    rect = getViewportRect(element, strategy);\n  } else if (clippingAncestor === 'document') {\n    rect = getDocumentRect(getDocumentElement(element));\n  } else if (isElement(clippingAncestor)) {\n    rect = getInnerBoundingClientRect(clippingAncestor, strategy);\n  } else {\n    const visualOffsets = getVisualOffsets(element);\n    rect = {\n      ...clippingAncestor,\n      x: clippingAncestor.x - visualOffsets.x,\n      y: clippingAncestor.y - visualOffsets.y\n    };\n  }\n  return rectToClientRect(rect);\n}\nfunction hasFixedPositionAncestor(element, stopNode) {\n  const parentNode = getParentNode(element);\n  if (parentNode === stopNode || !isElement(parentNode) || isLastTraversableNode(parentNode)) {\n    return false;\n  }\n  return getComputedStyle(parentNode).position === 'fixed' || hasFixedPositionAncestor(parentNode, stopNode);\n}\n\n// A \"clipping ancestor\" is an `overflow` element with the characteristic of\n// clipping (or hiding) child elements. This returns all clipping ancestors\n// of the given element up the tree.\nfunction getClippingElementAncestors(element, cache) {\n  const cachedResult = cache.get(element);\n  if (cachedResult) {\n    return cachedResult;\n  }\n  let result = getOverflowAncestors(element, [], false).filter(el => isElement(el) && getNodeName(el) !== 'body');\n  let currentContainingBlockComputedStyle = null;\n  const elementIsFixed = getComputedStyle(element).position === 'fixed';\n  let currentNode = elementIsFixed ? getParentNode(element) : element;\n\n  // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n  while (isElement(currentNode) && !isLastTraversableNode(currentNode)) {\n    const computedStyle = getComputedStyle(currentNode);\n    const currentNodeIsContaining = isContainingBlock(currentNode);\n    if (!currentNodeIsContaining && computedStyle.position === 'fixed') {\n      currentContainingBlockComputedStyle = null;\n    }\n    const shouldDropCurrentNode = elementIsFixed ? !currentNodeIsContaining && !currentContainingBlockComputedStyle : !currentNodeIsContaining && computedStyle.position === 'static' && !!currentContainingBlockComputedStyle && ['absolute', 'fixed'].includes(currentContainingBlockComputedStyle.position) || isOverflowElement(currentNode) && !currentNodeIsContaining && hasFixedPositionAncestor(element, currentNode);\n    if (shouldDropCurrentNode) {\n      // Drop non-containing blocks.\n      result = result.filter(ancestor => ancestor !== currentNode);\n    } else {\n      // Record last containing block for next iteration.\n      currentContainingBlockComputedStyle = computedStyle;\n    }\n    currentNode = getParentNode(currentNode);\n  }\n  cache.set(element, result);\n  return result;\n}\n\n// Gets the maximum area that the element is visible in due to any number of\n// clipping ancestors.\nfunction getClippingRect(_ref) {\n  let {\n    element,\n    boundary,\n    rootBoundary,\n    strategy\n  } = _ref;\n  const elementClippingAncestors = boundary === 'clippingAncestors' ? getClippingElementAncestors(element, this._c) : [].concat(boundary);\n  const clippingAncestors = [...elementClippingAncestors, rootBoundary];\n  const firstClippingAncestor = clippingAncestors[0];\n  const clippingRect = clippingAncestors.reduce((accRect, clippingAncestor) => {\n    const rect = getClientRectFromClippingAncestor(element, clippingAncestor, strategy);\n    accRect.top = max(rect.top, accRect.top);\n    accRect.right = min(rect.right, accRect.right);\n    accRect.bottom = min(rect.bottom, accRect.bottom);\n    accRect.left = max(rect.left, accRect.left);\n    return accRect;\n  }, getClientRectFromClippingAncestor(element, firstClippingAncestor, strategy));\n  return {\n    width: clippingRect.right - clippingRect.left,\n    height: clippingRect.bottom - clippingRect.top,\n    x: clippingRect.left,\n    y: clippingRect.top\n  };\n}\n\nfunction getDimensions(element) {\n  const {\n    width,\n    height\n  } = getCssDimensions(element);\n  return {\n    width,\n    height\n  };\n}\n\nfunction getRectRelativeToOffsetParent(element, offsetParent, strategy, floating) {\n  const isOffsetParentAnElement = isHTMLElement(offsetParent);\n  const documentElement = getDocumentElement(offsetParent);\n  const isFixed = strategy === 'fixed';\n  const rect = getBoundingClientRect(element, true, isFixed, offsetParent);\n  let scroll = {\n    scrollLeft: 0,\n    scrollTop: 0\n  };\n  const offsets = createCoords(0);\n  if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n    if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n      scroll = getNodeScroll(offsetParent);\n    }\n    if (isOffsetParentAnElement) {\n      const offsetRect = getBoundingClientRect(offsetParent, true, isFixed, offsetParent);\n      offsets.x = offsetRect.x + offsetParent.clientLeft;\n      offsets.y = offsetRect.y + offsetParent.clientTop;\n    } else if (documentElement) {\n      offsets.x = getWindowScrollBarX(documentElement);\n    }\n  }\n  let x = rect.left + scroll.scrollLeft - offsets.x;\n  let y = rect.top + scroll.scrollTop - offsets.y;\n  const [isTopLayer, topLayerX, topLayerY] = topLayer(floating);\n  if (isTopLayer) {\n    x += topLayerX;\n    y += topLayerY;\n    if (isOffsetParentAnElement) {\n      x += offsetParent.clientLeft;\n      y += offsetParent.clientTop;\n    }\n  }\n  return {\n    x,\n    y,\n    width: rect.width,\n    height: rect.height\n  };\n}\n\nfunction getTrueOffsetParent(element, polyfill) {\n  if (!isHTMLElement(element) || getComputedStyle(element).position === 'fixed') {\n    return null;\n  }\n  if (polyfill) {\n    return polyfill(element);\n  }\n  return element.offsetParent;\n}\n\n// Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\nfunction getOffsetParent(element, polyfill) {\n  const window = getWindow(element);\n  if (!isHTMLElement(element)) {\n    return window;\n  }\n  let offsetParent = getTrueOffsetParent(element, polyfill);\n  while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {\n    offsetParent = getTrueOffsetParent(offsetParent, polyfill);\n  }\n  if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static' && !isContainingBlock(offsetParent))) {\n    return window;\n  }\n  return offsetParent || getContainingBlock(element) || window;\n}\n\nconst getElementRects = async function (data) {\n  const getOffsetParentFn = this.getOffsetParent || getOffsetParent;\n  const getDimensionsFn = this.getDimensions;\n  return {\n    reference: getRectRelativeToOffsetParent(data.reference, await getOffsetParentFn(data.floating), data.strategy, data.floating),\n    floating: {\n      x: 0,\n      y: 0,\n      ...(await getDimensionsFn(data.floating))\n    }\n  };\n};\n\nfunction isRTL(element) {\n  return getComputedStyle(element).direction === 'rtl';\n}\n\nconst platform = {\n  convertOffsetParentRelativeRectToViewportRelativeRect,\n  getDocumentElement,\n  getClippingRect,\n  getOffsetParent,\n  getElementRects,\n  getClientRects,\n  getDimensions,\n  getScale,\n  isElement,\n  isRTL\n};\n\n// https://samthor.au/2021/observing-dom/\nfunction observeMove(element, onMove) {\n  let io = null;\n  let timeoutId;\n  const root = getDocumentElement(element);\n  function cleanup() {\n    var _io;\n    clearTimeout(timeoutId);\n    (_io = io) == null || _io.disconnect();\n    io = null;\n  }\n  function refresh(skip, threshold) {\n    if (skip === void 0) {\n      skip = false;\n    }\n    if (threshold === void 0) {\n      threshold = 1;\n    }\n    cleanup();\n    const {\n      left,\n      top,\n      width,\n      height\n    } = element.getBoundingClientRect();\n    if (!skip) {\n      onMove();\n    }\n    if (!width || !height) {\n      return;\n    }\n    const insetTop = floor(top);\n    const insetRight = floor(root.clientWidth - (left + width));\n    const insetBottom = floor(root.clientHeight - (top + height));\n    const insetLeft = floor(left);\n    const rootMargin = -insetTop + \"px \" + -insetRight + \"px \" + -insetBottom + \"px \" + -insetLeft + \"px\";\n    const options = {\n      rootMargin,\n      threshold: max(0, min(1, threshold)) || 1\n    };\n    let isFirstUpdate = true;\n    function handleObserve(entries) {\n      const ratio = entries[0].intersectionRatio;\n      if (ratio !== threshold) {\n        if (!isFirstUpdate) {\n          return refresh();\n        }\n        if (!ratio) {\n          timeoutId = setTimeout(() => {\n            refresh(false, 1e-7);\n          }, 100);\n        } else {\n          refresh(false, ratio);\n        }\n      }\n      isFirstUpdate = false;\n    }\n\n    // Older browsers don't support a `document` as the root and will throw an\n    // error.\n    try {\n      io = new IntersectionObserver(handleObserve, {\n        ...options,\n        // Handle <iframe>s\n        root: root.ownerDocument\n      });\n    } catch (e) {\n      io = new IntersectionObserver(handleObserve, options);\n    }\n    io.observe(element);\n  }\n  refresh(true);\n  return cleanup;\n}\n\n/**\n * Automatically updates the position of the floating element when necessary.\n * Should only be called when the floating element is mounted on the DOM or\n * visible on the screen.\n * @returns cleanup function that should be invoked when the floating element is\n * removed from the DOM or hidden from the screen.\n * @see https://floating-ui.com/docs/autoUpdate\n */\nfunction autoUpdate(reference, floating, update, options) {\n  if (options === void 0) {\n    options = {};\n  }\n  const {\n    ancestorScroll = true,\n    ancestorResize = true,\n    elementResize = typeof ResizeObserver === 'function',\n    layoutShift = typeof IntersectionObserver === 'function',\n    animationFrame = false\n  } = options;\n  const referenceEl = unwrapElement(reference);\n  const ancestors = ancestorScroll || ancestorResize ? [...(referenceEl ? getOverflowAncestors(referenceEl) : []), ...getOverflowAncestors(floating)] : [];\n  ancestors.forEach(ancestor => {\n    ancestorScroll && ancestor.addEventListener('scroll', update, {\n      passive: true\n    });\n    ancestorResize && ancestor.addEventListener('resize', update);\n  });\n  const cleanupIo = referenceEl && layoutShift ? observeMove(referenceEl, update) : null;\n  let reobserveFrame = -1;\n  let resizeObserver = null;\n  if (elementResize) {\n    resizeObserver = new ResizeObserver(_ref => {\n      let [firstEntry] = _ref;\n      if (firstEntry && firstEntry.target === referenceEl && resizeObserver) {\n        // Prevent update loops when using the `size` middleware.\n        // https://github.com/floating-ui/floating-ui/issues/1740\n        resizeObserver.unobserve(floating);\n        cancelAnimationFrame(reobserveFrame);\n        reobserveFrame = requestAnimationFrame(() => {\n          var _resizeObserver;\n          (_resizeObserver = resizeObserver) == null || _resizeObserver.observe(floating);\n        });\n      }\n      update();\n    });\n    if (referenceEl && !animationFrame) {\n      resizeObserver.observe(referenceEl);\n    }\n    resizeObserver.observe(floating);\n  }\n  let frameId;\n  let prevRefRect = animationFrame ? getBoundingClientRect(reference) : null;\n  if (animationFrame) {\n    frameLoop();\n  }\n  function frameLoop() {\n    const nextRefRect = getBoundingClientRect(reference);\n    if (prevRefRect && (nextRefRect.x !== prevRefRect.x || nextRefRect.y !== prevRefRect.y || nextRefRect.width !== prevRefRect.width || nextRefRect.height !== prevRefRect.height)) {\n      update();\n    }\n    prevRefRect = nextRefRect;\n    frameId = requestAnimationFrame(frameLoop);\n  }\n  update();\n  return () => {\n    var _resizeObserver2;\n    ancestors.forEach(ancestor => {\n      ancestorScroll && ancestor.removeEventListener('scroll', update);\n      ancestorResize && ancestor.removeEventListener('resize', update);\n    });\n    cleanupIo == null || cleanupIo();\n    (_resizeObserver2 = resizeObserver) == null || _resizeObserver2.disconnect();\n    resizeObserver = null;\n    if (animationFrame) {\n      cancelAnimationFrame(frameId);\n    }\n  };\n}\n\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = autoPlacement$1;\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = shift$1;\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = flip$1;\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = size$1;\n\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = hide$1;\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = arrow$1;\n\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = inline$1;\n\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = limitShift$1;\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a given reference element.\n */\nconst computePosition = (reference, floating, options) => {\n  // This caches the expensive `getClippingElementAncestors` function so that\n  // multiple lifecycle resets re-use the same result. It only lives for a\n  // single call. If other functions become expensive, we can add them as well.\n  const cache = new Map();\n  const mergedOptions = {\n    platform,\n    ...options\n  };\n  const platformWithCache = {\n    ...mergedOptions.platform,\n    _c: cache\n  };\n  return computePosition$1(reference, floating, {\n    ...mergedOptions,\n    platform: platformWithCache\n  });\n};\n\nexport { arrow, autoPlacement, autoUpdate, computePosition, flip, hide, inline, limitShift, platform, shift, size };\n", "import { isRef, onMounted, ref, unref, watchEffect } from 'vue'\nimport { unrefElement } from '@vueuse/core'\nimport { isNil } from 'lodash-unified'\nimport { arrow as arrowCore, computePosition } from '@floating-ui/dom'\nimport { buildProps, isClient, keysOf } from '@element-plus/utils'\n\nimport type { Ref, ToRefs } from 'vue'\nimport type {\n  ComputePositionReturn,\n  Middleware,\n  Placement,\n  SideObject,\n  Strategy,\n  VirtualElement,\n} from '@floating-ui/dom'\n\nexport const useFloatingProps = buildProps({} as const)\n\nexport type UseFloatingProps = ToRefs<{\n  middleware: Array<Middleware>\n  placement: Placement\n  strategy: Strategy\n}>\n\ntype ElementRef = Parameters<typeof unrefElement>['0']\n\nconst unrefReference = (\n  elRef: ElementRef | Ref<VirtualElement | undefined>\n) => {\n  if (!isClient) return\n  if (!elRef) return elRef\n  const unrefEl = unrefElement(elRef as ElementRef)\n  if (unrefEl) return unrefEl\n  return isRef(elRef) ? unrefEl : (elRef as VirtualElement)\n}\n\nexport const getPositionDataWithUnit = <T extends Record<string, number>>(\n  record: T | undefined,\n  key: keyof T\n) => {\n  const value = record?.[key]\n  return isNil(value) ? '' : `${value}px`\n}\n\nexport const useFloating = ({\n  middleware,\n  placement,\n  strategy,\n}: UseFloatingProps) => {\n  const referenceRef = ref<HTMLElement | VirtualElement>()\n  const contentRef = ref<HTMLElement>()\n  const x = ref<number>()\n  const y = ref<number>()\n  const middlewareData = ref<ComputePositionReturn['middlewareData']>({})\n\n  const states = {\n    x,\n    y,\n    placement,\n    strategy,\n    middlewareData,\n  } as const\n\n  const update = async () => {\n    if (!isClient) return\n\n    const referenceEl = unrefReference(referenceRef)\n    const contentEl = unrefElement(contentRef)\n    if (!referenceEl || !contentEl) return\n\n    const data = await computePosition(referenceEl, contentEl, {\n      placement: unref(placement),\n      strategy: unref(strategy),\n      middleware: unref(middleware),\n    })\n\n    keysOf(states).forEach((key) => {\n      states[key].value = data[key]\n    })\n  }\n\n  onMounted(() => {\n    watchEffect(() => {\n      update()\n    })\n  })\n\n  return {\n    ...states,\n    update,\n    referenceRef,\n    contentRef,\n  }\n}\n\nexport type ArrowMiddlewareProps = {\n  arrowRef: Ref<HTMLElement | null | undefined>\n  padding?: number | SideObject\n}\n\nexport const arrowMiddleware = ({\n  arrowRef,\n  padding,\n}: ArrowMiddlewareProps): Middleware => {\n  return {\n    name: 'arrow',\n    options: {\n      element: arrowRef,\n      padding,\n    },\n\n    fn(args) {\n      const arrowEl = unref(arrowRef)\n      if (!arrowEl) return {}\n\n      return arrowCore({\n        element: arrowEl,\n        padding,\n      }).fn(args)\n    },\n  }\n}\n", "import type { ShallowRef } from 'vue'\n\ninterface SelectionInfo {\n  selectionStart?: number\n  selectionEnd?: number\n  value?: string\n  beforeTxt?: string\n  afterTxt?: string\n}\n\n// Keep input cursor in the correct position when we use formatter.\nexport function useCursor(\n  input: ShallowRef<HTMLInputElement | undefined>\n): [() => void, () => void] {\n  let selectionInfo: SelectionInfo\n  function recordCursor() {\n    if (input.value == undefined) return\n\n    const { selectionStart, selectionEnd, value } = input.value\n\n    if (selectionStart == null || selectionEnd == null) return\n\n    const beforeTxt = value.slice(0, Math.max(0, selectionStart))\n    const afterTxt = value.slice(Math.max(0, selectionEnd))\n\n    selectionInfo = {\n      selectionStart,\n      selectionEnd,\n      value,\n      beforeTxt,\n      afterTxt,\n    }\n  }\n  function setCursor() {\n    if (input.value == undefined || selectionInfo == undefined) return\n\n    const { value } = input.value\n    const { beforeTxt, afterTxt, selectionStart } = selectionInfo\n\n    if (\n      beforeTxt == undefined ||\n      afterTxt == undefined ||\n      selectionStart == undefined\n    )\n      return\n\n    let startPos = value.length\n\n    if (value.endsWith(afterTxt)) {\n      startPos = value.length - afterTxt.length\n    } else if (value.startsWith(beforeTxt)) {\n      startPos = beforeTxt.length\n    } else {\n      const beforeLastChar = beforeTxt[selectionStart - 1]\n      const newIndex = value.indexOf(beforeLastChar, selectionStart - 1)\n      if (newIndex !== -1) {\n        startPos = newIndex + 1\n      }\n    }\n\n    input.value.setSelectionRange(startPos, startPos)\n  }\n\n  return [recordCursor, setCursor]\n}\n", "import { shallowRef } from 'vue'\nimport { flattedChildren, isVNode } from '@element-plus/utils'\n\nimport type { ComponentInternalInstance, VNode } from 'vue'\n\nconst getOrderedChildren = <T>(\n  vm: ComponentInternalInstance,\n  childComponentName: string,\n  children: Record<number, T>\n): T[] => {\n  const nodes = flattedChildren(vm.subTree).filter(\n    (n): n is VNode =>\n      isVNode(n) &&\n      (n.type as any)?.name === childComponentName &&\n      !!n.component\n  )\n  const uids = nodes.map((n) => n.component!.uid)\n  return uids.map((uid) => children[uid]).filter((p) => !!p)\n}\n\nexport const useOrderedChildren = <T extends { uid: number }>(\n  vm: ComponentInternalInstance,\n  childComponentName: string\n) => {\n  const children: Record<number, T> = {}\n  const orderedChildren = shallowRef<T[]>([])\n\n  // TODO: split into two functions: addChild and sortChildren\n  const addChild = (child: T) => {\n    children[child.uid] = child\n    orderedChildren.value = getOrderedChildren(vm, childComponentName, children)\n  }\n  const removeChild = (uid: number) => {\n    delete children[uid]\n    orderedChildren.value = orderedChildren.value.filter(\n      (children) => children.uid !== uid\n    )\n  }\n\n  return {\n    children: orderedChildren,\n    addChild,\n    removeChild,\n  }\n}\n", "import { computed, inject, unref } from 'vue'\nimport { buildProp } from '@element-plus/utils'\nimport { componentSizes } from '@element-plus/constants'\n\nimport type { InjectionKey, Ref } from 'vue'\nimport type { ComponentSize } from '@element-plus/constants'\n\nexport const useSizeProp = buildProp({\n  type: String,\n  values: componentSizes,\n  required: false,\n} as const)\n\nexport const useSizeProps = {\n  size: useSizeProp,\n}\n\nexport interface SizeContext {\n  size: Ref<ComponentSize>\n}\n\nexport const SIZE_INJECTION_KEY: InjectionKey<SizeContext> = Symbol('size')\n\nexport const useGlobalSize = () => {\n  const injectedSize = inject(SIZE_INJECTION_KEY, {} as SizeContext)\n\n  return computed<ComponentSize>(() => {\n    return unref(injectedSize.size) || ''\n  })\n}\n", "import { getCurrentInstance, onMounted, ref, shallowRef, watch } from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport { isElement, isFunction } from '@element-plus/utils'\nimport type { ShallowRef } from 'vue'\n\ninterface UseFocusControllerOptions {\n  /**\n   * return true to cancel focus\n   * @param event FocusEvent\n   */\n  beforeFocus?: (event: FocusEvent) => boolean | undefined\n  afterFocus?: () => void\n  /**\n   * return true to cancel blur\n   * @param event FocusEvent\n   */\n  beforeBlur?: (event: FocusEvent) => boolean | undefined\n  afterBlur?: () => void\n}\n\nexport function useFocusController<T extends { focus: () => void }>(\n  target: ShallowRef<T | undefined>,\n  {\n    beforeFocus,\n    afterFocus,\n    beforeBlur,\n    afterBlur,\n  }: UseFocusControllerOptions = {}\n) {\n  const instance = getCurrentInstance()!\n  const { emit } = instance\n  const wrapperRef = shallowRef<HTMLElement>()\n  const isFocused = ref(false)\n\n  const handleFocus = (event: FocusEvent) => {\n    const cancelFocus = isFunction(beforeFocus) ? beforeFocus(event) : false\n    if (cancelFocus || isFocused.value) return\n    isFocused.value = true\n    emit('focus', event)\n    afterFocus?.()\n  }\n\n  const handleBlur = (event: FocusEvent) => {\n    const cancelBlur = isFunction(beforeBlur) ? beforeBlur(event) : false\n    if (\n      cancelBlur ||\n      (event.relatedTarget &&\n        wrapperRef.value?.contains(event.relatedTarget as Node))\n    )\n      return\n\n    isFocused.value = false\n    emit('blur', event)\n    afterBlur?.()\n  }\n\n  const handleClick = () => {\n    if (\n      wrapperRef.value?.contains(document.activeElement) &&\n      wrapperRef.value !== document.activeElement\n    )\n      return\n\n    target.value?.focus()\n  }\n\n  watch(wrapperRef, (el) => {\n    if (el) {\n      el.setAttribute('tabindex', '-1')\n    }\n  })\n\n  useEventListener(wrapperRef, 'focus', handleFocus, true)\n  useEventListener(wrapperRef, 'blur', handleBlur, true)\n  useEventListener(wrapperRef, 'click', handleClick, true)\n\n  // only for test\n  if (process.env.NODE_ENV === 'test') {\n    onMounted(() => {\n      const targetEl = isElement(target.value)\n        ? target.value\n        : document.querySelector('input,textarea')\n\n      if (targetEl) {\n        useEventListener(targetEl, 'focus', handleFocus, true)\n        useEventListener(targetEl, 'blur', handleBlur, true)\n      }\n    })\n  }\n\n  return {\n    isFocused,\n    /** Avoid using wrapperRef and handleFocus/handleBlur together */\n    wrapperRef,\n    handleFocus,\n    handleBlur,\n  }\n}\n", "import { nextTick, ref } from 'vue'\nimport { isKorean } from '@element-plus/utils'\n\ninterface UseCompositionOptions {\n  afterComposition: (event: CompositionEvent) => void\n  emit?: ((event: 'compositionstart', evt: CompositionEvent) => void) &\n    ((event: 'compositionupdate', evt: CompositionEvent) => void) &\n    ((event: 'compositionend', evt: CompositionEvent) => void)\n}\n\nexport function useComposition({\n  afterComposition,\n  emit,\n}: UseCompositionOptions) {\n  const isComposing = ref(false)\n\n  const handleCompositionStart = (event: CompositionEvent) => {\n    emit?.('compositionstart', event)\n    isComposing.value = true\n  }\n\n  const handleCompositionUpdate = (event: CompositionEvent) => {\n    emit?.('compositionupdate', event)\n    const text = (event.target as HTMLInputElement)?.value\n    const lastCharacter = text[text.length - 1] || ''\n    isComposing.value = !isKorean(lastCharacter)\n  }\n\n  const handleCompositionEnd = (event: CompositionEvent) => {\n    emit?.('compositionend', event)\n    if (isComposing.value) {\n      isComposing.value = false\n      nextTick(() => afterComposition(event))\n    }\n  }\n\n  const handleComposition = (event: CompositionEvent) => {\n    event.type === 'compositionend'\n      ? handleCompositionEnd(event)\n      : handleCompositionUpdate(event)\n  }\n\n  return {\n    isComposing,\n    handleComposition,\n    handleCompositionStart,\n    handleCompositionUpdate,\n    handleCompositionEnd,\n  }\n}\n", "import { computed, getCurrentInstance, inject, ref } from 'vue'\nimport { buildProps, debugWarn, isFunction } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, InjectionKey, Ref } from 'vue'\n\ntype EmptyValuesContext = ExtractPropTypes<typeof useEmptyValuesProps>\n\nexport const emptyValuesContextKey: InjectionKey<Ref<EmptyValuesContext>> =\n  Symbol('emptyValuesContextKey')\nexport const SCOPE = 'use-empty-values'\nexport const DEFAULT_EMPTY_VALUES = ['', undefined, null]\nexport const DEFAULT_VALUE_ON_CLEAR = undefined\n\nexport const useEmptyValuesProps = buildProps({\n  /**\n   * @description empty values supported by the component\n   */\n  emptyValues: Array,\n  /**\n   * @description return value when cleared, if you want to set `undefined`, use `() => undefined`\n   */\n  valueOnClear: {\n    type: [String, Number, Boolean, Function],\n    default: undefined,\n    validator: (val: any) => (isFunction(val) ? !val() : !val),\n  },\n} as const)\n\nexport const useEmptyValues = (\n  props: EmptyValuesContext,\n  defaultValue?: null | undefined\n) => {\n  const config = getCurrentInstance()\n    ? inject(emptyValuesContextKey, ref<EmptyValuesContext>({}))\n    : ref<EmptyValuesContext>({})\n\n  const emptyValues = computed(\n    () => props.emptyValues || config.value.emptyValues || DEFAULT_EMPTY_VALUES\n  )\n\n  const valueOnClear = computed(() => {\n    // function is used for undefined cause undefined can't be a value of prop\n    if (isFunction(props.valueOnClear)) {\n      return props.valueOnClear()\n    } else if (props.valueOnClear !== undefined) {\n      return props.valueOnClear\n    } else if (isFunction(config.value.valueOnClear)) {\n      return config.value.valueOnClear()\n    } else if (config.value.valueOnClear !== undefined) {\n      return config.value.valueOnClear\n    }\n    return defaultValue !== undefined ? defaultValue : DEFAULT_VALUE_ON_CLEAR\n  })\n\n  const isEmptyValue = (value: any) => {\n    return emptyValues.value.includes(value)\n  }\n\n  if (!emptyValues.value.includes(valueOnClear.value)) {\n    debugWarn(SCOPE, 'value-on-clear should be a value of empty-values')\n  }\n\n  return {\n    emptyValues,\n    valueOnClear,\n    isEmptyValue,\n  }\n}\n", "import { pick } from 'lodash-unified'\nimport { buildProps } from '@element-plus/utils'\n\nexport const ariaProps = buildProps({\n  /**\n   * @description native `aria-label` attribute\n   */\n  ariaLabel: String,\n  /**\n   * @description native `aria-orientation` attribute\n   */\n  ariaOrientation: {\n    type: String,\n    values: ['horizontal', 'vertical', 'undefined'],\n  },\n  /**\n   * @description native `aria-controls` attribute\n   */\n  ariaControls: String,\n})\n\nexport const useAriaProps = <T extends keyof typeof ariaProps>(\n  arias: Array<T>\n) => {\n  return pick<typeof ariaProps, T>(ariaProps, arias)\n}\n", "import type { ConfigProviderProps } from './config-provider-props'\nimport type { InjectionKey, Ref } from 'vue'\n\nexport type ConfigProviderContext = Partial<ConfigProviderProps>\n\nexport const configProviderContextKey: InjectionKey<\n  Ref<ConfigProviderContext>\n> = Symbol()\n", "import { computed, getCurrentInstance, inject, provide, ref, unref } from 'vue'\nimport { debugWarn, keysOf } from '@element-plus/utils'\nimport {\n  SIZE_INJECTION_KEY,\n  defaultInitialZIndex,\n  defaultNamespace,\n  emptyValuesContextKey,\n  localeContextKey,\n  namespaceContextKey,\n  useLocale,\n  useNamespace,\n  useZIndex,\n  zIndexContextKey,\n} from '@element-plus/hooks'\nimport { configProviderContextKey } from '../constants'\n\nimport type { MaybeRef } from '@vueuse/core'\nimport type { App, Ref } from 'vue'\nimport type { ConfigProviderContext } from '../constants'\n\n// this is meant to fix global methods like `ElMessage(opts)`, this way we can inject current locale\n// into the component as default injection value.\n// refer to: https://github.com/element-plus/element-plus/issues/2610#issuecomment-887965266\nconst globalConfig = ref<ConfigProviderContext>()\n\nexport function useGlobalConfig<\n  K extends keyof ConfigProviderContext,\n  D extends ConfigProviderContext[K]\n>(\n  key: K,\n  defaultValue?: D\n): Ref<Exclude<ConfigProviderContext[K], undefined> | D>\nexport function useGlobalConfig(): Ref<ConfigProviderContext>\nexport function useGlobalConfig(\n  key?: keyof ConfigProviderContext,\n  defaultValue = undefined\n) {\n  const config = getCurrentInstance()\n    ? inject(configProviderContextKey, globalConfig)\n    : globalConfig\n  if (key) {\n    return computed(() => config.value?.[key] ?? defaultValue)\n  } else {\n    return config\n  }\n}\n\n// for components like `ElMessage` `ElNotification` `ElMessageBox`.\nexport function useGlobalComponentSettings(\n  block: string,\n  sizeFallback?: MaybeRef<ConfigProviderContext['size']>\n) {\n  const config = useGlobalConfig()\n\n  const ns = useNamespace(\n    block,\n    computed(() => config.value?.namespace || defaultNamespace)\n  )\n\n  const locale = useLocale(computed(() => config.value?.locale))\n  const zIndex = useZIndex(\n    computed(() => config.value?.zIndex || defaultInitialZIndex)\n  )\n  const size = computed(() => unref(sizeFallback) || config.value?.size || '')\n  provideGlobalConfig(computed(() => unref(config) || {}))\n\n  return {\n    ns,\n    locale,\n    zIndex,\n    size,\n  }\n}\n\nexport const provideGlobalConfig = (\n  config: MaybeRef<ConfigProviderContext>,\n  app?: App,\n  global = false\n) => {\n  const inSetup = !!getCurrentInstance()\n  const oldConfig = inSetup ? useGlobalConfig() : undefined\n\n  const provideFn = app?.provide ?? (inSetup ? provide : undefined)\n  if (!provideFn) {\n    debugWarn(\n      'provideGlobalConfig',\n      'provideGlobalConfig() can only be used inside setup().'\n    )\n    return\n  }\n\n  const context = computed(() => {\n    const cfg = unref(config)\n    if (!oldConfig?.value) return cfg\n    return mergeConfig(oldConfig.value, cfg)\n  })\n  provideFn(configProviderContextKey, context)\n  provideFn(\n    localeContextKey,\n    computed(() => context.value.locale)\n  )\n  provideFn(\n    namespaceContextKey,\n    computed(() => context.value.namespace)\n  )\n  provideFn(\n    zIndexContextKey,\n    computed(() => context.value.zIndex)\n  )\n\n  provideFn(SIZE_INJECTION_KEY, {\n    size: computed(() => context.value.size || ''),\n  })\n\n  provideFn(\n    emptyValuesContextKey,\n    computed(() => ({\n      emptyValues: context.value.emptyValues,\n      valueOnClear: context.value.valueOnClear,\n    }))\n  )\n\n  if (global || !globalConfig.value) {\n    globalConfig.value = context.value\n  }\n  return context\n}\n\nconst mergeConfig = (\n  a: ConfigProviderContext,\n  b: ConfigProviderContext\n): ConfigProviderContext => {\n  const keys = [...new Set([...keysOf(a), ...keysOf(b)])]\n  const obj: Record<string, any> = {}\n  for (const key of keys) {\n    obj[key] = b[key] !== undefined ? b[key] : a[key]\n  }\n  return obj\n}\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { useEmptyValuesProps, useSizeProp } from '@element-plus/hooks'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { Language } from '@element-plus/locale'\nimport type { ButtonConfigContext } from '@element-plus/components/button'\nimport type { MessageConfigContext } from '@element-plus/components/message'\n\nexport type ExperimentalFeatures = {\n  // TO BE Defined\n}\n\nexport const configProviderProps = buildProps({\n  /**\n   * @description Controlling if the users want a11y features\n   */\n  a11y: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description Locale Object\n   */\n  locale: {\n    type: definePropType<Language>(Object),\n  },\n  /**\n   * @description global component size\n   */\n  size: useSizeProp,\n  /**\n   * @description button related configuration, [see the following table](#button-attributes)\n   */\n  button: {\n    type: definePropType<ButtonConfigContext>(Object),\n  },\n  /**\n   * @description features at experimental stage to be added, all features are default to be set to false                                                                                | ^[object]\n   */\n  experimentalFeatures: {\n    type: definePropType<ExperimentalFeatures>(Object),\n  },\n  /**\n   * @description Controls if we should handle keyboard navigation\n   */\n  keyboardNavigation: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description message related configuration, [see the following table](#message-attributes)\n   */\n  message: {\n    type: definePropType<MessageConfigContext>(Object),\n  },\n  /**\n   * @description global Initial zIndex\n   */\n  zIndex: Number,\n  /**\n   * @description global component className prefix (cooperated with [$namespace](https://github.com/element-plus/element-plus/blob/dev/packages/theme-chalk/src/mixins/config.scss#L1)) | ^[string]\n   */\n  namespace: {\n    type: String,\n    default: 'el',\n  },\n  ...useEmptyValuesProps,\n} as const)\nexport type ConfigProviderProps = ExtractPropTypes<typeof configProviderProps>\n", "import { defineComponent, renderSlot, watch } from 'vue'\nimport { provideGlobalConfig } from './hooks/use-global-config'\nimport { configProviderProps } from './config-provider-props'\n\nimport type { MessageConfigContext } from '@element-plus/components/message'\n\nexport const messageConfig: MessageConfigContext = {}\n\nconst ConfigProvider = defineComponent({\n  name: 'ElConfigProvider',\n  props: configProviderProps,\n\n  setup(props, { slots }) {\n    watch(\n      () => props.message,\n      (val) => {\n        Object.assign(messageConfig, val ?? {})\n      },\n      { immediate: true, deep: true }\n    )\n    const config = provideGlobalConfig(props)\n    return () => renderSlot(slots, 'default', { config: config?.value })\n  },\n})\nexport type ConfigProviderInstance = InstanceType<typeof ConfigProvider>\n\nexport default ConfigProvider\n", "import { withInstall } from '@element-plus/utils'\n\nimport ConfigProvider from './src/config-provider'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElConfigProvider: SFCWithInstall<typeof ConfigProvider> =\n  withInstall(ConfigProvider)\nexport default ElConfigProvider\n\nexport * from './src/config-provider'\nexport * from './src/config-provider-props'\nexport * from './src/constants'\nexport * from './src/hooks/use-global-config'\n", "export const version = '2.8.4'\n", "import { provideGlobalConfig } from '@element-plus/components/config-provider'\nimport { INSTALLED_KEY } from '@element-plus/constants'\nimport { version } from './version'\n\nimport type { App, Plugin } from '@vue/runtime-core'\nimport type { ConfigProviderContext } from '@element-plus/components/config-provider'\n\nexport const makeInstaller = (components: Plugin[] = []) => {\n  const install = (app: App, options?: ConfigProviderContext) => {\n    if (app[INSTALLED_KEY]) return\n\n    app[INSTALLED_KEY] = true\n    components.forEach((c) => app.use(c))\n\n    if (options) provideGlobalConfig(options, app, true)\n  }\n\n  return {\n    version,\n    install,\n  }\n}\n", "import {\n  buildProps,\n  definePropType,\n  isBoolean,\n  isNumber,\n} from '@element-plus/utils'\nimport { CHANGE_EVENT } from '@element-plus/constants'\nimport type { ExtractPropTypes } from 'vue'\nimport type { ZIndexProperty } from 'csstype'\nimport type Affix from './affix.vue'\n\nexport const affixProps = buildProps({\n  /**\n   * @description affix element zIndex value\n   * */\n  zIndex: {\n    type: definePropType<ZIndexProperty>([Number, String]),\n    default: 100,\n  },\n  /**\n   * @description target container. (CSS selector)\n   */\n  target: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description offset distance\n   * */\n  offset: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description position of affix\n   * */\n  position: {\n    type: String,\n    values: ['top', 'bottom'],\n    default: 'top',\n  },\n} as const)\nexport type AffixProps = ExtractPropTypes<typeof affixProps>\n\nexport const affixEmits = {\n  scroll: ({ scrollTop, fixed }: { scrollTop: number; fixed: boolean }) =>\n    isNumber(scrollTop) && isBoolean(fixed),\n  [CHANGE_EVENT]: (fixed: boolean) => isBoolean(fixed),\n}\nexport type AffixEmits = typeof affixEmits\n\nexport type AffixInstance = InstanceType<typeof Affix>\n", "\nexport default (sfc, props) => {\n  const target = sfc.__vccOpts || sfc;\n  for (const [key, val] of props) {\n    target[key] = val;\n  }\n  return target;\n}\n", "<template>\n  <div ref=\"root\" :class=\"ns.b()\" :style=\"rootStyle\">\n    <div :class=\"{ [ns.m('fixed')]: fixed }\" :style=\"affixStyle\">\n      <slot />\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, onMounted, ref, shallowRef, watch, watchEffect } from 'vue'\nimport {\n  useElementBounding,\n  useEventListener,\n  useWindowSize,\n} from '@vueuse/core'\nimport { addUnit, getScrollContainer, throwError } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { affixEmits, affixProps } from './affix'\nimport type { CSSProperties } from 'vue'\n\nconst COMPONENT_NAME = 'ElAffix'\ndefineOptions({\n  name: COMPONENT_NAME,\n})\n\nconst props = defineProps(affixProps)\nconst emit = defineEmits(affixEmits)\n\nconst ns = useNamespace('affix')\n\nconst target = shallowRef<HTMLElement>()\nconst root = shallowRef<HTMLDivElement>()\nconst scrollContainer = shallowRef<HTMLElement | Window>()\nconst { height: windowHeight } = useWindowSize()\nconst {\n  height: rootHeight,\n  width: rootWidth,\n  top: rootTop,\n  bottom: rootBottom,\n  update: updateRoot,\n} = useElementBounding(root, { windowScroll: false })\nconst targetRect = useElementBounding(target)\n\nconst fixed = ref(false)\nconst scrollTop = ref(0)\nconst transform = ref(0)\n\nconst rootStyle = computed<CSSProperties>(() => {\n  return {\n    height: fixed.value ? `${rootHeight.value}px` : '',\n    width: fixed.value ? `${rootWidth.value}px` : '',\n  }\n})\n\nconst affixStyle = computed<CSSProperties>(() => {\n  if (!fixed.value) return {}\n\n  const offset = props.offset ? addUnit(props.offset) : 0\n  return {\n    height: `${rootHeight.value}px`,\n    width: `${rootWidth.value}px`,\n    top: props.position === 'top' ? offset : '',\n    bottom: props.position === 'bottom' ? offset : '',\n    transform: transform.value ? `translateY(${transform.value}px)` : '',\n    zIndex: props.zIndex,\n  }\n})\n\nconst update = () => {\n  if (!scrollContainer.value) return\n\n  scrollTop.value =\n    scrollContainer.value instanceof Window\n      ? document.documentElement.scrollTop\n      : scrollContainer.value.scrollTop || 0\n\n  const { position, target, offset } = props\n  const rootHeightOffset = offset + rootHeight.value\n\n  if (position === 'top') {\n    if (target) {\n      const difference = targetRect.bottom.value - rootHeightOffset\n      fixed.value = offset > rootTop.value && targetRect.bottom.value > 0\n      transform.value = difference < 0 ? difference : 0\n    } else {\n      fixed.value = offset > rootTop.value\n    }\n  } else if (target) {\n    const difference =\n      windowHeight.value - targetRect.top.value - rootHeightOffset\n    fixed.value =\n      windowHeight.value - offset < rootBottom.value &&\n      windowHeight.value > targetRect.top.value\n    transform.value = difference < 0 ? -difference : 0\n  } else {\n    fixed.value = windowHeight.value - offset < rootBottom.value\n  }\n}\n\nconst handleScroll = () => {\n  updateRoot()\n  emit('scroll', {\n    scrollTop: scrollTop.value,\n    fixed: fixed.value,\n  })\n}\n\nwatch(fixed, (val) => emit('change', val))\n\nonMounted(() => {\n  if (props.target) {\n    target.value =\n      document.querySelector<HTMLElement>(props.target) ?? undefined\n    if (!target.value)\n      throwError(COMPONENT_NAME, `Target does not exist: ${props.target}`)\n  } else {\n    target.value = document.documentElement\n  }\n  scrollContainer.value = getScrollContainer(root.value!, true)\n  updateRoot()\n})\n\nuseEventListener(scrollContainer, 'scroll', handleScroll)\nwatchEffect(update)\n\ndefineExpose({\n  /** @description update affix status */\n  update,\n  /** @description update rootRect info */\n  updateRoot,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Affix from './src/affix.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\nexport const ElAffix: SFCWithInstall<typeof Affix> = withInstall(Affix)\nexport default ElAffix\n\nexport * from './src/affix'\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Icon from './icon.vue'\n\nexport const iconProps = buildProps({\n  /**\n   * @description SVG icon size, size x size\n   */\n  size: {\n    type: definePropType<number | string>([Number, String]),\n  },\n  /**\n   * @description SVG tag's fill attribute\n   */\n  color: {\n    type: String,\n  },\n} as const)\nexport type IconProps = ExtractPropTypes<typeof iconProps>\nexport type IconInstance = InstanceType<typeof Icon>\n", "<template>\n  <i :class=\"ns.b()\" :style=\"style\" v-bind=\"$attrs\">\n    <slot />\n  </i>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { addUnit, isUndefined } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { iconProps } from './icon'\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElIcon',\n  inheritAttrs: false,\n})\nconst props = defineProps(iconProps)\nconst ns = useNamespace('icon')\n\nconst style = computed<CSSProperties>(() => {\n  const { size, color } = props\n  if (!size && !color) return {}\n\n  return {\n    fontSize: isUndefined(size) ? undefined : addUnit(size),\n    '--color': color,\n  }\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Icon from './src/icon.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElIcon: SFCWithInstall<typeof Icon> = withInstall(Icon)\nexport default ElIcon\n\nexport * from './src/icon'\n", "import { TypeComponentsMap, buildProps, keysOf } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const alertEffects = ['light', 'dark'] as const\n\nexport const alertProps = buildProps({\n  /**\n   * @description alert title.\n   */\n  title: {\n    type: String,\n    default: '',\n  },\n  description: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description alert type.\n   */\n  type: {\n    type: String,\n    values: keysOf(TypeComponentsMap),\n    default: 'info',\n  },\n  /**\n   * @description whether alert can be dismissed.\n   */\n  closable: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description text for replacing x button\n   */\n  closeText: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description whether show icon\n   */\n  showIcon: Boolean,\n  /**\n   * @description should content be placed in center.\n   */\n  center: Boolean,\n  effect: {\n    type: String,\n    values: alertEffects,\n    default: 'light',\n  },\n} as const)\nexport type AlertProps = ExtractPropTypes<typeof alertProps>\n\nexport const alertEmits = {\n  close: (evt: MouseEvent) => evt instanceof MouseEvent,\n}\nexport type AlertEmits = typeof alertEmits\n", "<template>\n  <transition :name=\"ns.b('fade')\">\n    <div\n      v-show=\"visible\"\n      :class=\"[ns.b(), ns.m(type), ns.is('center', center), ns.is(effect)]\"\n      role=\"alert\"\n    >\n      <el-icon v-if=\"showIcon && iconComponent\" :class=\"iconClass\">\n        <component :is=\"iconComponent\" />\n      </el-icon>\n\n      <div :class=\"ns.e('content')\">\n        <span\n          v-if=\"title || $slots.title\"\n          :class=\"[ns.e('title'), withDescription]\"\n        >\n          <slot name=\"title\">{{ title }}</slot>\n        </span>\n        <p v-if=\"$slots.default || description\" :class=\"ns.e('description')\">\n          <slot>\n            {{ description }}\n          </slot>\n        </p>\n        <template v-if=\"closable\">\n          <div\n            v-if=\"closeText\"\n            :class=\"[ns.e('close-btn'), ns.is('customed')]\"\n            @click=\"close\"\n          >\n            {{ closeText }}\n          </div>\n          <el-icon v-else :class=\"ns.e('close-btn')\" @click=\"close\">\n            <Close />\n          </el-icon>\n        </template>\n      </div>\n    </div>\n  </transition>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, ref, useSlots } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { TypeComponents, TypeComponentsMap } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { alertEmits, alertProps } from './alert'\n\nconst { Close } = TypeComponents\n\ndefineOptions({\n  name: 'ElAlert',\n})\n\nconst props = defineProps(alertProps)\nconst emit = defineEmits(alertEmits)\nconst slots = useSlots()\n\nconst ns = useNamespace('alert')\n\nconst visible = ref(true)\n\nconst iconComponent = computed(() => TypeComponentsMap[props.type])\n\nconst iconClass = computed(() => [\n  ns.e('icon'),\n  { [ns.is('big')]: !!props.description || !!slots.default },\n])\n\nconst withDescription = computed(() => {\n  return { 'with-description': props.description || slots.default }\n})\n\nconst close = (evt: MouseEvent) => {\n  visible.value = false\n  emit('close', evt)\n}\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Alert from './src/alert.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElAlert: SFCWithInstall<typeof Alert> = withInstall(Alert)\nexport default ElAlert\n\nexport * from './src/alert'\nexport type { AlertInstance } from './src/instance'\n", "import type { InjectionKey } from 'vue'\nimport type { FormContext, FormItemContext } from './types'\n\nexport const formContextKey: InjectionKey<FormContext> =\n  Symbol('formContextKey')\nexport const formItemContextKey: InjectionKey<FormItemContext> =\n  Symbol('formItemContextKey')\n", "import { computed, inject, ref, unref } from 'vue'\nimport { useGlobalSize, useProp } from '@element-plus/hooks'\nimport { formContextKey, formItemContextKey } from '../constants'\n\nimport type { ComponentSize } from '@element-plus/constants'\nimport type { MaybeRef } from '@vueuse/core'\n\nexport const useFormSize = (\n  fallback?: MaybeRef<ComponentSize | undefined>,\n  ignore: Partial<Record<'prop' | 'form' | 'formItem' | 'global', boolean>> = {}\n) => {\n  const emptyRef = ref(undefined)\n\n  const size = ignore.prop ? emptyRef : useProp<ComponentSize>('size')\n  const globalConfig = ignore.global ? emptyRef : useGlobalSize()\n  const form = ignore.form\n    ? { size: undefined }\n    : inject(formContextKey, undefined)\n  const formItem = ignore.formItem\n    ? { size: undefined }\n    : inject(formItemContextKey, undefined)\n\n  return computed(\n    (): ComponentSize =>\n      size.value ||\n      unref(fallback) ||\n      formItem?.size ||\n      form?.size ||\n      globalConfig.value ||\n      ''\n  )\n}\n\nexport const useFormDisabled = (fallback?: MaybeRef<boolean | undefined>) => {\n  const disabled = useProp<boolean>('disabled')\n  const form = inject(formContextKey, undefined)\n  return computed(\n    () => disabled.value || unref(fallback) || form?.disabled || false\n  )\n}\n\n// These exports are used for preventing breaking changes\nexport const useSize = useFormSize\nexport const useDisabled = useFormDisabled\n", "import {\n  computed,\n  inject,\n  onMounted,\n  onUnmounted,\n  ref,\n  toRef,\n  watch,\n} from 'vue'\nimport { useId } from '@element-plus/hooks'\nimport { formContextKey, formItemContextKey } from '../constants'\n\nimport type { ComputedRef, Ref, WatchStopHandle } from 'vue'\nimport type { FormItemContext } from '../types'\n\nexport const useFormItem = () => {\n  const form = inject(formContextKey, undefined)\n  const formItem = inject(formItemContextKey, undefined)\n  return {\n    form,\n    formItem,\n  }\n}\n\nexport type IUseFormItemInputCommonProps = {\n  id?: string\n  label?: string | number | boolean | Record<string, any>\n  ariaLabel?: string | number | boolean | Record<string, any>\n}\n\nexport const useFormItemInputId = (\n  props: Partial<IUseFormItemInputCommonProps>,\n  {\n    formItemContext,\n    disableIdGeneration,\n    disableIdManagement,\n  }: {\n    formItemContext?: FormItemContext\n    disableIdGeneration?: ComputedRef<boolean> | Ref<boolean>\n    disableIdManagement?: ComputedRef<boolean> | Ref<boolean>\n  }\n) => {\n  if (!disableIdGeneration) {\n    disableIdGeneration = ref<boolean>(false)\n  }\n  if (!disableIdManagement) {\n    disableIdManagement = ref<boolean>(false)\n  }\n\n  const inputId = ref<string>()\n  let idUnwatch: WatchStopHandle | undefined = undefined\n\n  const isLabeledByFormItem = computed<boolean>(() => {\n    return !!(\n      !(props.label || props.ariaLabel) &&\n      formItemContext &&\n      formItemContext.inputIds &&\n      formItemContext.inputIds?.length <= 1\n    )\n  })\n\n  // Generate id for ElFormItem label if not provided as prop\n  onMounted(() => {\n    idUnwatch = watch(\n      [toRef(props, 'id'), disableIdGeneration] as any,\n      ([id, disableIdGeneration]: [string, boolean]) => {\n        const newId = id ?? (!disableIdGeneration ? useId().value : undefined)\n        if (newId !== inputId.value) {\n          if (formItemContext?.removeInputId) {\n            inputId.value && formItemContext.removeInputId(inputId.value)\n            if (!disableIdManagement?.value && !disableIdGeneration && newId) {\n              formItemContext.addInputId(newId)\n            }\n          }\n          inputId.value = newId\n        }\n      },\n      { immediate: true }\n    )\n  })\n\n  onUnmounted(() => {\n    idUnwatch && idUnwatch()\n    if (formItemContext?.removeInputId) {\n      inputId.value && formItemContext.removeInputId(inputId.value)\n    }\n  })\n\n  return {\n    isLabeledByFormItem,\n    inputId,\n  }\n}\n", "import { componentSizes } from '@element-plus/constants'\nimport {\n  buildProps,\n  definePropType,\n  isArray,\n  isBoolean,\n  isString,\n} from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { FormItemProp } from './form-item'\nimport type { FormRules } from './types'\n\nexport const formMetaProps = buildProps({\n  /**\n   * @description Control the size of components in this form.\n   */\n  size: {\n    type: String,\n    values: componentSizes,\n  },\n  /**\n   * @description Whether to disable all components in this form. If set to `true`, it will override the `disabled` prop of the inner component.\n   */\n  disabled: Boolean,\n} as const)\n\nexport const formProps = buildProps({\n  ...formMetaProps,\n  /**\n   * @description Data of form component.\n   */\n  model: Object,\n  /**\n   * @description Validation rules of form.\n   */\n  rules: {\n    type: definePropType<FormRules>(Object),\n  },\n  /**\n   * @description Position of label. If set to `'left'` or `'right'`, `label-width` prop is also required.\n   */\n  labelPosition: {\n    type: String,\n    values: ['left', 'right', 'top'],\n    default: 'right',\n  },\n  /**\n   * @description Position of asterisk.\n   */\n  requireAsteriskPosition: {\n    type: String,\n    values: ['left', 'right'],\n    default: 'left',\n  },\n  /**\n   * @description Width of label, e.g. `'50px'`. All its direct child form items will inherit this value. `auto` is supported.\n   */\n  labelWidth: {\n    type: [String, Number],\n    default: '',\n  },\n  /**\n   * @description Suffix of the label.\n   */\n  labelSuffix: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description Whether the form is inline.\n   */\n  inline: Boolean,\n  /**\n   * @description Whether to display the error message inline with the form item.\n   */\n  inlineMessage: Boolean,\n  /**\n   * @description Whether to display an icon indicating the validation result.\n   */\n  statusIcon: Boolean,\n  /**\n   * @description Whether to show the error message.\n   */\n  showMessage: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description Whether to trigger validation when the `rules` prop is changed.\n   */\n  validateOnRuleChange: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description Whether to hide required fields should have a red asterisk (star) beside their labels.\n   */\n  hideRequiredAsterisk: Boolean,\n  /**\n   * @description When validation fails, scroll to the first error form entry.\n   */\n  scrollToError: Boolean,\n  /**\n   * @description When validation fails, it scrolls to the first error item based on the scrollIntoView option.\n   */\n  scrollIntoViewOptions: {\n    type: [Object, Boolean],\n  },\n} as const)\nexport type FormProps = ExtractPropTypes<typeof formProps>\nexport type FormMetaProps = ExtractPropTypes<typeof formMetaProps>\n\nexport const formEmits = {\n  validate: (prop: FormItemProp, isValid: boolean, message: string) =>\n    (isArray(prop) || isString(prop)) &&\n    isBoolean(isValid) &&\n    isString(message),\n}\nexport type FormEmits = typeof formEmits\n", "import { computed, ref } from 'vue'\nimport { debugWarn, ensureArray } from '@element-plus/utils'\nimport type { Arrayable } from '@element-plus/utils'\nimport type { FormItemContext } from './types'\nimport type { FormItemProp } from './form-item'\n\nconst SCOPE = 'ElForm'\n\nexport function useFormLabelWidth() {\n  const potentialLabelWidthArr = ref<number[]>([])\n\n  const autoLabelWidth = computed(() => {\n    if (!potentialLabelWidthArr.value.length) return '0'\n    const max = Math.max(...potentialLabelWidthArr.value)\n    return max ? `${max}px` : ''\n  })\n\n  function getLabelWidthIndex(width: number) {\n    const index = potentialLabelWidthArr.value.indexOf(width)\n    if (index === -1 && autoLabelWidth.value === '0') {\n      debugWarn(SCOPE, `unexpected width ${width}`)\n    }\n    return index\n  }\n\n  function registerLabelWidth(val: number, oldVal: number) {\n    if (val && oldVal) {\n      const index = getLabelWidthIndex(oldVal)\n      potentialLabelWidthArr.value.splice(index, 1, val)\n    } else if (val) {\n      potentialLabelWidthArr.value.push(val)\n    }\n  }\n\n  function deregisterLabelWidth(val: number) {\n    const index = getLabelWidthIndex(val)\n    if (index > -1) {\n      potentialLabelWidthArr.value.splice(index, 1)\n    }\n  }\n\n  return {\n    autoLabelWidth,\n    registerLabelWidth,\n    deregisterLabelWidth,\n  }\n}\n\nexport const filterFields = (\n  fields: FormItemContext[],\n  props: Arrayable<FormItemProp>\n) => {\n  const normalized = ensureArray(props)\n  return normalized.length > 0\n    ? fields.filter((field) => field.prop && normalized.includes(field.prop))\n    : fields\n}\n", "<template>\n  <form :class=\"formClasses\">\n    <slot />\n  </form>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, provide, reactive, toRefs, watch } from 'vue'\nimport { debugWarn, isFunction } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormSize } from './hooks'\nimport { formContextKey } from './constants'\nimport { formEmits, formProps } from './form'\nimport { filterFields, useFormLabelWidth } from './utils'\n\nimport type { ValidateFieldsError } from 'async-validator'\nimport type { Arrayable } from '@element-plus/utils'\nimport type {\n  FormContext,\n  FormItemContext,\n  FormValidateCallback,\n  FormValidationResult,\n} from './types'\nimport type { FormItemProp } from './form-item'\n\nconst COMPONENT_NAME = 'ElForm'\ndefineOptions({\n  name: COMPONENT_NAME,\n})\nconst props = defineProps(formProps)\nconst emit = defineEmits(formEmits)\n\nconst fields: FormItemContext[] = []\n\nconst formSize = useFormSize()\nconst ns = useNamespace('form')\nconst formClasses = computed(() => {\n  const { labelPosition, inline } = props\n  return [\n    ns.b(),\n    // todo: in v2.2.0, we can remove default\n    // in fact, remove it doesn't affect the final style\n    ns.m(formSize.value || 'default'),\n    {\n      [ns.m(`label-${labelPosition}`)]: labelPosition,\n      [ns.m('inline')]: inline,\n    },\n  ]\n})\n\nconst getField: FormContext['getField'] = (prop) => {\n  return fields.find((field) => field.prop === prop)\n}\n\nconst addField: FormContext['addField'] = (field) => {\n  fields.push(field)\n}\n\nconst removeField: FormContext['removeField'] = (field) => {\n  if (field.prop) {\n    fields.splice(fields.indexOf(field), 1)\n  }\n}\n\nconst resetFields: FormContext['resetFields'] = (properties = []) => {\n  if (!props.model) {\n    debugWarn(COMPONENT_NAME, 'model is required for resetFields to work.')\n    return\n  }\n  filterFields(fields, properties).forEach((field) => field.resetField())\n}\n\nconst clearValidate: FormContext['clearValidate'] = (props = []) => {\n  filterFields(fields, props).forEach((field) => field.clearValidate())\n}\n\nconst isValidatable = computed(() => {\n  const hasModel = !!props.model\n  if (!hasModel) {\n    debugWarn(COMPONENT_NAME, 'model is required for validate to work.')\n  }\n  return hasModel\n})\n\nconst obtainValidateFields = (props: Arrayable<FormItemProp>) => {\n  if (fields.length === 0) return []\n\n  const filteredFields = filterFields(fields, props)\n  if (!filteredFields.length) {\n    debugWarn(COMPONENT_NAME, 'please pass correct props!')\n    return []\n  }\n  return filteredFields\n}\n\nconst validate = async (\n  callback?: FormValidateCallback\n): FormValidationResult => validateField(undefined, callback)\n\nconst doValidateField = async (\n  props: Arrayable<FormItemProp> = []\n): Promise<boolean> => {\n  if (!isValidatable.value) return false\n\n  const fields = obtainValidateFields(props)\n  if (fields.length === 0) return true\n\n  let validationErrors: ValidateFieldsError = {}\n  for (const field of fields) {\n    try {\n      await field.validate('')\n    } catch (fields) {\n      validationErrors = {\n        ...validationErrors,\n        ...(fields as ValidateFieldsError),\n      }\n    }\n  }\n\n  if (Object.keys(validationErrors).length === 0) return true\n  return Promise.reject(validationErrors)\n}\n\nconst validateField: FormContext['validateField'] = async (\n  modelProps = [],\n  callback\n) => {\n  const shouldThrow = !isFunction(callback)\n  try {\n    const result = await doValidateField(modelProps)\n    // When result is false meaning that the fields are not validatable\n    if (result === true) {\n      await callback?.(result)\n    }\n    return result\n  } catch (e) {\n    if (e instanceof Error) throw e\n\n    const invalidFields = e as ValidateFieldsError\n\n    if (props.scrollToError) {\n      scrollToField(Object.keys(invalidFields)[0])\n    }\n    await callback?.(false, invalidFields)\n    return shouldThrow && Promise.reject(invalidFields)\n  }\n}\n\nconst scrollToField = (prop: FormItemProp) => {\n  const field = filterFields(fields, prop)[0]\n  if (field) {\n    field.$el?.scrollIntoView(props.scrollIntoViewOptions)\n  }\n}\n\nwatch(\n  () => props.rules,\n  () => {\n    if (props.validateOnRuleChange) {\n      validate().catch((err) => debugWarn(err))\n    }\n  },\n  { deep: true }\n)\n\nprovide(\n  formContextKey,\n  reactive({\n    ...toRefs(props),\n    emit,\n\n    resetFields,\n    clearValidate,\n    validateField,\n    getField,\n    addField,\n    removeField,\n\n    ...useFormLabelWidth(),\n  })\n)\n\ndefineExpose({\n  /**\n   * @description Validate the whole form. Receives a callback or returns `Promise`.\n   */\n  validate,\n  /**\n   * @description Validate specified fields.\n   */\n  validateField,\n  /**\n   * @description Reset specified fields and remove validation result.\n   */\n  resetFields,\n  /**\n   * @description Clear validation message for specified fields.\n   */\n  clearValidate,\n  /**\n   * @description Scroll to the specified fields.\n   */\n  scrollToField,\n  /**\n   * @description All fields context.\n   */\n  fields,\n})\n</script>\n", "/* eslint no-console:0 */\n\nimport {\n  ValidateError,\n  ValidateOption,\n  RuleValuePackage,\n  InternalRuleItem,\n  SyncErrorType,\n  RuleType,\n  Value,\n  Values,\n} from './interface';\n\nconst formatRegExp = /%[sdj%]/g;\n\ndeclare var ASYNC_VALIDATOR_NO_WARNING;\n\nexport let warning: (type: string, errors: SyncErrorType[]) => void = () => {};\n\n// don't print warning message when in production env or node runtime\nif (\n  typeof process !== 'undefined' &&\n  process.env &&\n  process.env.NODE_ENV !== 'production' &&\n  typeof window !== 'undefined' &&\n  typeof document !== 'undefined'\n) {\n  warning = (type, errors) => {\n    if (\n      typeof console !== 'undefined' &&\n      console.warn &&\n      typeof ASYNC_VALIDATOR_NO_WARNING === 'undefined'\n    ) {\n      if (errors.every(e => typeof e === 'string')) {\n        console.warn(type, errors);\n      }\n    }\n  };\n}\n\nexport function convertFieldsError(\n  errors: ValidateError[],\n): Record<string, ValidateError[]> {\n  if (!errors || !errors.length) return null;\n  const fields = {};\n  errors.forEach(error => {\n    const field = error.field;\n    fields[field] = fields[field] || [];\n    fields[field].push(error);\n  });\n  return fields;\n}\n\nexport function format(\n  template: ((...args: any[]) => string) | string,\n  ...args: any[]\n): string {\n  let i = 0;\n  const len = args.length;\n  if (typeof template === 'function') {\n    return template.apply(null, args);\n  }\n  if (typeof template === 'string') {\n    let str = template.replace(formatRegExp, x => {\n      if (x === '%%') {\n        return '%';\n      }\n      if (i >= len) {\n        return x;\n      }\n      switch (x) {\n        case '%s':\n          return String(args[i++]);\n        case '%d':\n          return (Number(args[i++]) as unknown) as string;\n        case '%j':\n          try {\n            return JSON.stringify(args[i++]);\n          } catch (_) {\n            return '[Circular]';\n          }\n          break;\n        default:\n          return x;\n      }\n    });\n    return str;\n  }\n  return template;\n}\n\nfunction isNativeStringType(type: string) {\n  return (\n    type === 'string' ||\n    type === 'url' ||\n    type === 'hex' ||\n    type === 'email' ||\n    type === 'date' ||\n    type === 'pattern'\n  );\n}\n\nexport function isEmptyValue(value: Value, type?: string) {\n  if (value === undefined || value === null) {\n    return true;\n  }\n  if (type === 'array' && Array.isArray(value) && !value.length) {\n    return true;\n  }\n  if (isNativeStringType(type) && typeof value === 'string' && !value) {\n    return true;\n  }\n  return false;\n}\n\nexport function isEmptyObject(obj: object) {\n  return Object.keys(obj).length === 0;\n}\n\nfunction asyncParallelArray(\n  arr: RuleValuePackage[],\n  func: ValidateFunc,\n  callback: (errors: ValidateError[]) => void,\n) {\n  const results: ValidateError[] = [];\n  let total = 0;\n  const arrLength = arr.length;\n\n  function count(errors: ValidateError[]) {\n    results.push(...(errors || []));\n    total++;\n    if (total === arrLength) {\n      callback(results);\n    }\n  }\n\n  arr.forEach(a => {\n    func(a, count);\n  });\n}\n\nfunction asyncSerialArray(\n  arr: RuleValuePackage[],\n  func: ValidateFunc,\n  callback: (errors: ValidateError[]) => void,\n) {\n  let index = 0;\n  const arrLength = arr.length;\n\n  function next(errors: ValidateError[]) {\n    if (errors && errors.length) {\n      callback(errors);\n      return;\n    }\n    const original = index;\n    index = index + 1;\n    if (original < arrLength) {\n      func(arr[original], next);\n    } else {\n      callback([]);\n    }\n  }\n\n  next([]);\n}\n\nfunction flattenObjArr(objArr: Record<string, RuleValuePackage[]>) {\n  const ret: RuleValuePackage[] = [];\n  Object.keys(objArr).forEach(k => {\n    ret.push(...(objArr[k] || []));\n  });\n  return ret;\n}\n\nexport class AsyncValidationError extends Error {\n  errors: ValidateError[];\n  fields: Record<string, ValidateError[]>;\n\n  constructor(\n    errors: ValidateError[],\n    fields: Record<string, ValidateError[]>,\n  ) {\n    super('Async Validation Error');\n    this.errors = errors;\n    this.fields = fields;\n  }\n}\n\ntype ValidateFunc = (\n  data: RuleValuePackage,\n  doIt: (errors: ValidateError[]) => void,\n) => void;\n\nexport function asyncMap(\n  objArr: Record<string, RuleValuePackage[]>,\n  option: ValidateOption,\n  func: ValidateFunc,\n  callback: (errors: ValidateError[]) => void,\n  source: Values,\n): Promise<Values> {\n  if (option.first) {\n    const pending = new Promise<Values>((resolve, reject) => {\n      const next = (errors: ValidateError[]) => {\n        callback(errors);\n        return errors.length\n          ? reject(new AsyncValidationError(errors, convertFieldsError(errors)))\n          : resolve(source);\n      };\n      const flattenArr = flattenObjArr(objArr);\n      asyncSerialArray(flattenArr, func, next);\n    });\n    pending.catch(e => e);\n    return pending;\n  }\n  const firstFields =\n    option.firstFields === true\n      ? Object.keys(objArr)\n      : option.firstFields || [];\n\n  const objArrKeys = Object.keys(objArr);\n  const objArrLength = objArrKeys.length;\n  let total = 0;\n  const results: ValidateError[] = [];\n  const pending = new Promise<Values>((resolve, reject) => {\n    const next = (errors: ValidateError[]) => {\n      results.push.apply(results, errors);\n      total++;\n      if (total === objArrLength) {\n        callback(results);\n        return results.length\n          ? reject(\n              new AsyncValidationError(results, convertFieldsError(results)),\n            )\n          : resolve(source);\n      }\n    };\n    if (!objArrKeys.length) {\n      callback(results);\n      resolve(source);\n    }\n    objArrKeys.forEach(key => {\n      const arr = objArr[key];\n      if (firstFields.indexOf(key) !== -1) {\n        asyncSerialArray(arr, func, next);\n      } else {\n        asyncParallelArray(arr, func, next);\n      }\n    });\n  });\n  pending.catch(e => e);\n  return pending;\n}\n\nfunction isErrorObj(\n  obj: ValidateError | string | (() => string),\n): obj is ValidateError {\n  return !!(obj && (obj as ValidateError).message !== undefined);\n}\n\nfunction getValue(value: Values, path: string[]) {\n  let v = value;\n  for (let i = 0; i < path.length; i++) {\n    if (v == undefined) {\n      return v;\n    }\n    v = v[path[i]];\n  }\n  return v;\n}\n\nexport function complementError(rule: InternalRuleItem, source: Values) {\n  return (oe: ValidateError | (() => string) | string): ValidateError => {\n    let fieldValue;\n    if (rule.fullFields) {\n      fieldValue = getValue(source, rule.fullFields);\n    } else {\n      fieldValue = source[(oe as any).field || rule.fullField];\n    }\n    if (isErrorObj(oe)) {\n      oe.field = oe.field || rule.fullField;\n      oe.fieldValue = fieldValue;\n      return oe;\n    }\n    return {\n      message: typeof oe === 'function' ? oe() : oe,\n      fieldValue,\n      field: ((oe as unknown) as ValidateError).field || rule.fullField,\n    };\n  };\n}\n\nexport function deepMerge<T extends object>(target: T, source: Partial<T>): T {\n  if (source) {\n    for (const s in source) {\n      if (source.hasOwnProperty(s)) {\n        const value = source[s];\n        if (typeof value === 'object' && typeof target[s] === 'object') {\n          target[s] = {\n            ...target[s],\n            ...value,\n          };\n        } else {\n          target[s] = value;\n        }\n      }\n    }\n  }\n  return target;\n}\n", "import { ExecuteRule } from '../interface';\nimport { format, isEmptyValue } from '../util';\n\nconst required: ExecuteRule = (rule, value, source, errors, options, type) => {\n  if (\n    rule.required &&\n    (!source.hasOwnProperty(rule.field) ||\n      isEmptyValue(value, type || rule.type))\n  ) {\n    errors.push(format(options.messages.required, rule.fullField));\n  }\n};\n\nexport default required;\n", "import { ExecuteRule } from '../interface';\nimport { format } from '../util';\n\n/**\n *  Rule for validating whitespace.\n *\n *  @param rule The validation rule.\n *  @param value The value of the field on the source object.\n *  @param source The source object being validated.\n *  @param errors An array of errors that this rule may add\n *  validation errors to.\n *  @param options The validation options.\n *  @param options.messages The validation messages.\n */\nconst whitespace: ExecuteRule = (rule, value, source, errors, options) => {\n  if (/^\\s+$/.test(value) || value === '') {\n    errors.push(format(options.messages.whitespace, rule.fullField));\n  }\n};\n\nexport default whitespace;\n", "// https://github.com/kevva/url-regex/blob/master/index.js\nlet urlReg: RegExp;\n\nexport default () => {\n  if (urlReg) {\n    return urlReg;\n  }\n\n  const word = '[a-fA-F\\\\d:]';\n  const b = options =>\n    options && options.includeBoundaries\n      ? `(?:(?<=\\\\s|^)(?=${word})|(?<=${word})(?=\\\\s|$))`\n      : '';\n\n  const v4 =\n    '(?:25[0-5]|2[0-4]\\\\d|1\\\\d\\\\d|[1-9]\\\\d|\\\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\\\d|1\\\\d\\\\d|[1-9]\\\\d|\\\\d)){3}';\n\n  const v6seg = '[a-fA-F\\\\d]{1,4}';\n  const v6 = `\n(?:\n(?:${v6seg}:){7}(?:${v6seg}|:)|                                    // 1:2:3:4:5:6:7::  1:2:3:4:5:6:7:8\n(?:${v6seg}:){6}(?:${v4}|:${v6seg}|:)|                             // 1:2:3:4:5:6::    1:2:3:4:5:6::8   1:2:3:4:5:6::8  1:2:3:4:5:6::1.2.3.4\n(?:${v6seg}:){5}(?::${v4}|(?::${v6seg}){1,2}|:)|                   // 1:2:3:4:5::      1:2:3:4:5::7:8   1:2:3:4:5::8    1:2:3:4:5::7:1.2.3.4\n(?:${v6seg}:){4}(?:(?::${v6seg}){0,1}:${v4}|(?::${v6seg}){1,3}|:)| // 1:2:3:4::        1:2:3:4::6:7:8   1:2:3:4::8      1:2:3:4::6:7:1.2.3.4\n(?:${v6seg}:){3}(?:(?::${v6seg}){0,2}:${v4}|(?::${v6seg}){1,4}|:)| // 1:2:3::          1:2:3::5:6:7:8   1:2:3::8        1:2:3::5:6:7:1.2.3.4\n(?:${v6seg}:){2}(?:(?::${v6seg}){0,3}:${v4}|(?::${v6seg}){1,5}|:)| // 1:2::            1:2::4:5:6:7:8   1:2::8          1:2::4:5:6:7:1.2.3.4\n(?:${v6seg}:){1}(?:(?::${v6seg}){0,4}:${v4}|(?::${v6seg}){1,6}|:)| // 1::              1::3:4:5:6:7:8   1::8            1::3:4:5:6:7:1.2.3.4\n(?::(?:(?::${v6seg}){0,5}:${v4}|(?::${v6seg}){1,7}|:))             // ::2:3:4:5:6:7:8  ::2:3:4:5:6:7:8  ::8             ::1.2.3.4\n)(?:%[0-9a-zA-Z]{1,})?                                             // %eth0            %1\n`\n    .replace(/\\s*\\/\\/.*$/gm, '')\n    .replace(/\\n/g, '')\n    .trim();\n\n  // Pre-compile only the exact regexes because adding a global flag make regexes stateful\n  const v46Exact = new RegExp(`(?:^${v4}$)|(?:^${v6}$)`);\n  const v4exact = new RegExp(`^${v4}$`);\n  const v6exact = new RegExp(`^${v6}$`);\n\n  const ip = options =>\n    options && options.exact\n      ? v46Exact\n      : new RegExp(\n          `(?:${b(options)}${v4}${b(options)})|(?:${b(options)}${v6}${b(\n            options,\n          )})`,\n          'g',\n        );\n\n  ip.v4 = (options?) =>\n    options && options.exact\n      ? v4exact\n      : new RegExp(`${b(options)}${v4}${b(options)}`, 'g');\n  ip.v6 = (options?) =>\n    options && options.exact\n      ? v6exact\n      : new RegExp(`${b(options)}${v6}${b(options)}`, 'g');\n\n  const protocol = `(?:(?:[a-z]+:)?//)`;\n  const auth = '(?:\\\\S+(?::\\\\S*)?@)?';\n  const ipv4 = ip.v4().source;\n  const ipv6 = ip.v6().source;\n  const host = '(?:(?:[a-z\\\\u00a1-\\\\uffff0-9][-_]*)*[a-z\\\\u00a1-\\\\uffff0-9]+)';\n  const domain =\n    '(?:\\\\.(?:[a-z\\\\u00a1-\\\\uffff0-9]-*)*[a-z\\\\u00a1-\\\\uffff0-9]+)*';\n  const tld = `(?:\\\\.(?:[a-z\\\\u00a1-\\\\uffff]{2,}))`;\n  const port = '(?::\\\\d{2,5})?';\n  const path = '(?:[/?#][^\\\\s\"]*)?';\n  const regex = `(?:${protocol}|www\\\\.)${auth}(?:localhost|${ipv4}|${ipv6}|${host}${domain}${tld})${port}${path}`;\n  urlReg = new RegExp(`(?:^${regex}$)`, 'i');\n  return urlReg;\n};\n", "import { ExecuteRule, Value } from '../interface';\nimport { format } from '../util';\nimport required from './required';\nimport getUrlRegex from './url';\n/* eslint max-len:0 */\n\nconst pattern = {\n  // http://emailregex.com/\n  email: /^(([^<>()\\[\\]\\\\.,;:\\s@\"]+(\\.[^<>()\\[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}])|(([a-zA-Z\\-0-9\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF]+\\.)+[a-zA-Z\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF]{2,}))$/,\n  // url: new RegExp(\n  //   '^(?!mailto:)(?:(?:http|https|ftp)://|//)(?:\\\\S+(?::\\\\S*)?@)?(?:(?:(?:[1-9]\\\\d?|1\\\\d\\\\d|2[01]\\\\d|22[0-3])(?:\\\\.(?:1?\\\\d{1,2}|2[0-4]\\\\d|25[0-5])){2}(?:\\\\.(?:[0-9]\\\\d?|1\\\\d\\\\d|2[0-4]\\\\d|25[0-4]))|(?:(?:[a-z\\\\u00a1-\\\\uffff0-9]+-*)*[a-z\\\\u00a1-\\\\uffff0-9]+)(?:\\\\.(?:[a-z\\\\u00a1-\\\\uffff0-9]+-*)*[a-z\\\\u00a1-\\\\uffff0-9]+)*(?:\\\\.(?:[a-z\\\\u00a1-\\\\uffff]{2,})))|localhost)(?::\\\\d{2,5})?(?:(/|\\\\?|#)[^\\\\s]*)?$',\n  //   'i',\n  // ),\n  hex: /^#?([a-f0-9]{6}|[a-f0-9]{3})$/i,\n};\n\nconst types = {\n  integer(value: Value) {\n    return types.number(value) && parseInt(value, 10) === value;\n  },\n  float(value: Value) {\n    return types.number(value) && !types.integer(value);\n  },\n  array(value: Value) {\n    return Array.isArray(value);\n  },\n  regexp(value: Value) {\n    if (value instanceof RegExp) {\n      return true;\n    }\n    try {\n      return !!new RegExp(value);\n    } catch (e) {\n      return false;\n    }\n  },\n  date(value: Value) {\n    return (\n      typeof value.getTime === 'function' &&\n      typeof value.getMonth === 'function' &&\n      typeof value.getYear === 'function' &&\n      !isNaN(value.getTime())\n    );\n  },\n  number(value: Value) {\n    if (isNaN(value)) {\n      return false;\n    }\n    return typeof value === 'number';\n  },\n  object(value: Value) {\n    return typeof value === 'object' && !types.array(value);\n  },\n  method(value: Value) {\n    return typeof value === 'function';\n  },\n  email(value: Value) {\n    return (\n      typeof value === 'string' &&\n      value.length <= 320 &&\n      !!value.match(pattern.email)\n    );\n  },\n  url(value: Value) {\n    return (\n      typeof value === 'string' &&\n      value.length <= 2048 &&\n      !!value.match(getUrlRegex())\n    );\n  },\n  hex(value: Value) {\n    return typeof value === 'string' && !!value.match(pattern.hex);\n  },\n};\n\nconst type: ExecuteRule = (rule, value, source, errors, options) => {\n  if (rule.required && value === undefined) {\n    required(rule, value, source, errors, options);\n    return;\n  }\n  const custom = [\n    'integer',\n    'float',\n    'array',\n    'regexp',\n    'object',\n    'method',\n    'email',\n    'number',\n    'date',\n    'url',\n    'hex',\n  ];\n  const ruleType = rule.type;\n  if (custom.indexOf(ruleType) > -1) {\n    if (!types[ruleType](value)) {\n      errors.push(\n        format(options.messages.types[ruleType], rule.fullField, rule.type),\n      );\n    }\n    // straight typeof check\n  } else if (ruleType && typeof value !== rule.type) {\n    errors.push(\n      format(options.messages.types[ruleType], rule.fullField, rule.type),\n    );\n  }\n};\n\nexport default type;\n", "import { ExecuteRule } from '../interface';\nimport { format } from '../util';\n\nconst range: ExecuteRule = (rule, value, source, errors, options) => {\n  const len = typeof rule.len === 'number';\n  const min = typeof rule.min === 'number';\n  const max = typeof rule.max === 'number';\n  // 正则匹配码点范围从U+010000一直到U+10FFFF的文字(补充平面Supplementary Plane)\n  const spRegexp = /[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]/g;\n  let val = value;\n  let key = null;\n  const num = typeof value === 'number';\n  const str = typeof value === 'string';\n  const arr = Array.isArray(value);\n  if (num) {\n    key = 'number';\n  } else if (str) {\n    key = 'string';\n  } else if (arr) {\n    key = 'array';\n  }\n  // if the value is not of a supported type for range validation\n  // the validation rule rule should use the\n  // type property to also test for a particular type\n  if (!key) {\n    return false;\n  }\n  if (arr) {\n    val = value.length;\n  }\n  if (str) {\n    // 处理码点大于U+010000的文字length属性不准确的bug,如\"𠮷𠮷𠮷\".lenght !== 3\n    val = value.replace(spRegexp, '_').length;\n  }\n  if (len) {\n    if (val !== rule.len) {\n      errors.push(format(options.messages[key].len, rule.fullField, rule.len));\n    }\n  } else if (min && !max && val < rule.min) {\n    errors.push(format(options.messages[key].min, rule.fullField, rule.min));\n  } else if (max && !min && val > rule.max) {\n    errors.push(format(options.messages[key].max, rule.fullField, rule.max));\n  } else if (min && max && (val < rule.min || val > rule.max)) {\n    errors.push(\n      format(options.messages[key].range, rule.fullField, rule.min, rule.max),\n    );\n  }\n};\n\nexport default range;\n", "import { ExecuteRule } from '../interface';\nimport { format } from '../util';\n\nconst ENUM = 'enum' as const;\n\nconst enumerable: ExecuteRule = (rule, value, source, errors, options) => {\n  rule[ENUM] = Array.isArray(rule[ENUM]) ? rule[ENUM] : [];\n  if (rule[ENUM].indexOf(value) === -1) {\n    errors.push(\n      format(options.messages[ENUM], rule.fullField, rule[ENUM].join(', ')),\n    );\n  }\n};\n\nexport default enumerable;\n", "import { ExecuteRule } from '../interface';\nimport { format } from '../util';\n\nconst pattern: ExecuteRule = (rule, value, source, errors, options) => {\n  if (rule.pattern) {\n    if (rule.pattern instanceof RegExp) {\n      // if a RegExp instance is passed, reset `lastIndex` in case its `global`\n      // flag is accidentally set to `true`, which in a validation scenario\n      // is not necessary and the result might be misleading\n      rule.pattern.lastIndex = 0;\n      if (!rule.pattern.test(value)) {\n        errors.push(\n          format(\n            options.messages.pattern.mismatch,\n            rule.fullField,\n            value,\n            rule.pattern,\n          ),\n        );\n      }\n    } else if (typeof rule.pattern === 'string') {\n      const _pattern = new RegExp(rule.pattern);\n      if (!_pattern.test(value)) {\n        errors.push(\n          format(\n            options.messages.pattern.mismatch,\n            rule.fullField,\n            value,\n            rule.pattern,\n          ),\n        );\n      }\n    }\n  }\n};\n\nexport default pattern;\n", "import required from './required';\nimport whitespace from './whitespace';\nimport type from './type';\nimport range from './range';\nimport enumRule from './enum';\nimport pattern from './pattern';\n\nexport default {\n  required,\n  whitespace,\n  type,\n  range,\n  enum: enumRule,\n  pattern,\n};\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst string: ExecuteValidator = (rule, value, callback, source, options) => {\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if (isEmptyValue(value, 'string') && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options, 'string');\n    if (!isEmptyValue(value, 'string')) {\n      rules.type(rule, value, source, errors, options);\n      rules.range(rule, value, source, errors, options);\n      rules.pattern(rule, value, source, errors, options);\n      if (rule.whitespace === true) {\n        rules.whitespace(rule, value, source, errors, options);\n      }\n    }\n  }\n  callback(errors);\n};\n\nexport default string;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst method: ExecuteValidator = (rule, value, callback, source, options) => {\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if (isEmptyValue(value) && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options);\n    if (value !== undefined) {\n      rules.type(rule, value, source, errors, options);\n    }\n  }\n  callback(errors);\n};\n\nexport default method;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst number: ExecuteValidator = (rule, value, callback, source, options) => {\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if (value === '') {\n      value = undefined;\n    }\n    if (isEmptyValue(value) && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options);\n    if (value !== undefined) {\n      rules.type(rule, value, source, errors, options);\n      rules.range(rule, value, source, errors, options);\n    }\n  }\n  callback(errors);\n};\n\nexport default number;\n", "import { isEmptyValue } from '../util';\nimport rules from '../rule';\nimport { ExecuteValidator } from '../interface';\n\nconst boolean: ExecuteValidator = (rule, value, callback, source, options) => {\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if (isEmptyValue(value) && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options);\n    if (value !== undefined) {\n      rules.type(rule, value, source, errors, options);\n    }\n  }\n  callback(errors);\n};\n\nexport default boolean;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst regexp: ExecuteValidator = (rule, value, callback, source, options) => {\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if (isEmptyValue(value) && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options);\n    if (!isEmptyValue(value)) {\n      rules.type(rule, value, source, errors, options);\n    }\n  }\n  callback(errors);\n};\n\nexport default regexp;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst integer: ExecuteValidator = (rule, value, callback, source, options) => {\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if (isEmptyValue(value) && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options);\n    if (value !== undefined) {\n      rules.type(rule, value, source, errors, options);\n      rules.range(rule, value, source, errors, options);\n    }\n  }\n  callback(errors);\n};\n\nexport default integer;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst floatFn: ExecuteValidator = (rule, value, callback, source, options) => {\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if (isEmptyValue(value) && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options);\n    if (value !== undefined) {\n      rules.type(rule, value, source, errors, options);\n      rules.range(rule, value, source, errors, options);\n    }\n  }\n  callback(errors);\n};\n\nexport default floatFn;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule/index';\n\nconst array: ExecuteValidator = (rule, value, callback, source, options) => {\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if ((value === undefined || value === null) && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options, 'array');\n    if (value !== undefined && value !== null) {\n      rules.type(rule, value, source, errors, options);\n      rules.range(rule, value, source, errors, options);\n    }\n  }\n  callback(errors);\n};\n\nexport default array;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst object: ExecuteValidator = (rule, value, callback, source, options) => {\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if (isEmptyValue(value) && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options);\n    if (value !== undefined) {\n      rules.type(rule, value, source, errors, options);\n    }\n  }\n  callback(errors);\n};\n\nexport default object;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst ENUM = 'enum' as const;\n\nconst enumerable: ExecuteValidator = (\n  rule,\n  value,\n  callback,\n  source,\n  options,\n) => {\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if (isEmptyValue(value) && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options);\n    if (value !== undefined) {\n      rules[ENUM](rule, value, source, errors, options);\n    }\n  }\n  callback(errors);\n};\n\nexport default enumerable;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst pattern: ExecuteValidator = (rule, value, callback, source, options) => {\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if (isEmptyValue(value, 'string') && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options);\n    if (!isEmptyValue(value, 'string')) {\n      rules.pattern(rule, value, source, errors, options);\n    }\n  }\n  callback(errors);\n};\n\nexport default pattern;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst date: ExecuteValidator = (rule, value, callback, source, options) => {\n  // console.log('integer rule called %j', rule);\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  // console.log('validate on %s value', value);\n  if (validate) {\n    if (isEmptyValue(value, 'date') && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options);\n    if (!isEmptyValue(value, 'date')) {\n      let dateObject;\n\n      if (value instanceof Date) {\n        dateObject = value;\n      } else {\n        dateObject = new Date(value);\n      }\n\n      rules.type(rule, dateObject, source, errors, options);\n      if (dateObject) {\n        rules.range(rule, dateObject.getTime(), source, errors, options);\n      }\n    }\n  }\n  callback(errors);\n};\n\nexport default date;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\n\nconst required: ExecuteValidator = (rule, value, callback, source, options) => {\n  const errors: string[] = [];\n  const type = Array.isArray(value) ? 'array' : typeof value;\n  rules.required(rule, value, source, errors, options, type);\n  callback(errors);\n};\n\nexport default required;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst type: ExecuteValidator = (rule, value, callback, source, options) => {\n  const ruleType = rule.type;\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if (isEmptyValue(value, ruleType) && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options, ruleType);\n    if (!isEmptyValue(value, ruleType)) {\n      rules.type(rule, value, source, errors, options);\n    }\n  }\n  callback(errors);\n};\n\nexport default type;\n", "import { ExecuteValidator } from '../interface';\nimport rules from '../rule';\nimport { isEmptyValue } from '../util';\n\nconst any: ExecuteValidator = (rule, value, callback, source, options) => {\n  const errors: string[] = [];\n  const validate =\n    rule.required || (!rule.required && source.hasOwnProperty(rule.field));\n  if (validate) {\n    if (isEmptyValue(value) && !rule.required) {\n      return callback();\n    }\n    rules.required(rule, value, source, errors, options);\n  }\n  callback(errors);\n};\n\nexport default any;\n", "import string from './string';\nimport method from './method';\nimport number from './number';\nimport boolean from './boolean';\nimport regexp from './regexp';\nimport integer from './integer';\nimport float from './float';\nimport array from './array';\nimport object from './object';\nimport enumValidator from './enum';\nimport pattern from './pattern';\nimport date from './date';\nimport required from './required';\nimport type from './type';\nimport any from './any';\n\nexport default {\n  string,\n  method,\n  number,\n  boolean,\n  regexp,\n  integer,\n  float,\n  array,\n  object,\n  enum: enumValidator,\n  pattern,\n  date,\n  url: type,\n  hex: type,\n  email: type,\n  required,\n  any,\n};\n", "import { InternalValidateMessages } from './interface';\n\nexport function newMessages(): InternalValidateMessages {\n  return {\n    default: 'Validation error on field %s',\n    required: '%s is required',\n    enum: '%s must be one of %s',\n    whitespace: '%s cannot be empty',\n    date: {\n      format: '%s date %s is invalid for format %s',\n      parse: '%s date could not be parsed, %s is invalid ',\n      invalid: '%s date %s is invalid',\n    },\n    types: {\n      string: '%s is not a %s',\n      method: '%s is not a %s (function)',\n      array: '%s is not an %s',\n      object: '%s is not an %s',\n      number: '%s is not a %s',\n      date: '%s is not a %s',\n      boolean: '%s is not a %s',\n      integer: '%s is not an %s',\n      float: '%s is not a %s',\n      regexp: '%s is not a valid %s',\n      email: '%s is not a valid %s',\n      url: '%s is not a valid %s',\n      hex: '%s is not a valid %s',\n    },\n    string: {\n      len: '%s must be exactly %s characters',\n      min: '%s must be at least %s characters',\n      max: '%s cannot be longer than %s characters',\n      range: '%s must be between %s and %s characters',\n    },\n    number: {\n      len: '%s must equal %s',\n      min: '%s cannot be less than %s',\n      max: '%s cannot be greater than %s',\n      range: '%s must be between %s and %s',\n    },\n    array: {\n      len: '%s must be exactly %s in length',\n      min: '%s cannot be less than %s in length',\n      max: '%s cannot be greater than %s in length',\n      range: '%s must be between %s and %s in length',\n    },\n    pattern: {\n      mismatch: '%s value %s does not match pattern %s',\n    },\n    clone() {\n      const cloned = JSON.parse(JSON.stringify(this));\n      cloned.clone = this.clone;\n      return cloned;\n    },\n  };\n}\n\nexport const messages = newMessages();\n", "import {\n  format,\n  complementError,\n  asyncMap,\n  warning,\n  deepMerge,\n  convertFieldsError,\n} from './util';\nimport validators from './validator/index';\nimport { messages as defaultMessages, newMessages } from './messages';\nimport {\n  InternalRuleItem,\n  InternalValidateMessages,\n  Rule,\n  RuleItem,\n  Rules,\n  ValidateCallback,\n  ValidateMessages,\n  ValidateOption,\n  Values,\n  RuleValuePackage,\n  ValidateError,\n  ValidateFieldsError,\n  SyncErrorType,\n  ValidateResult,\n} from './interface';\n\nexport * from './interface';\n\n/**\n *  Encapsulates a validation schema.\n *\n *  @param descriptor An object declaring validation rules\n *  for this schema.\n */\nclass Schema {\n  // ========================= Static =========================\n  static register = function register(type: string, validator) {\n    if (typeof validator !== 'function') {\n      throw new Error(\n        'Cannot register a validator by type, validator is not a function',\n      );\n    }\n    validators[type] = validator;\n  };\n\n  static warning = warning;\n\n  static messages = defaultMessages;\n\n  static validators = validators;\n\n  // ======================== Instance ========================\n  rules: Record<string, RuleItem[]> = null;\n  _messages: InternalValidateMessages = defaultMessages;\n\n  constructor(descriptor: Rules) {\n    this.define(descriptor);\n  }\n\n  define(rules: Rules) {\n    if (!rules) {\n      throw new Error('Cannot configure a schema with no rules');\n    }\n    if (typeof rules !== 'object' || Array.isArray(rules)) {\n      throw new Error('Rules must be an object');\n    }\n    this.rules = {};\n\n    Object.keys(rules).forEach(name => {\n      const item: Rule = rules[name];\n      this.rules[name] = Array.isArray(item) ? item : [item];\n    });\n  }\n\n  messages(messages?: ValidateMessages) {\n    if (messages) {\n      this._messages = deepMerge(newMessages(), messages);\n    }\n    return this._messages;\n  }\n\n  validate(\n    source: Values,\n    option?: ValidateOption,\n    callback?: ValidateCallback,\n  ): Promise<Values>;\n  validate(source: Values, callback: ValidateCallback): Promise<Values>;\n  validate(source: Values): Promise<Values>;\n\n  validate(source_: Values, o: any = {}, oc: any = () => {}): Promise<Values> {\n    let source: Values = source_;\n    let options: ValidateOption = o;\n    let callback: ValidateCallback = oc;\n    if (typeof options === 'function') {\n      callback = options;\n      options = {};\n    }\n    if (!this.rules || Object.keys(this.rules).length === 0) {\n      if (callback) {\n        callback(null, source);\n      }\n      return Promise.resolve(source);\n    }\n\n    function complete(results: (ValidateError | ValidateError[])[]) {\n      let errors: ValidateError[] = [];\n      let fields: ValidateFieldsError = {};\n\n      function add(e: ValidateError | ValidateError[]) {\n        if (Array.isArray(e)) {\n          errors = errors.concat(...e);\n        } else {\n          errors.push(e);\n        }\n      }\n\n      for (let i = 0; i < results.length; i++) {\n        add(results[i]);\n      }\n      if (!errors.length) {\n        callback(null, source);\n      } else {\n        fields = convertFieldsError(errors);\n        (callback as (\n          errors: ValidateError[],\n          fields: ValidateFieldsError,\n        ) => void)(errors, fields);\n      }\n    }\n\n    if (options.messages) {\n      let messages = this.messages();\n      if (messages === defaultMessages) {\n        messages = newMessages();\n      }\n      deepMerge(messages, options.messages);\n      options.messages = messages;\n    } else {\n      options.messages = this.messages();\n    }\n\n    const series: Record<string, RuleValuePackage[]> = {};\n    const keys = options.keys || Object.keys(this.rules);\n    keys.forEach(z => {\n      const arr = this.rules[z];\n      let value = source[z];\n      arr.forEach(r => {\n        let rule: InternalRuleItem = r;\n        if (typeof rule.transform === 'function') {\n          if (source === source_) {\n            source = { ...source };\n          }\n          value = source[z] = rule.transform(value);\n        }\n        if (typeof rule === 'function') {\n          rule = {\n            validator: rule,\n          };\n        } else {\n          rule = { ...rule };\n        }\n\n        // Fill validator. Skip if nothing need to validate\n        rule.validator = this.getValidationMethod(rule);\n        if (!rule.validator) {\n          return;\n        }\n\n        rule.field = z;\n        rule.fullField = rule.fullField || z;\n        rule.type = this.getType(rule);\n        series[z] = series[z] || [];\n        series[z].push({\n          rule,\n          value,\n          source,\n          field: z,\n        });\n      });\n    });\n    const errorFields = {};\n    return asyncMap(\n      series,\n      options,\n      (data, doIt) => {\n        const rule = data.rule;\n        let deep =\n          (rule.type === 'object' || rule.type === 'array') &&\n          (typeof rule.fields === 'object' ||\n            typeof rule.defaultField === 'object');\n        deep = deep && (rule.required || (!rule.required && data.value));\n        rule.field = data.field;\n\n        function addFullField(key: string, schema: RuleItem) {\n          return {\n            ...schema,\n            fullField: `${rule.fullField}.${key}`,\n            fullFields: rule.fullFields ? [...rule.fullFields, key] : [key],\n          };\n        }\n\n        function cb(e: SyncErrorType | SyncErrorType[] = []) {\n          let errorList = Array.isArray(e) ? e : [e];\n          if (!options.suppressWarning && errorList.length) {\n            Schema.warning('async-validator:', errorList);\n          }\n          if (errorList.length && rule.message !== undefined) {\n            errorList = [].concat(rule.message);\n          }\n\n          // Fill error info\n          let filledErrors = errorList.map(complementError(rule, source));\n\n          if (options.first && filledErrors.length) {\n            errorFields[rule.field] = 1;\n            return doIt(filledErrors);\n          }\n          if (!deep) {\n            doIt(filledErrors);\n          } else {\n            // if rule is required but the target object\n            // does not exist fail at the rule level and don't\n            // go deeper\n            if (rule.required && !data.value) {\n              if (rule.message !== undefined) {\n                filledErrors = []\n                  .concat(rule.message)\n                  .map(complementError(rule, source));\n              } else if (options.error) {\n                filledErrors = [\n                  options.error(\n                    rule,\n                    format(options.messages.required, rule.field),\n                  ),\n                ];\n              }\n              return doIt(filledErrors);\n            }\n\n            let fieldsSchema: Record<string, Rule> = {};\n            if (rule.defaultField) {\n              Object.keys(data.value).map(key => {\n                fieldsSchema[key] = rule.defaultField;\n              });\n            }\n            fieldsSchema = {\n              ...fieldsSchema,\n              ...data.rule.fields,\n            };\n\n            const paredFieldsSchema: Record<string, RuleItem[]> = {};\n\n            Object.keys(fieldsSchema).forEach(field => {\n              const fieldSchema = fieldsSchema[field];\n              const fieldSchemaList = Array.isArray(fieldSchema)\n                ? fieldSchema\n                : [fieldSchema];\n              paredFieldsSchema[field] = fieldSchemaList.map(\n                addFullField.bind(null, field),\n              );\n            });\n            const schema = new Schema(paredFieldsSchema);\n            schema.messages(options.messages);\n            if (data.rule.options) {\n              data.rule.options.messages = options.messages;\n              data.rule.options.error = options.error;\n            }\n            schema.validate(data.value, data.rule.options || options, errs => {\n              const finalErrors = [];\n              if (filledErrors && filledErrors.length) {\n                finalErrors.push(...filledErrors);\n              }\n              if (errs && errs.length) {\n                finalErrors.push(...errs);\n              }\n              doIt(finalErrors.length ? finalErrors : null);\n            });\n          }\n        }\n\n        let res: ValidateResult;\n        if (rule.asyncValidator) {\n          res = rule.asyncValidator(rule, data.value, cb, data.source, options);\n        } else if (rule.validator) {\n          try {\n            res = rule.validator(rule, data.value, cb, data.source, options);\n          } catch (error) {\n            console.error?.(error);\n            // rethrow to report error\n            if (!options.suppressValidatorError) {\n              setTimeout(() => {\n                throw error;\n              }, 0);\n            }\n            cb(error.message);\n          }\n          if (res === true) {\n            cb();\n          } else if (res === false) {\n            cb(\n              typeof rule.message === 'function'\n                ? rule.message(rule.fullField || rule.field)\n                : rule.message || `${rule.fullField || rule.field} fails`,\n            );\n          } else if (res instanceof Array) {\n            cb(res);\n          } else if (res instanceof Error) {\n            cb(res.message);\n          }\n        }\n        if (res && (res as Promise<void>).then) {\n          (res as Promise<void>).then(\n            () => cb(),\n            e => cb(e),\n          );\n        }\n      },\n      results => {\n        complete(results);\n      },\n      source,\n    );\n  }\n\n  getType(rule: InternalRuleItem) {\n    if (rule.type === undefined && rule.pattern instanceof RegExp) {\n      rule.type = 'pattern';\n    }\n    if (\n      typeof rule.validator !== 'function' &&\n      rule.type &&\n      !validators.hasOwnProperty(rule.type)\n    ) {\n      throw new Error(format('Unknown rule type %s', rule.type));\n    }\n    return rule.type || 'string';\n  }\n\n  getValidationMethod(rule: InternalRuleItem) {\n    if (typeof rule.validator === 'function') {\n      return rule.validator;\n    }\n    const keys = Object.keys(rule);\n    const messageIndex = keys.indexOf('message');\n    if (messageIndex !== -1) {\n      keys.splice(messageIndex, 1);\n    }\n    if (keys.length === 1 && keys[0] === 'required') {\n      return validators.required;\n    }\n    return validators[this.getType(rule)] || undefined;\n  }\n}\n\nexport default Schema;\n", "import { componentSizes } from '@element-plus/constants'\nimport { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { Arrayable } from '@element-plus/utils'\nimport type { FormItemRule } from './types'\n\nexport const formItemValidateStates = [\n  '',\n  'error',\n  'validating',\n  'success',\n] as const\nexport type FormItemValidateState = typeof formItemValidateStates[number]\n\nexport type FormItemProp = Arrayable<string>\n\nexport const formItemProps = buildProps({\n  /**\n   * @description Label text.\n   */\n  label: String,\n  /**\n   * @description Width of label, e.g. `'50px'`. `'auto'` is supported.\n   */\n  labelWidth: {\n    type: [String, Number],\n    default: '',\n  },\n  /**\n   * @description Position of label. If set to `'left'` or `'right'`, `label-width` prop is also required. The default is extend from `form label-position`.\n   */\n  labelPosition: {\n    type: String,\n    values: ['left', 'right', 'top', ''],\n    default: '',\n  },\n  /**\n   * @description  A key of `model`. It could be an array of property paths (e.g `['a', 'b', '0']`). In the use of `validate` and `resetFields` method, the attribute is required.\n   */\n  prop: {\n    type: definePropType<FormItemProp>([String, Array]),\n  },\n  /**\n   * @description Whether the field is required or not, will be determined by validation rules if omitted.\n   */\n  required: {\n    type: Boolean,\n    default: undefined,\n  },\n  /**\n   * @description Validation rules of form, see the [following table](#formitemrule), more advanced usage at [async-validator](https://github.com/yiminghe/async-validator).\n   */\n  rules: {\n    type: definePropType<Arrayable<FormItemRule>>([Object, Array]),\n  },\n  /**\n   * @description Field error message, set its value and the field will validate error and show this message immediately.\n   */\n  error: String,\n  /**\n   * @description Validation state of formItem.\n   */\n  validateStatus: {\n    type: String,\n    values: formItemValidateStates,\n  },\n  /**\n   * @description Same as for in native label.\n   */\n  for: String,\n  /**\n   * @description Inline style validate message.\n   */\n  inlineMessage: {\n    type: [String, Boolean],\n    default: '',\n  },\n  /**\n   * @description Whether to show the error message.\n   */\n  showMessage: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description Control the size of components in this form-item.\n   */\n  size: {\n    type: String,\n    values: componentSizes,\n  },\n} as const)\nexport type FormItemProps = ExtractPropTypes<typeof formItemProps>\n", "import {\n  Fragment,\n  computed,\n  defineComponent,\n  inject,\n  nextTick,\n  onBeforeUnmount,\n  onMounted,\n  onUpdated,\n  ref,\n  watch,\n} from 'vue'\nimport { useResizeObserver } from '@vueuse/core'\nimport { throwError } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { formContextKey, formItemContextKey } from './constants'\n\nimport type { CSSProperties } from 'vue'\n\nconst COMPONENT_NAME = 'ElLabelWrap'\nexport default defineComponent({\n  name: COMPONENT_NAME,\n  props: {\n    isAutoWidth: Boolean,\n    updateAll: Boolean,\n  },\n\n  setup(props, { slots }) {\n    const formContext = inject(formContextKey, undefined)\n    const formItemContext = inject(formItemContextKey)\n    if (!formItemContext)\n      throwError(\n        COMPONENT_NAME,\n        'usage: <el-form-item><label-wrap /></el-form-item>'\n      )\n\n    const ns = useNamespace('form')\n\n    const el = ref<HTMLElement>()\n    const computedWidth = ref(0)\n\n    const getLabelWidth = () => {\n      if (el.value?.firstElementChild) {\n        const width = window.getComputedStyle(el.value.firstElementChild).width\n        return Math.ceil(Number.parseFloat(width))\n      } else {\n        return 0\n      }\n    }\n\n    const updateLabelWidth = (action: 'update' | 'remove' = 'update') => {\n      nextTick(() => {\n        if (slots.default && props.isAutoWidth) {\n          if (action === 'update') {\n            computedWidth.value = getLabelWidth()\n          } else if (action === 'remove') {\n            formContext?.deregisterLabelWidth(computedWidth.value)\n          }\n        }\n      })\n    }\n    const updateLabelWidthFn = () => updateLabelWidth('update')\n\n    onMounted(() => {\n      updateLabelWidthFn()\n    })\n    onBeforeUnmount(() => {\n      updateLabelWidth('remove')\n    })\n    onUpdated(() => updateLabelWidthFn())\n\n    watch(computedWidth, (val, oldVal) => {\n      if (props.updateAll) {\n        formContext?.registerLabelWidth(val, oldVal)\n      }\n    })\n\n    useResizeObserver(\n      computed(\n        () => (el.value?.firstElementChild ?? null) as HTMLElement | null\n      ),\n      updateLabelWidthFn\n    )\n\n    return () => {\n      if (!slots) return null\n\n      const { isAutoWidth } = props\n      if (isAutoWidth) {\n        const autoLabelWidth = formContext?.autoLabelWidth\n        const hasLabel = formItemContext?.hasLabel\n        const style: CSSProperties = {}\n        if (hasLabel && autoLabelWidth && autoLabelWidth !== 'auto') {\n          const marginWidth = Math.max(\n            0,\n            Number.parseInt(autoLabelWidth, 10) - computedWidth.value\n          )\n          const labelPosition =\n            formItemContext.labelPosition || formContext.labelPosition\n\n          const marginPosition =\n            labelPosition === 'left' ? 'marginRight' : 'marginLeft'\n\n          if (marginWidth) {\n            style[marginPosition] = `${marginWidth}px`\n          }\n        }\n        return (\n          <div ref={el} class={[ns.be('item', 'label-wrap')]} style={style}>\n            {slots.default?.()}\n          </div>\n        )\n      } else {\n        return <Fragment ref={el}>{slots.default?.()}</Fragment>\n      }\n    }\n  },\n})\n", "<template>\n  <div\n    ref=\"formItemRef\"\n    :class=\"formItemClasses\"\n    :role=\"isGroup ? 'group' : undefined\"\n    :aria-labelledby=\"isGroup ? labelId : undefined\"\n  >\n    <form-label-wrap\n      :is-auto-width=\"labelStyle.width === 'auto'\"\n      :update-all=\"formContext?.labelWidth === 'auto'\"\n    >\n      <component\n        :is=\"labelFor ? 'label' : 'div'\"\n        v-if=\"hasLabel\"\n        :id=\"labelId\"\n        :for=\"labelFor\"\n        :class=\"ns.e('label')\"\n        :style=\"labelStyle\"\n      >\n        <slot name=\"label\" :label=\"currentLabel\">\n          {{ currentLabel }}\n        </slot>\n      </component>\n    </form-label-wrap>\n\n    <div :class=\"ns.e('content')\" :style=\"contentStyle\">\n      <slot />\n      <transition-group :name=\"`${ns.namespace.value}-zoom-in-top`\">\n        <slot v-if=\"shouldShowError\" name=\"error\" :error=\"validateMessage\">\n          <div :class=\"validateClasses\">\n            {{ validateMessage }}\n          </div>\n        </slot>\n      </transition-group>\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  inject,\n  nextTick,\n  onBeforeUnmount,\n  onMounted,\n  provide,\n  reactive,\n  ref,\n  toRefs,\n  useSlots,\n  watch,\n} from 'vue'\nimport AsyncValidator from 'async-validator'\nimport { clone } from 'lodash-unified'\nimport { refDebounced } from '@vueuse/core'\nimport {\n  addUnit,\n  ensureArray,\n  getProp,\n  isBoolean,\n  isFunction,\n  isString,\n} from '@element-plus/utils'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport { useFormSize } from './hooks'\nimport { formItemProps } from './form-item'\nimport FormLabelWrap from './form-label-wrap'\nimport { formContextKey, formItemContextKey } from './constants'\n\nimport type { CSSProperties } from 'vue'\nimport type { RuleItem } from 'async-validator'\nimport type { Arrayable } from '@element-plus/utils'\nimport type {\n  FormItemContext,\n  FormItemRule,\n  FormValidateFailure,\n} from './types'\nimport type { FormItemValidateState } from './form-item'\n\ndefineOptions({\n  name: 'ElFormItem',\n})\nconst props = defineProps(formItemProps)\nconst slots = useSlots()\n\nconst formContext = inject(formContextKey, undefined)\nconst parentFormItemContext = inject(formItemContextKey, undefined)\n\nconst _size = useFormSize(undefined, { formItem: false })\nconst ns = useNamespace('form-item')\n\nconst labelId = useId().value\nconst inputIds = ref<string[]>([])\n\nconst validateState = ref<FormItemValidateState>('')\nconst validateStateDebounced = refDebounced(validateState, 100)\nconst validateMessage = ref('')\nconst formItemRef = ref<HTMLDivElement>()\n// special inline value.\nlet initialValue: any = undefined\nlet isResettingField = false\n\nconst labelPosition = computed(\n  () => props.labelPosition || formContext?.labelPosition\n)\n\nconst labelStyle = computed<CSSProperties>(() => {\n  if (labelPosition.value === 'top') {\n    return {}\n  }\n\n  const labelWidth = addUnit(props.labelWidth || formContext?.labelWidth || '')\n  if (labelWidth) return { width: labelWidth }\n  return {}\n})\n\nconst contentStyle = computed<CSSProperties>(() => {\n  if (labelPosition.value === 'top' || formContext?.inline) {\n    return {}\n  }\n  if (!props.label && !props.labelWidth && isNested) {\n    return {}\n  }\n  const labelWidth = addUnit(props.labelWidth || formContext?.labelWidth || '')\n  if (!props.label && !slots.label) {\n    return { marginLeft: labelWidth }\n  }\n  return {}\n})\n\nconst formItemClasses = computed(() => [\n  ns.b(),\n  ns.m(_size.value),\n  ns.is('error', validateState.value === 'error'),\n  ns.is('validating', validateState.value === 'validating'),\n  ns.is('success', validateState.value === 'success'),\n  ns.is('required', isRequired.value || props.required),\n  ns.is('no-asterisk', formContext?.hideRequiredAsterisk),\n  formContext?.requireAsteriskPosition === 'right'\n    ? 'asterisk-right'\n    : 'asterisk-left',\n  {\n    [ns.m('feedback')]: formContext?.statusIcon,\n    [ns.m(`label-${labelPosition.value}`)]: labelPosition.value,\n  },\n])\n\nconst _inlineMessage = computed(() =>\n  isBoolean(props.inlineMessage)\n    ? props.inlineMessage\n    : formContext?.inlineMessage || false\n)\n\nconst validateClasses = computed(() => [\n  ns.e('error'),\n  { [ns.em('error', 'inline')]: _inlineMessage.value },\n])\n\nconst propString = computed(() => {\n  if (!props.prop) return ''\n  return isString(props.prop) ? props.prop : props.prop.join('.')\n})\n\nconst hasLabel = computed<boolean>(() => {\n  return !!(props.label || slots.label)\n})\n\nconst labelFor = computed<string | undefined>(() => {\n  return (\n    props.for || (inputIds.value.length === 1 ? inputIds.value[0] : undefined)\n  )\n})\n\nconst isGroup = computed<boolean>(() => {\n  return !labelFor.value && hasLabel.value\n})\n\nconst isNested = !!parentFormItemContext\n\nconst fieldValue = computed(() => {\n  const model = formContext?.model\n  if (!model || !props.prop) {\n    return\n  }\n  return getProp(model, props.prop).value\n})\n\nconst normalizedRules = computed(() => {\n  const { required } = props\n\n  const rules: FormItemRule[] = []\n\n  if (props.rules) {\n    rules.push(...ensureArray(props.rules))\n  }\n\n  const formRules = formContext?.rules\n  if (formRules && props.prop) {\n    const _rules = getProp<Arrayable<FormItemRule> | undefined>(\n      formRules,\n      props.prop\n    ).value\n    if (_rules) {\n      rules.push(...ensureArray(_rules))\n    }\n  }\n\n  if (required !== undefined) {\n    const requiredRules = rules\n      .map((rule, i) => [rule, i] as const)\n      .filter(([rule]) => Object.keys(rule).includes('required'))\n\n    if (requiredRules.length > 0) {\n      for (const [rule, i] of requiredRules) {\n        if (rule.required === required) continue\n        rules[i] = { ...rule, required }\n      }\n    } else {\n      rules.push({ required })\n    }\n  }\n\n  return rules\n})\n\nconst validateEnabled = computed(() => normalizedRules.value.length > 0)\n\nconst getFilteredRule = (trigger: string) => {\n  const rules = normalizedRules.value\n  return (\n    rules\n      .filter((rule) => {\n        if (!rule.trigger || !trigger) return true\n        if (Array.isArray(rule.trigger)) {\n          return rule.trigger.includes(trigger)\n        } else {\n          return rule.trigger === trigger\n        }\n      })\n      // exclude trigger\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      .map(({ trigger, ...rule }): RuleItem => rule)\n  )\n}\n\nconst isRequired = computed(() =>\n  normalizedRules.value.some((rule) => rule.required)\n)\n\nconst shouldShowError = computed(\n  () =>\n    validateStateDebounced.value === 'error' &&\n    props.showMessage &&\n    (formContext?.showMessage ?? true)\n)\n\nconst currentLabel = computed(\n  () => `${props.label || ''}${formContext?.labelSuffix || ''}`\n)\n\nconst setValidationState = (state: FormItemValidateState) => {\n  validateState.value = state\n}\n\nconst onValidationFailed = (error: FormValidateFailure) => {\n  const { errors, fields } = error\n  if (!errors || !fields) {\n    console.error(error)\n  }\n\n  setValidationState('error')\n  validateMessage.value = errors\n    ? errors?.[0]?.message ?? `${props.prop} is required`\n    : ''\n\n  formContext?.emit('validate', props.prop!, false, validateMessage.value)\n}\n\nconst onValidationSucceeded = () => {\n  setValidationState('success')\n  formContext?.emit('validate', props.prop!, true, '')\n}\n\nconst doValidate = async (rules: RuleItem[]): Promise<true> => {\n  const modelName = propString.value\n  const validator = new AsyncValidator({\n    [modelName]: rules,\n  })\n  return validator\n    .validate({ [modelName]: fieldValue.value }, { firstFields: true })\n    .then(() => {\n      onValidationSucceeded()\n      return true as const\n    })\n    .catch((err: FormValidateFailure) => {\n      onValidationFailed(err as FormValidateFailure)\n      return Promise.reject(err)\n    })\n}\n\nconst validate: FormItemContext['validate'] = async (trigger, callback) => {\n  // skip validation if its resetting\n  if (isResettingField || !props.prop) {\n    return false\n  }\n\n  const hasCallback = isFunction(callback)\n  if (!validateEnabled.value) {\n    callback?.(false)\n    return false\n  }\n\n  const rules = getFilteredRule(trigger)\n  if (rules.length === 0) {\n    callback?.(true)\n    return true\n  }\n\n  setValidationState('validating')\n\n  return doValidate(rules)\n    .then(() => {\n      callback?.(true)\n      return true as const\n    })\n    .catch((err: FormValidateFailure) => {\n      const { fields } = err\n      callback?.(false, fields)\n      return hasCallback ? false : Promise.reject(fields)\n    })\n}\n\nconst clearValidate: FormItemContext['clearValidate'] = () => {\n  setValidationState('')\n  validateMessage.value = ''\n  isResettingField = false\n}\n\nconst resetField: FormItemContext['resetField'] = async () => {\n  const model = formContext?.model\n  if (!model || !props.prop) return\n\n  const computedValue = getProp(model, props.prop)\n\n  // prevent validation from being triggered\n  isResettingField = true\n\n  computedValue.value = clone(initialValue)\n\n  await nextTick()\n  clearValidate()\n\n  isResettingField = false\n}\n\nconst addInputId: FormItemContext['addInputId'] = (id: string) => {\n  if (!inputIds.value.includes(id)) {\n    inputIds.value.push(id)\n  }\n}\n\nconst removeInputId: FormItemContext['removeInputId'] = (id: string) => {\n  inputIds.value = inputIds.value.filter((listId) => listId !== id)\n}\n\nwatch(\n  () => props.error,\n  (val) => {\n    validateMessage.value = val || ''\n    setValidationState(val ? 'error' : '')\n  },\n  { immediate: true }\n)\n\nwatch(\n  () => props.validateStatus,\n  (val) => setValidationState(val || '')\n)\n\nconst context: FormItemContext = reactive({\n  ...toRefs(props),\n  $el: formItemRef,\n  size: _size,\n  validateState,\n  labelId,\n  inputIds,\n  isGroup,\n  hasLabel,\n  fieldValue,\n  addInputId,\n  removeInputId,\n  resetField,\n  clearValidate,\n  validate,\n})\n\nprovide(formItemContextKey, context)\n\nonMounted(() => {\n  if (props.prop) {\n    formContext?.addField(context)\n    initialValue = clone(fieldValue.value)\n  }\n})\n\nonBeforeUnmount(() => {\n  formContext?.removeField(context)\n})\n\ndefineExpose({\n  /**\n   * @description Form item size.\n   */\n  size: _size,\n  /**\n   * @description Validation message.\n   */\n  validateMessage,\n  /**\n   * @description Validation state.\n   */\n  validateState,\n  /**\n   * @description Validate form item.\n   */\n  validate,\n  /**\n   * @description Remove validation status of the field.\n   */\n  clearValidate,\n  /**\n   * @description Reset current field and remove validation result.\n   */\n  resetField,\n})\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Form from './src/form.vue'\nimport FormItem from './src/form-item.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElForm: SFCWithInstall<typeof Form> & {\n  FormItem: typeof FormItem\n} = withInstall(Form, {\n  FormItem,\n})\nexport default ElForm\nexport const ElFormItem: SFCWithInstall<typeof FormItem> =\n  withNoopInstall(FormItem)\n\nexport * from './src/form'\nexport * from './src/form-item'\nexport * from './src/types'\nexport * from './src/constants'\nexport * from './src/hooks'\n\nexport type FormInstance = InstanceType<typeof Form>\nexport type FormItemInstance = InstanceType<typeof FormItem>\n", "import { isFirefox, isNumber } from '@element-plus/utils'\n\nlet hiddenTextarea: HTMLTextAreaElement | undefined = undefined\n\nconst HIDDEN_STYLE = `\n  height:0 !important;\n  visibility:hidden !important;\n  ${isFirefox() ? '' : 'overflow:hidden !important;'}\n  position:absolute !important;\n  z-index:-1000 !important;\n  top:0 !important;\n  right:0 !important;\n`\n\nconst CONTEXT_STYLE = [\n  'letter-spacing',\n  'line-height',\n  'padding-top',\n  'padding-bottom',\n  'font-family',\n  'font-weight',\n  'font-size',\n  'text-rendering',\n  'text-transform',\n  'width',\n  'text-indent',\n  'padding-left',\n  'padding-right',\n  'border-width',\n  'box-sizing',\n]\n\ntype NodeStyle = {\n  contextStyle: string\n  boxSizing: string\n  paddingSize: number\n  borderSize: number\n}\n\ntype TextAreaHeight = {\n  height: string\n  minHeight?: string\n}\n\nfunction calculateNodeStyling(targetElement: Element): NodeStyle {\n  const style = window.getComputedStyle(targetElement)\n\n  const boxSizing = style.getPropertyValue('box-sizing')\n\n  const paddingSize =\n    Number.parseFloat(style.getPropertyValue('padding-bottom')) +\n    Number.parseFloat(style.getPropertyValue('padding-top'))\n\n  const borderSize =\n    Number.parseFloat(style.getPropertyValue('border-bottom-width')) +\n    Number.parseFloat(style.getPropertyValue('border-top-width'))\n\n  const contextStyle = CONTEXT_STYLE.map(\n    (name) => `${name}:${style.getPropertyValue(name)}`\n  ).join(';')\n\n  return { contextStyle, paddingSize, borderSize, boxSizing }\n}\n\nexport function calcTextareaHeight(\n  targetElement: HTMLTextAreaElement,\n  minRows = 1,\n  maxRows?: number\n): TextAreaHeight {\n  if (!hiddenTextarea) {\n    hiddenTextarea = document.createElement('textarea')\n    document.body.appendChild(hiddenTextarea)\n  }\n\n  const { paddingSize, borderSize, boxSizing, contextStyle } =\n    calculateNodeStyling(targetElement)\n\n  hiddenTextarea.setAttribute('style', `${contextStyle};${HIDDEN_STYLE}`)\n  hiddenTextarea.value = targetElement.value || targetElement.placeholder || ''\n\n  let height = hiddenTextarea.scrollHeight\n  const result = {} as TextAreaHeight\n\n  if (boxSizing === 'border-box') {\n    height = height + borderSize\n  } else if (boxSizing === 'content-box') {\n    height = height - paddingSize\n  }\n\n  hiddenTextarea.value = ''\n  const singleRowHeight = hiddenTextarea.scrollHeight - paddingSize\n\n  if (isNumber(minRows)) {\n    let minHeight = singleRowHeight * minRows\n    if (boxSizing === 'border-box') {\n      minHeight = minHeight + paddingSize + borderSize\n    }\n    height = Math.max(minHeight, height)\n    result.minHeight = `${minHeight}px`\n  }\n  if (isNumber(maxRows)) {\n    let maxHeight = singleRowHeight * maxRows\n    if (boxSizing === 'border-box') {\n      maxHeight = maxHeight + paddingSize + borderSize\n    }\n    height = Math.min(maxHeight, height)\n  }\n  result.height = `${height}px`\n  hiddenTextarea.parentNode?.removeChild(hiddenTextarea)\n  hiddenTextarea = undefined\n\n  return result\n}\n", "import {\n  buildProps,\n  definePropType,\n  iconPropType,\n  isString,\n  mutable,\n} from '@element-plus/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport type { ExtractPropTypes, StyleValue } from 'vue'\n\nexport type InputAutoSize = { minRows?: number; maxRows?: number } | boolean\n\nexport const inputProps = buildProps({\n  /**\n   * @description native input id\n   */\n  id: {\n    type: String,\n    default: undefined,\n  },\n  /**\n   * @description input box size\n   */\n  size: useSizeProp,\n  /**\n   * @description whether to disable\n   */\n  disabled: Boolean,\n  /**\n   * @description binding value\n   */\n  modelValue: {\n    type: definePropType<string | number | null | undefined>([\n      String,\n      Number,\n      Object,\n    ]),\n    default: '',\n  },\n  /**\n   * @description same as `maxlength` in native input\n   */\n  maxlength: {\n    type: [String, Number],\n  },\n  /**\n   * @description same as `minlength` in native input\n   */\n  minlength: {\n    type: [String, Number],\n  },\n  /**\n   * @description type of input\n   */\n  type: {\n    type: String,\n    default: 'text',\n  },\n  /**\n   * @description control the resizability\n   */\n  resize: {\n    type: String,\n    values: ['none', 'both', 'horizontal', 'vertical'],\n  },\n  /**\n   * @description whether textarea has an adaptive height\n   */\n  autosize: {\n    type: definePropType<InputAutoSize>([Boolean, Object]),\n    default: false,\n  },\n  /**\n   * @description native input autocomplete\n   */\n  autocomplete: {\n    type: String,\n    default: 'off',\n  },\n  /**\n   * @description format content\n   */\n  formatter: {\n    type: Function,\n  },\n  /**\n   * @description parse content\n   */\n  parser: {\n    type: Function,\n  },\n  /**\n   * @description placeholder\n   */\n  placeholder: {\n    type: String,\n  },\n  /**\n   * @description native input form\n   */\n  form: {\n    type: String,\n  },\n  /**\n   * @description native input readonly\n   */\n  readonly: Boolean,\n  /**\n   * @description native input readonly\n   */\n  clearable: Boolean,\n  /**\n   * @description toggleable password input\n   */\n  showPassword: Boolean,\n  /**\n   * @description word count\n   */\n  showWordLimit: Boolean,\n  /**\n   * @description suffix icon\n   */\n  suffixIcon: {\n    type: iconPropType,\n  },\n  /**\n   * @description prefix icon\n   */\n  prefixIcon: {\n    type: iconPropType,\n  },\n  /**\n   * @description container role, internal properties provided for use by the picker component\n   */\n  containerRole: {\n    type: String,\n    default: undefined,\n  },\n  /**\n   * @description input tabindex\n   */\n  tabindex: {\n    type: [String, Number],\n    default: 0,\n  },\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description input or textarea element style\n   */\n  inputStyle: {\n    type: definePropType<StyleValue>([Object, Array, String]),\n    default: () => mutable({} as const),\n  },\n  /**\n   * @description native input autofocus\n   */\n  autofocus: Boolean,\n  rows: {\n    type: Number,\n    default: 2,\n  },\n  ...useAriaProps(['ariaLabel']),\n} as const)\nexport type InputProps = ExtractPropTypes<typeof inputProps>\n\nexport const inputEmits = {\n  [UPDATE_MODEL_EVENT]: (value: string) => isString(value),\n  input: (value: string) => isString(value),\n  change: (value: string) => isString(value),\n  focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n  blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n  clear: () => true,\n  mouseleave: (evt: MouseEvent) => evt instanceof MouseEvent,\n  mouseenter: (evt: MouseEvent) => evt instanceof MouseEvent,\n  // NOTE: when autofill by browser, the keydown event is instanceof Event, not KeyboardEvent\n  // relative bug report https://github.com/element-plus/element-plus/issues/6665\n  keydown: (evt: KeyboardEvent | Event) => evt instanceof Event,\n  compositionstart: (evt: CompositionEvent) => evt instanceof CompositionEvent,\n  compositionupdate: (evt: CompositionEvent) => evt instanceof CompositionEvent,\n  compositionend: (evt: CompositionEvent) => evt instanceof CompositionEvent,\n}\nexport type InputEmits = typeof inputEmits\n", "<template>\n  <div\n    v-bind=\"containerAttrs\"\n    :class=\"[\n      containerKls,\n      {\n        [nsInput.bm('group', 'append')]: $slots.append,\n        [nsInput.bm('group', 'prepend')]: $slots.prepend,\n      },\n    ]\"\n    :style=\"containerStyle\"\n    :role=\"containerRole\"\n    @mouseenter=\"handleMouseEnter\"\n    @mouseleave=\"handleMouseLeave\"\n  >\n    <!-- input -->\n    <template v-if=\"type !== 'textarea'\">\n      <!-- prepend slot -->\n      <div v-if=\"$slots.prepend\" :class=\"nsInput.be('group', 'prepend')\">\n        <slot name=\"prepend\" />\n      </div>\n\n      <div ref=\"wrapperRef\" :class=\"wrapperKls\">\n        <!-- prefix slot -->\n        <span v-if=\"$slots.prefix || prefixIcon\" :class=\"nsInput.e('prefix')\">\n          <span :class=\"nsInput.e('prefix-inner')\">\n            <slot name=\"prefix\" />\n            <el-icon v-if=\"prefixIcon\" :class=\"nsInput.e('icon')\">\n              <component :is=\"prefixIcon\" />\n            </el-icon>\n          </span>\n        </span>\n\n        <input\n          :id=\"inputId\"\n          ref=\"input\"\n          :class=\"nsInput.e('inner')\"\n          v-bind=\"attrs\"\n          :minlength=\"minlength\"\n          :maxlength=\"maxlength\"\n          :type=\"showPassword ? (passwordVisible ? 'text' : 'password') : type\"\n          :disabled=\"inputDisabled\"\n          :readonly=\"readonly\"\n          :autocomplete=\"autocomplete\"\n          :tabindex=\"tabindex\"\n          :aria-label=\"ariaLabel\"\n          :placeholder=\"placeholder\"\n          :style=\"inputStyle\"\n          :form=\"form\"\n          :autofocus=\"autofocus\"\n          @compositionstart=\"handleCompositionStart\"\n          @compositionupdate=\"handleCompositionUpdate\"\n          @compositionend=\"handleCompositionEnd\"\n          @input=\"handleInput\"\n          @change=\"handleChange\"\n          @keydown=\"handleKeydown\"\n        />\n\n        <!-- suffix slot -->\n        <span v-if=\"suffixVisible\" :class=\"nsInput.e('suffix')\">\n          <span :class=\"nsInput.e('suffix-inner')\">\n            <template\n              v-if=\"!showClear || !showPwdVisible || !isWordLimitVisible\"\n            >\n              <slot name=\"suffix\" />\n              <el-icon v-if=\"suffixIcon\" :class=\"nsInput.e('icon')\">\n                <component :is=\"suffixIcon\" />\n              </el-icon>\n            </template>\n            <el-icon\n              v-if=\"showClear\"\n              :class=\"[nsInput.e('icon'), nsInput.e('clear')]\"\n              @mousedown.prevent=\"NOOP\"\n              @click=\"clear\"\n            >\n              <circle-close />\n            </el-icon>\n            <el-icon\n              v-if=\"showPwdVisible\"\n              :class=\"[nsInput.e('icon'), nsInput.e('password')]\"\n              @click=\"handlePasswordVisible\"\n            >\n              <component :is=\"passwordIcon\" />\n            </el-icon>\n            <span v-if=\"isWordLimitVisible\" :class=\"nsInput.e('count')\">\n              <span :class=\"nsInput.e('count-inner')\">\n                {{ textLength }} / {{ maxlength }}\n              </span>\n            </span>\n            <el-icon\n              v-if=\"validateState && validateIcon && needStatusIcon\"\n              :class=\"[\n                nsInput.e('icon'),\n                nsInput.e('validateIcon'),\n                nsInput.is('loading', validateState === 'validating'),\n              ]\"\n            >\n              <component :is=\"validateIcon\" />\n            </el-icon>\n          </span>\n        </span>\n      </div>\n\n      <!-- append slot -->\n      <div v-if=\"$slots.append\" :class=\"nsInput.be('group', 'append')\">\n        <slot name=\"append\" />\n      </div>\n    </template>\n\n    <!-- textarea -->\n    <template v-else>\n      <textarea\n        :id=\"inputId\"\n        ref=\"textarea\"\n        :class=\"[nsTextarea.e('inner'), nsInput.is('focus', isFocused)]\"\n        v-bind=\"attrs\"\n        :minlength=\"minlength\"\n        :maxlength=\"maxlength\"\n        :tabindex=\"tabindex\"\n        :disabled=\"inputDisabled\"\n        :readonly=\"readonly\"\n        :autocomplete=\"autocomplete\"\n        :style=\"textareaStyle\"\n        :aria-label=\"ariaLabel\"\n        :placeholder=\"placeholder\"\n        :form=\"form\"\n        :autofocus=\"autofocus\"\n        :rows=\"rows\"\n        @compositionstart=\"handleCompositionStart\"\n        @compositionupdate=\"handleCompositionUpdate\"\n        @compositionend=\"handleCompositionEnd\"\n        @input=\"handleInput\"\n        @focus=\"handleFocus\"\n        @blur=\"handleBlur\"\n        @change=\"handleChange\"\n        @keydown=\"handleKeydown\"\n      />\n      <span\n        v-if=\"isWordLimitVisible\"\n        :style=\"countStyle\"\n        :class=\"nsInput.e('count')\"\n      >\n        {{ textLength }} / {{ maxlength }}\n      </span>\n    </template>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  nextTick,\n  onMounted,\n  ref,\n  shallowRef,\n  toRef,\n  useAttrs as useRawAttrs,\n  useSlots,\n  watch,\n} from 'vue'\nimport { useResizeObserver } from '@vueuse/core'\nimport { isNil } from 'lodash-unified'\nimport { ElIcon } from '@element-plus/components/icon'\nimport {\n  CircleClose,\n  Hide as IconHide,\n  View as IconView,\n} from '@element-plus/icons-vue'\nimport {\n  useFormDisabled,\n  useFormItem,\n  useFormItemInputId,\n  useFormSize,\n} from '@element-plus/components/form'\nimport {\n  NOOP,\n  ValidateComponentsMap,\n  debugWarn,\n  isClient,\n  isObject,\n} from '@element-plus/utils'\nimport {\n  useAttrs,\n  useComposition,\n  useCursor,\n  useFocusController,\n  useNamespace,\n} from '@element-plus/hooks'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { calcTextareaHeight } from './utils'\nimport { inputEmits, inputProps } from './input'\nimport type { StyleValue } from 'vue'\n\ntype TargetElement = HTMLInputElement | HTMLTextAreaElement\n\ndefineOptions({\n  name: 'ElInput',\n  inheritAttrs: false,\n})\nconst props = defineProps(inputProps)\nconst emit = defineEmits(inputEmits)\n\nconst rawAttrs = useRawAttrs()\nconst slots = useSlots()\n\nconst containerAttrs = computed(() => {\n  const comboBoxAttrs: Record<string, unknown> = {}\n  if (props.containerRole === 'combobox') {\n    comboBoxAttrs['aria-haspopup'] = rawAttrs['aria-haspopup']\n    comboBoxAttrs['aria-owns'] = rawAttrs['aria-owns']\n    comboBoxAttrs['aria-expanded'] = rawAttrs['aria-expanded']\n  }\n  return comboBoxAttrs\n})\n\nconst containerKls = computed(() => [\n  props.type === 'textarea' ? nsTextarea.b() : nsInput.b(),\n  nsInput.m(inputSize.value),\n  nsInput.is('disabled', inputDisabled.value),\n  nsInput.is('exceed', inputExceed.value),\n  {\n    [nsInput.b('group')]: slots.prepend || slots.append,\n    [nsInput.m('prefix')]: slots.prefix || props.prefixIcon,\n    [nsInput.m('suffix')]:\n      slots.suffix || props.suffixIcon || props.clearable || props.showPassword,\n    [nsInput.bm('suffix', 'password-clear')]:\n      showClear.value && showPwdVisible.value,\n    [nsInput.b('hidden')]: props.type === 'hidden',\n  },\n  rawAttrs.class,\n])\n\nconst wrapperKls = computed(() => [\n  nsInput.e('wrapper'),\n  nsInput.is('focus', isFocused.value),\n])\n\nconst attrs = useAttrs({\n  excludeKeys: computed<string[]>(() => {\n    return Object.keys(containerAttrs.value)\n  }),\n})\nconst { form: elForm, formItem: elFormItem } = useFormItem()\nconst { inputId } = useFormItemInputId(props, {\n  formItemContext: elFormItem,\n})\nconst inputSize = useFormSize()\nconst inputDisabled = useFormDisabled()\nconst nsInput = useNamespace('input')\nconst nsTextarea = useNamespace('textarea')\n\nconst input = shallowRef<HTMLInputElement>()\nconst textarea = shallowRef<HTMLTextAreaElement>()\n\nconst hovering = ref(false)\nconst passwordVisible = ref(false)\nconst countStyle = ref<StyleValue>()\nconst textareaCalcStyle = shallowRef(props.inputStyle)\n\nconst _ref = computed(() => input.value || textarea.value)\n\n// wrapperRef for type=\"text\", handleFocus and handleBlur for type=\"textarea\"\nconst { wrapperRef, isFocused, handleFocus, handleBlur } = useFocusController(\n  _ref,\n  {\n    beforeFocus() {\n      return inputDisabled.value\n    },\n    afterBlur() {\n      if (props.validateEvent) {\n        elFormItem?.validate?.('blur').catch((err) => debugWarn(err))\n      }\n    },\n  }\n)\n\nconst needStatusIcon = computed(() => elForm?.statusIcon ?? false)\nconst validateState = computed(() => elFormItem?.validateState || '')\nconst validateIcon = computed(\n  () => validateState.value && ValidateComponentsMap[validateState.value]\n)\nconst passwordIcon = computed(() =>\n  passwordVisible.value ? IconView : IconHide\n)\nconst containerStyle = computed<StyleValue>(() => [\n  rawAttrs.style as StyleValue,\n])\nconst textareaStyle = computed<StyleValue>(() => [\n  props.inputStyle,\n  textareaCalcStyle.value,\n  { resize: props.resize },\n])\nconst nativeInputValue = computed(() =>\n  isNil(props.modelValue) ? '' : String(props.modelValue)\n)\nconst showClear = computed(\n  () =>\n    props.clearable &&\n    !inputDisabled.value &&\n    !props.readonly &&\n    !!nativeInputValue.value &&\n    (isFocused.value || hovering.value)\n)\nconst showPwdVisible = computed(\n  () =>\n    props.showPassword &&\n    !inputDisabled.value &&\n    !props.readonly &&\n    !!nativeInputValue.value &&\n    (!!nativeInputValue.value || isFocused.value)\n)\nconst isWordLimitVisible = computed(\n  () =>\n    props.showWordLimit &&\n    !!props.maxlength &&\n    (props.type === 'text' || props.type === 'textarea') &&\n    !inputDisabled.value &&\n    !props.readonly &&\n    !props.showPassword\n)\nconst textLength = computed(() => nativeInputValue.value.length)\nconst inputExceed = computed(\n  () =>\n    // show exceed style if length of initial value greater then maxlength\n    !!isWordLimitVisible.value && textLength.value > Number(props.maxlength)\n)\nconst suffixVisible = computed(\n  () =>\n    !!slots.suffix ||\n    !!props.suffixIcon ||\n    showClear.value ||\n    props.showPassword ||\n    isWordLimitVisible.value ||\n    (!!validateState.value && needStatusIcon.value)\n)\n\nconst [recordCursor, setCursor] = useCursor(input)\n\nuseResizeObserver(textarea, (entries) => {\n  onceInitSizeTextarea()\n  if (!isWordLimitVisible.value || props.resize !== 'both') return\n  const entry = entries[0]\n  const { width } = entry.contentRect\n  countStyle.value = {\n    /** right: 100% - width + padding(15) + right(6) */\n    right: `calc(100% - ${width + 15 + 6}px)`,\n  }\n})\n\nconst resizeTextarea = () => {\n  const { type, autosize } = props\n\n  if (!isClient || type !== 'textarea' || !textarea.value) return\n\n  if (autosize) {\n    const minRows = isObject(autosize) ? autosize.minRows : undefined\n    const maxRows = isObject(autosize) ? autosize.maxRows : undefined\n    const textareaStyle = calcTextareaHeight(textarea.value, minRows, maxRows)\n\n    // If the scrollbar is displayed, the height of the textarea needs more space than the calculated height.\n    // If set textarea height in this case, the scrollbar will not hide.\n    // So we need to hide scrollbar first, and reset it in next tick.\n    // see https://github.com/element-plus/element-plus/issues/8825\n    textareaCalcStyle.value = {\n      overflowY: 'hidden',\n      ...textareaStyle,\n    }\n\n    nextTick(() => {\n      // NOTE: Force repaint to make sure the style set above is applied.\n      textarea.value!.offsetHeight\n      textareaCalcStyle.value = textareaStyle\n    })\n  } else {\n    textareaCalcStyle.value = {\n      minHeight: calcTextareaHeight(textarea.value).minHeight,\n    }\n  }\n}\n\nconst createOnceInitResize = (resizeTextarea: () => void) => {\n  let isInit = false\n  return () => {\n    if (isInit || !props.autosize) return\n    const isElHidden = textarea.value?.offsetParent === null\n    if (!isElHidden) {\n      resizeTextarea()\n      isInit = true\n    }\n  }\n}\n// fix: https://github.com/element-plus/element-plus/issues/12074\nconst onceInitSizeTextarea = createOnceInitResize(resizeTextarea)\n\nconst setNativeInputValue = () => {\n  const input = _ref.value\n  const formatterValue = props.formatter\n    ? props.formatter(nativeInputValue.value)\n    : nativeInputValue.value\n  if (!input || input.value === formatterValue) return\n  input.value = formatterValue\n}\n\nconst handleInput = async (event: Event) => {\n  recordCursor()\n\n  let { value } = event.target as TargetElement\n\n  if (props.formatter) {\n    value = props.parser ? props.parser(value) : value\n  }\n\n  // should not emit input during composition\n  // see: https://github.com/ElemeFE/element/issues/10516\n  if (isComposing.value) return\n\n  // hack for https://github.com/ElemeFE/element/issues/8548\n  // should remove the following line when we don't support IE\n  if (value === nativeInputValue.value) {\n    setNativeInputValue()\n    return\n  }\n\n  emit(UPDATE_MODEL_EVENT, value)\n  emit('input', value)\n\n  // ensure native input value is controlled\n  // see: https://github.com/ElemeFE/element/issues/12850\n  await nextTick()\n  setNativeInputValue()\n  setCursor()\n}\n\nconst handleChange = (event: Event) => {\n  emit('change', (event.target as TargetElement).value)\n}\n\nconst {\n  isComposing,\n  handleCompositionStart,\n  handleCompositionUpdate,\n  handleCompositionEnd,\n} = useComposition({ emit, afterComposition: handleInput })\n\nconst handlePasswordVisible = () => {\n  passwordVisible.value = !passwordVisible.value\n  focus()\n}\n\nconst focus = async () => {\n  // see: https://github.com/ElemeFE/element/issues/18573\n  await nextTick()\n  _ref.value?.focus()\n}\n\nconst blur = () => _ref.value?.blur()\n\nconst handleMouseLeave = (evt: MouseEvent) => {\n  hovering.value = false\n  emit('mouseleave', evt)\n}\n\nconst handleMouseEnter = (evt: MouseEvent) => {\n  hovering.value = true\n  emit('mouseenter', evt)\n}\n\nconst handleKeydown = (evt: KeyboardEvent) => {\n  emit('keydown', evt)\n}\n\nconst select = () => {\n  _ref.value?.select()\n}\n\nconst clear = () => {\n  emit(UPDATE_MODEL_EVENT, '')\n  emit('change', '')\n  emit('clear')\n  emit('input', '')\n}\n\nwatch(\n  () => props.modelValue,\n  () => {\n    nextTick(() => resizeTextarea())\n    if (props.validateEvent) {\n      elFormItem?.validate?.('change').catch((err) => debugWarn(err))\n    }\n  }\n)\n\n// native input value is set explicitly\n// do not use v-model / :value in template\n// see: https://github.com/ElemeFE/element/issues/14521\nwatch(nativeInputValue, () => setNativeInputValue())\n\n// when change between <input> and <textarea>,\n// update DOM dependent value and styles\n// https://github.com/ElemeFE/element/issues/14857\nwatch(\n  () => props.type,\n  async () => {\n    await nextTick()\n    setNativeInputValue()\n    resizeTextarea()\n  }\n)\n\nonMounted(() => {\n  if (!props.formatter && props.parser) {\n    debugWarn(\n      'ElInput',\n      'If you set the parser, you also need to set the formatter.'\n    )\n  }\n  setNativeInputValue()\n  nextTick(resizeTextarea)\n})\n\ndefineExpose({\n  /** @description HTML input element */\n  input,\n  /** @description HTML textarea element */\n  textarea,\n  /** @description HTML element, input or textarea */\n  ref: _ref,\n  /** @description style of textarea. */\n  textareaStyle,\n\n  /** @description from props (used on unit test) */\n  autosize: toRef(props, 'autosize'),\n\n  /** @description is input composing */\n  isComposing,\n\n  /** @description HTML input element native method */\n  focus,\n  /** @description HTML input element native method */\n  blur,\n  /** @description HTML input element native method */\n  select,\n  /** @description clear input value */\n  clear,\n  /** @description resize textarea. */\n  resizeTextarea,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Input from './src/input.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElInput: SFCWithInstall<typeof Input> = withInstall(Input)\nexport default ElInput\n\nexport * from './src/input'\nexport type { InputInstance } from './src/instance'\n", "import type { CSSProperties } from 'vue'\nimport type { ThumbProps } from './thumb'\n\nexport const GAP = 4 // top 2 + bottom 2 of bar instance\n\nexport const BAR_MAP = {\n  vertical: {\n    offset: 'offsetHeight',\n    scroll: 'scrollTop',\n    scrollSize: 'scrollHeight',\n    size: 'height',\n    key: 'vertical',\n    axis: 'Y',\n    client: 'clientY',\n    direction: 'top',\n  },\n  horizontal: {\n    offset: 'offsetWidth',\n    scroll: 'scrollLeft',\n    scrollSize: 'scrollWidth',\n    size: 'width',\n    key: 'horizontal',\n    axis: 'X',\n    client: 'clientX',\n    direction: 'left',\n  },\n} as const\n\nexport const renderThumbStyle = ({\n  move,\n  size,\n  bar,\n}: Pick<ThumbProps, 'move' | 'size'> & {\n  bar: typeof BAR_MAP[keyof typeof BAR_MAP]\n}): CSSProperties => ({\n  [bar.size]: size,\n  transform: `translate${bar.axis}(${move}%)`,\n})\n", "import type { InjectionKey } from 'vue'\n\nexport interface ScrollbarContext {\n  scrollbarElement: HTMLDivElement\n  wrapElement: HTMLDivElement\n}\n\nexport const scrollbarContextKey: InjectionKey<ScrollbarContext> = Symbol(\n  'scrollbarContextKey'\n)\n", "import { buildProps } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Thumb from './thumb.vue'\n\nexport const thumbProps = buildProps({\n  vertical: Boolean,\n  size: String,\n  move: Number,\n  ratio: {\n    type: Number,\n    required: true,\n  },\n  always: Boolean,\n} as const)\nexport type ThumbProps = ExtractPropTypes<typeof thumbProps>\n\nexport type ThumbInstance = InstanceType<typeof Thumb>\n", "<template>\n  <transition :name=\"ns.b('fade')\">\n    <div\n      v-show=\"always || visible\"\n      ref=\"instance\"\n      :class=\"[ns.e('bar'), ns.is(bar.key)]\"\n      @mousedown=\"clickTrackHandler\"\n    >\n      <div\n        ref=\"thumb\"\n        :class=\"ns.e('thumb')\"\n        :style=\"thumbStyle\"\n        @mousedown=\"clickThumbHandler\"\n      />\n    </div>\n  </transition>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, onBeforeUnmount, ref, toRef } from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport { isClient, throwError } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { scrollbarContextKey } from './constants'\nimport { BAR_MAP, renderThumbStyle } from './util'\nimport { thumbProps } from './thumb'\n\nconst COMPONENT_NAME = 'Thumb'\nconst props = defineProps(thumbProps)\n\nconst scrollbar = inject(scrollbarContextKey)\nconst ns = useNamespace('scrollbar')\n\nif (!scrollbar) throwError(COMPONENT_NAME, 'can not inject scrollbar context')\n\nconst instance = ref<HTMLDivElement>()\nconst thumb = ref<HTMLDivElement>()\n\nconst thumbState = ref<Partial<Record<'X' | 'Y', number>>>({})\nconst visible = ref(false)\n\nlet cursorDown = false\nlet cursorLeave = false\nlet originalOnSelectStart:\n  | ((this: GlobalEventHandlers, ev: Event) => any)\n  | null = isClient ? document.onselectstart : null\n\nconst bar = computed(() => BAR_MAP[props.vertical ? 'vertical' : 'horizontal'])\n\nconst thumbStyle = computed(() =>\n  renderThumbStyle({\n    size: props.size,\n    move: props.move,\n    bar: bar.value,\n  })\n)\n\nconst offsetRatio = computed(\n  () =>\n    // offsetRatioX = original width of thumb / current width of thumb / ratioX\n    // offsetRatioY = original height of thumb / current height of thumb / ratioY\n    // instance height = wrap height - GAP\n    instance.value![bar.value.offset] ** 2 /\n    scrollbar.wrapElement![bar.value.scrollSize] /\n    props.ratio /\n    thumb.value![bar.value.offset]\n)\n\nconst clickThumbHandler = (e: MouseEvent) => {\n  // prevent click event of middle and right button\n  e.stopPropagation()\n  if (e.ctrlKey || [1, 2].includes(e.button)) return\n\n  window.getSelection()?.removeAllRanges()\n  startDrag(e)\n\n  const el = e.currentTarget as HTMLDivElement\n  if (!el) return\n  thumbState.value[bar.value.axis] =\n    el[bar.value.offset] -\n    (e[bar.value.client] - el.getBoundingClientRect()[bar.value.direction])\n}\n\nconst clickTrackHandler = (e: MouseEvent) => {\n  if (!thumb.value || !instance.value || !scrollbar.wrapElement) return\n\n  const offset = Math.abs(\n    (e.target as HTMLElement).getBoundingClientRect()[bar.value.direction] -\n      e[bar.value.client]\n  )\n  const thumbHalf = thumb.value[bar.value.offset] / 2\n  const thumbPositionPercentage =\n    ((offset - thumbHalf) * 100 * offsetRatio.value) /\n    instance.value[bar.value.offset]\n\n  scrollbar.wrapElement[bar.value.scroll] =\n    (thumbPositionPercentage * scrollbar.wrapElement[bar.value.scrollSize]) /\n    100\n}\n\nconst startDrag = (e: MouseEvent) => {\n  e.stopImmediatePropagation()\n  cursorDown = true\n  document.addEventListener('mousemove', mouseMoveDocumentHandler)\n  document.addEventListener('mouseup', mouseUpDocumentHandler)\n  originalOnSelectStart = document.onselectstart\n  document.onselectstart = () => false\n}\n\nconst mouseMoveDocumentHandler = (e: MouseEvent) => {\n  if (!instance.value || !thumb.value) return\n  if (cursorDown === false) return\n\n  const prevPage = thumbState.value[bar.value.axis]\n  if (!prevPage) return\n\n  const offset =\n    (instance.value.getBoundingClientRect()[bar.value.direction] -\n      e[bar.value.client]) *\n    -1\n  const thumbClickPosition = thumb.value[bar.value.offset] - prevPage\n  const thumbPositionPercentage =\n    ((offset - thumbClickPosition) * 100 * offsetRatio.value) /\n    instance.value[bar.value.offset]\n  scrollbar.wrapElement[bar.value.scroll] =\n    (thumbPositionPercentage * scrollbar.wrapElement[bar.value.scrollSize]) /\n    100\n}\n\nconst mouseUpDocumentHandler = () => {\n  cursorDown = false\n  thumbState.value[bar.value.axis] = 0\n  document.removeEventListener('mousemove', mouseMoveDocumentHandler)\n  document.removeEventListener('mouseup', mouseUpDocumentHandler)\n  restoreOnselectstart()\n  if (cursorLeave) visible.value = false\n}\n\nconst mouseMoveScrollbarHandler = () => {\n  cursorLeave = false\n  visible.value = !!props.size\n}\n\nconst mouseLeaveScrollbarHandler = () => {\n  cursorLeave = true\n  visible.value = cursorDown\n}\n\nonBeforeUnmount(() => {\n  restoreOnselectstart()\n  document.removeEventListener('mouseup', mouseUpDocumentHandler)\n})\n\nconst restoreOnselectstart = () => {\n  if (document.onselectstart !== originalOnSelectStart)\n    document.onselectstart = originalOnSelectStart\n}\n\nuseEventListener(\n  toRef(scrollbar, 'scrollbarElement'),\n  'mousemove',\n  mouseMoveScrollbarHandler\n)\nuseEventListener(\n  toRef(scrollbar, 'scrollbarElement'),\n  'mouseleave',\n  mouseLeaveScrollbarHandler\n)\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Bar from './bar.vue'\n\nexport const barProps = buildProps({\n  always: {\n    type: Boolean,\n    default: true,\n  },\n  minSize: {\n    type: Number,\n    required: true,\n  },\n} as const)\nexport type BarProps = ExtractPropTypes<typeof barProps>\n\nexport type BarInstance = InstanceType<typeof Bar>\n", "<template>\n  <thumb :move=\"moveX\" :ratio=\"ratioX\" :size=\"sizeWidth\" :always=\"always\" />\n  <thumb\n    :move=\"moveY\"\n    :ratio=\"ratioY\"\n    :size=\"sizeHeight\"\n    vertical\n    :always=\"always\"\n  />\n</template>\n<script lang=\"ts\" setup>\nimport { inject, ref } from 'vue'\nimport { GAP } from './util'\nimport Thumb from './thumb.vue'\nimport { barProps } from './bar'\nimport { scrollbarContextKey } from './constants'\n\nconst props = defineProps(barProps)\n\nconst scrollbar = inject(scrollbarContextKey)\n\nconst moveX = ref(0)\nconst moveY = ref(0)\nconst sizeWidth = ref('')\nconst sizeHeight = ref('')\nconst ratioY = ref(1)\nconst ratioX = ref(1)\n\nconst handleScroll = (wrap: HTMLDivElement) => {\n  if (wrap) {\n    const offsetHeight = wrap.offsetHeight - GAP\n    const offsetWidth = wrap.offsetWidth - GAP\n\n    moveY.value = ((wrap.scrollTop * 100) / offsetHeight) * ratioY.value\n    moveX.value = ((wrap.scrollLeft * 100) / offsetWidth) * ratioX.value\n  }\n}\n\nconst update = () => {\n  const wrap = scrollbar?.wrapElement\n  if (!wrap) return\n  const offsetHeight = wrap.offsetHeight - GAP\n  const offsetWidth = wrap.offsetWidth - GAP\n\n  const originalHeight = offsetHeight ** 2 / wrap.scrollHeight\n  const originalWidth = offsetWidth ** 2 / wrap.scrollWidth\n  const height = Math.max(originalHeight, props.minSize)\n  const width = Math.max(originalWidth, props.minSize)\n\n  ratioY.value =\n    originalHeight /\n    (offsetHeight - originalHeight) /\n    (height / (offsetHeight - height))\n  ratioX.value =\n    originalWidth /\n    (offsetWidth - originalWidth) /\n    (width / (offsetWidth - width))\n\n  sizeHeight.value = height + GAP < offsetHeight ? `${height}px` : ''\n  sizeWidth.value = width + GAP < offsetWidth ? `${width}px` : ''\n}\n\ndefineExpose({\n  handleScroll,\n  update,\n})\n</script>\n", "import { buildProps, definePropType, isNumber } from '@element-plus/utils'\nimport { useAriaProps } from '@element-plus/hooks'\nimport type { ExtractPropTypes, StyleValue } from 'vue'\nimport type Scrollbar from './scrollbar.vue'\n\nexport const scrollbarProps = buildProps({\n  /**\n   * @description height of scrollbar\n   */\n  height: {\n    type: [String, Number],\n    default: '',\n  },\n  /**\n   * @description max height of scrollbar\n   */\n  maxHeight: {\n    type: [String, Number],\n    default: '',\n  },\n  /**\n   * @description whether to use the native scrollbar\n   */\n  native: {\n    type: Boolean,\n    default: false,\n  },\n  /**\n   * @description style of wrap\n   */\n  wrapStyle: {\n    type: definePropType<StyleValue>([String, Object, Array]),\n    default: '',\n  },\n  /**\n   * @description class of wrap\n   */\n  wrapClass: {\n    type: [String, Array],\n    default: '',\n  },\n  /**\n   * @description class of view\n   */\n  viewClass: {\n    type: [String, Array],\n    default: '',\n  },\n  /**\n   * @description style of view\n   */\n  viewStyle: {\n    type: [String, Array, Object],\n    default: '',\n  },\n  /**\n   * @description do not respond to container size changes, if the container size does not change, it is better to set it to optimize performance\n   */\n  noresize: Boolean, // 如果 container 尺寸不会发生变化,最好设置它可以优化性能\n  /**\n   * @description element tag of the view\n   */\n  tag: {\n    type: String,\n    default: 'div',\n  },\n  /**\n   * @description always show\n   */\n  always: Boolean,\n  /**\n   * @description minimum size of scrollbar\n   */\n  minSize: {\n    type: Number,\n    default: 20,\n  },\n  /**\n   * @description Wrap tabindex\n   */\n  tabindex: {\n    type: [String, Number],\n    default: undefined,\n  },\n  /**\n   * @description id of view\n   */\n  id: String,\n  /**\n   * @description role of view\n   */\n  role: String,\n  ...useAriaProps(['ariaLabel', 'ariaOrientation']),\n} as const)\nexport type ScrollbarProps = ExtractPropTypes<typeof scrollbarProps>\n\nexport const scrollbarEmits = {\n  scroll: ({\n    scrollTop,\n    scrollLeft,\n  }: {\n    scrollTop: number\n    scrollLeft: number\n  }) => [scrollTop, scrollLeft].every(isNumber),\n}\nexport type ScrollbarEmits = typeof scrollbarEmits\n\nexport type ScrollbarInstance = InstanceType<typeof Scrollbar>\n", "<template>\n  <div ref=\"scrollbarRef\" :class=\"ns.b()\">\n    <div\n      ref=\"wrapRef\"\n      :class=\"wrapKls\"\n      :style=\"wrapStyle\"\n      :tabindex=\"tabindex\"\n      @scroll=\"handleScroll\"\n    >\n      <component\n        :is=\"tag\"\n        :id=\"id\"\n        ref=\"resizeRef\"\n        :class=\"resizeKls\"\n        :style=\"viewStyle\"\n        :role=\"role\"\n        :aria-label=\"ariaLabel\"\n        :aria-orientation=\"ariaOrientation\"\n      >\n        <slot />\n      </component>\n    </div>\n    <template v-if=\"!native\">\n      <bar ref=\"barRef\" :always=\"always\" :min-size=\"minSize\" />\n    </template>\n  </div>\n</template>\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  nextTick,\n  onActivated,\n  onMounted,\n  onUpdated,\n  provide,\n  reactive,\n  ref,\n  watch,\n} from 'vue'\nimport { useEventListener, useResizeObserver } from '@vueuse/core'\nimport { addUnit, debugWarn, isNumber, isObject } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport Bar from './bar.vue'\nimport { scrollbarContextKey } from './constants'\nimport { scrollbarEmits, scrollbarProps } from './scrollbar'\nimport type { BarInstance } from './bar'\nimport type { CSSProperties, StyleValue } from 'vue'\n\nconst COMPONENT_NAME = 'ElScrollbar'\n\ndefineOptions({\n  name: COMPONENT_NAME,\n})\n\nconst props = defineProps(scrollbarProps)\nconst emit = defineEmits(scrollbarEmits)\n\nconst ns = useNamespace('scrollbar')\n\nlet stopResizeObserver: (() => void) | undefined = undefined\nlet stopResizeListener: (() => void) | undefined = undefined\nlet wrapScrollTop = 0\nlet wrapScrollLeft = 0\n\nconst scrollbarRef = ref<HTMLDivElement>()\nconst wrapRef = ref<HTMLDivElement>()\nconst resizeRef = ref<HTMLElement>()\nconst barRef = ref<BarInstance>()\n\nconst wrapStyle = computed<StyleValue>(() => {\n  const style: CSSProperties = {}\n  if (props.height) style.height = addUnit(props.height)\n  if (props.maxHeight) style.maxHeight = addUnit(props.maxHeight)\n  return [props.wrapStyle, style]\n})\n\nconst wrapKls = computed(() => {\n  return [\n    props.wrapClass,\n    ns.e('wrap'),\n    { [ns.em('wrap', 'hidden-default')]: !props.native },\n  ]\n})\n\nconst resizeKls = computed(() => {\n  return [ns.e('view'), props.viewClass]\n})\n\nconst handleScroll = () => {\n  if (wrapRef.value) {\n    barRef.value?.handleScroll(wrapRef.value)\n    wrapScrollTop = wrapRef.value.scrollTop\n    wrapScrollLeft = wrapRef.value.scrollLeft\n\n    emit('scroll', {\n      scrollTop: wrapRef.value.scrollTop,\n      scrollLeft: wrapRef.value.scrollLeft,\n    })\n  }\n}\n\n// TODO: refactor method overrides, due to script setup dts\n// @ts-nocheck\nfunction scrollTo(xCord: number, yCord?: number): void\nfunction scrollTo(options: ScrollToOptions): void\nfunction scrollTo(arg1: unknown, arg2?: number) {\n  if (isObject(arg1)) {\n    wrapRef.value!.scrollTo(arg1)\n  } else if (isNumber(arg1) && isNumber(arg2)) {\n    wrapRef.value!.scrollTo(arg1, arg2)\n  }\n}\n\nconst setScrollTop = (value: number) => {\n  if (!isNumber(value)) {\n    debugWarn(COMPONENT_NAME, 'value must be a number')\n    return\n  }\n  wrapRef.value!.scrollTop = value\n}\n\nconst setScrollLeft = (value: number) => {\n  if (!isNumber(value)) {\n    debugWarn(COMPONENT_NAME, 'value must be a number')\n    return\n  }\n  wrapRef.value!.scrollLeft = value\n}\n\nconst update = () => {\n  barRef.value?.update()\n}\n\nwatch(\n  () => props.noresize,\n  (noresize) => {\n    if (noresize) {\n      stopResizeObserver?.()\n      stopResizeListener?.()\n    } else {\n      ;({ stop: stopResizeObserver } = useResizeObserver(resizeRef, update))\n      stopResizeListener = useEventListener('resize', update)\n    }\n  },\n  { immediate: true }\n)\n\nwatch(\n  () => [props.maxHeight, props.height],\n  () => {\n    if (!props.native)\n      nextTick(() => {\n        update()\n        if (wrapRef.value) {\n          barRef.value?.handleScroll(wrapRef.value)\n        }\n      })\n  }\n)\n\nprovide(\n  scrollbarContextKey,\n  reactive({\n    scrollbarElement: scrollbarRef,\n    wrapElement: wrapRef,\n  })\n)\n\nonActivated(() => {\n  if (wrapRef.value) {\n    wrapRef.value.scrollTop = wrapScrollTop\n    wrapRef.value.scrollLeft = wrapScrollLeft\n  }\n})\n\nonMounted(() => {\n  if (!props.native)\n    nextTick(() => {\n      update()\n    })\n})\nonUpdated(() => update())\n\ndefineExpose({\n  /** @description scrollbar wrap ref */\n  wrapRef,\n  /** @description update scrollbar state manually */\n  update,\n  /** @description scrolls to a particular set of coordinates */\n  scrollTo,\n  /** @description set distance to scroll top */\n  setScrollTop,\n  /** @description set distance to scroll left */\n  setScrollLeft,\n  /** @description handle scroll event */\n  handleScroll,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Scrollbar from './src/scrollbar.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElScrollbar: SFCWithInstall<typeof Scrollbar> =\n  withInstall(Scrollbar)\nexport default ElScrollbar\n\nexport * from './src/util'\nexport * from './src/scrollbar'\nexport * from './src/thumb'\nexport * from './src/constants'\n", "import type { CSSProperties, ComputedRef, InjectionKey, Ref } from 'vue'\nimport type { Instance } from '@popperjs/core'\n\nexport type Measurable = {\n  getBoundingClientRect: () => DOMRect\n}\n\n/**\n * triggerRef indicates the element that triggers popper\n * contentRef indicates the element of popper content\n * referenceRef indicates the element that popper content relative with\n */\nexport type ElPopperInjectionContext = {\n  triggerRef: Ref<Measurable | undefined>\n  contentRef: Ref<HTMLElement | undefined>\n  popperInstanceRef: Ref<Instance | undefined>\n  referenceRef: Ref<Measurable | undefined>\n  role: ComputedRef<string>\n}\n\nexport type ElPopperContentInjectionContext = {\n  arrowRef: Ref<HTMLElement | undefined>\n  arrowOffset: Ref<number | undefined>\n  arrowStyle: ComputedRef<CSSProperties>\n}\n\nexport const POPPER_INJECTION_KEY: InjectionKey<ElPopperInjectionContext> =\n  Symbol('popper')\n\nexport const POPPER_CONTENT_INJECTION_KEY: InjectionKey<ElPopperContentInjectionContext> =\n  Symbol('popperContent')\n", "import { buildProps } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Popper from './popper.vue'\n\nconst effects = ['light', 'dark'] as const\nconst triggers = ['click', 'contextmenu', 'hover', 'focus'] as const\n\nexport const Effect = {\n  LIGHT: 'light',\n  DARK: 'dark',\n} as const\n\nexport const roleTypes = [\n  'dialog',\n  'grid',\n  'group',\n  'listbox',\n  'menu',\n  'navigation',\n  'tooltip',\n  'tree',\n] as const\n\nexport type PopperEffect = typeof effects[number]\nexport type PopperTrigger = typeof triggers[number]\n\nexport const popperProps = buildProps({\n  role: {\n    type: String,\n    values: roleTypes,\n    default: 'tooltip',\n  },\n} as const)\n\nexport type PopperProps = ExtractPropTypes<typeof popperProps>\n\nexport type PopperInstance = InstanceType<typeof Popper>\n\n/** @deprecated use `popperProps` instead, and it will be deprecated in the next major version */\nexport const usePopperProps = popperProps\n\n/** @deprecated use `PopperProps` instead, and it will be deprecated in the next major version */\nexport type UsePopperProps = PopperProps\n", "<template>\n  <slot />\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, provide, ref } from 'vue'\nimport { POPPER_INJECTION_KEY } from './constants'\nimport { popperProps } from './popper'\n\nimport type { Instance as PopperInstance } from '@popperjs/core'\nimport type { ElPopperInjectionContext } from './constants'\n\ndefineOptions({\n  name: 'ElPopper',\n  inheritAttrs: false,\n})\nconst props = defineProps(popperProps)\n\nconst triggerRef = ref<HTMLElement>()\nconst popperInstanceRef = ref<PopperInstance>()\nconst contentRef = ref<HTMLElement>()\nconst referenceRef = ref<HTMLElement>()\nconst role = computed(() => props.role)\n\nconst popperProvides = {\n  /**\n   * @description trigger element\n   */\n  triggerRef,\n  /**\n   * @description popperjs instance\n   */\n  popperInstanceRef,\n  /**\n   * @description popper content element\n   */\n  contentRef,\n  /**\n   * @description popper reference element\n   */\n  referenceRef,\n  /**\n   * @description role determines how aria attributes are distributed\n   */\n  role,\n} as ElPopperInjectionContext\n\ndefineExpose(popperProvides)\n\nprovide(POPPER_INJECTION_KEY, popperProvides)\n</script>\n", "import { buildProps } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Arrow from './arrow.vue'\n\nexport const popperArrowProps = buildProps({\n  arrowOffset: {\n    type: Number,\n    default: 5,\n  },\n} as const)\nexport type PopperArrowProps = ExtractPropTypes<typeof popperArrowProps>\n\nexport type PopperArrowInstance = InstanceType<typeof Arrow>\n\n/** @deprecated use `popperArrowProps` instead, and it will be deprecated in the next major version */\nexport const usePopperArrowProps = popperArrowProps\n\n/** @deprecated use `PopperArrowProps` instead, and it will be deprecated in the next major version */\nexport type UsePopperArrowProps = PopperArrowProps\n\n/** @deprecated use `PopperArrowInstance` instead, and it will be deprecated in the next major version */\nexport type ElPopperArrowInstance = PopperArrowInstance\n", "<template>\n  <span\n    ref=\"arrowRef\"\n    :class=\"ns.e('arrow')\"\n    :style=\"arrowStyle\"\n    data-popper-arrow\n  />\n</template>\n\n<script lang=\"ts\" setup>\nimport { inject, onBeforeUnmount, watch } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { POPPER_CONTENT_INJECTION_KEY } from './constants'\nimport { popperArrowProps } from './arrow'\n\ndefineOptions({\n  name: 'ElPopperArrow',\n  inheritAttrs: false,\n})\n\nconst props = defineProps(popperArrowProps)\n\nconst ns = useNamespace('popper')\nconst { arrowOffset, arrowRef, arrowStyle } = inject(\n  POPPER_CONTENT_INJECTION_KEY,\n  undefined\n)!\n\nwatch(\n  () => props.arrowOffset,\n  (val) => {\n    arrowOffset.value = val\n  }\n)\nonBeforeUnmount(() => {\n  arrowRef.value = undefined\n})\n\ndefineExpose({\n  /**\n   * @description Arrow element\n   */\n  arrowRef,\n})\n</script>\n", "import {\n  Comment,\n  Fragment,\n  Text,\n  cloneVNode,\n  defineComponent,\n  inject,\n  withDirectives,\n} from 'vue'\nimport { NOOP, debugWarn, isObject } from '@element-plus/utils'\nimport {\n  FORWARD_REF_INJECTION_KEY,\n  useForwardRefDirective,\n  useNamespace,\n} from '@element-plus/hooks'\n\nimport type { Ref, VNode } from 'vue'\n\nconst NAME = 'ElOnlyChild'\n\nexport const OnlyChild = defineComponent({\n  name: NAME,\n  setup(_, { slots, attrs }) {\n    const forwardRefInjection = inject(FORWARD_REF_INJECTION_KEY)\n    const forwardRefDirective = useForwardRefDirective(\n      forwardRefInjection?.setForwardRef ?? NOOP\n    )\n    return () => {\n      const defaultSlot = slots.default?.(attrs)\n      if (!defaultSlot) return null\n\n      if (defaultSlot.length > 1) {\n        debugWarn(NAME, 'requires exact only one valid child.')\n        return null\n      }\n\n      const firstLegitNode = findFirstLegitChild(defaultSlot)\n      if (!firstLegitNode) {\n        debugWarn(NAME, 'no valid child node found')\n        return null\n      }\n\n      return withDirectives(cloneVNode(firstLegitNode!, attrs), [\n        [forwardRefDirective],\n      ])\n    }\n  },\n})\n\nfunction findFirstLegitChild(node: VNode[] | undefined): VNode | null {\n  if (!node) return null\n  const children = node as VNode[]\n  for (const child of children) {\n    /**\n     * when user uses h(Fragment, [text]) to render plain string,\n     * this switch case just cannot handle, when the value is primitives\n     * we should just return the wrapped string\n     */\n    if (isObject(child)) {\n      switch (child.type) {\n        case Comment:\n          continue\n        case Text:\n        case 'svg':\n          return wrapTextContent(child)\n        case Fragment:\n          return findFirstLegitChild(child.children as VNode[])\n        default:\n          return child\n      }\n    }\n    return wrapTextContent(child)\n  }\n  return null\n}\n\nfunction wrapTextContent(s: string | VNode) {\n  const ns = useNamespace('only-child')\n  return <span class={ns.e('content')}>{s}</span>\n}\n\nexport type OnlyChildExpose = {\n  forwardRef: Ref<HTMLElement>\n}\n", "import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { Measurable } from './constants'\nimport type Trigger from './trigger.vue'\n\nexport const popperTriggerProps = buildProps({\n  virtualRef: {\n    type: definePropType<Measurable>(Object),\n  },\n  virtualTriggering: Boolean,\n  onMouseenter: {\n    type: definePropType<(e: Event) => void>(Function),\n  },\n  onMouseleave: {\n    type: definePropType<(e: Event) => void>(Function),\n  },\n  onClick: {\n    type: definePropType<(e: Event) => void>(Function),\n  },\n  onKeydown: {\n    type: definePropType<(e: Event) => void>(Function),\n  },\n  onFocus: {\n    type: definePropType<(e: Event) => void>(Function),\n  },\n  onBlur: {\n    type: definePropType<(e: Event) => void>(Function),\n  },\n  onContextmenu: {\n    type: definePropType<(e: Event) => void>(Function),\n  },\n  id: String,\n  open: Boolean,\n} as const)\n\nexport type PopperTriggerProps = typeof popperTriggerProps\n\nexport type PopperTriggerInstance = InstanceType<typeof Trigger>\n\n/** @deprecated use `popperTriggerProps` instead, and it will be deprecated in the next major version */\nexport const usePopperTriggerProps = popperTriggerProps\n\n/** @deprecated use `PopperTriggerInstance` instead, and it will be deprecated in the next major version */\nexport type ElPopperArrowTrigger = PopperTriggerInstance\n", "<template>\n  <el-only-child\n    v-if=\"!virtualTriggering\"\n    v-bind=\"$attrs\"\n    :aria-controls=\"ariaControls\"\n    :aria-describedby=\"ariaDescribedby\"\n    :aria-expanded=\"ariaExpanded\"\n    :aria-haspopup=\"ariaHaspopup\"\n  >\n    <slot />\n  </el-only-child>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, onBeforeUnmount, onMounted, watch } from 'vue'\nimport { isNil } from 'lodash-unified'\nimport { unrefElement } from '@vueuse/core'\nimport { ElOnlyChild } from '@element-plus/components/slot'\nimport { useForwardRef } from '@element-plus/hooks'\nimport { isElement } from '@element-plus/utils'\nimport { POPPER_INJECTION_KEY } from './constants'\nimport { popperTriggerProps } from './trigger'\n\nimport type { WatchStopHandle } from 'vue'\n\ndefineOptions({\n  name: 'ElPopperTrigger',\n  inheritAttrs: false,\n})\n\nconst props = defineProps(popperTriggerProps)\n\nconst { role, triggerRef } = inject(POPPER_INJECTION_KEY, undefined)!\n\nuseForwardRef(triggerRef)\n\nconst ariaControls = computed<string | undefined>(() => {\n  return ariaHaspopup.value ? props.id : undefined\n})\n\nconst ariaDescribedby = computed<string | undefined>(() => {\n  if (role && role.value === 'tooltip') {\n    return props.open && props.id ? props.id : undefined\n  }\n  return undefined\n})\n\nconst ariaHaspopup = computed<string | undefined>(() => {\n  if (role && role.value !== 'tooltip') {\n    return role.value\n  }\n  return undefined\n})\n\nconst ariaExpanded = computed<string | undefined>(() => {\n  return ariaHaspopup.value ? `${props.open}` : undefined\n})\n\nlet virtualTriggerAriaStopWatch: WatchStopHandle | undefined = undefined\n\nconst TRIGGER_ELE_EVENTS = [\n  'onMouseenter',\n  'onMouseleave',\n  'onClick',\n  'onKeydown',\n  'onFocus',\n  'onBlur',\n  'onContextmenu',\n] as const\n\nonMounted(() => {\n  watch(\n    () => props.virtualRef,\n    (virtualEl) => {\n      if (virtualEl) {\n        triggerRef.value = unrefElement(virtualEl as HTMLElement)\n      }\n    },\n    {\n      immediate: true,\n    }\n  )\n\n  watch(\n    triggerRef,\n    (el, prevEl) => {\n      virtualTriggerAriaStopWatch?.()\n      virtualTriggerAriaStopWatch = undefined\n      if (isElement(el)) {\n        TRIGGER_ELE_EVENTS.forEach((eventName) => {\n          const handler = props[eventName]\n          if (handler) {\n            ;(el as HTMLElement).addEventListener(\n              eventName.slice(2).toLowerCase(),\n              handler\n            )\n            ;(prevEl as HTMLElement)?.removeEventListener?.(\n              eventName.slice(2).toLowerCase(),\n              handler\n            )\n          }\n        })\n        virtualTriggerAriaStopWatch = watch(\n          [ariaControls, ariaDescribedby, ariaHaspopup, ariaExpanded],\n          (watches) => {\n            ;[\n              'aria-controls',\n              'aria-describedby',\n              'aria-haspopup',\n              'aria-expanded',\n            ].forEach((key, idx) => {\n              isNil(watches[idx])\n                ? el.removeAttribute(key)\n                : el.setAttribute(key, watches[idx]!)\n            })\n          },\n          { immediate: true }\n        )\n      }\n      if (isElement(prevEl)) {\n        ;[\n          'aria-controls',\n          'aria-describedby',\n          'aria-haspopup',\n          'aria-expanded',\n        ].forEach((key) => prevEl.removeAttribute(key))\n      }\n    },\n    {\n      immediate: true,\n    }\n  )\n})\n\nonBeforeUnmount(() => {\n  virtualTriggerAriaStopWatch?.()\n  virtualTriggerAriaStopWatch = undefined\n  if (triggerRef.value && isElement(triggerRef.value)) {\n    const el = triggerRef.value as HTMLElement\n    TRIGGER_ELE_EVENTS.forEach((eventName) => {\n      const handler = props[eventName]\n      if (handler) {\n        el.removeEventListener(eventName.slice(2).toLowerCase(), handler)\n      }\n    })\n    triggerRef.value = undefined\n  }\n})\n\ndefineExpose({\n  /**\n   * @description trigger element\n   */\n  triggerRef,\n})\n</script>\n", "import type { InjectionKey, Ref } from 'vue'\n\nexport const FOCUS_AFTER_TRAPPED = 'focus-trap.focus-after-trapped'\nexport const FOCUS_AFTER_RELEASED = 'focus-trap.focus-after-released'\nexport const FOCUSOUT_PREVENTED = 'focus-trap.focusout-prevented'\nexport const FOCUS_AFTER_TRAPPED_OPTS: EventInit = {\n  cancelable: true,\n  bubbles: false,\n}\nexport const FOCUSOUT_PREVENTED_OPTS: EventInit = {\n  cancelable: true,\n  bubbles: false,\n}\n\nexport const ON_TRAP_FOCUS_EVT = 'focusAfterTrapped'\nexport const ON_RELEASE_FOCUS_EVT = 'focusAfterReleased'\n\nexport type FocusTrapInjectionContext = {\n  focusTrapRef: Ref<HTMLElement | undefined>\n  onKeydown: (e: KeyboardEvent) => void\n}\n\nexport const FOCUS_TRAP_INJECTION_KEY: InjectionKey<FocusTrapInjectionContext> =\n  Symbol('elFocusTrap')\n", "import { onBeforeUnmount, onMounted, ref } from 'vue'\nimport { FOCUSOUT_PREVENTED, FOCUSOUT_PREVENTED_OPTS } from './tokens'\n\nconst focusReason = ref<'pointer' | 'keyboard'>()\nconst lastUserFocusTimestamp = ref<number>(0)\nconst lastAutomatedFocusTimestamp = ref<number>(0)\nlet focusReasonUserCount = 0\n\nexport type FocusLayer = {\n  paused: boolean\n  pause: () => void\n  resume: () => void\n}\n\nexport type FocusStack = FocusLayer[]\n\nexport const obtainAllFocusableElements = (\n  element: HTMLElement\n): HTMLElement[] => {\n  const nodes: HTMLElement[] = []\n  const walker = document.createTreeWalker(element, NodeFilter.SHOW_ELEMENT, {\n    acceptNode: (\n      node: Element & {\n        disabled: boolean\n        hidden: boolean\n        type: string\n        tabIndex: number\n      }\n    ) => {\n      const isHiddenInput = node.tagName === 'INPUT' && node.type === 'hidden'\n      if (node.disabled || node.hidden || isHiddenInput)\n        return NodeFilter.FILTER_SKIP\n      return node.tabIndex >= 0 || node === document.activeElement\n        ? NodeFilter.FILTER_ACCEPT\n        : NodeFilter.FILTER_SKIP\n    },\n  })\n  while (walker.nextNode()) nodes.push(walker.currentNode as HTMLElement)\n\n  return nodes\n}\n\nexport const getVisibleElement = (\n  elements: HTMLElement[],\n  container: HTMLElement\n) => {\n  for (const element of elements) {\n    if (!isHidden(element, container)) return element\n  }\n}\n\nexport const isHidden = (element: HTMLElement, container: HTMLElement) => {\n  if (process.env.NODE_ENV === 'test') return false\n  if (getComputedStyle(element).visibility === 'hidden') return true\n\n  while (element) {\n    if (container && element === container) return false\n    if (getComputedStyle(element).display === 'none') return true\n    element = element.parentElement as HTMLElement\n  }\n\n  return false\n}\n\nexport const getEdges = (container: HTMLElement) => {\n  const focusable = obtainAllFocusableElements(container)\n  const first = getVisibleElement(focusable, container)\n  const last = getVisibleElement(focusable.reverse(), container)\n  return [first, last]\n}\n\nconst isSelectable = (\n  element: any\n): element is HTMLInputElement & { select: () => void } => {\n  return element instanceof HTMLInputElement && 'select' in element\n}\n\nexport const tryFocus = (\n  element?: HTMLElement | { focus: () => void } | null,\n  shouldSelect?: boolean\n) => {\n  if (element && element.focus) {\n    const prevFocusedElement = document.activeElement\n    element.focus({ preventScroll: true })\n    lastAutomatedFocusTimestamp.value = window.performance.now()\n    if (\n      element !== prevFocusedElement &&\n      isSelectable(element) &&\n      shouldSelect\n    ) {\n      element.select()\n    }\n  }\n}\n\nfunction removeFromStack<T>(list: T[], item: T) {\n  const copy = [...list]\n\n  const idx = list.indexOf(item)\n\n  if (idx !== -1) {\n    copy.splice(idx, 1)\n  }\n  return copy\n}\n\nconst createFocusableStack = () => {\n  let stack = [] as FocusStack\n\n  const push = (layer: FocusLayer) => {\n    const currentLayer = stack[0]\n\n    if (currentLayer && layer !== currentLayer) {\n      currentLayer.pause()\n    }\n\n    stack = removeFromStack(stack, layer)\n    stack.unshift(layer)\n  }\n\n  const remove = (layer: FocusLayer) => {\n    stack = removeFromStack(stack, layer)\n    stack[0]?.resume?.()\n  }\n\n  return {\n    push,\n    remove,\n  }\n}\n\nexport const focusFirstDescendant = (\n  elements: HTMLElement[],\n  shouldSelect = false\n) => {\n  const prevFocusedElement = document.activeElement\n  for (const element of elements) {\n    tryFocus(element, shouldSelect)\n    if (document.activeElement !== prevFocusedElement) return\n  }\n}\n\nexport const focusableStack = createFocusableStack()\n\nexport const isFocusCausedByUserEvent = (): boolean => {\n  return lastUserFocusTimestamp.value > lastAutomatedFocusTimestamp.value\n}\n\nconst notifyFocusReasonPointer = () => {\n  focusReason.value = 'pointer'\n  lastUserFocusTimestamp.value = window.performance.now()\n}\n\nconst notifyFocusReasonKeydown = () => {\n  focusReason.value = 'keyboard'\n  lastUserFocusTimestamp.value = window.performance.now()\n}\n\nexport const useFocusReason = (): {\n  focusReason: typeof focusReason\n  lastUserFocusTimestamp: typeof lastUserFocusTimestamp\n  lastAutomatedFocusTimestamp: typeof lastAutomatedFocusTimestamp\n} => {\n  onMounted(() => {\n    if (focusReasonUserCount === 0) {\n      document.addEventListener('mousedown', notifyFocusReasonPointer)\n      document.addEventListener('touchstart', notifyFocusReasonPointer)\n      document.addEventListener('keydown', notifyFocusReasonKeydown)\n    }\n    focusReasonUserCount++\n  })\n\n  onBeforeUnmount(() => {\n    focusReasonUserCount--\n    if (focusReasonUserCount <= 0) {\n      document.removeEventListener('mousedown', notifyFocusReasonPointer)\n      document.removeEventListener('touchstart', notifyFocusReasonPointer)\n      document.removeEventListener('keydown', notifyFocusReasonKeydown)\n    }\n  })\n\n  return {\n    focusReason,\n    lastUserFocusTimestamp,\n    lastAutomatedFocusTimestamp,\n  }\n}\n\nexport const createFocusOutPreventedEvent = (\n  detail: CustomEventInit['detail']\n) => {\n  return new CustomEvent(FOCUSOUT_PREVENTED, {\n    ...FOCUSOUT_PREVENTED_OPTS,\n    detail,\n  })\n}\n", "<template>\n  <slot :handle-keydown=\"onKeydown\" />\n</template>\n<script lang=\"ts\">\nimport {\n  defineComponent,\n  nextTick,\n  onBeforeUnmount,\n  onMounted,\n  provide,\n  ref,\n  unref,\n  watch,\n} from 'vue'\nimport { isNil } from 'lodash-unified'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { useEscapeKeydown } from '@element-plus/hooks'\nimport { isString } from '@element-plus/utils'\nimport {\n  createFocusOutPreventedEvent,\n  focusFirstDescendant,\n  focusableStack,\n  getEdges,\n  isFocusCausedByUserEvent,\n  obtainAllFocusableElements,\n  tryFocus,\n  useFocusReason,\n} from './utils'\nimport {\n  FOCUS_AFTER_RELEASED,\n  FOCUS_AFTER_TRAPPED,\n  FOCUS_AFTER_TRAPPED_OPTS,\n  FOCUS_TRAP_INJECTION_KEY,\n  ON_RELEASE_FOCUS_EVT,\n  ON_TRAP_FOCUS_EVT,\n} from './tokens'\n\nimport type { PropType } from 'vue'\nimport type { FocusLayer } from './utils'\n\nexport default defineComponent({\n  name: 'ElFocusTrap',\n  inheritAttrs: false,\n  props: {\n    loop: Boolean,\n    trapped: Boolean,\n    focusTrapEl: Object as PropType<HTMLElement>,\n    focusStartEl: {\n      type: [Object, String] as PropType<'container' | 'first' | HTMLElement>,\n      default: 'first',\n    },\n  },\n  emits: [\n    ON_TRAP_FOCUS_EVT,\n    ON_RELEASE_FOCUS_EVT,\n    'focusin',\n    'focusout',\n    'focusout-prevented',\n    'release-requested',\n  ],\n  setup(props, { emit }) {\n    const forwardRef = ref<HTMLElement | undefined>()\n    let lastFocusBeforeTrapped: HTMLElement | null\n    let lastFocusAfterTrapped: HTMLElement | null\n\n    const { focusReason } = useFocusReason()\n\n    useEscapeKeydown((event) => {\n      if (props.trapped && !focusLayer.paused) {\n        emit('release-requested', event)\n      }\n    })\n\n    const focusLayer: FocusLayer = {\n      paused: false,\n      pause() {\n        this.paused = true\n      },\n      resume() {\n        this.paused = false\n      },\n    }\n\n    const onKeydown = (e: KeyboardEvent) => {\n      if (!props.loop && !props.trapped) return\n      if (focusLayer.paused) return\n\n      const { key, altKey, ctrlKey, metaKey, currentTarget, shiftKey } = e\n      const { loop } = props\n      const isTabbing =\n        key === EVENT_CODE.tab && !altKey && !ctrlKey && !metaKey\n\n      const currentFocusingEl = document.activeElement\n      if (isTabbing && currentFocusingEl) {\n        const container = currentTarget as HTMLElement\n        const [first, last] = getEdges(container)\n        const isTabbable = first && last\n        if (!isTabbable) {\n          if (currentFocusingEl === container) {\n            const focusoutPreventedEvent = createFocusOutPreventedEvent({\n              focusReason: focusReason.value,\n            })\n            emit('focusout-prevented', focusoutPreventedEvent)\n            if (!focusoutPreventedEvent.defaultPrevented) {\n              e.preventDefault()\n            }\n          }\n        } else {\n          if (!shiftKey && currentFocusingEl === last) {\n            const focusoutPreventedEvent = createFocusOutPreventedEvent({\n              focusReason: focusReason.value,\n            })\n            emit('focusout-prevented', focusoutPreventedEvent)\n            if (!focusoutPreventedEvent.defaultPrevented) {\n              e.preventDefault()\n              if (loop) tryFocus(first, true)\n            }\n          } else if (\n            shiftKey &&\n            [first, container].includes(currentFocusingEl as HTMLElement)\n          ) {\n            const focusoutPreventedEvent = createFocusOutPreventedEvent({\n              focusReason: focusReason.value,\n            })\n            emit('focusout-prevented', focusoutPreventedEvent)\n            if (!focusoutPreventedEvent.defaultPrevented) {\n              e.preventDefault()\n              if (loop) tryFocus(last, true)\n            }\n          }\n        }\n      }\n    }\n\n    provide(FOCUS_TRAP_INJECTION_KEY, {\n      focusTrapRef: forwardRef,\n      onKeydown,\n    })\n\n    watch(\n      () => props.focusTrapEl,\n      (focusTrapEl) => {\n        if (focusTrapEl) {\n          forwardRef.value = focusTrapEl\n        }\n      },\n      { immediate: true }\n    )\n\n    watch([forwardRef], ([forwardRef], [oldForwardRef]) => {\n      if (forwardRef) {\n        forwardRef.addEventListener('keydown', onKeydown)\n        forwardRef.addEventListener('focusin', onFocusIn)\n        forwardRef.addEventListener('focusout', onFocusOut)\n      }\n      if (oldForwardRef) {\n        oldForwardRef.removeEventListener('keydown', onKeydown)\n        oldForwardRef.removeEventListener('focusin', onFocusIn)\n        oldForwardRef.removeEventListener('focusout', onFocusOut)\n      }\n    })\n\n    const trapOnFocus = (e: Event) => {\n      emit(ON_TRAP_FOCUS_EVT, e)\n    }\n    const releaseOnFocus = (e: Event) => emit(ON_RELEASE_FOCUS_EVT, e)\n\n    const onFocusIn = (e: FocusEvent) => {\n      const trapContainer = unref(forwardRef)\n      if (!trapContainer) return\n\n      const target = e.target as HTMLElement | null\n      const relatedTarget = e.relatedTarget as HTMLElement | null\n      const isFocusedInTrap = target && trapContainer.contains(target)\n\n      if (!props.trapped) {\n        const isPrevFocusedInTrap =\n          relatedTarget && trapContainer.contains(relatedTarget)\n        if (!isPrevFocusedInTrap) {\n          lastFocusBeforeTrapped = relatedTarget\n        }\n      }\n\n      if (isFocusedInTrap) emit('focusin', e)\n\n      if (focusLayer.paused) return\n\n      if (props.trapped) {\n        if (isFocusedInTrap) {\n          lastFocusAfterTrapped = target\n        } else {\n          tryFocus(lastFocusAfterTrapped, true)\n        }\n      }\n    }\n\n    const onFocusOut = (e: Event) => {\n      const trapContainer = unref(forwardRef)\n      if (focusLayer.paused || !trapContainer) return\n\n      if (props.trapped) {\n        const relatedTarget = (e as FocusEvent)\n          .relatedTarget as HTMLElement | null\n        if (!isNil(relatedTarget) && !trapContainer.contains(relatedTarget)) {\n          // Give embedded focus layer time to pause this layer before reclaiming focus\n          // And only reclaim focus if it should currently be trapping\n          setTimeout(() => {\n            if (!focusLayer.paused && props.trapped) {\n              const focusoutPreventedEvent = createFocusOutPreventedEvent({\n                focusReason: focusReason.value,\n              })\n              emit('focusout-prevented', focusoutPreventedEvent)\n              if (!focusoutPreventedEvent.defaultPrevented) {\n                tryFocus(lastFocusAfterTrapped, true)\n              }\n            }\n          }, 0)\n        }\n      } else {\n        const target = e.target as HTMLElement | null\n        const isFocusedInTrap = target && trapContainer.contains(target)\n        if (!isFocusedInTrap) emit('focusout', e)\n      }\n    }\n\n    async function startTrap() {\n      // Wait for forwardRef to resolve\n      await nextTick()\n      const trapContainer = unref(forwardRef)\n      if (trapContainer) {\n        focusableStack.push(focusLayer)\n        const prevFocusedElement = trapContainer.contains(\n          document.activeElement\n        )\n          ? lastFocusBeforeTrapped\n          : document.activeElement\n        lastFocusBeforeTrapped = prevFocusedElement as HTMLElement | null\n        const isPrevFocusContained = trapContainer.contains(prevFocusedElement)\n        if (!isPrevFocusContained) {\n          const focusEvent = new Event(\n            FOCUS_AFTER_TRAPPED,\n            FOCUS_AFTER_TRAPPED_OPTS\n          )\n          trapContainer.addEventListener(FOCUS_AFTER_TRAPPED, trapOnFocus)\n          trapContainer.dispatchEvent(focusEvent)\n          if (!focusEvent.defaultPrevented) {\n            nextTick(() => {\n              let focusStartEl = props.focusStartEl\n              if (!isString(focusStartEl)) {\n                tryFocus(focusStartEl)\n                if (document.activeElement !== focusStartEl) {\n                  focusStartEl = 'first'\n                }\n              }\n              if (focusStartEl === 'first') {\n                focusFirstDescendant(\n                  obtainAllFocusableElements(trapContainer),\n                  true\n                )\n              }\n              if (\n                document.activeElement === prevFocusedElement ||\n                focusStartEl === 'container'\n              ) {\n                tryFocus(trapContainer)\n              }\n            })\n          }\n        }\n      }\n    }\n\n    function stopTrap() {\n      const trapContainer = unref(forwardRef)\n\n      if (trapContainer) {\n        trapContainer.removeEventListener(FOCUS_AFTER_TRAPPED, trapOnFocus)\n\n        const releasedEvent = new CustomEvent(FOCUS_AFTER_RELEASED, {\n          ...FOCUS_AFTER_TRAPPED_OPTS,\n          detail: {\n            focusReason: focusReason.value,\n          },\n        })\n        trapContainer.addEventListener(FOCUS_AFTER_RELEASED, releaseOnFocus)\n        trapContainer.dispatchEvent(releasedEvent)\n        if (\n          !releasedEvent.defaultPrevented &&\n          (focusReason.value == 'keyboard' ||\n            !isFocusCausedByUserEvent() ||\n            trapContainer.contains(document.activeElement))\n        ) {\n          tryFocus(lastFocusBeforeTrapped ?? document.body)\n        }\n\n        trapContainer.removeEventListener(FOCUS_AFTER_RELEASED, releaseOnFocus)\n        focusableStack.remove(focusLayer)\n      }\n    }\n\n    onMounted(() => {\n      if (props.trapped) {\n        startTrap()\n      }\n\n      watch(\n        () => props.trapped,\n        (trapped) => {\n          if (trapped) {\n            startTrap()\n          } else {\n            stopTrap()\n          }\n        }\n      )\n    })\n\n    onBeforeUnmount(() => {\n      if (props.trapped) {\n        stopTrap()\n      }\n\n      if (forwardRef.value) {\n        forwardRef.value.removeEventListener('keydown', onKeydown)\n        forwardRef.value.removeEventListener('focusin', onFocusIn)\n        forwardRef.value.removeEventListener('focusout', onFocusOut)\n        forwardRef.value = undefined\n      }\n    })\n\n    return {\n      onKeydown,\n    }\n  },\n})\n</script>\n", "import { placements } from '@popperjs/core'\nimport { buildProps, definePropType } from '@element-plus/utils'\nimport { useAriaProps } from '@element-plus/hooks'\n\nimport type { PopperEffect } from './popper'\nimport type { ExtractPropTypes, StyleValue } from 'vue'\nimport type { Options, Placement } from '@popperjs/core'\nimport type { Measurable } from './constants'\nimport type Content from './content.vue'\n\ntype ClassObjectType = Record<string, boolean>\ntype ClassType = string | ClassObjectType | ClassType[]\n\nconst POSITIONING_STRATEGIES = ['fixed', 'absolute'] as const\n\nexport interface CreatePopperInstanceParams {\n  referenceEl: Measurable\n  popperContentEl: HTMLElement\n  arrowEl: HTMLElement | undefined\n}\n\nexport const popperCoreConfigProps = buildProps({\n  boundariesPadding: {\n    type: Number,\n    default: 0,\n  },\n  fallbackPlacements: {\n    type: definePropType<Placement[]>(Array),\n    default: undefined,\n  },\n  gpuAcceleration: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description offset of the Tooltip\n   */\n  offset: {\n    type: Number,\n    default: 12,\n  },\n  /**\n   * @description position of Tooltip\n   */\n  placement: {\n    type: String,\n    values: placements,\n    default: 'bottom',\n  },\n  /**\n   * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n   */\n  popperOptions: {\n    type: definePropType<Partial<Options>>(Object),\n    default: () => ({}),\n  },\n  strategy: {\n    type: String,\n    values: POSITIONING_STRATEGIES,\n    default: 'absolute',\n  },\n} as const)\nexport type PopperCoreConfigProps = ExtractPropTypes<\n  typeof popperCoreConfigProps\n>\n\nexport const popperContentProps = buildProps({\n  ...popperCoreConfigProps,\n  id: String,\n  style: {\n    type: definePropType<StyleValue>([String, Array, Object]),\n  },\n  className: {\n    type: definePropType<ClassType>([String, Array, Object]),\n  },\n  effect: {\n    type: definePropType<PopperEffect | string>(String),\n    default: 'dark',\n  },\n  visible: Boolean,\n  enterable: {\n    type: Boolean,\n    default: true,\n  },\n  pure: Boolean,\n  focusOnShow: {\n    type: Boolean,\n    default: false,\n  },\n  trapping: {\n    type: Boolean,\n    default: false,\n  },\n  popperClass: {\n    type: definePropType<ClassType>([String, Array, Object]),\n  },\n  popperStyle: {\n    type: definePropType<StyleValue>([String, Array, Object]),\n  },\n  referenceEl: {\n    type: definePropType<HTMLElement>(Object),\n  },\n  triggerTargetEl: {\n    type: definePropType<HTMLElement>(Object),\n  },\n  stopPopperMouseEvent: {\n    type: Boolean,\n    default: true,\n  },\n  virtualTriggering: Boolean,\n  zIndex: Number,\n  ...useAriaProps(['ariaLabel']),\n} as const)\nexport type PopperContentProps = ExtractPropTypes<typeof popperContentProps>\n\nexport const popperContentEmits = {\n  mouseenter: (evt: MouseEvent) => evt instanceof MouseEvent,\n  mouseleave: (evt: MouseEvent) => evt instanceof MouseEvent,\n  focus: () => true,\n  blur: () => true,\n  close: () => true,\n}\nexport type PopperContentEmits = typeof popperContentEmits\n\nexport type PopperContentInstance = InstanceType<typeof Content>\n\n/** @deprecated use `popperCoreConfigProps` instead, and it will be deprecated in the next major version */\nexport const usePopperCoreConfigProps = popperCoreConfigProps\n\n/** @deprecated use `popperContentProps` instead, and it will be deprecated in the next major version */\nexport const usePopperContentProps = popperContentProps\n\n/** @deprecated use `popperContentEmits` instead, and it will be deprecated in the next major version */\nexport const usePopperContentEmits = popperContentEmits\n\n/** @deprecated use `PopperCoreConfigProps` instead, and it will be deprecated in the next major version */\nexport type UsePopperCoreConfigProps = PopperCoreConfigProps\n\n/** @deprecated use `PopperContentProps` instead, and it will be deprecated in the next major version */\nexport type UsePopperContentProps = PopperContentProps\n\n/** @deprecated use `PopperContentInstance` instead, and it will be deprecated in the next major version */\nexport type ElPopperArrowContent = PopperContentInstance\n", "import { unrefElement } from '@vueuse/core'\nimport { isClient } from '@element-plus/utils'\n\nimport type { ComponentPublicInstance } from 'vue'\nimport type { MaybeRef } from '@vueuse/core'\nimport type { Modifier } from '@popperjs/core'\nimport type { Measurable } from './constants'\nimport type { PopperCoreConfigProps } from './content'\n\nexport const buildPopperOptions = (\n  props: PopperCoreConfigProps,\n  modifiers: Modifier<any, any>[] = []\n) => {\n  const { placement, strategy, popperOptions } = props\n  const options = {\n    placement,\n    strategy,\n    ...popperOptions,\n    modifiers: [...genModifiers(props), ...modifiers],\n  }\n\n  deriveExtraModifiers(options, popperOptions?.modifiers)\n  return options\n}\n\nexport const unwrapMeasurableEl = (\n  $el: MaybeRef<Measurable | undefined | ComponentPublicInstance>\n) => {\n  if (!isClient) return\n  return unrefElement($el as HTMLElement)\n}\n\nfunction genModifiers(options: PopperCoreConfigProps) {\n  const { offset, gpuAcceleration, fallbackPlacements } = options\n  return [\n    {\n      name: 'offset',\n      options: {\n        offset: [0, offset ?? 12],\n      },\n    },\n    {\n      name: 'preventOverflow',\n      options: {\n        padding: {\n          top: 2,\n          bottom: 2,\n          left: 5,\n          right: 5,\n        },\n      },\n    },\n    {\n      name: 'flip',\n      options: {\n        padding: 5,\n        fallbackPlacements,\n      },\n    },\n    {\n      name: 'computeStyles',\n      options: {\n        gpuAcceleration,\n      },\n    },\n  ]\n}\n\nfunction deriveExtraModifiers(\n  options: any,\n  modifiers: PopperCoreConfigProps['popperOptions']['modifiers']\n) {\n  if (modifiers) {\n    options.modifiers = [...options.modifiers, ...(modifiers ?? [])]\n  }\n}\n", "import { computed, inject, onMounted, ref, unref, watch } from 'vue'\nimport { isUndefined } from 'lodash-unified'\nimport { usePopper } from '@element-plus/hooks'\nimport { POPPER_INJECTION_KEY } from '../constants'\nimport { buildPopperOptions, unwrapMeasurableEl } from '../utils'\n\nimport type { Modifier } from '@popperjs/core'\nimport type { PartialOptions } from '@element-plus/hooks'\nimport type { PopperContentProps } from '../content'\n\nconst DEFAULT_ARROW_OFFSET = 0\n\nexport const usePopperContent = (props: PopperContentProps) => {\n  const { popperInstanceRef, contentRef, triggerRef, role } = inject(\n    POPPER_INJECTION_KEY,\n    undefined\n  )!\n\n  const arrowRef = ref<HTMLElement>()\n  const arrowOffset = ref<number>()\n\n  const eventListenerModifier = computed(() => {\n    return {\n      name: 'eventListeners',\n      enabled: !!props.visible,\n    } as Modifier<'eventListeners', any>\n  })\n\n  const arrowModifier = computed(() => {\n    const arrowEl = unref(arrowRef)\n    const offset = unref(arrowOffset) ?? DEFAULT_ARROW_OFFSET\n    // Seems like the `phase` and `fn` is required by Modifier type\n    // But on its documentation they didn't specify that.\n    // Refer to https://popper.js.org/docs/v2/modifiers/arrow/\n    return {\n      name: 'arrow',\n      enabled: !isUndefined(arrowEl),\n      options: {\n        element: arrowEl,\n        padding: offset,\n      },\n    } as any\n  })\n\n  const options = computed<PartialOptions>(() => {\n    return {\n      onFirstUpdate: () => {\n        update()\n      },\n      ...buildPopperOptions(props, [\n        unref(arrowModifier),\n        unref(eventListenerModifier),\n      ]),\n    }\n  })\n\n  const computedReference = computed(\n    () => unwrapMeasurableEl(props.referenceEl) || unref(triggerRef)\n  )\n\n  const { attributes, state, styles, update, forceUpdate, instanceRef } =\n    usePopper(computedReference, contentRef, options)\n\n  watch(instanceRef, (instance) => (popperInstanceRef.value = instance))\n\n  onMounted(() => {\n    watch(\n      () => unref(computedReference)?.getBoundingClientRect(),\n      () => {\n        update()\n      }\n    )\n  })\n\n  return {\n    attributes,\n    arrowRef,\n    contentRef,\n    instanceRef,\n    state,\n    styles,\n    role,\n\n    forceUpdate,\n    update,\n  }\n}\n\nexport type UsePopperContentReturn = ReturnType<typeof usePopperContent>\n", "import { computed, ref, unref } from 'vue'\nimport { useNamespace, useZIndex } from '@element-plus/hooks'\n\nimport { isNumber } from '@element-plus/utils'\nimport type { CSSProperties, StyleValue } from 'vue'\nimport type { UsePopperReturn } from '@element-plus/hooks'\nimport type { UsePopperContentReturn } from './use-content'\nimport type { PopperContentProps } from '../content'\n\nexport const usePopperContentDOM = (\n  props: PopperContentProps,\n  {\n    attributes,\n    styles,\n    role,\n  }: Pick<UsePopperReturn, 'attributes' | 'styles'> &\n    Pick<UsePopperContentReturn, 'role'>\n) => {\n  const { nextZIndex } = useZIndex()\n  const ns = useNamespace('popper')\n\n  const contentAttrs = computed(() => unref(attributes).popper)\n  const contentZIndex = ref<number>(\n    isNumber(props.zIndex) ? props.zIndex : nextZIndex()\n  )\n  const contentClass = computed(() => [\n    ns.b(),\n    ns.is('pure', props.pure),\n    ns.is(props.effect),\n    props.popperClass,\n  ])\n  const contentStyle = computed<StyleValue[]>(() => {\n    return [\n      { zIndex: unref(contentZIndex) } as CSSProperties,\n      unref(styles).popper as CSSProperties,\n      props.popperStyle || {},\n    ]\n  })\n  const ariaModal = computed<string | undefined>(() =>\n    role.value === 'dialog' ? 'false' : undefined\n  )\n  const arrowStyle = computed(\n    () => (unref(styles).arrow || {}) as CSSProperties\n  )\n\n  const updateZIndex = () => {\n    contentZIndex.value = isNumber(props.zIndex) ? props.zIndex : nextZIndex()\n  }\n\n  return {\n    ariaModal,\n    arrowStyle,\n    contentAttrs,\n    contentClass,\n    contentStyle,\n    contentZIndex,\n\n    updateZIndex,\n  }\n}\n\nexport type UsePopperContentDOMReturn = ReturnType<typeof usePopperContentDOM>\n", "import { ref } from 'vue'\n\nimport type { SetupContext } from 'vue'\nimport type { PopperContentEmits, PopperContentProps } from '../content'\n\nexport const usePopperContentFocusTrap = (\n  props: PopperContentProps,\n  emit: SetupContext<PopperContentEmits>['emit']\n) => {\n  const trapped = ref(false)\n  const focusStartRef = ref<'container' | 'first' | HTMLElement>()\n\n  const onFocusAfterTrapped = () => {\n    emit('focus')\n  }\n\n  const onFocusAfterReleased = (event: CustomEvent) => {\n    if (event.detail?.focusReason !== 'pointer') {\n      focusStartRef.value = 'first'\n      emit('blur')\n    }\n  }\n\n  const onFocusInTrap = (event: FocusEvent) => {\n    if (props.visible && !trapped.value) {\n      if (event.target) {\n        focusStartRef.value = event.target as typeof focusStartRef.value\n      }\n      trapped.value = true\n    }\n  }\n\n  const onFocusoutPrevented = (event: CustomEvent) => {\n    if (!props.trapping) {\n      if (event.detail.focusReason === 'pointer') {\n        event.preventDefault()\n      }\n      trapped.value = false\n    }\n  }\n\n  const onReleaseRequested = () => {\n    trapped.value = false\n    emit('close')\n  }\n\n  return {\n    focusStartRef,\n    trapped,\n\n    onFocusAfterReleased,\n    onFocusAfterTrapped,\n    onFocusInTrap,\n    onFocusoutPrevented,\n    onReleaseRequested,\n  }\n}\n\nexport type UsePopperContentFocusTrapReturn = ReturnType<\n  typeof usePopperContentFocusTrap\n>\n", "<template>\n  <div\n    ref=\"contentRef\"\n    v-bind=\"contentAttrs\"\n    :style=\"contentStyle\"\n    :class=\"contentClass\"\n    tabindex=\"-1\"\n    @mouseenter=\"(e) => $emit('mouseenter', e)\"\n    @mouseleave=\"(e) => $emit('mouseleave', e)\"\n  >\n    <el-focus-trap\n      :trapped=\"trapped\"\n      :trap-on-focus-in=\"true\"\n      :focus-trap-el=\"contentRef\"\n      :focus-start-el=\"focusStartRef\"\n      @focus-after-trapped=\"onFocusAfterTrapped\"\n      @focus-after-released=\"onFocusAfterReleased\"\n      @focusin=\"onFocusInTrap\"\n      @focusout-prevented=\"onFocusoutPrevented\"\n      @release-requested=\"onReleaseRequested\"\n    >\n      <slot />\n    </el-focus-trap>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  inject,\n  onBeforeUnmount,\n  onMounted,\n  provide,\n  ref,\n  unref,\n  watch,\n} from 'vue'\nimport { isNil } from 'lodash-unified'\nimport { NOOP, isElement } from '@element-plus/utils'\nimport ElFocusTrap from '@element-plus/components/focus-trap'\nimport { formItemContextKey } from '@element-plus/components/form'\nimport { POPPER_CONTENT_INJECTION_KEY } from './constants'\nimport { popperContentEmits, popperContentProps } from './content'\nimport {\n  usePopperContent,\n  usePopperContentDOM,\n  usePopperContentFocusTrap,\n} from './composables'\n\nimport type { WatchStopHandle } from 'vue'\n\ndefineOptions({\n  name: 'ElPopperContent',\n})\n\nconst emit = defineEmits(popperContentEmits)\n\nconst props = defineProps(popperContentProps)\n\nconst {\n  focusStartRef,\n  trapped,\n\n  onFocusAfterReleased,\n  onFocusAfterTrapped,\n  onFocusInTrap,\n  onFocusoutPrevented,\n  onReleaseRequested,\n} = usePopperContentFocusTrap(props, emit)\n\nconst { attributes, arrowRef, contentRef, styles, instanceRef, role, update } =\n  usePopperContent(props)\n\nconst {\n  ariaModal,\n  arrowStyle,\n  contentAttrs,\n  contentClass,\n  contentStyle,\n  updateZIndex,\n} = usePopperContentDOM(props, {\n  styles,\n  attributes,\n  role,\n})\n\nconst formItemContext = inject(formItemContextKey, undefined)\nconst arrowOffset = ref<number>()\n\nprovide(POPPER_CONTENT_INJECTION_KEY, {\n  arrowStyle,\n  arrowRef,\n  arrowOffset,\n})\n\nif (formItemContext) {\n  // disallow auto-id from inside popper content\n  provide(formItemContextKey, {\n    ...formItemContext,\n    addInputId: NOOP,\n    removeInputId: NOOP,\n  })\n}\n\nlet triggerTargetAriaStopWatch: WatchStopHandle | undefined = undefined\n\nconst updatePopper = (shouldUpdateZIndex = true) => {\n  update()\n  shouldUpdateZIndex && updateZIndex()\n}\n\nconst togglePopperAlive = () => {\n  updatePopper(false)\n  if (props.visible && props.focusOnShow) {\n    trapped.value = true\n  } else if (props.visible === false) {\n    trapped.value = false\n  }\n}\n\nonMounted(() => {\n  watch(\n    () => props.triggerTargetEl,\n    (triggerTargetEl, prevTriggerTargetEl) => {\n      triggerTargetAriaStopWatch?.()\n      triggerTargetAriaStopWatch = undefined\n\n      const el = unref(triggerTargetEl || contentRef.value)\n      const prevEl = unref(prevTriggerTargetEl || contentRef.value)\n\n      if (isElement(el)) {\n        triggerTargetAriaStopWatch = watch(\n          [role, () => props.ariaLabel, ariaModal, () => props.id],\n          (watches) => {\n            ;['role', 'aria-label', 'aria-modal', 'id'].forEach((key, idx) => {\n              isNil(watches[idx])\n                ? el.removeAttribute(key)\n                : el.setAttribute(key, watches[idx]!)\n            })\n          },\n          { immediate: true }\n        )\n      }\n      if (prevEl !== el && isElement(prevEl)) {\n        ;['role', 'aria-label', 'aria-modal', 'id'].forEach((key) => {\n          prevEl.removeAttribute(key)\n        })\n      }\n    },\n    { immediate: true }\n  )\n\n  watch(() => props.visible, togglePopperAlive, { immediate: true })\n})\n\nonBeforeUnmount(() => {\n  triggerTargetAriaStopWatch?.()\n  triggerTargetAriaStopWatch = undefined\n})\n\ndefineExpose({\n  /**\n   * @description popper content element\n   */\n  popperContentRef: contentRef,\n  /**\n   * @description popperjs instance\n   */\n  popperInstanceRef: instanceRef,\n  /**\n   * @description method for updating popper\n   */\n  updatePopper,\n\n  /**\n   * @description content style\n   */\n  contentStyle,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Popper from './src/popper.vue'\n\nimport ElPopperArrow from './src/arrow.vue'\nimport ElPopperTrigger from './src/trigger.vue'\nimport ElPopperContent from './src/content.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport { ElPopperArrow, ElPopperTrigger, ElPopperContent }\n\nexport const ElPopper: SFCWithInstall<typeof Popper> = withInstall(Popper)\nexport default ElPopper\n\nexport * from './src/popper'\nexport * from './src/trigger'\nexport * from './src/content'\nexport * from './src/arrow'\nexport * from './src/constants'\n\nexport type { Placement, Options } from '@popperjs/core'\n", "import type { Arrayable } from '@element-plus/utils'\nimport type { InjectionKey, Ref } from 'vue'\nimport type { TooltipTriggerType } from './trigger'\n\nexport type ElTooltipInjectionContext = {\n  controlled: Ref<boolean>\n  id: Ref<string>\n  open: Ref<boolean>\n  trigger: Ref<Arrayable<TooltipTriggerType>>\n  onOpen: (e?: Event) => void\n  onClose: (e?: Event) => void\n  onToggle: (e: Event) => void\n  onShow: () => void\n  onHide: () => void\n  onBeforeShow: () => void\n  onBeforeHide: () => void\n  updatePopper: () => void\n}\n\nexport const TOOLTIP_INJECTION_KEY: InjectionKey<ElTooltipInjectionContext> =\n  Symbol('elTooltip')\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { popperContentProps } from '@element-plus/components/popper'\nimport { useAriaProps, useDelayedToggleProps } from '@element-plus/hooks'\n\nimport type TooltipContent from './content.vue'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const useTooltipContentProps = buildProps({\n  ...useDelayedToggleProps,\n  ...popperContentProps,\n  /**\n   * @description which element the tooltip CONTENT appends to\n   */\n  appendTo: {\n    type: definePropType<string | HTMLElement>([String, Object]),\n  },\n  /**\n   * @description display content, can be overridden by `slot#content`\n   */\n  content: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description whether `content` is treated as HTML string\n   */\n  rawContent: Boolean,\n  /**\n   * @description when tooltip inactive and `persistent` is `false` , popconfirm will be destroyed\n   */\n  persistent: Boolean,\n  // because model toggle prop is generated dynamically\n  // so the typing cannot be evaluated by typescript as type:\n  // [name]: { type: Boolean, default: null }\n  // so we need to declare that again for type checking.\n  /**\n   * @description visibility of Tooltip\n   */\n  visible: {\n    type: definePropType<boolean | null>(Boolean),\n    default: null,\n  },\n  /**\n   * @description animation name\n   */\n  transition: String,\n  /**\n   * @description whether tooltip content is teleported, if `true` it will be teleported to where `append-to` sets\n   */\n  teleported: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether Tooltip is disabled\n   */\n  disabled: Boolean,\n  ...useAriaProps(['ariaLabel']),\n} as const)\n\nexport type ElTooltipContentProps = ExtractPropTypes<\n  typeof useTooltipContentProps\n>\n\nexport type TooltipContentInstance = InstanceType<typeof TooltipContent>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { popperTriggerProps } from '@element-plus/components/popper'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport type { Arrayable } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\n\nexport type TooltipTriggerType = 'hover' | 'focus' | 'click' | 'contextmenu'\n\nexport const useTooltipTriggerProps = buildProps({\n  ...popperTriggerProps,\n  /**\n   * @description whether Tooltip is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description How should the tooltip be triggered (to show)\n   */\n  trigger: {\n    type: definePropType<Arrayable<TooltipTriggerType>>([String, Array]),\n    default: 'hover',\n  },\n  /**\n   * @description When you click the mouse to focus on the trigger element, you can define a set of keyboard codes to control the display of tooltip through the keyboard\n   */\n  triggerKeys: {\n    type: definePropType<string[]>(Array),\n    default: () => [EVENT_CODE.enter, EVENT_CODE.space],\n  },\n} as const)\n\nexport type ElTooltipTriggerProps = ExtractPropTypes<\n  typeof useTooltipTriggerProps\n>\n", "import { buildProps } from '@element-plus/utils'\nimport { createModelToggleComposable } from '@element-plus/hooks'\nimport { popperArrowProps, popperProps } from '@element-plus/components/popper'\nimport { useTooltipContentProps } from './content'\nimport { useTooltipTriggerProps } from './trigger'\nimport type Tooltip from './tooltip.vue'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const {\n  useModelToggleProps: useTooltipModelToggleProps,\n  useModelToggleEmits: useTooltipModelToggleEmits,\n  useModelToggle: useTooltipModelToggle,\n} = createModelToggleComposable('visible' as const)\n\nexport const useTooltipProps = buildProps({\n  ...popperProps,\n  ...useTooltipModelToggleProps,\n  ...useTooltipContentProps,\n  ...useTooltipTriggerProps,\n  ...popperArrowProps,\n  /**\n   * @description whether the tooltip content has an arrow\n   */\n  showArrow: {\n    type: Boolean,\n    default: true,\n  },\n})\n\nexport const tooltipEmits = [\n  ...useTooltipModelToggleEmits,\n  'before-show',\n  'before-hide',\n  'show',\n  'hide',\n  'open',\n  'close',\n]\n\nexport type ElTooltipProps = ExtractPropTypes<typeof useTooltipProps>\n\nexport type TooltipInstance = InstanceType<typeof Tooltip>\n", "import { unref } from 'vue'\nimport { isArray } from '@element-plus/utils'\nimport type { Arrayable } from '@element-plus/utils'\nimport type { Ref } from 'vue'\nimport type { TooltipTriggerType } from './trigger'\n\nexport const isTriggerType = (\n  trigger: Arrayable<TooltipTriggerType>,\n  type: TooltipTriggerType\n) => {\n  if (isArray(trigger)) {\n    return trigger.includes(type)\n  }\n  return trigger === type\n}\n\nexport const whenTrigger = (\n  trigger: Ref<Arrayable<TooltipTriggerType>>,\n  type: TooltipTriggerType,\n  handler: (e: Event) => void\n) => {\n  return (e: Event) => {\n    isTriggerType(unref(trigger), type) && handler(e)\n  }\n}\n", "<template>\n  <el-popper-trigger\n    :id=\"id\"\n    :virtual-ref=\"virtualRef\"\n    :open=\"open\"\n    :virtual-triggering=\"virtualTriggering\"\n    :class=\"ns.e('trigger')\"\n    @blur=\"onBlur\"\n    @click=\"onClick\"\n    @contextmenu=\"onContextMenu\"\n    @focus=\"onFocus\"\n    @mouseenter=\"onMouseenter\"\n    @mouseleave=\"onMouseleave\"\n    @keydown=\"onKeydown\"\n  >\n    <slot />\n  </el-popper-trigger>\n</template>\n<script lang=\"ts\" setup>\nimport { inject, ref, toRef, unref } from 'vue'\nimport { ElPopperTrigger } from '@element-plus/components/popper'\nimport { composeEventHandlers } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { TOOLTIP_INJECTION_KEY } from './constants'\nimport { useTooltipTriggerProps } from './trigger'\nimport { whenTrigger } from './utils'\nimport type { OnlyChildExpose } from '@element-plus/components/slot'\n\ndefineOptions({\n  name: 'ElTooltipTrigger',\n})\n\nconst props = defineProps(useTooltipTriggerProps)\n\nconst ns = useNamespace('tooltip')\nconst { controlled, id, open, onOpen, onClose, onToggle } = inject(\n  TOOLTIP_INJECTION_KEY,\n  undefined\n)!\n\nconst triggerRef = ref<OnlyChildExpose | null>(null)\n\nconst stopWhenControlledOrDisabled = () => {\n  if (unref(controlled) || props.disabled) {\n    return true\n  }\n}\nconst trigger = toRef(props, 'trigger')\nconst onMouseenter = composeEventHandlers(\n  stopWhenControlledOrDisabled,\n  whenTrigger(trigger, 'hover', onOpen)\n)\nconst onMouseleave = composeEventHandlers(\n  stopWhenControlledOrDisabled,\n  whenTrigger(trigger, 'hover', onClose)\n)\nconst onClick = composeEventHandlers(\n  stopWhenControlledOrDisabled,\n  whenTrigger(trigger, 'click', (e) => {\n    // distinguish left click\n    if ((e as MouseEvent).button === 0) {\n      onToggle(e)\n    }\n  })\n)\n\nconst onFocus = composeEventHandlers(\n  stopWhenControlledOrDisabled,\n  whenTrigger(trigger, 'focus', onOpen)\n)\n\nconst onBlur = composeEventHandlers(\n  stopWhenControlledOrDisabled,\n  whenTrigger(trigger, 'focus', onClose)\n)\n\nconst onContextMenu = composeEventHandlers(\n  stopWhenControlledOrDisabled,\n  whenTrigger(trigger, 'contextmenu', (e: Event) => {\n    e.preventDefault()\n    onToggle(e)\n  })\n)\n\nconst onKeydown = composeEventHandlers(\n  stopWhenControlledOrDisabled,\n  (e: KeyboardEvent) => {\n    const { code } = e\n    if (props.triggerKeys.includes(code)) {\n      e.preventDefault()\n      onToggle(e)\n    }\n  }\n)\n\ndefineExpose({\n  /**\n   * @description trigger element\n   */\n  triggerRef,\n})\n</script>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Teleport from './teleport.vue'\n\nexport const teleportProps = buildProps({\n  to: {\n    type: definePropType<string | HTMLElement>([String, Object]),\n    required: true,\n  },\n  disabled: Boolean,\n} as const)\n\nexport type TeleportProps = ExtractPropTypes<typeof teleportProps>\nexport type TeleportInstance = InstanceType<typeof Teleport>\n", "import { defineComponent, renderSlot, openBlock, createBlock, Teleport as Teleport$1 } from 'vue';\nimport { teleportProps } from './teleport2.mjs';\nimport _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n  __name: \"teleport\",\n  props: teleportProps,\n  setup(__props) {\n    return (_ctx, _cache) => {\n      return _ctx.disabled ? renderSlot(_ctx.$slots, \"default\", { key: 0 }) : (openBlock(), createBlock(Teleport$1, {\n        key: 1,\n        to: _ctx.to\n      }, [\n        renderSlot(_ctx.$slots, \"default\")\n      ], 8, [\"to\"]));\n    };\n  }\n});\nvar Teleport = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__file\", \"teleport.vue\"]]);\n\nexport { Teleport as default };\n//# sourceMappingURL=teleport.mjs.map\n", "import { withInstall } from '@element-plus/utils'\nimport Teleport from './src/teleport.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTeleport: SFCWithInstall<typeof Teleport> = withInstall(Teleport)\n\nexport default ElTeleport\n\nexport * from './src/teleport'\n", "<template>\n  <el-teleport :disabled=\"!teleported\" :to=\"appendTo\">\n    <transition\n      :name=\"transitionClass\"\n      @after-leave=\"onTransitionLeave\"\n      @before-enter=\"onBeforeEnter\"\n      @after-enter=\"onAfterShow\"\n      @before-leave=\"onBeforeLeave\"\n    >\n      <el-popper-content\n        v-if=\"shouldRender\"\n        v-show=\"shouldShow\"\n        :id=\"id\"\n        ref=\"contentRef\"\n        v-bind=\"$attrs\"\n        :aria-label=\"ariaLabel\"\n        :aria-hidden=\"ariaHidden\"\n        :boundaries-padding=\"boundariesPadding\"\n        :fallback-placements=\"fallbackPlacements\"\n        :gpu-acceleration=\"gpuAcceleration\"\n        :offset=\"offset\"\n        :placement=\"placement\"\n        :popper-options=\"popperOptions\"\n        :strategy=\"strategy\"\n        :effect=\"effect\"\n        :enterable=\"enterable\"\n        :pure=\"pure\"\n        :popper-class=\"popperClass\"\n        :popper-style=\"[popperStyle, contentStyle]\"\n        :reference-el=\"referenceEl\"\n        :trigger-target-el=\"triggerTargetEl\"\n        :visible=\"shouldShow\"\n        :z-index=\"zIndex\"\n        @mouseenter=\"onContentEnter\"\n        @mouseleave=\"onContentLeave\"\n        @blur=\"onBlur\"\n        @close=\"onClose\"\n      >\n        <slot />\n      </el-popper-content>\n    </transition>\n  </el-teleport>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, onBeforeUnmount, ref, unref, watch } from 'vue'\nimport { onClickOutside } from '@vueuse/core'\nimport { useNamespace, usePopperContainerId } from '@element-plus/hooks'\nimport { composeEventHandlers } from '@element-plus/utils'\nimport { ElPopperContent } from '@element-plus/components/popper'\nimport ElTeleport from '@element-plus/components/teleport'\nimport { TOOLTIP_INJECTION_KEY } from './constants'\nimport { useTooltipContentProps } from './content'\n\ndefineOptions({\n  name: 'ElTooltipContent',\n  inheritAttrs: false,\n})\n\nconst props = defineProps(useTooltipContentProps)\n\nconst { selector } = usePopperContainerId()\nconst ns = useNamespace('tooltip')\n// TODO any is temporary, replace with `InstanceType<typeof ElPopperContent> | null` later\nconst contentRef = ref<any>(null)\nlet stopHandle: ReturnType<typeof onClickOutside>\nconst {\n  controlled,\n  id,\n  open,\n  trigger,\n  onClose,\n  onOpen,\n  onShow,\n  onHide,\n  onBeforeShow,\n  onBeforeHide,\n} = inject(TOOLTIP_INJECTION_KEY, undefined)!\nconst transitionClass = computed(() => {\n  return props.transition || `${ns.namespace.value}-fade-in-linear`\n})\nconst persistentRef = computed(() => {\n  // For testing, we would always want the content to be rendered\n  // to the DOM, so we need to return true here.\n  if (process.env.NODE_ENV === 'test') {\n    return true\n  }\n  return props.persistent\n})\n\nonBeforeUnmount(() => {\n  stopHandle?.()\n})\n\nconst shouldRender = computed(() => {\n  return unref(persistentRef) ? true : unref(open)\n})\n\nconst shouldShow = computed(() => {\n  return props.disabled ? false : unref(open)\n})\n\nconst appendTo = computed(() => {\n  return props.appendTo || selector.value\n})\n\nconst contentStyle = computed(() => (props.style ?? {}) as any)\n\nconst ariaHidden = ref(true)\n\nconst onTransitionLeave = () => {\n  onHide()\n  ariaHidden.value = true\n}\n\nconst stopWhenControlled = () => {\n  if (unref(controlled)) return true\n}\n\nconst onContentEnter = composeEventHandlers(stopWhenControlled, () => {\n  if (props.enterable && unref(trigger) === 'hover') {\n    onOpen()\n  }\n})\n\nconst onContentLeave = composeEventHandlers(stopWhenControlled, () => {\n  if (unref(trigger) === 'hover') {\n    onClose()\n  }\n})\n\nconst onBeforeEnter = () => {\n  contentRef.value?.updatePopper?.()\n  onBeforeShow?.()\n}\n\nconst onBeforeLeave = () => {\n  onBeforeHide?.()\n}\n\nconst onAfterShow = () => {\n  onShow()\n  stopHandle = onClickOutside(\n    computed(() => {\n      return contentRef.value?.popperContentRef\n    }),\n    () => {\n      if (unref(controlled)) return\n      const $trigger = unref(trigger)\n      if ($trigger !== 'hover') {\n        onClose()\n      }\n    }\n  )\n}\n\nconst onBlur = () => {\n  if (!props.virtualTriggering) {\n    onClose()\n  }\n}\n\nwatch(\n  () => unref(open),\n  (val) => {\n    if (!val) {\n      stopHandle?.()\n    } else {\n      ariaHidden.value = false\n    }\n  },\n  {\n    flush: 'post',\n  }\n)\n\nwatch(\n  () => props.content,\n  () => {\n    contentRef.value?.updatePopper?.()\n  }\n)\n\ndefineExpose({\n  /**\n   * @description el-popper-content component instance\n   */\n  contentRef,\n})\n</script>\n", "<template>\n  <el-popper ref=\"popperRef\" :role=\"role\">\n    <el-tooltip-trigger\n      :disabled=\"disabled\"\n      :trigger=\"trigger\"\n      :trigger-keys=\"triggerKeys\"\n      :virtual-ref=\"virtualRef\"\n      :virtual-triggering=\"virtualTriggering\"\n    >\n      <slot v-if=\"$slots.default\" />\n    </el-tooltip-trigger>\n    <el-tooltip-content\n      ref=\"contentRef\"\n      :aria-label=\"ariaLabel\"\n      :boundaries-padding=\"boundariesPadding\"\n      :content=\"content\"\n      :disabled=\"disabled\"\n      :effect=\"effect\"\n      :enterable=\"enterable\"\n      :fallback-placements=\"fallbackPlacements\"\n      :hide-after=\"hideAfter\"\n      :gpu-acceleration=\"gpuAcceleration\"\n      :offset=\"offset\"\n      :persistent=\"persistent\"\n      :popper-class=\"popperClass\"\n      :popper-style=\"popperStyle\"\n      :placement=\"placement\"\n      :popper-options=\"popperOptions\"\n      :pure=\"pure\"\n      :raw-content=\"rawContent\"\n      :reference-el=\"referenceEl\"\n      :trigger-target-el=\"triggerTargetEl\"\n      :show-after=\"showAfter\"\n      :strategy=\"strategy\"\n      :teleported=\"teleported\"\n      :transition=\"transition\"\n      :virtual-triggering=\"virtualTriggering\"\n      :z-index=\"zIndex\"\n      :append-to=\"appendTo\"\n    >\n      <slot name=\"content\">\n        <span v-if=\"rawContent\" v-html=\"content\" />\n        <span v-else>{{ content }}</span>\n      </slot>\n      <el-popper-arrow v-if=\"showArrow\" :arrow-offset=\"arrowOffset\" />\n    </el-tooltip-content>\n  </el-popper>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  onDeactivated,\n  provide,\n  readonly,\n  ref,\n  toRef,\n  unref,\n  watch,\n} from 'vue'\nimport { ElPopper, ElPopperArrow } from '@element-plus/components/popper'\n\nimport { isBoolean } from '@element-plus/utils'\nimport {\n  useDelayedToggle,\n  useId,\n  usePopperContainer,\n} from '@element-plus/hooks'\nimport { TOOLTIP_INJECTION_KEY } from './constants'\nimport { tooltipEmits, useTooltipModelToggle, useTooltipProps } from './tooltip'\nimport ElTooltipTrigger from './trigger.vue'\nimport ElTooltipContent from './content.vue'\nimport type { PopperInstance } from '@element-plus/components/popper'\n\ndefineOptions({\n  name: 'ElTooltip',\n})\n\nconst props = defineProps(useTooltipProps)\nconst emit = defineEmits(tooltipEmits)\n\nusePopperContainer()\n\nconst id = useId()\nconst popperRef = ref<PopperInstance>()\n// TODO any is temporary, replace with `TooltipContentInstance` later\nconst contentRef = ref<any>()\n\nconst updatePopper = () => {\n  const popperComponent = unref(popperRef)\n  if (popperComponent) {\n    popperComponent.popperInstanceRef?.update()\n  }\n}\nconst open = ref(false)\nconst toggleReason = ref<Event>()\n\nconst { show, hide, hasUpdateHandler } = useTooltipModelToggle({\n  indicator: open,\n  toggleReason,\n})\n\nconst { onOpen, onClose } = useDelayedToggle({\n  showAfter: toRef(props, 'showAfter'),\n  hideAfter: toRef(props, 'hideAfter'),\n  autoClose: toRef(props, 'autoClose'),\n  open: show,\n  close: hide,\n})\n\nconst controlled = computed(\n  () => isBoolean(props.visible) && !hasUpdateHandler.value\n)\n\nprovide(TOOLTIP_INJECTION_KEY, {\n  controlled,\n  id,\n  open: readonly(open),\n  trigger: toRef(props, 'trigger'),\n  onOpen: (event?: Event) => {\n    onOpen(event)\n  },\n  onClose: (event?: Event) => {\n    onClose(event)\n  },\n  onToggle: (event?: Event) => {\n    if (unref(open)) {\n      onClose(event)\n    } else {\n      onOpen(event)\n    }\n  },\n  onShow: () => {\n    emit('show', toggleReason.value)\n  },\n  onHide: () => {\n    emit('hide', toggleReason.value)\n  },\n  onBeforeShow: () => {\n    emit('before-show', toggleReason.value)\n  },\n  onBeforeHide: () => {\n    emit('before-hide', toggleReason.value)\n  },\n  updatePopper,\n})\n\nwatch(\n  () => props.disabled,\n  (disabled) => {\n    if (disabled && open.value) {\n      open.value = false\n    }\n  }\n)\n\nconst isFocusInsideContent = (event?: FocusEvent) => {\n  const popperContent: HTMLElement | undefined =\n    contentRef.value?.contentRef?.popperContentRef\n  const activeElement = (event?.relatedTarget as Node) || document.activeElement\n\n  return popperContent && popperContent.contains(activeElement)\n}\n\nonDeactivated(() => open.value && hide())\n\ndefineExpose({\n  /**\n   * @description el-popper component instance\n   */\n  popperRef,\n  /**\n   * @description el-tooltip-content component instance\n   */\n  contentRef,\n  /**\n   * @description validate current focus event is trigger inside el-tooltip-content\n   */\n  isFocusInsideContent,\n  /**\n   * @description update el-popper component instance\n   */\n  updatePopper,\n  /**\n   * @description expose onOpen function to mange el-tooltip open state\n   */\n  onOpen,\n  /**\n   * @description expose onOpen function to mange el-tooltip open state\n   */\n  onClose,\n  /**\n   * @description expose hide function\n   */\n  hide,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Tooltip from './src/tooltip.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTooltip: SFCWithInstall<typeof Tooltip> = withInstall(Tooltip)\nexport * from './src/tooltip'\nexport * from './src/trigger'\nexport * from './src/content'\nexport * from './src/constants'\nexport default ElTooltip\n", "import {\n  NOOP,\n  buildProps,\n  definePropType,\n  isObject,\n  isString,\n} from '@element-plus/utils'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport { useAriaProps } from '@element-plus/hooks'\nimport {\n  CHANGE_EVENT,\n  INPUT_EVENT,\n  UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Autocomplete from './autocomplete.vue'\nimport type { Placement } from '@element-plus/components/popper'\nimport type { Awaitable } from '@element-plus/utils'\n\nexport type AutocompleteData = Record<string, any>[]\nexport type AutocompleteFetchSuggestionsCallback = (\n  data: AutocompleteData\n) => void\nexport type AutocompleteFetchSuggestions =\n  | ((\n      queryString: string,\n      cb: AutocompleteFetchSuggestionsCallback\n    ) => Awaitable<AutocompleteData> | void)\n  | AutocompleteData\n\nexport const autocompleteProps = buildProps({\n  /**\n   * @description key name of the input suggestion object for display\n   */\n  valueKey: {\n    type: String,\n    default: 'value',\n  },\n  /**\n   * @description binding value\n   */\n  modelValue: {\n    type: [String, Number],\n    default: '',\n  },\n  /**\n   * @description debounce delay when typing, in milliseconds\n   */\n  debounce: {\n    type: Number,\n    default: 300,\n  },\n  /**\n   * @description placement of the popup menu\n   */\n  placement: {\n    type: definePropType<Placement>(String),\n    values: [\n      'top',\n      'top-start',\n      'top-end',\n      'bottom',\n      'bottom-start',\n      'bottom-end',\n    ],\n    default: 'bottom-start',\n  },\n  /**\n   * @description a method to fetch input suggestions. When suggestions are ready, invoke `callback(data:[])` to return them to Autocomplete\n   */\n  fetchSuggestions: {\n    type: definePropType<AutocompleteFetchSuggestions>([Function, Array]),\n    default: NOOP,\n  },\n  /**\n   * @description custom class name for autocomplete's dropdown\n   */\n  popperClass: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description whether show suggestions when input focus\n   */\n  triggerOnFocus: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether to emit a `select` event on enter when there is no autocomplete match\n   */\n  selectWhenUnmatched: {\n    type: Boolean,\n    default: false,\n  },\n  /**\n   * @description whether to hide the loading icon in remote search\n   */\n  hideLoading: {\n    type: Boolean,\n    default: false,\n  },\n  teleported: useTooltipContentProps.teleported,\n  /**\n   * @description whether to highlight first item in remote search suggestions by default\n   */\n  highlightFirstItem: {\n    type: Boolean,\n    default: false,\n  },\n  /**\n   * @description whether the width of the dropdown is the same as the input\n   */\n  fitInputWidth: {\n    type: Boolean,\n    default: false,\n  },\n  /**\n   * @description whether to show clear button\n   */\n  clearable: {\n    type: Boolean,\n    default: false,\n  },\n  /**\n   * @description whether to disable\n   */\n  disabled: {\n    type: Boolean,\n    default: false,\n  },\n  /**\n   * @description same as `name` in native input\n   */\n  name: String,\n  ...useAriaProps(['ariaLabel']),\n} as const)\nexport type AutocompleteProps = ExtractPropTypes<typeof autocompleteProps>\n\nexport const autocompleteEmits = {\n  [UPDATE_MODEL_EVENT]: (value: string) => isString(value),\n  [INPUT_EVENT]: (value: string) => isString(value),\n  [CHANGE_EVENT]: (value: string) => isString(value),\n  focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n  blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n  clear: () => true,\n  select: (item: Record<string, any>) => isObject(item),\n}\nexport type AutocompleteEmits = typeof autocompleteEmits\n\nexport type AutocompleteInstance = InstanceType<typeof Autocomplete>\n", "<template>\n  <el-tooltip\n    ref=\"popperRef\"\n    :visible=\"suggestionVisible\"\n    :placement=\"placement\"\n    :fallback-placements=\"['bottom-start', 'top-start']\"\n    :popper-class=\"[ns.e('popper'), popperClass]\"\n    :teleported=\"teleported\"\n    :gpu-acceleration=\"false\"\n    pure\n    manual-mode\n    effect=\"light\"\n    trigger=\"click\"\n    :transition=\"`${ns.namespace.value}-zoom-in-top`\"\n    persistent\n    role=\"listbox\"\n    @before-show=\"onSuggestionShow\"\n    @hide=\"onHide\"\n  >\n    <div\n      ref=\"listboxRef\"\n      :class=\"[ns.b(), $attrs.class]\"\n      :style=\"styles\"\n      role=\"combobox\"\n      aria-haspopup=\"listbox\"\n      :aria-expanded=\"suggestionVisible\"\n      :aria-owns=\"listboxId\"\n    >\n      <el-input\n        ref=\"inputRef\"\n        v-bind=\"attrs\"\n        :clearable=\"clearable\"\n        :disabled=\"disabled\"\n        :name=\"name\"\n        :model-value=\"modelValue\"\n        :aria-label=\"ariaLabel\"\n        @input=\"handleInput\"\n        @change=\"handleChange\"\n        @focus=\"handleFocus\"\n        @blur=\"handleBlur\"\n        @clear=\"handleClear\"\n        @keydown.up.prevent=\"highlight(highlightedIndex - 1)\"\n        @keydown.down.prevent=\"highlight(highlightedIndex + 1)\"\n        @keydown.enter=\"handleKeyEnter\"\n        @keydown.tab=\"close\"\n        @keydown.esc=\"handleKeyEscape\"\n        @mousedown=\"handleMouseDown\"\n      >\n        <template v-if=\"$slots.prepend\" #prepend>\n          <slot name=\"prepend\" />\n        </template>\n        <template v-if=\"$slots.append\" #append>\n          <slot name=\"append\" />\n        </template>\n        <template v-if=\"$slots.prefix\" #prefix>\n          <slot name=\"prefix\" />\n        </template>\n        <template v-if=\"$slots.suffix\" #suffix>\n          <slot name=\"suffix\" />\n        </template>\n      </el-input>\n    </div>\n    <template #content>\n      <div\n        ref=\"regionRef\"\n        :class=\"[ns.b('suggestion'), ns.is('loading', suggestionLoading)]\"\n        :style=\"{\n          [fitInputWidth ? 'width' : 'minWidth']: dropdownWidth,\n          outline: 'none',\n        }\"\n        role=\"region\"\n      >\n        <el-scrollbar\n          :id=\"listboxId\"\n          tag=\"ul\"\n          :wrap-class=\"ns.be('suggestion', 'wrap')\"\n          :view-class=\"ns.be('suggestion', 'list')\"\n          role=\"listbox\"\n        >\n          <li v-if=\"suggestionLoading\">\n            <slot name=\"loading\">\n              <el-icon :class=\"ns.is('loading')\">\n                <Loading />\n              </el-icon>\n            </slot>\n          </li>\n          <template v-else>\n            <li\n              v-for=\"(item, index) in suggestions\"\n              :id=\"`${listboxId}-item-${index}`\"\n              :key=\"index\"\n              :class=\"{ highlighted: highlightedIndex === index }\"\n              role=\"option\"\n              :aria-selected=\"highlightedIndex === index\"\n              @click=\"handleSelect(item)\"\n            >\n              <slot :item=\"item\">{{ item[valueKey] }}</slot>\n            </li>\n          </template>\n        </el-scrollbar>\n      </div>\n    </template>\n  </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  onBeforeUnmount,\n  onMounted,\n  ref,\n  useAttrs as useRawAttrs,\n} from 'vue'\nimport { debounce } from 'lodash-unified'\nimport { onClickOutside } from '@vueuse/core'\nimport { Loading } from '@element-plus/icons-vue'\nimport { useAttrs, useId, useNamespace } from '@element-plus/hooks'\nimport { isArray, throwError } from '@element-plus/utils'\nimport {\n  CHANGE_EVENT,\n  INPUT_EVENT,\n  UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport ElInput from '@element-plus/components/input'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElIcon from '@element-plus/components/icon'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport { autocompleteEmits, autocompleteProps } from './autocomplete'\nimport type { AutocompleteData } from './autocomplete'\n\nimport type { StyleValue } from 'vue'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { InputInstance } from '@element-plus/components/input'\n\nconst COMPONENT_NAME = 'ElAutocomplete'\ndefineOptions({\n  name: COMPONENT_NAME,\n  inheritAttrs: false,\n})\n\nconst props = defineProps(autocompleteProps)\nconst emit = defineEmits(autocompleteEmits)\n\nconst attrs = useAttrs()\nconst rawAttrs = useRawAttrs()\nconst disabled = useFormDisabled()\nconst ns = useNamespace('autocomplete')\n\nconst inputRef = ref<InputInstance>()\nconst regionRef = ref<HTMLElement>()\nconst popperRef = ref<TooltipInstance>()\nconst listboxRef = ref<HTMLElement>()\n\nlet readonly = false\nlet ignoreFocusEvent = false\nconst suggestions = ref<AutocompleteData>([])\nconst highlightedIndex = ref(-1)\nconst dropdownWidth = ref('')\nconst activated = ref(false)\nconst suggestionDisabled = ref(false)\nconst loading = ref(false)\n\nconst listboxId = useId()\nconst styles = computed(() => rawAttrs.style as StyleValue)\n\nconst suggestionVisible = computed(() => {\n  const isValidData = suggestions.value.length > 0\n  return (isValidData || loading.value) && activated.value\n})\n\nconst suggestionLoading = computed(() => !props.hideLoading && loading.value)\n\nconst refInput = computed<HTMLInputElement[]>(() => {\n  if (inputRef.value) {\n    return Array.from<HTMLInputElement>(\n      inputRef.value.$el.querySelectorAll('input')\n    )\n  }\n  return []\n})\n\nconst onSuggestionShow = () => {\n  if (suggestionVisible.value) {\n    dropdownWidth.value = `${inputRef.value!.$el.offsetWidth}px`\n  }\n}\n\nconst onHide = () => {\n  highlightedIndex.value = -1\n}\n\nconst getData = async (queryString: string) => {\n  if (suggestionDisabled.value) return\n\n  const cb = (suggestionList: AutocompleteData) => {\n    loading.value = false\n    if (suggestionDisabled.value) return\n\n    if (isArray(suggestionList)) {\n      suggestions.value = suggestionList\n      highlightedIndex.value = props.highlightFirstItem ? 0 : -1\n    } else {\n      throwError(COMPONENT_NAME, 'autocomplete suggestions must be an array')\n    }\n  }\n\n  loading.value = true\n  if (isArray(props.fetchSuggestions)) {\n    cb(props.fetchSuggestions)\n  } else {\n    const result = await props.fetchSuggestions(queryString, cb)\n    if (isArray(result)) cb(result)\n  }\n}\nconst debouncedGetData = debounce(getData, props.debounce)\n\nconst handleInput = (value: string) => {\n  const valuePresented = !!value\n\n  emit(INPUT_EVENT, value)\n  emit(UPDATE_MODEL_EVENT, value)\n\n  suggestionDisabled.value = false\n  activated.value ||= valuePresented\n\n  if (!props.triggerOnFocus && !value) {\n    suggestionDisabled.value = true\n    suggestions.value = []\n    return\n  }\n\n  debouncedGetData(value)\n}\n\nconst handleMouseDown = (event: MouseEvent) => {\n  if (disabled.value) return\n  if (\n    (event.target as HTMLElement)?.tagName !== 'INPUT' ||\n    refInput.value.includes(document.activeElement as HTMLInputElement)\n  ) {\n    activated.value = true\n  }\n}\n\nconst handleChange = (value: string) => {\n  emit(CHANGE_EVENT, value)\n}\n\nconst handleFocus = (evt: FocusEvent) => {\n  if (!ignoreFocusEvent) {\n    activated.value = true\n    emit('focus', evt)\n\n    if (props.triggerOnFocus && !readonly) {\n      debouncedGetData(String(props.modelValue))\n    }\n  } else {\n    ignoreFocusEvent = false\n  }\n}\n\nconst handleBlur = (evt: FocusEvent) => {\n  setTimeout(() => {\n    // validate current focus event is inside el-tooltip-content\n    // if so, ignore the blur event and the next focus event\n    if (popperRef.value?.isFocusInsideContent()) {\n      ignoreFocusEvent = true\n      return\n    }\n    activated.value && close()\n    emit('blur', evt)\n  })\n}\n\nconst handleClear = () => {\n  activated.value = false\n  emit(UPDATE_MODEL_EVENT, '')\n  emit('clear')\n}\n\nconst handleKeyEnter = async () => {\n  if (\n    suggestionVisible.value &&\n    highlightedIndex.value >= 0 &&\n    highlightedIndex.value < suggestions.value.length\n  ) {\n    handleSelect(suggestions.value[highlightedIndex.value])\n  } else if (props.selectWhenUnmatched) {\n    emit('select', { value: props.modelValue })\n    suggestions.value = []\n    highlightedIndex.value = -1\n  }\n}\n\nconst handleKeyEscape = (evt: Event) => {\n  if (suggestionVisible.value) {\n    evt.preventDefault()\n    evt.stopPropagation()\n    close()\n  }\n}\n\nconst close = () => {\n  activated.value = false\n}\n\nconst focus = () => {\n  inputRef.value?.focus()\n}\n\nconst blur = () => {\n  inputRef.value?.blur()\n}\n\nconst handleSelect = async (item: any) => {\n  emit(INPUT_EVENT, item[props.valueKey])\n  emit(UPDATE_MODEL_EVENT, item[props.valueKey])\n  emit('select', item)\n  suggestions.value = []\n  highlightedIndex.value = -1\n}\n\nconst highlight = (index: number) => {\n  if (!suggestionVisible.value || loading.value) return\n\n  if (index < 0) {\n    highlightedIndex.value = -1\n    return\n  }\n\n  if (index >= suggestions.value.length) {\n    index = suggestions.value.length - 1\n  }\n  const suggestion = regionRef.value!.querySelector(\n    `.${ns.be('suggestion', 'wrap')}`\n  )!\n  const suggestionList = suggestion.querySelectorAll<HTMLElement>(\n    `.${ns.be('suggestion', 'list')} li`\n  )!\n  const highlightItem = suggestionList[index]\n  const scrollTop = suggestion.scrollTop\n  const { offsetTop, scrollHeight } = highlightItem\n\n  if (offsetTop + scrollHeight > scrollTop + suggestion.clientHeight) {\n    suggestion.scrollTop += scrollHeight\n  }\n  if (offsetTop < scrollTop) {\n    suggestion.scrollTop -= scrollHeight\n  }\n  highlightedIndex.value = index\n  // TODO: use Volar generate dts to fix it.\n  ;(inputRef.value as any).ref!.setAttribute(\n    'aria-activedescendant',\n    `${listboxId.value}-item-${highlightedIndex.value}`\n  )\n}\n\nconst stopHandle = onClickOutside(listboxRef, () => {\n  suggestionVisible.value && close()\n})\n\nonBeforeUnmount(() => {\n  stopHandle?.()\n})\n\nonMounted(() => {\n  // TODO: use Volar generate dts to fix it.\n  ;(inputRef.value as any).ref!.setAttribute('role', 'textbox')\n  ;(inputRef.value as any).ref!.setAttribute('aria-autocomplete', 'list')\n  ;(inputRef.value as any).ref!.setAttribute('aria-controls', 'id')\n  ;(inputRef.value as any).ref!.setAttribute(\n    'aria-activedescendant',\n    `${listboxId.value}-item-${highlightedIndex.value}`\n  )\n  // get readonly attr\n  readonly = (inputRef.value as any).ref!.hasAttribute('readonly')\n})\n\ndefineExpose({\n  /** @description the index of the currently highlighted item */\n  highlightedIndex,\n  /** @description autocomplete whether activated */\n  activated,\n  /** @description remote search loading status */\n  loading,\n  /** @description el-input component instance */\n  inputRef,\n  /** @description el-tooltip component instance */\n  popperRef,\n  /** @description fetch suggestions result */\n  suggestions,\n  /** @description triggers when a suggestion is clicked */\n  handleSelect,\n  /** @description handle keyboard enter event */\n  handleKeyEnter,\n  /** @description focus the input element */\n  focus,\n  /** @description blur the input element */\n  blur,\n  /** @description close suggestion */\n  close,\n  /** @description highlight an item in a suggestion */\n  highlight,\n  /** @description loading suggestion list */\n  getData,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Autocomplete from './src/autocomplete.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElAutocomplete: SFCWithInstall<typeof Autocomplete> =\n  withInstall(Autocomplete)\n\nexport default ElAutocomplete\n\nexport * from './src/autocomplete'\n", "import {\n  buildProps,\n  definePropType,\n  iconPropType,\n  isNumber,\n} from '@element-plus/utils'\nimport { componentSizes } from '@element-plus/constants'\nimport type { ExtractPropTypes } from 'vue'\nimport type { ObjectFitProperty } from 'csstype'\n\nexport const avatarProps = buildProps({\n  /**\n   * @description avatar size.\n   */\n  size: {\n    type: [Number, String],\n    values: componentSizes,\n    default: '',\n    validator: (val: unknown): val is number => isNumber(val),\n  },\n  /**\n   * @description avatar shape.\n   */\n  shape: {\n    type: String,\n    values: ['circle', 'square'],\n    default: 'circle',\n  },\n  /**\n   * @description representation type to icon, more info on icon component.\n   */\n  icon: {\n    type: iconPropType,\n  },\n  /**\n   * @description the source of the image for an image avatar.\n   */\n  src: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description native attribute `alt` of image avatar.\n   */\n  alt: String,\n  /**\n   * @description native attribute srcset of image avatar.\n   */\n  srcSet: String,\n  /**\n   * @description set how the image fit its container for an image avatar.\n   */\n  fit: {\n    type: definePropType<ObjectFitProperty>(String),\n    default: 'cover',\n  },\n} as const)\nexport type AvatarProps = ExtractPropTypes<typeof avatarProps>\n\nexport const avatarEmits = {\n  error: (evt: Event) => evt instanceof Event,\n}\nexport type AvatarEmits = typeof avatarEmits\n", "<template>\n  <span :class=\"avatarClass\" :style=\"sizeStyle\">\n    <img\n      v-if=\"(src || srcSet) && !hasLoadError\"\n      :src=\"src\"\n      :alt=\"alt\"\n      :srcset=\"srcSet\"\n      :style=\"fitStyle\"\n      @error=\"handleError\"\n    />\n    <el-icon v-else-if=\"icon\">\n      <component :is=\"icon\" />\n    </el-icon>\n    <slot v-else />\n  </span>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, ref, watch } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { useNamespace } from '@element-plus/hooks'\nimport { addUnit, isNumber, isString } from '@element-plus/utils'\nimport { avatarEmits, avatarProps } from './avatar'\n\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElAvatar',\n})\n\nconst props = defineProps(avatarProps)\nconst emit = defineEmits(avatarEmits)\n\nconst ns = useNamespace('avatar')\n\nconst hasLoadError = ref(false)\n\nconst avatarClass = computed(() => {\n  const { size, icon, shape } = props\n  const classList = [ns.b()]\n  if (isString(size)) classList.push(ns.m(size))\n  if (icon) classList.push(ns.m('icon'))\n  if (shape) classList.push(ns.m(shape))\n  return classList\n})\n\nconst sizeStyle = computed(() => {\n  const { size } = props\n  return isNumber(size)\n    ? (ns.cssVarBlock({\n        size: addUnit(size) || '',\n      }) as CSSProperties)\n    : undefined\n})\n\nconst fitStyle = computed<CSSProperties>(() => ({\n  objectFit: props.fit,\n}))\n\n// need reset hasLoadError to false if src changed\nwatch(\n  () => props.src,\n  () => (hasLoadError.value = false)\n)\n\nfunction handleError(e: Event) {\n  hasLoadError.value = true\n  emit('error', e)\n}\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Avatar from './src/avatar.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElAvatar: SFCWithInstall<typeof Avatar> = withInstall(Avatar)\nexport default ElAvatar\n\nexport * from './src/avatar'\nexport type { AvatarInstance } from './src/instance'\n", "import type { ExtractPropTypes } from 'vue'\n\nexport const backtopProps = {\n  /**\n   * @description the button will not show until the scroll height reaches this value.\n   */\n  visibilityHeight: {\n    type: Number,\n    default: 200,\n  },\n  /**\n   * @description the target to trigger scroll.\n   */\n  target: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description right distance.\n   */\n  right: {\n    type: Number,\n    default: 40,\n  },\n  /**\n   * @description bottom distance.\n   */\n  bottom: {\n    type: Number,\n    default: 40,\n  },\n} as const\nexport type BacktopProps = ExtractPropTypes<typeof backtopProps>\n\nexport const backtopEmits = {\n  click: (evt: MouseEvent) => evt instanceof MouseEvent,\n}\nexport type BacktopEmits = typeof backtopEmits\n", "import { onMounted, ref, shallowRef } from 'vue'\nimport { useEventListener, useThrottleFn } from '@vueuse/core'\nimport { throwError } from '@element-plus/utils'\nimport type { SetupContext } from 'vue'\nimport type { BacktopEmits, BacktopProps } from './backtop'\n\nexport const useBackTop = (\n  props: BacktopProps,\n  emit: SetupContext<BacktopEmits>['emit'],\n  componentName: string\n) => {\n  const el = shallowRef<HTMLElement>()\n  const container = shallowRef<Document | HTMLElement>()\n  const visible = ref(false)\n\n  const handleScroll = () => {\n    if (el.value) visible.value = el.value.scrollTop >= props.visibilityHeight\n  }\n\n  const handleClick = (event: MouseEvent) => {\n    el.value?.scrollTo({ top: 0, behavior: 'smooth' })\n    emit('click', event)\n  }\n\n  const handleScrollThrottled = useThrottleFn(handleScroll, 300, true)\n\n  useEventListener(container, 'scroll', handleScrollThrottled)\n  onMounted(() => {\n    container.value = document\n    el.value = document.documentElement\n\n    if (props.target) {\n      el.value = document.querySelector<HTMLElement>(props.target) ?? undefined\n      if (!el.value) {\n        throwError(componentName, `target does not exist: ${props.target}`)\n      }\n      container.value = el.value\n    }\n    // Give visible an initial value, fix #13066\n    handleScroll()\n  })\n\n  return {\n    visible,\n    handleClick,\n  }\n}\n", "<template>\n  <transition :name=\"`${ns.namespace.value}-fade-in`\">\n    <div\n      v-if=\"visible\"\n      :style=\"backTopStyle\"\n      :class=\"ns.b()\"\n      @click.stop=\"handleClick\"\n    >\n      <slot>\n        <el-icon :class=\"ns.e('icon')\"><caret-top /></el-icon>\n      </slot>\n    </div>\n  </transition>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { CaretTop } from '@element-plus/icons-vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { backtopEmits, backtopProps } from './backtop'\nimport { useBackTop } from './use-backtop'\n\nconst COMPONENT_NAME = 'ElBacktop'\n\ndefineOptions({\n  name: COMPONENT_NAME,\n})\n\nconst props = defineProps(backtopProps)\nconst emit = defineEmits(backtopEmits)\n\nconst ns = useNamespace('backtop')\n\nconst { handleClick, visible } = useBackTop(props, emit, COMPONENT_NAME)\n\nconst backTopStyle = computed(() => ({\n  right: `${props.right}px`,\n  bottom: `${props.bottom}px`,\n}))\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Backtop from './src/backtop.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElBacktop: SFCWithInstall<typeof Backtop> = withInstall(Backtop)\nexport default ElBacktop\n\nexport * from './src/backtop'\nexport type { BacktopInstance } from './src/instance'\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport type { ExtractPropTypes, StyleValue } from 'vue'\n\nexport const badgeProps = buildProps({\n  /**\n   * @description display value.\n   */\n  value: {\n    type: [String, Number],\n    default: '',\n  },\n  /**\n   * @description maximum value, shows `{max}+` when exceeded. Only works if value is a number.\n   */\n  max: {\n    type: Number,\n    default: 99,\n  },\n  /**\n   * @description if a little dot is displayed.\n   */\n  isDot: Boolean,\n  /**\n   * @description hidden badge.\n   */\n  hidden: Boolean,\n  /**\n   * @description badge type.\n   */\n  type: {\n    type: String,\n    values: ['primary', 'success', 'warning', 'info', 'danger'],\n    default: 'danger',\n  },\n  /**\n   * @description whether to show badge when value is zero.\n   */\n  showZero: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description customize dot background color\n   */\n  color: String,\n  /**\n   * @description CSS style of badge\n   */\n  badgeStyle: {\n    type: definePropType<StyleValue>([String, Object, Array]),\n  },\n  /**\n   * @description set offset of the badge\n   */\n  offset: {\n    type: definePropType<[number, number]>(Array),\n    default: [0, 0],\n  },\n  /**\n   * @description custom class name of badge\n   */\n  badgeClass: {\n    type: String,\n  },\n} as const)\nexport type BadgeProps = ExtractPropTypes<typeof badgeProps>\n", "<template>\n  <div :class=\"ns.b()\">\n    <slot />\n    <transition :name=\"`${ns.namespace.value}-zoom-in-center`\">\n      <sup\n        v-show=\"!hidden && (content || isDot)\"\n        :class=\"[\n          ns.e('content'),\n          ns.em('content', type),\n          ns.is('fixed', !!$slots.default),\n          ns.is('dot', isDot),\n          badgeClass,\n        ]\"\n        :style=\"style\"\n        v-text=\"content\"\n      />\n    </transition>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { addUnit, isNumber } from '@element-plus/utils'\nimport { badgeProps } from './badge'\nimport type { StyleValue } from 'vue'\n\ndefineOptions({\n  name: 'ElBadge',\n})\n\nconst props = defineProps(badgeProps)\n\nconst ns = useNamespace('badge')\n\nconst content = computed<string>(() => {\n  if (props.isDot) return ''\n  if (isNumber(props.value) && isNumber(props.max)) {\n    if (props.max < props.value) {\n      return `${props.max}+`\n    }\n    return props.value === 0 && !props.showZero ? '' : `${props.value}`\n  }\n  return `${props.value}`\n})\nconst style = computed<StyleValue>(() => {\n  return [\n    {\n      backgroundColor: props.color,\n      marginRight: addUnit(-(props.offset?.[0] ?? 0)),\n      marginTop: addUnit(props.offset?.[1] ?? 0),\n    },\n    props.badgeStyle ?? {},\n  ]\n})\n\ndefineExpose({\n  /** @description badge content */\n  content,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Badge from './src/badge.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElBadge: SFCWithInstall<typeof Badge> = withInstall(Badge)\nexport default ElBadge\n\nexport * from './src/badge'\nexport type { BadgeInstance } from './src/instance'\n", "import type { InjectionKey } from 'vue'\nimport type { BreadcrumbProps } from './breadcrumb'\n\nexport const breadcrumbKey: InjectionKey<BreadcrumbProps> =\n  Symbol('breadcrumbKey')\n", "import { buildProps, iconPropType } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const breadcrumbProps = buildProps({\n  /**\n   * @description separator character\n   */\n  separator: {\n    type: String,\n    default: '/',\n  },\n  /**\n   * @description icon component of icon separator\n   */\n  separatorIcon: {\n    type: iconPropType,\n  },\n} as const)\nexport type BreadcrumbProps = ExtractPropTypes<typeof breadcrumbProps>\n", "<template>\n  <div\n    ref=\"breadcrumb\"\n    :class=\"ns.b()\"\n    :aria-label=\"t('el.breadcrumb.label')\"\n    role=\"navigation\"\n  >\n    <slot />\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { onMounted, provide, ref } from 'vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { breadcrumbKey } from './constants'\nimport { breadcrumbProps } from './breadcrumb'\n\ndefineOptions({\n  name: 'ElBreadcrumb',\n})\n\nconst { t } = useLocale()\nconst props = defineProps(breadcrumbProps)\n\nconst ns = useNamespace('breadcrumb')\nconst breadcrumb = ref<HTMLDivElement>()\n\nprovide(breadcrumbKey, props)\n\nonMounted(() => {\n  const items = breadcrumb.value!.querySelectorAll(`.${ns.e('item')}`)\n  if (items.length) {\n    items[items.length - 1].setAttribute('aria-current', 'page')\n  }\n})\n</script>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type { RouteLocationRaw } from 'vue-router'\n\nexport const breadcrumbItemProps = buildProps({\n  /**\n   * @description target route of the link, same as `to` of `vue-router`\n   */\n  to: {\n    type: definePropType<RouteLocationRaw>([String, Object]),\n    default: '',\n  },\n  /**\n   * @description if `true`, the navigation will not leave a history record\n   */\n  replace: Boolean,\n} as const)\nexport type BreadcrumbItemProps = ExtractPropTypes<typeof breadcrumbItemProps>\n", "<template>\n  <span :class=\"ns.e('item')\">\n    <span\n      ref=\"link\"\n      :class=\"[ns.e('inner'), ns.is('link', !!to)]\"\n      role=\"link\"\n      @click=\"onClick\"\n    >\n      <slot />\n    </span>\n    <el-icon v-if=\"breadcrumbContext?.separatorIcon\" :class=\"ns.e('separator')\">\n      <component :is=\"breadcrumbContext.separatorIcon\" />\n    </el-icon>\n    <span v-else :class=\"ns.e('separator')\" role=\"presentation\">\n      {{ breadcrumbContext?.separator }}\n    </span>\n  </span>\n</template>\n\n<script lang=\"ts\" setup>\nimport { getCurrentInstance, inject, ref } from 'vue'\nimport ElIcon from '@element-plus/components/icon'\nimport { useNamespace } from '@element-plus/hooks'\nimport { breadcrumbKey } from './constants'\nimport { breadcrumbItemProps } from './breadcrumb-item'\n\nimport type { Router } from 'vue-router'\n\ndefineOptions({\n  name: 'ElBreadcrumbItem',\n})\n\nconst props = defineProps(breadcrumbItemProps)\n\nconst instance = getCurrentInstance()!\nconst breadcrumbContext = inject(breadcrumbKey, undefined)\nconst ns = useNamespace('breadcrumb')\n\nconst router = instance.appContext.config.globalProperties.$router as Router\n\nconst link = ref<HTMLSpanElement>()\n\nconst onClick = () => {\n  if (!props.to || !router) return\n  props.replace ? router.replace(props.to) : router.push(props.to)\n}\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\n\nimport Breadcrumb from './src/breadcrumb.vue'\nimport BreadcrumbItem from './src/breadcrumb-item.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElBreadcrumb: SFCWithInstall<typeof Breadcrumb> & {\n  BreadcrumbItem: typeof BreadcrumbItem\n} = withInstall(Breadcrumb, {\n  BreadcrumbItem,\n})\nexport const ElBreadcrumbItem: SFCWithInstall<typeof BreadcrumbItem> =\n  withNoopInstall(BreadcrumbItem)\nexport default ElBreadcrumb\n\nexport * from './src/breadcrumb'\nexport * from './src/breadcrumb-item'\nexport * from './src/constants'\nexport type {\n  BreadcrumbInstance,\n  BreadcrumbItemInstance,\n} from './src/instances'\n", "import type { InjectionKey } from 'vue'\n\nimport type { ButtonProps } from './button'\n\nexport interface ButtonGroupContext {\n  size?: ButtonProps['size']\n  type?: ButtonProps['type']\n}\n\nexport const buttonGroupContextKey: InjectionKey<ButtonGroupContext> = Symbol(\n  'buttonGroupContextKey'\n)\n", "import { Text, computed, inject, ref, useSlots } from 'vue'\nimport {\n  useFormDisabled,\n  useFormItem,\n  useFormSize,\n} from '@element-plus/components/form'\nimport { useGlobalConfig } from '@element-plus/components/config-provider'\nimport { useDeprecated } from '@element-plus/hooks'\nimport { buttonGroupContextKey } from './constants'\n\nimport type { SetupContext } from 'vue'\nimport type { ButtonEmits, ButtonProps } from './button'\n\nexport const useButton = (\n  props: ButtonProps,\n  emit: SetupContext<ButtonEmits>['emit']\n) => {\n  useDeprecated(\n    {\n      from: 'type.text',\n      replacement: 'link',\n      version: '3.0.0',\n      scope: 'props',\n      ref: 'https://element-plus.org/en-US/component/button.html#button-attributes',\n    },\n    computed(() => props.type === 'text')\n  )\n\n  const buttonGroupContext = inject(buttonGroupContextKey, undefined)\n  const globalConfig = useGlobalConfig('button')\n  const { form } = useFormItem()\n  const _size = useFormSize(computed(() => buttonGroupContext?.size))\n  const _disabled = useFormDisabled()\n  const _ref = ref<HTMLButtonElement>()\n  const slots = useSlots()\n\n  const _type = computed(() => props.type || buttonGroupContext?.type || '')\n  const autoInsertSpace = computed(\n    () => props.autoInsertSpace ?? globalConfig.value?.autoInsertSpace ?? false\n  )\n\n  const _props = computed(() => {\n    if (props.tag === 'button') {\n      return {\n        ariaDisabled: _disabled.value || props.loading,\n        disabled: _disabled.value || props.loading,\n        autofocus: props.autofocus,\n        type: props.nativeType,\n      }\n    }\n    return {}\n  })\n\n  // add space between two characters in Chinese\n  const shouldAddSpace = computed(() => {\n    const defaultSlot = slots.default?.()\n    if (autoInsertSpace.value && defaultSlot?.length === 1) {\n      const slot = defaultSlot[0]\n      if (slot?.type === Text) {\n        const text = slot.children as string\n        return /^\\p{Unified_Ideograph}{2}$/u.test(text.trim())\n      }\n    }\n    return false\n  })\n\n  const handleClick = (evt: MouseEvent) => {\n    if (_disabled.value || props.loading) {\n      evt.stopPropagation()\n      return\n    }\n    if (props.nativeType === 'reset') {\n      form?.resetFields()\n    }\n    emit('click', evt)\n  }\n\n  return {\n    _disabled,\n    _size,\n    _type,\n    _ref,\n    _props,\n    shouldAddSpace,\n    handleClick,\n  }\n}\n", "import { useSizeProp } from '@element-plus/hooks'\nimport { buildProps, definePropType, iconPropType } from '@element-plus/utils'\nimport { Loading } from '@element-plus/icons-vue'\nimport type { Component, ExtractPropTypes } from 'vue'\n\nexport const buttonTypes = [\n  'default',\n  'primary',\n  'success',\n  'warning',\n  'info',\n  'danger',\n  /**\n   * @deprecated\n   * Text type will be deprecated in the next major version (3.0.0)\n   */\n  'text',\n  '',\n] as const\nexport const buttonNativeTypes = ['button', 'submit', 'reset'] as const\n\nexport const buttonProps = buildProps({\n  /**\n   * @description button size\n   */\n  size: useSizeProp,\n  /**\n   * @description disable the button\n   */\n  disabled: Boolean,\n  /**\n   * @description button type\n   */\n  type: {\n    type: String,\n    values: buttonTypes,\n    default: '',\n  },\n  /**\n   * @description icon component\n   */\n  icon: {\n    type: iconPropType,\n  },\n  /**\n   * @description native button type\n   */\n  nativeType: {\n    type: String,\n    values: buttonNativeTypes,\n    default: 'button',\n  },\n  /**\n   * @description determine whether it's loading\n   */\n  loading: Boolean,\n  /**\n   * @description customize loading icon component\n   */\n  loadingIcon: {\n    type: iconPropType,\n    default: () => Loading,\n  },\n  /**\n   * @description determine whether it's a plain button\n   */\n  plain: Boolean,\n  /**\n   * @description determine whether it's a text button\n   */\n  text: Boolean,\n  /**\n   * @description determine whether it's a link button\n   */\n  link: Boolean,\n  /**\n   * @description determine whether the text button background color is always on\n   */\n  bg: Boolean,\n  /**\n   * @description native button autofocus\n   */\n  autofocus: Boolean,\n  /**\n   * @description determine whether it's a round button\n   */\n  round: Boolean,\n  /**\n   * @description determine whether it's a circle button\n   */\n  circle: Boolean,\n  /**\n   * @description custom button color, automatically calculate `hover` and `active` color\n   */\n  color: String,\n  /**\n   * @description dark mode, which automatically converts `color` to dark mode colors\n   */\n  dark: Boolean,\n  /**\n   * @description automatically insert a space between two chinese characters\n   */\n  autoInsertSpace: {\n    type: Boolean,\n    default: undefined,\n  },\n  /**\n   * @description custom element tag\n   */\n  tag: {\n    type: definePropType<string | Component>([String, Object]),\n    default: 'button',\n  },\n} as const)\nexport const buttonEmits = {\n  click: (evt: MouseEvent) => evt instanceof MouseEvent,\n}\n\nexport type ButtonProps = ExtractPropTypes<typeof buttonProps>\nexport type ButtonEmits = typeof buttonEmits\n\nexport type ButtonType = ButtonProps['type']\nexport type ButtonNativeType = ButtonProps['nativeType']\n\nexport interface ButtonConfigContext {\n  autoInsertSpace?: boolean\n}\n", "/**\n * Take input from [0, n] and return it as [0, 1]\n * @hidden\n */\nexport function bound01(n, max) {\n    if (isOnePointZero(n)) {\n        n = '100%';\n    }\n    var isPercent = isPercentage(n);\n    n = max === 360 ? n : Math.min(max, Math.max(0, parseFloat(n)));\n    // Automatically convert percentage into number\n    if (isPercent) {\n        n = parseInt(String(n * max), 10) / 100;\n    }\n    // Handle floating point rounding errors\n    if (Math.abs(n - max) < 0.000001) {\n        return 1;\n    }\n    // Convert into [0, 1] range if it isn't already\n    if (max === 360) {\n        // If n is a hue given in degrees,\n        // wrap around out-of-range values into [0, 360] range\n        // then convert into [0, 1].\n        n = (n < 0 ? (n % max) + max : n % max) / parseFloat(String(max));\n    }\n    else {\n        // If n not a hue given in degrees\n        // Convert into [0, 1] range if it isn't already.\n        n = (n % max) / parseFloat(String(max));\n    }\n    return n;\n}\n/**\n * Force a number between 0 and 1\n * @hidden\n */\nexport function clamp01(val) {\n    return Math.min(1, Math.max(0, val));\n}\n/**\n * Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1\n * <http://stackoverflow.com/questions/7422072/javascript-how-to-detect-number-as-a-decimal-including-1-0>\n * @hidden\n */\nexport function isOnePointZero(n) {\n    return typeof n === 'string' && n.indexOf('.') !== -1 && parseFloat(n) === 1;\n}\n/**\n * Check to see if string passed in is a percentage\n * @hidden\n */\nexport function isPercentage(n) {\n    return typeof n === 'string' && n.indexOf('%') !== -1;\n}\n/**\n * Return a valid alpha value [0,1] with all invalid values being set to 1\n * @hidden\n */\nexport function boundAlpha(a) {\n    a = parseFloat(a);\n    if (isNaN(a) || a < 0 || a > 1) {\n        a = 1;\n    }\n    return a;\n}\n/**\n * Replace a decimal with it's percentage value\n * @hidden\n */\nexport function convertToPercentage(n) {\n    if (n <= 1) {\n        return \"\".concat(Number(n) * 100, \"%\");\n    }\n    return n;\n}\n/**\n * Force a hex value to have 2 characters\n * @hidden\n */\nexport function pad2(c) {\n    return c.length === 1 ? '0' + c : String(c);\n}\n", "import { bound01, pad2 } from './util.js';\n// `rgbToHsl`, `rgbToHsv`, `hslToRgb`, `hsvToRgb` modified from:\n// <http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript>\n/**\n * Handle bounds / percentage checking to conform to CSS color spec\n * <http://www.w3.org/TR/css3-color/>\n * *Assumes:* r, g, b in [0, 255] or [0, 1]\n * *Returns:* { r, g, b } in [0, 255]\n */\nexport function rgbToRgb(r, g, b) {\n    return {\n        r: bound01(r, 255) * 255,\n        g: bound01(g, 255) * 255,\n        b: bound01(b, 255) * 255,\n    };\n}\n/**\n * Converts an RGB color value to HSL.\n * *Assumes:* r, g, and b are contained in [0, 255] or [0, 1]\n * *Returns:* { h, s, l } in [0,1]\n */\nexport function rgbToHsl(r, g, b) {\n    r = bound01(r, 255);\n    g = bound01(g, 255);\n    b = bound01(b, 255);\n    var max = Math.max(r, g, b);\n    var min = Math.min(r, g, b);\n    var h = 0;\n    var s = 0;\n    var l = (max + min) / 2;\n    if (max === min) {\n        s = 0;\n        h = 0; // achromatic\n    }\n    else {\n        var d = max - min;\n        s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n        switch (max) {\n            case r:\n                h = (g - b) / d + (g < b ? 6 : 0);\n                break;\n            case g:\n                h = (b - r) / d + 2;\n                break;\n            case b:\n                h = (r - g) / d + 4;\n                break;\n            default:\n                break;\n        }\n        h /= 6;\n    }\n    return { h: h, s: s, l: l };\n}\nfunction hue2rgb(p, q, t) {\n    if (t < 0) {\n        t += 1;\n    }\n    if (t > 1) {\n        t -= 1;\n    }\n    if (t < 1 / 6) {\n        return p + (q - p) * (6 * t);\n    }\n    if (t < 1 / 2) {\n        return q;\n    }\n    if (t < 2 / 3) {\n        return p + (q - p) * (2 / 3 - t) * 6;\n    }\n    return p;\n}\n/**\n * Converts an HSL color value to RGB.\n *\n * *Assumes:* h is contained in [0, 1] or [0, 360] and s and l are contained [0, 1] or [0, 100]\n * *Returns:* { r, g, b } in the set [0, 255]\n */\nexport function hslToRgb(h, s, l) {\n    var r;\n    var g;\n    var b;\n    h = bound01(h, 360);\n    s = bound01(s, 100);\n    l = bound01(l, 100);\n    if (s === 0) {\n        // achromatic\n        g = l;\n        b = l;\n        r = l;\n    }\n    else {\n        var q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n        var p = 2 * l - q;\n        r = hue2rgb(p, q, h + 1 / 3);\n        g = hue2rgb(p, q, h);\n        b = hue2rgb(p, q, h - 1 / 3);\n    }\n    return { r: r * 255, g: g * 255, b: b * 255 };\n}\n/**\n * Converts an RGB color value to HSV\n *\n * *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1]\n * *Returns:* { h, s, v } in [0,1]\n */\nexport function rgbToHsv(r, g, b) {\n    r = bound01(r, 255);\n    g = bound01(g, 255);\n    b = bound01(b, 255);\n    var max = Math.max(r, g, b);\n    var min = Math.min(r, g, b);\n    var h = 0;\n    var v = max;\n    var d = max - min;\n    var s = max === 0 ? 0 : d / max;\n    if (max === min) {\n        h = 0; // achromatic\n    }\n    else {\n        switch (max) {\n            case r:\n                h = (g - b) / d + (g < b ? 6 : 0);\n                break;\n            case g:\n                h = (b - r) / d + 2;\n                break;\n            case b:\n                h = (r - g) / d + 4;\n                break;\n            default:\n                break;\n        }\n        h /= 6;\n    }\n    return { h: h, s: s, v: v };\n}\n/**\n * Converts an HSV color value to RGB.\n *\n * *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100]\n * *Returns:* { r, g, b } in the set [0, 255]\n */\nexport function hsvToRgb(h, s, v) {\n    h = bound01(h, 360) * 6;\n    s = bound01(s, 100);\n    v = bound01(v, 100);\n    var i = Math.floor(h);\n    var f = h - i;\n    var p = v * (1 - s);\n    var q = v * (1 - f * s);\n    var t = v * (1 - (1 - f) * s);\n    var mod = i % 6;\n    var r = [v, q, p, p, t, v][mod];\n    var g = [t, v, v, q, p, p][mod];\n    var b = [p, p, t, v, v, q][mod];\n    return { r: r * 255, g: g * 255, b: b * 255 };\n}\n/**\n * Converts an RGB color to hex\n *\n * Assumes r, g, and b are contained in the set [0, 255]\n * Returns a 3 or 6 character hex\n */\nexport function rgbToHex(r, g, b, allow3Char) {\n    var hex = [\n        pad2(Math.round(r).toString(16)),\n        pad2(Math.round(g).toString(16)),\n        pad2(Math.round(b).toString(16)),\n    ];\n    // Return a 3 character hex if possible\n    if (allow3Char &&\n        hex[0].startsWith(hex[0].charAt(1)) &&\n        hex[1].startsWith(hex[1].charAt(1)) &&\n        hex[2].startsWith(hex[2].charAt(1))) {\n        return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0);\n    }\n    return hex.join('');\n}\n/**\n * Converts an RGBA color plus alpha transparency to hex\n *\n * Assumes r, g, b are contained in the set [0, 255] and\n * a in [0, 1]. Returns a 4 or 8 character rgba hex\n */\n// eslint-disable-next-line max-params\nexport function rgbaToHex(r, g, b, a, allow4Char) {\n    var hex = [\n        pad2(Math.round(r).toString(16)),\n        pad2(Math.round(g).toString(16)),\n        pad2(Math.round(b).toString(16)),\n        pad2(convertDecimalToHex(a)),\n    ];\n    // Return a 4 character hex if possible\n    if (allow4Char &&\n        hex[0].startsWith(hex[0].charAt(1)) &&\n        hex[1].startsWith(hex[1].charAt(1)) &&\n        hex[2].startsWith(hex[2].charAt(1)) &&\n        hex[3].startsWith(hex[3].charAt(1))) {\n        return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0) + hex[3].charAt(0);\n    }\n    return hex.join('');\n}\n/**\n * Converts an RGBA color to an ARGB Hex8 string\n * Rarely used, but required for \"toFilter()\"\n */\nexport function rgbaToArgbHex(r, g, b, a) {\n    var hex = [\n        pad2(convertDecimalToHex(a)),\n        pad2(Math.round(r).toString(16)),\n        pad2(Math.round(g).toString(16)),\n        pad2(Math.round(b).toString(16)),\n    ];\n    return hex.join('');\n}\n/** Converts a decimal to a hex value */\nexport function convertDecimalToHex(d) {\n    return Math.round(parseFloat(d) * 255).toString(16);\n}\n/** Converts a hex value to a decimal */\nexport function convertHexToDecimal(h) {\n    return parseIntFromHex(h) / 255;\n}\n/** Parse a base-16 hex value into a base-10 integer */\nexport function parseIntFromHex(val) {\n    return parseInt(val, 16);\n}\nexport function numberInputToObject(color) {\n    return {\n        r: color >> 16,\n        g: (color & 0xff00) >> 8,\n        b: color & 0xff,\n    };\n}\n", "// https://github.com/bahamas10/css-color-names/blob/master/css-color-names.json\n/**\n * @hidden\n */\nexport var names = {\n    aliceblue: '#f0f8ff',\n    antiquewhite: '#faebd7',\n    aqua: '#00ffff',\n    aquamarine: '#7fffd4',\n    azure: '#f0ffff',\n    beige: '#f5f5dc',\n    bisque: '#ffe4c4',\n    black: '#000000',\n    blanchedalmond: '#ffebcd',\n    blue: '#0000ff',\n    blueviolet: '#8a2be2',\n    brown: '#a52a2a',\n    burlywood: '#deb887',\n    cadetblue: '#5f9ea0',\n    chartreuse: '#7fff00',\n    chocolate: '#d2691e',\n    coral: '#ff7f50',\n    cornflowerblue: '#6495ed',\n    cornsilk: '#fff8dc',\n    crimson: '#dc143c',\n    cyan: '#00ffff',\n    darkblue: '#00008b',\n    darkcyan: '#008b8b',\n    darkgoldenrod: '#b8860b',\n    darkgray: '#a9a9a9',\n    darkgreen: '#006400',\n    darkgrey: '#a9a9a9',\n    darkkhaki: '#bdb76b',\n    darkmagenta: '#8b008b',\n    darkolivegreen: '#556b2f',\n    darkorange: '#ff8c00',\n    darkorchid: '#9932cc',\n    darkred: '#8b0000',\n    darksalmon: '#e9967a',\n    darkseagreen: '#8fbc8f',\n    darkslateblue: '#483d8b',\n    darkslategray: '#2f4f4f',\n    darkslategrey: '#2f4f4f',\n    darkturquoise: '#00ced1',\n    darkviolet: '#9400d3',\n    deeppink: '#ff1493',\n    deepskyblue: '#00bfff',\n    dimgray: '#696969',\n    dimgrey: '#696969',\n    dodgerblue: '#1e90ff',\n    firebrick: '#b22222',\n    floralwhite: '#fffaf0',\n    forestgreen: '#228b22',\n    fuchsia: '#ff00ff',\n    gainsboro: '#dcdcdc',\n    ghostwhite: '#f8f8ff',\n    goldenrod: '#daa520',\n    gold: '#ffd700',\n    gray: '#808080',\n    green: '#008000',\n    greenyellow: '#adff2f',\n    grey: '#808080',\n    honeydew: '#f0fff0',\n    hotpink: '#ff69b4',\n    indianred: '#cd5c5c',\n    indigo: '#4b0082',\n    ivory: '#fffff0',\n    khaki: '#f0e68c',\n    lavenderblush: '#fff0f5',\n    lavender: '#e6e6fa',\n    lawngreen: '#7cfc00',\n    lemonchiffon: '#fffacd',\n    lightblue: '#add8e6',\n    lightcoral: '#f08080',\n    lightcyan: '#e0ffff',\n    lightgoldenrodyellow: '#fafad2',\n    lightgray: '#d3d3d3',\n    lightgreen: '#90ee90',\n    lightgrey: '#d3d3d3',\n    lightpink: '#ffb6c1',\n    lightsalmon: '#ffa07a',\n    lightseagreen: '#20b2aa',\n    lightskyblue: '#87cefa',\n    lightslategray: '#778899',\n    lightslategrey: '#778899',\n    lightsteelblue: '#b0c4de',\n    lightyellow: '#ffffe0',\n    lime: '#00ff00',\n    limegreen: '#32cd32',\n    linen: '#faf0e6',\n    magenta: '#ff00ff',\n    maroon: '#800000',\n    mediumaquamarine: '#66cdaa',\n    mediumblue: '#0000cd',\n    mediumorchid: '#ba55d3',\n    mediumpurple: '#9370db',\n    mediumseagreen: '#3cb371',\n    mediumslateblue: '#7b68ee',\n    mediumspringgreen: '#00fa9a',\n    mediumturquoise: '#48d1cc',\n    mediumvioletred: '#c71585',\n    midnightblue: '#191970',\n    mintcream: '#f5fffa',\n    mistyrose: '#ffe4e1',\n    moccasin: '#ffe4b5',\n    navajowhite: '#ffdead',\n    navy: '#000080',\n    oldlace: '#fdf5e6',\n    olive: '#808000',\n    olivedrab: '#6b8e23',\n    orange: '#ffa500',\n    orangered: '#ff4500',\n    orchid: '#da70d6',\n    palegoldenrod: '#eee8aa',\n    palegreen: '#98fb98',\n    paleturquoise: '#afeeee',\n    palevioletred: '#db7093',\n    papayawhip: '#ffefd5',\n    peachpuff: '#ffdab9',\n    peru: '#cd853f',\n    pink: '#ffc0cb',\n    plum: '#dda0dd',\n    powderblue: '#b0e0e6',\n    purple: '#800080',\n    rebeccapurple: '#663399',\n    red: '#ff0000',\n    rosybrown: '#bc8f8f',\n    royalblue: '#4169e1',\n    saddlebrown: '#8b4513',\n    salmon: '#fa8072',\n    sandybrown: '#f4a460',\n    seagreen: '#2e8b57',\n    seashell: '#fff5ee',\n    sienna: '#a0522d',\n    silver: '#c0c0c0',\n    skyblue: '#87ceeb',\n    slateblue: '#6a5acd',\n    slategray: '#708090',\n    slategrey: '#708090',\n    snow: '#fffafa',\n    springgreen: '#00ff7f',\n    steelblue: '#4682b4',\n    tan: '#d2b48c',\n    teal: '#008080',\n    thistle: '#d8bfd8',\n    tomato: '#ff6347',\n    turquoise: '#40e0d0',\n    violet: '#ee82ee',\n    wheat: '#f5deb3',\n    white: '#ffffff',\n    whitesmoke: '#f5f5f5',\n    yellow: '#ffff00',\n    yellowgreen: '#9acd32',\n};\n", "/* eslint-disable @typescript-eslint/no-redundant-type-constituents */\nimport { convertHexToDecimal, hslToRgb, hsvToRgb, parseIntFromHex, rgbToRgb, } from './conversion.js';\nimport { names } from './css-color-names.js';\nimport { boundAlpha, convertToPercentage } from './util.js';\n/**\n * Given a string or object, convert that input to RGB\n *\n * Possible string inputs:\n * ```\n * \"red\"\n * \"#f00\" or \"f00\"\n * \"#ff0000\" or \"ff0000\"\n * \"#ff000000\" or \"ff000000\"\n * \"rgb 255 0 0\" or \"rgb (255, 0, 0)\"\n * \"rgb 1.0 0 0\" or \"rgb (1, 0, 0)\"\n * \"rgba (255, 0, 0, 1)\" or \"rgba 255, 0, 0, 1\"\n * \"rgba (1.0, 0, 0, 1)\" or \"rgba 1.0, 0, 0, 1\"\n * \"hsl(0, 100%, 50%)\" or \"hsl 0 100% 50%\"\n * \"hsla(0, 100%, 50%, 1)\" or \"hsla 0 100% 50%, 1\"\n * \"hsv(0, 100%, 100%)\" or \"hsv 0 100% 100%\"\n * ```\n */\nexport function inputToRGB(color) {\n    var rgb = { r: 0, g: 0, b: 0 };\n    var a = 1;\n    var s = null;\n    var v = null;\n    var l = null;\n    var ok = false;\n    var format = false;\n    if (typeof color === 'string') {\n        color = stringInputToObject(color);\n    }\n    if (typeof color === 'object') {\n        if (isValidCSSUnit(color.r) && isValidCSSUnit(color.g) && isValidCSSUnit(color.b)) {\n            rgb = rgbToRgb(color.r, color.g, color.b);\n            ok = true;\n            format = String(color.r).substr(-1) === '%' ? 'prgb' : 'rgb';\n        }\n        else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.v)) {\n            s = convertToPercentage(color.s);\n            v = convertToPercentage(color.v);\n            rgb = hsvToRgb(color.h, s, v);\n            ok = true;\n            format = 'hsv';\n        }\n        else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.l)) {\n            s = convertToPercentage(color.s);\n            l = convertToPercentage(color.l);\n            rgb = hslToRgb(color.h, s, l);\n            ok = true;\n            format = 'hsl';\n        }\n        if (Object.prototype.hasOwnProperty.call(color, 'a')) {\n            a = color.a;\n        }\n    }\n    a = boundAlpha(a);\n    return {\n        ok: ok,\n        format: color.format || format,\n        r: Math.min(255, Math.max(rgb.r, 0)),\n        g: Math.min(255, Math.max(rgb.g, 0)),\n        b: Math.min(255, Math.max(rgb.b, 0)),\n        a: a,\n    };\n}\n// <http://www.w3.org/TR/css3-values/#integers>\nvar CSS_INTEGER = '[-\\\\+]?\\\\d+%?';\n// <http://www.w3.org/TR/css3-values/#number-value>\nvar CSS_NUMBER = '[-\\\\+]?\\\\d*\\\\.\\\\d+%?';\n// Allow positive/negative integer/number.  Don't capture the either/or, just the entire outcome.\nvar CSS_UNIT = \"(?:\".concat(CSS_NUMBER, \")|(?:\").concat(CSS_INTEGER, \")\");\n// Actual matching.\n// Parentheses and commas are optional, but not required.\n// Whitespace can take the place of commas or opening paren\nvar PERMISSIVE_MATCH3 = \"[\\\\s|\\\\(]+(\".concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")\\\\s*\\\\)?\");\nvar PERMISSIVE_MATCH4 = \"[\\\\s|\\\\(]+(\".concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")\\\\s*\\\\)?\");\nvar matchers = {\n    CSS_UNIT: new RegExp(CSS_UNIT),\n    rgb: new RegExp('rgb' + PERMISSIVE_MATCH3),\n    rgba: new RegExp('rgba' + PERMISSIVE_MATCH4),\n    hsl: new RegExp('hsl' + PERMISSIVE_MATCH3),\n    hsla: new RegExp('hsla' + PERMISSIVE_MATCH4),\n    hsv: new RegExp('hsv' + PERMISSIVE_MATCH3),\n    hsva: new RegExp('hsva' + PERMISSIVE_MATCH4),\n    hex3: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n    hex6: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,\n    hex4: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n    hex8: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,\n};\n/**\n * Permissive string parsing.  Take in a number of formats, and output an object\n * based on detected format.  Returns `{ r, g, b }` or `{ h, s, l }` or `{ h, s, v}`\n */\nexport function stringInputToObject(color) {\n    color = color.trim().toLowerCase();\n    if (color.length === 0) {\n        return false;\n    }\n    var named = false;\n    if (names[color]) {\n        color = names[color];\n        named = true;\n    }\n    else if (color === 'transparent') {\n        return { r: 0, g: 0, b: 0, a: 0, format: 'name' };\n    }\n    // Try to match string input using regular expressions.\n    // Keep most of the number bounding out of this function - don't worry about [0,1] or [0,100] or [0,360]\n    // Just return an object and let the conversion functions handle that.\n    // This way the result will be the same whether the tinycolor is initialized with string or object.\n    var match = matchers.rgb.exec(color);\n    if (match) {\n        return { r: match[1], g: match[2], b: match[3] };\n    }\n    match = matchers.rgba.exec(color);\n    if (match) {\n        return { r: match[1], g: match[2], b: match[3], a: match[4] };\n    }\n    match = matchers.hsl.exec(color);\n    if (match) {\n        return { h: match[1], s: match[2], l: match[3] };\n    }\n    match = matchers.hsla.exec(color);\n    if (match) {\n        return { h: match[1], s: match[2], l: match[3], a: match[4] };\n    }\n    match = matchers.hsv.exec(color);\n    if (match) {\n        return { h: match[1], s: match[2], v: match[3] };\n    }\n    match = matchers.hsva.exec(color);\n    if (match) {\n        return { h: match[1], s: match[2], v: match[3], a: match[4] };\n    }\n    match = matchers.hex8.exec(color);\n    if (match) {\n        return {\n            r: parseIntFromHex(match[1]),\n            g: parseIntFromHex(match[2]),\n            b: parseIntFromHex(match[3]),\n            a: convertHexToDecimal(match[4]),\n            format: named ? 'name' : 'hex8',\n        };\n    }\n    match = matchers.hex6.exec(color);\n    if (match) {\n        return {\n            r: parseIntFromHex(match[1]),\n            g: parseIntFromHex(match[2]),\n            b: parseIntFromHex(match[3]),\n            format: named ? 'name' : 'hex',\n        };\n    }\n    match = matchers.hex4.exec(color);\n    if (match) {\n        return {\n            r: parseIntFromHex(match[1] + match[1]),\n            g: parseIntFromHex(match[2] + match[2]),\n            b: parseIntFromHex(match[3] + match[3]),\n            a: convertHexToDecimal(match[4] + match[4]),\n            format: named ? 'name' : 'hex8',\n        };\n    }\n    match = matchers.hex3.exec(color);\n    if (match) {\n        return {\n            r: parseIntFromHex(match[1] + match[1]),\n            g: parseIntFromHex(match[2] + match[2]),\n            b: parseIntFromHex(match[3] + match[3]),\n            format: named ? 'name' : 'hex',\n        };\n    }\n    return false;\n}\n/**\n * Check to see if it looks like a CSS unit\n * (see `matchers` above for definition).\n */\nexport function isValidCSSUnit(color) {\n    return Boolean(matchers.CSS_UNIT.exec(String(color)));\n}\n", "import { numberInputToObject, rgbaToHex, rgbToHex, rgbToHsl, rgbToHsv } from './conversion.js';\nimport { names } from './css-color-names.js';\nimport { inputToRGB } from './format-input';\nimport { bound01, boundAlpha, clamp01 } from './util.js';\nvar TinyColor = /** @class */ (function () {\n    function TinyColor(color, opts) {\n        if (color === void 0) { color = ''; }\n        if (opts === void 0) { opts = {}; }\n        var _a;\n        // If input is already a tinycolor, return itself\n        if (color instanceof TinyColor) {\n            // eslint-disable-next-line no-constructor-return\n            return color;\n        }\n        if (typeof color === 'number') {\n            color = numberInputToObject(color);\n        }\n        this.originalInput = color;\n        var rgb = inputToRGB(color);\n        this.originalInput = color;\n        this.r = rgb.r;\n        this.g = rgb.g;\n        this.b = rgb.b;\n        this.a = rgb.a;\n        this.roundA = Math.round(100 * this.a) / 100;\n        this.format = (_a = opts.format) !== null && _a !== void 0 ? _a : rgb.format;\n        this.gradientType = opts.gradientType;\n        // Don't let the range of [0,255] come back in [0,1].\n        // Potentially lose a little bit of precision here, but will fix issues where\n        // .5 gets interpreted as half of the total, instead of half of 1\n        // If it was supposed to be 128, this was already taken care of by `inputToRgb`\n        if (this.r < 1) {\n            this.r = Math.round(this.r);\n        }\n        if (this.g < 1) {\n            this.g = Math.round(this.g);\n        }\n        if (this.b < 1) {\n            this.b = Math.round(this.b);\n        }\n        this.isValid = rgb.ok;\n    }\n    TinyColor.prototype.isDark = function () {\n        return this.getBrightness() < 128;\n    };\n    TinyColor.prototype.isLight = function () {\n        return !this.isDark();\n    };\n    /**\n     * Returns the perceived brightness of the color, from 0-255.\n     */\n    TinyColor.prototype.getBrightness = function () {\n        // http://www.w3.org/TR/AERT#color-contrast\n        var rgb = this.toRgb();\n        return (rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1000;\n    };\n    /**\n     * Returns the perceived luminance of a color, from 0-1.\n     */\n    TinyColor.prototype.getLuminance = function () {\n        // http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n        var rgb = this.toRgb();\n        var R;\n        var G;\n        var B;\n        var RsRGB = rgb.r / 255;\n        var GsRGB = rgb.g / 255;\n        var BsRGB = rgb.b / 255;\n        if (RsRGB <= 0.03928) {\n            R = RsRGB / 12.92;\n        }\n        else {\n            // eslint-disable-next-line prefer-exponentiation-operator\n            R = Math.pow((RsRGB + 0.055) / 1.055, 2.4);\n        }\n        if (GsRGB <= 0.03928) {\n            G = GsRGB / 12.92;\n        }\n        else {\n            // eslint-disable-next-line prefer-exponentiation-operator\n            G = Math.pow((GsRGB + 0.055) / 1.055, 2.4);\n        }\n        if (BsRGB <= 0.03928) {\n            B = BsRGB / 12.92;\n        }\n        else {\n            // eslint-disable-next-line prefer-exponentiation-operator\n            B = Math.pow((BsRGB + 0.055) / 1.055, 2.4);\n        }\n        return 0.2126 * R + 0.7152 * G + 0.0722 * B;\n    };\n    /**\n     * Returns the alpha value of a color, from 0-1.\n     */\n    TinyColor.prototype.getAlpha = function () {\n        return this.a;\n    };\n    /**\n     * Sets the alpha value on the current color.\n     *\n     * @param alpha - The new alpha value. The accepted range is 0-1.\n     */\n    TinyColor.prototype.setAlpha = function (alpha) {\n        this.a = boundAlpha(alpha);\n        this.roundA = Math.round(100 * this.a) / 100;\n        return this;\n    };\n    /**\n     * Returns whether the color is monochrome.\n     */\n    TinyColor.prototype.isMonochrome = function () {\n        var s = this.toHsl().s;\n        return s === 0;\n    };\n    /**\n     * Returns the object as a HSVA object.\n     */\n    TinyColor.prototype.toHsv = function () {\n        var hsv = rgbToHsv(this.r, this.g, this.b);\n        return { h: hsv.h * 360, s: hsv.s, v: hsv.v, a: this.a };\n    };\n    /**\n     * Returns the hsva values interpolated into a string with the following format:\n     * \"hsva(xxx, xxx, xxx, xx)\".\n     */\n    TinyColor.prototype.toHsvString = function () {\n        var hsv = rgbToHsv(this.r, this.g, this.b);\n        var h = Math.round(hsv.h * 360);\n        var s = Math.round(hsv.s * 100);\n        var v = Math.round(hsv.v * 100);\n        return this.a === 1 ? \"hsv(\".concat(h, \", \").concat(s, \"%, \").concat(v, \"%)\") : \"hsva(\".concat(h, \", \").concat(s, \"%, \").concat(v, \"%, \").concat(this.roundA, \")\");\n    };\n    /**\n     * Returns the object as a HSLA object.\n     */\n    TinyColor.prototype.toHsl = function () {\n        var hsl = rgbToHsl(this.r, this.g, this.b);\n        return { h: hsl.h * 360, s: hsl.s, l: hsl.l, a: this.a };\n    };\n    /**\n     * Returns the hsla values interpolated into a string with the following format:\n     * \"hsla(xxx, xxx, xxx, xx)\".\n     */\n    TinyColor.prototype.toHslString = function () {\n        var hsl = rgbToHsl(this.r, this.g, this.b);\n        var h = Math.round(hsl.h * 360);\n        var s = Math.round(hsl.s * 100);\n        var l = Math.round(hsl.l * 100);\n        return this.a === 1 ? \"hsl(\".concat(h, \", \").concat(s, \"%, \").concat(l, \"%)\") : \"hsla(\".concat(h, \", \").concat(s, \"%, \").concat(l, \"%, \").concat(this.roundA, \")\");\n    };\n    /**\n     * Returns the hex value of the color.\n     * @param allow3Char will shorten hex value to 3 char if possible\n     */\n    TinyColor.prototype.toHex = function (allow3Char) {\n        if (allow3Char === void 0) { allow3Char = false; }\n        return rgbToHex(this.r, this.g, this.b, allow3Char);\n    };\n    /**\n     * Returns the hex value of the color -with a # prefixed.\n     * @param allow3Char will shorten hex value to 3 char if possible\n     */\n    TinyColor.prototype.toHexString = function (allow3Char) {\n        if (allow3Char === void 0) { allow3Char = false; }\n        return '#' + this.toHex(allow3Char);\n    };\n    /**\n     * Returns the hex 8 value of the color.\n     * @param allow4Char will shorten hex value to 4 char if possible\n     */\n    TinyColor.prototype.toHex8 = function (allow4Char) {\n        if (allow4Char === void 0) { allow4Char = false; }\n        return rgbaToHex(this.r, this.g, this.b, this.a, allow4Char);\n    };\n    /**\n     * Returns the hex 8 value of the color -with a # prefixed.\n     * @param allow4Char will shorten hex value to 4 char if possible\n     */\n    TinyColor.prototype.toHex8String = function (allow4Char) {\n        if (allow4Char === void 0) { allow4Char = false; }\n        return '#' + this.toHex8(allow4Char);\n    };\n    /**\n     * Returns the shorter hex value of the color depends on its alpha -with a # prefixed.\n     * @param allowShortChar will shorten hex value to 3 or 4 char if possible\n     */\n    TinyColor.prototype.toHexShortString = function (allowShortChar) {\n        if (allowShortChar === void 0) { allowShortChar = false; }\n        return this.a === 1 ? this.toHexString(allowShortChar) : this.toHex8String(allowShortChar);\n    };\n    /**\n     * Returns the object as a RGBA object.\n     */\n    TinyColor.prototype.toRgb = function () {\n        return {\n            r: Math.round(this.r),\n            g: Math.round(this.g),\n            b: Math.round(this.b),\n            a: this.a,\n        };\n    };\n    /**\n     * Returns the RGBA values interpolated into a string with the following format:\n     * \"RGBA(xxx, xxx, xxx, xx)\".\n     */\n    TinyColor.prototype.toRgbString = function () {\n        var r = Math.round(this.r);\n        var g = Math.round(this.g);\n        var b = Math.round(this.b);\n        return this.a === 1 ? \"rgb(\".concat(r, \", \").concat(g, \", \").concat(b, \")\") : \"rgba(\".concat(r, \", \").concat(g, \", \").concat(b, \", \").concat(this.roundA, \")\");\n    };\n    /**\n     * Returns the object as a RGBA object.\n     */\n    TinyColor.prototype.toPercentageRgb = function () {\n        var fmt = function (x) { return \"\".concat(Math.round(bound01(x, 255) * 100), \"%\"); };\n        return {\n            r: fmt(this.r),\n            g: fmt(this.g),\n            b: fmt(this.b),\n            a: this.a,\n        };\n    };\n    /**\n     * Returns the RGBA relative values interpolated into a string\n     */\n    TinyColor.prototype.toPercentageRgbString = function () {\n        var rnd = function (x) { return Math.round(bound01(x, 255) * 100); };\n        return this.a === 1\n            ? \"rgb(\".concat(rnd(this.r), \"%, \").concat(rnd(this.g), \"%, \").concat(rnd(this.b), \"%)\")\n            : \"rgba(\".concat(rnd(this.r), \"%, \").concat(rnd(this.g), \"%, \").concat(rnd(this.b), \"%, \").concat(this.roundA, \")\");\n    };\n    /**\n     * The 'real' name of the color -if there is one.\n     */\n    TinyColor.prototype.toName = function () {\n        if (this.a === 0) {\n            return 'transparent';\n        }\n        if (this.a < 1) {\n            return false;\n        }\n        var hex = '#' + rgbToHex(this.r, this.g, this.b, false);\n        for (var _i = 0, _a = Object.entries(names); _i < _a.length; _i++) {\n            var _b = _a[_i], key = _b[0], value = _b[1];\n            if (hex === value) {\n                return key;\n            }\n        }\n        return false;\n    };\n    TinyColor.prototype.toString = function (format) {\n        var formatSet = Boolean(format);\n        format = format !== null && format !== void 0 ? format : this.format;\n        var formattedString = false;\n        var hasAlpha = this.a < 1 && this.a >= 0;\n        var needsAlphaFormat = !formatSet && hasAlpha && (format.startsWith('hex') || format === 'name');\n        if (needsAlphaFormat) {\n            // Special case for \"transparent\", all other non-alpha formats\n            // will return rgba when there is transparency.\n            if (format === 'name' && this.a === 0) {\n                return this.toName();\n            }\n            return this.toRgbString();\n        }\n        if (format === 'rgb') {\n            formattedString = this.toRgbString();\n        }\n        if (format === 'prgb') {\n            formattedString = this.toPercentageRgbString();\n        }\n        if (format === 'hex' || format === 'hex6') {\n            formattedString = this.toHexString();\n        }\n        if (format === 'hex3') {\n            formattedString = this.toHexString(true);\n        }\n        if (format === 'hex4') {\n            formattedString = this.toHex8String(true);\n        }\n        if (format === 'hex8') {\n            formattedString = this.toHex8String();\n        }\n        if (format === 'name') {\n            formattedString = this.toName();\n        }\n        if (format === 'hsl') {\n            formattedString = this.toHslString();\n        }\n        if (format === 'hsv') {\n            formattedString = this.toHsvString();\n        }\n        return formattedString || this.toHexString();\n    };\n    TinyColor.prototype.toNumber = function () {\n        return (Math.round(this.r) << 16) + (Math.round(this.g) << 8) + Math.round(this.b);\n    };\n    TinyColor.prototype.clone = function () {\n        return new TinyColor(this.toString());\n    };\n    /**\n     * Lighten the color a given amount. Providing 100 will always return white.\n     * @param amount - valid between 1-100\n     */\n    TinyColor.prototype.lighten = function (amount) {\n        if (amount === void 0) { amount = 10; }\n        var hsl = this.toHsl();\n        hsl.l += amount / 100;\n        hsl.l = clamp01(hsl.l);\n        return new TinyColor(hsl);\n    };\n    /**\n     * Brighten the color a given amount, from 0 to 100.\n     * @param amount - valid between 1-100\n     */\n    TinyColor.prototype.brighten = function (amount) {\n        if (amount === void 0) { amount = 10; }\n        var rgb = this.toRgb();\n        rgb.r = Math.max(0, Math.min(255, rgb.r - Math.round(255 * -(amount / 100))));\n        rgb.g = Math.max(0, Math.min(255, rgb.g - Math.round(255 * -(amount / 100))));\n        rgb.b = Math.max(0, Math.min(255, rgb.b - Math.round(255 * -(amount / 100))));\n        return new TinyColor(rgb);\n    };\n    /**\n     * Darken the color a given amount, from 0 to 100.\n     * Providing 100 will always return black.\n     * @param amount - valid between 1-100\n     */\n    TinyColor.prototype.darken = function (amount) {\n        if (amount === void 0) { amount = 10; }\n        var hsl = this.toHsl();\n        hsl.l -= amount / 100;\n        hsl.l = clamp01(hsl.l);\n        return new TinyColor(hsl);\n    };\n    /**\n     * Mix the color with pure white, from 0 to 100.\n     * Providing 0 will do nothing, providing 100 will always return white.\n     * @param amount - valid between 1-100\n     */\n    TinyColor.prototype.tint = function (amount) {\n        if (amount === void 0) { amount = 10; }\n        return this.mix('white', amount);\n    };\n    /**\n     * Mix the color with pure black, from 0 to 100.\n     * Providing 0 will do nothing, providing 100 will always return black.\n     * @param amount - valid between 1-100\n     */\n    TinyColor.prototype.shade = function (amount) {\n        if (amount === void 0) { amount = 10; }\n        return this.mix('black', amount);\n    };\n    /**\n     * Desaturate the color a given amount, from 0 to 100.\n     * Providing 100 will is the same as calling greyscale\n     * @param amount - valid between 1-100\n     */\n    TinyColor.prototype.desaturate = function (amount) {\n        if (amount === void 0) { amount = 10; }\n        var hsl = this.toHsl();\n        hsl.s -= amount / 100;\n        hsl.s = clamp01(hsl.s);\n        return new TinyColor(hsl);\n    };\n    /**\n     * Saturate the color a given amount, from 0 to 100.\n     * @param amount - valid between 1-100\n     */\n    TinyColor.prototype.saturate = function (amount) {\n        if (amount === void 0) { amount = 10; }\n        var hsl = this.toHsl();\n        hsl.s += amount / 100;\n        hsl.s = clamp01(hsl.s);\n        return new TinyColor(hsl);\n    };\n    /**\n     * Completely desaturates a color into greyscale.\n     * Same as calling `desaturate(100)`\n     */\n    TinyColor.prototype.greyscale = function () {\n        return this.desaturate(100);\n    };\n    /**\n     * Spin takes a positive or negative amount within [-360, 360] indicating the change of hue.\n     * Values outside of this range will be wrapped into this range.\n     */\n    TinyColor.prototype.spin = function (amount) {\n        var hsl = this.toHsl();\n        var hue = (hsl.h + amount) % 360;\n        hsl.h = hue < 0 ? 360 + hue : hue;\n        return new TinyColor(hsl);\n    };\n    /**\n     * Mix the current color a given amount with another color, from 0 to 100.\n     * 0 means no mixing (return current color).\n     */\n    TinyColor.prototype.mix = function (color, amount) {\n        if (amount === void 0) { amount = 50; }\n        var rgb1 = this.toRgb();\n        var rgb2 = new TinyColor(color).toRgb();\n        var p = amount / 100;\n        var rgba = {\n            r: (rgb2.r - rgb1.r) * p + rgb1.r,\n            g: (rgb2.g - rgb1.g) * p + rgb1.g,\n            b: (rgb2.b - rgb1.b) * p + rgb1.b,\n            a: (rgb2.a - rgb1.a) * p + rgb1.a,\n        };\n        return new TinyColor(rgba);\n    };\n    TinyColor.prototype.analogous = function (results, slices) {\n        if (results === void 0) { results = 6; }\n        if (slices === void 0) { slices = 30; }\n        var hsl = this.toHsl();\n        var part = 360 / slices;\n        var ret = [this];\n        for (hsl.h = (hsl.h - ((part * results) >> 1) + 720) % 360; --results;) {\n            hsl.h = (hsl.h + part) % 360;\n            ret.push(new TinyColor(hsl));\n        }\n        return ret;\n    };\n    /**\n     * taken from https://github.com/infusion/jQuery-xcolor/blob/master/jquery.xcolor.js\n     */\n    TinyColor.prototype.complement = function () {\n        var hsl = this.toHsl();\n        hsl.h = (hsl.h + 180) % 360;\n        return new TinyColor(hsl);\n    };\n    TinyColor.prototype.monochromatic = function (results) {\n        if (results === void 0) { results = 6; }\n        var hsv = this.toHsv();\n        var h = hsv.h;\n        var s = hsv.s;\n        var v = hsv.v;\n        var res = [];\n        var modification = 1 / results;\n        while (results--) {\n            res.push(new TinyColor({ h: h, s: s, v: v }));\n            v = (v + modification) % 1;\n        }\n        return res;\n    };\n    TinyColor.prototype.splitcomplement = function () {\n        var hsl = this.toHsl();\n        var h = hsl.h;\n        return [\n            this,\n            new TinyColor({ h: (h + 72) % 360, s: hsl.s, l: hsl.l }),\n            new TinyColor({ h: (h + 216) % 360, s: hsl.s, l: hsl.l }),\n        ];\n    };\n    /**\n     * Compute how the color would appear on a background\n     */\n    TinyColor.prototype.onBackground = function (background) {\n        var fg = this.toRgb();\n        var bg = new TinyColor(background).toRgb();\n        var alpha = fg.a + bg.a * (1 - fg.a);\n        return new TinyColor({\n            r: (fg.r * fg.a + bg.r * bg.a * (1 - fg.a)) / alpha,\n            g: (fg.g * fg.a + bg.g * bg.a * (1 - fg.a)) / alpha,\n            b: (fg.b * fg.a + bg.b * bg.a * (1 - fg.a)) / alpha,\n            a: alpha,\n        });\n    };\n    /**\n     * Alias for `polyad(3)`\n     */\n    TinyColor.prototype.triad = function () {\n        return this.polyad(3);\n    };\n    /**\n     * Alias for `polyad(4)`\n     */\n    TinyColor.prototype.tetrad = function () {\n        return this.polyad(4);\n    };\n    /**\n     * Get polyad colors, like (for 1, 2, 3, 4, 5, 6, 7, 8, etc...)\n     * monad, dyad, triad, tetrad, pentad, hexad, heptad, octad, etc...\n     */\n    TinyColor.prototype.polyad = function (n) {\n        var hsl = this.toHsl();\n        var h = hsl.h;\n        var result = [this];\n        var increment = 360 / n;\n        for (var i = 1; i < n; i++) {\n            result.push(new TinyColor({ h: (h + i * increment) % 360, s: hsl.s, l: hsl.l }));\n        }\n        return result;\n    };\n    /**\n     * compare color vs current color\n     */\n    TinyColor.prototype.equals = function (color) {\n        return this.toRgbString() === new TinyColor(color).toRgbString();\n    };\n    return TinyColor;\n}());\nexport { TinyColor };\n// kept for backwards compatability with v1\nexport function tinycolor(color, opts) {\n    if (color === void 0) { color = ''; }\n    if (opts === void 0) { opts = {}; }\n    return new TinyColor(color, opts);\n}\n", "import { computed } from 'vue'\nimport { TinyColor } from '@ctrl/tinycolor'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport type { ButtonProps } from './button'\n\nexport function darken(color: TinyColor, amount = 20) {\n  return color.mix('#141414', amount).toString()\n}\n\nexport function useButtonCustomStyle(props: ButtonProps) {\n  const _disabled = useFormDisabled()\n  const ns = useNamespace('button')\n\n  // calculate hover & active color by custom color\n  // only work when custom color\n  return computed(() => {\n    let styles: Record<string, string> = {}\n\n    let buttonColor = props.color\n\n    if (buttonColor) {\n      const match = (buttonColor as string).match(/var\\((.*?)\\)/)\n      if (match) {\n        buttonColor = window\n          .getComputedStyle(window.document.documentElement)\n          .getPropertyValue(match[1])\n      }\n      const color = new TinyColor(buttonColor)\n      const activeBgColor = props.dark\n        ? color.tint(20).toString()\n        : darken(color, 20)\n\n      if (props.plain) {\n        styles = ns.cssVarBlock({\n          'bg-color': props.dark\n            ? darken(color, 90)\n            : color.tint(90).toString(),\n          'text-color': buttonColor,\n          'border-color': props.dark\n            ? darken(color, 50)\n            : color.tint(50).toString(),\n          'hover-text-color': `var(${ns.cssVarName('color-white')})`,\n          'hover-bg-color': buttonColor,\n          'hover-border-color': buttonColor,\n          'active-bg-color': activeBgColor,\n          'active-text-color': `var(${ns.cssVarName('color-white')})`,\n          'active-border-color': activeBgColor,\n        })\n\n        if (_disabled.value) {\n          styles[ns.cssVarBlockName('disabled-bg-color')] = props.dark\n            ? darken(color, 90)\n            : color.tint(90).toString()\n          styles[ns.cssVarBlockName('disabled-text-color')] = props.dark\n            ? darken(color, 50)\n            : color.tint(50).toString()\n          styles[ns.cssVarBlockName('disabled-border-color')] = props.dark\n            ? darken(color, 80)\n            : color.tint(80).toString()\n        }\n      } else {\n        const hoverBgColor = props.dark\n          ? darken(color, 30)\n          : color.tint(30).toString()\n        const textColor = color.isDark()\n          ? `var(${ns.cssVarName('color-white')})`\n          : `var(${ns.cssVarName('color-black')})`\n        styles = ns.cssVarBlock({\n          'bg-color': buttonColor,\n          'text-color': textColor,\n          'border-color': buttonColor,\n          'hover-bg-color': hoverBgColor,\n          'hover-text-color': textColor,\n          'hover-border-color': hoverBgColor,\n          'active-bg-color': activeBgColor,\n          'active-border-color': activeBgColor,\n        })\n\n        if (_disabled.value) {\n          const disabledButtonColor = props.dark\n            ? darken(color, 50)\n            : color.tint(50).toString()\n          styles[ns.cssVarBlockName('disabled-bg-color')] = disabledButtonColor\n          styles[ns.cssVarBlockName('disabled-text-color')] = props.dark\n            ? 'rgba(255, 255, 255, 0.5)'\n            : `var(${ns.cssVarName('color-white')})`\n          styles[ns.cssVarBlockName('disabled-border-color')] =\n            disabledButtonColor\n        }\n      }\n    }\n\n    return styles\n  })\n}\n", "<template>\n  <component\n    :is=\"tag\"\n    ref=\"_ref\"\n    v-bind=\"_props\"\n    :class=\"buttonKls\"\n    :style=\"buttonStyle\"\n    @click=\"handleClick\"\n  >\n    <template v-if=\"loading\">\n      <slot v-if=\"$slots.loading\" name=\"loading\" />\n      <el-icon v-else :class=\"ns.is('loading')\">\n        <component :is=\"loadingIcon\" />\n      </el-icon>\n    </template>\n    <el-icon v-else-if=\"icon || $slots.icon\">\n      <component :is=\"icon\" v-if=\"icon\" />\n      <slot v-else name=\"icon\" />\n    </el-icon>\n    <span\n      v-if=\"$slots.default\"\n      :class=\"{ [ns.em('text', 'expand')]: shouldAddSpace }\"\n    >\n      <slot />\n    </span>\n  </component>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useButton } from './use-button'\nimport { buttonEmits, buttonProps } from './button'\nimport { useButtonCustomStyle } from './button-custom'\n\ndefineOptions({\n  name: 'ElButton',\n})\n\nconst props = defineProps(buttonProps)\nconst emit = defineEmits(buttonEmits)\n\nconst buttonStyle = useButtonCustomStyle(props)\nconst ns = useNamespace('button')\nconst { _ref, _size, _type, _disabled, _props, shouldAddSpace, handleClick } =\n  useButton(props, emit)\nconst buttonKls = computed(() => [\n  ns.b(),\n  ns.m(_type.value),\n  ns.m(_size.value),\n  ns.is('disabled', _disabled.value),\n  ns.is('loading', props.loading),\n  ns.is('plain', props.plain),\n  ns.is('round', props.round),\n  ns.is('circle', props.circle),\n  ns.is('text', props.text),\n  ns.is('link', props.link),\n  ns.is('has-bg', props.bg),\n])\n\ndefineExpose({\n  /** @description button html element */\n  ref: _ref,\n  /** @description button size */\n  size: _size,\n  /** @description button type */\n  type: _type,\n  /** @description button disabled */\n  disabled: _disabled,\n  /** @description whether adding space */\n  shouldAddSpace,\n})\n</script>\n", "import { buttonProps } from './button'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const buttonGroupProps = {\n  /**\n   * @description control the size of buttons in this button-group\n   */\n  size: buttonProps.size,\n  /**\n   * @description control the type of buttons in this button-group\n   */\n  type: buttonProps.type,\n} as const\nexport type ButtonGroupProps = ExtractPropTypes<typeof buttonGroupProps>\n", "<template>\n  <div :class=\"ns.b('group')\">\n    <slot />\n  </div>\n</template>\n<script lang=\"ts\" setup>\nimport { provide, reactive, toRef } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { buttonGroupProps } from './button-group'\nimport { buttonGroupContextKey } from './constants'\n\ndefineOptions({\n  name: 'ElButtonGroup',\n})\nconst props = defineProps(buttonGroupProps)\nprovide(\n  buttonGroupContextKey,\n  reactive({\n    size: toRef(props, 'size'),\n    type: toRef(props, 'type'),\n  })\n)\nconst ns = useNamespace('button')\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Button from './src/button.vue'\nimport ButtonGroup from './src/button-group.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElButton: SFCWithInstall<typeof Button> & {\n  ButtonGroup: typeof ButtonGroup\n} = withInstall(Button, {\n  ButtonGroup,\n})\nexport const ElButtonGroup: SFCWithInstall<typeof ButtonGroup> =\n  withNoopInstall(ButtonGroup)\nexport default ElButton\n\nexport * from './src/button'\nexport * from './src/constants'\nexport type { ButtonInstance, ButtonGroupInstance } from './src/instance'\n", "export const timeUnits = ['hours', 'minutes', 'seconds'] as const\n\nexport const DEFAULT_FORMATS_TIME = 'HH:mm:ss'\nexport const DEFAULT_FORMATS_DATE = 'YYYY-MM-DD'\nexport const DEFAULT_FORMATS_DATEPICKER = {\n  date: DEFAULT_FORMATS_DATE,\n  dates: DEFAULT_FORMATS_DATE,\n  week: 'gggg[w]ww',\n  year: 'YYYY',\n  years: 'YYYY',\n  month: 'YYYY-MM',\n  months: 'YYYY-MM',\n  datetime: `${DEFAULT_FORMATS_DATE} ${DEFAULT_FORMATS_TIME}`,\n  monthrange: 'YYYY-MM',\n  yearrange: 'YYYY',\n  daterange: DEFAULT_FORMATS_DATE,\n  datetimerange: `${DEFAULT_FORMATS_DATE} ${DEFAULT_FORMATS_TIME}`,\n}\n\nexport type TimeUnit = typeof timeUnits[number]\n", "import dayjs from 'dayjs'\nimport { isArray, isDate, isEmpty } from '@element-plus/utils'\n\nimport type { Dayjs } from 'dayjs'\nexport type TimeList = [number | undefined, number, undefined | number]\n\nexport const buildTimeList = (value: number, bound: number): TimeList => {\n  return [\n    value > 0 ? value - 1 : undefined,\n    value,\n    value < bound ? value + 1 : undefined,\n  ]\n}\n\nexport const rangeArr = (n: number) =>\n  Array.from(Array.from({ length: n }).keys())\n\nexport const extractDateFormat = (format: string) => {\n  return format\n    .replace(/\\W?m{1,2}|\\W?ZZ/g, '')\n    .replace(/\\W?h{1,2}|\\W?s{1,3}|\\W?a/gi, '')\n    .trim()\n}\n\nexport const extractTimeFormat = (format: string) => {\n  return format\n    .replace(/\\W?D{1,2}|\\W?Do|\\W?d{1,4}|\\W?M{1,4}|\\W?Y{2,4}/g, '')\n    .trim()\n}\n\nexport const dateEquals = function (a: Date | unknown, b: Date | unknown) {\n  const aIsDate = isDate(a)\n  const bIsDate = isDate(b)\n  if (aIsDate && bIsDate) {\n    return a.getTime() === b.getTime()\n  }\n  if (!aIsDate && !bIsDate) {\n    return a === b\n  }\n  return false\n}\n\nexport const valueEquals = function (\n  a: Array<Date> | unknown,\n  b: Array<Date> | unknown\n) {\n  const aIsArray = isArray(a)\n  const bIsArray = isArray(b)\n  if (aIsArray && bIsArray) {\n    if (a.length !== b.length) {\n      return false\n    }\n    return a.every((item, index) => dateEquals(item, b[index]))\n  }\n  if (!aIsArray && !bIsArray) {\n    return dateEquals(a, b)\n  }\n  return false\n}\n\nexport const parseDate = function (\n  date: string | number | Date,\n  format: string | undefined,\n  lang: string\n) {\n  const day =\n    isEmpty(format) || format === 'x'\n      ? dayjs(date).locale(lang)\n      : dayjs(date, format).locale(lang)\n  return day.isValid() ? day : undefined\n}\n\nexport const formatter = function (\n  date: string | number | Date | Dayjs,\n  format: string | undefined,\n  lang: string\n) {\n  if (isEmpty(format)) return date\n  if (format === 'x') return +date\n  return dayjs(date).locale(lang).format(format)\n}\n\nexport const makeList = (total: number, method?: () => number[]) => {\n  const arr: boolean[] = []\n  const disabledArr = method?.()\n  for (let i = 0; i < total; i++) {\n    arr.push(disabledArr?.includes(i) ?? false)\n  }\n  return arr\n}\n", "import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport type GetDisabledHours = (role: string, comparingDate?: Dayjs) => number[]\nexport type GetDisabledMinutes = (\n  hour: number,\n  role: string,\n  comparingDate?: Dayjs\n) => number[]\nexport type GetDisabledSeconds = (\n  hour: number,\n  minute: number,\n  role: string,\n  comparingDate?: Dayjs\n) => number[]\n\nexport const disabledTimeListsProps = buildProps({\n  /**\n   * @description To specify the array of hours that cannot be selected\n   */\n  disabledHours: {\n    type: definePropType<GetDisabledHours>(Function),\n  },\n  /**\n   * @description To specify the array of minutes that cannot be selected\n   */\n  disabledMinutes: {\n    type: definePropType<GetDisabledMinutes>(Function),\n  },\n  /**\n   * @description To specify the array of seconds that cannot be selected\n   */\n  disabledSeconds: {\n    type: definePropType<GetDisabledSeconds>(Function),\n  },\n} as const)\n\nexport type DisabledTimeListsProps = ExtractPropTypes<\n  typeof disabledTimeListsProps\n>\n\nexport const timePanelSharedProps = buildProps({\n  visible: Boolean,\n  actualVisible: {\n    type: Boolean,\n    default: undefined,\n  },\n  format: {\n    type: String,\n    default: '',\n  },\n} as const)\n\nexport type TimePanelSharedProps = ExtractPropTypes<typeof timePanelSharedProps>\n", "import { placements } from '@popperjs/core'\nimport { buildProps, definePropType } from '@element-plus/utils'\nimport {\n  useAriaProps,\n  useEmptyValuesProps,\n  useSizeProp,\n} from '@element-plus/hooks'\nimport { CircleClose } from '@element-plus/icons-vue'\nimport { disabledTimeListsProps } from '../props/shared'\n\nimport type { Component, ExtractPropTypes } from 'vue'\nimport type { Options } from '@popperjs/core'\nimport type { Dayjs } from 'dayjs'\nimport type { Placement } from '@element-plus/components/popper'\n\nexport type SingleOrRange<T> = T | [T, T]\nexport type DateModelType = number | string | Date\nexport type ModelValueType = SingleOrRange<DateModelType> | string[]\nexport type DayOrDays = SingleOrRange<Dayjs>\nexport type DateOrDates = SingleOrRange<Date>\nexport type UserInput = SingleOrRange<string | null>\nexport type GetDisabledHours = (role: string, comparingDate?: Dayjs) => number[]\nexport type GetDisabledMinutes = (\n  hour: number,\n  role: string,\n  comparingDate?: Dayjs\n) => number[]\nexport type GetDisabledSeconds = (\n  hour: number,\n  minute: number,\n  role: string,\n  comparingDate?: Dayjs\n) => number[]\n\nexport const timePickerDefaultProps = buildProps({\n  /**\n   * @description same as `id` in native input\n   */\n  id: {\n    type: definePropType<SingleOrRange<string>>([Array, String]),\n  },\n  /**\n   * @description same as `name` in native input\n   */\n  name: {\n    type: definePropType<SingleOrRange<string>>([Array, String]),\n    default: '',\n  },\n  /**\n   * @description custom class name for TimePicker's dropdown\n   */\n  popperClass: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description format of the displayed value in the input box\n   */\n  format: String,\n  /**\n   * @description optional, format of binding value. If not specified, the binding value will be a Date object\n   */\n  valueFormat: String,\n  /**\n   * @description optional, format of the date displayed value in TimePicker's dropdown\n   */\n  dateFormat: String,\n  /**\n   * @description optional, format of the time displayed value in TimePicker's dropdown\n   */\n  timeFormat: String,\n  /**\n   * @description type of the picker\n   */\n  type: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description whether to show clear button\n   */\n  clearable: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description Custom clear icon component\n   */\n  clearIcon: {\n    type: definePropType<string | Component>([String, Object]),\n    default: CircleClose,\n  },\n  /**\n   * @description whether the input is editable\n   */\n  editable: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description Custom prefix icon component\n   */\n  prefixIcon: {\n    type: definePropType<string | Component>([String, Object]),\n    default: '',\n  },\n  /**\n   * @description size of Input\n   */\n  size: useSizeProp,\n  /**\n   * @description whether TimePicker is read only\n   */\n  readonly: Boolean,\n  /**\n   * @description whether TimePicker is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description placeholder in non-range mode\n   */\n  placeholder: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n   */\n  popperOptions: {\n    type: definePropType<Partial<Options>>(Object),\n    default: () => ({}),\n  },\n  /**\n   * @description binding value, if it is an array, the length should be 2\n   */\n  modelValue: {\n    type: definePropType<ModelValueType>([Date, Array, String, Number]),\n    default: '',\n  },\n  /**\n   * @description range separator\n   */\n  rangeSeparator: {\n    type: String,\n    default: '-',\n  },\n  /**\n   * @description placeholder for the start date in range mode\n   */\n  startPlaceholder: String,\n  /**\n   * @description placeholder for the end date in range mode\n   */\n  endPlaceholder: String,\n  /**\n   * @description optional, default date of the calendar\n   */\n  defaultValue: {\n    type: definePropType<SingleOrRange<Date>>([Date, Array]),\n  },\n  /**\n   * @description optional, the time value to use when selecting date range\n   */\n  defaultTime: {\n    type: definePropType<SingleOrRange<Date>>([Date, Array]),\n  },\n  /**\n   * @description whether to pick a time range\n   */\n  isRange: Boolean,\n  ...disabledTimeListsProps,\n  /**\n   * @description a function determining if a date is disabled with that date as its parameter. Should return a Boolean\n   */\n  disabledDate: {\n    type: Function,\n  },\n  /**\n   * @description set custom className\n   */\n  cellClassName: {\n    type: Function,\n  },\n  /**\n   * @description an object array to set shortcut options\n   */\n  shortcuts: {\n    type: Array,\n    default: () => [],\n  },\n  /**\n   * @description whether to pick time using arrow buttons\n   */\n  arrowControl: Boolean,\n  /**\n   * @description input tabindex\n   */\n  tabindex: {\n    type: definePropType<string | number>([String, Number]),\n    default: 0,\n  },\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description unlink two date-panels in range-picker\n   */\n  unlinkPanels: Boolean,\n  /**\n   * @description position of dropdown\n   */\n  placement: {\n    type: definePropType<Placement>(String),\n    values: placements,\n    default: 'bottom',\n  },\n  /**\n   * @description list of possible positions for dropdown\n   */\n  fallbackPlacements: {\n    type: definePropType<Placement[]>(Array),\n    default: ['bottom', 'top', 'right', 'left'],\n  },\n  ...useEmptyValuesProps,\n  ...useAriaProps(['ariaLabel']),\n} as const)\n\nexport type TimePickerDefaultProps = ExtractPropTypes<\n  typeof timePickerDefaultProps\n>\n\nexport interface PickerOptions {\n  isValidValue: (date: DayOrDays) => boolean\n  handleKeydownInput: (event: KeyboardEvent) => void\n  parseUserInput: (value: UserInput) => DayOrDays\n  formatToString: (value: DayOrDays) => UserInput\n  getRangeAvailableTime: (date: DayOrDays) => DayOrDays\n  getDefaultValue: () => DayOrDays\n  panelReady: boolean\n  handleClear: () => void\n  handleFocusPicker?: () => void\n}\n", "<template>\n  <el-tooltip\n    ref=\"refPopper\"\n    :visible=\"pickerVisible\"\n    effect=\"light\"\n    pure\n    trigger=\"click\"\n    v-bind=\"$attrs\"\n    role=\"dialog\"\n    teleported\n    :transition=\"`${nsDate.namespace.value}-zoom-in-top`\"\n    :popper-class=\"[`${nsDate.namespace.value}-picker__popper`, popperClass]\"\n    :popper-options=\"elPopperOptions\"\n    :fallback-placements=\"fallbackPlacements\"\n    :gpu-acceleration=\"false\"\n    :placement=\"placement\"\n    :stop-popper-mouse-event=\"false\"\n    :hide-after=\"0\"\n    persistent\n    @before-show=\"onBeforeShow\"\n    @show=\"onShow\"\n    @hide=\"onHide\"\n  >\n    <template #default>\n      <el-input\n        v-if=\"!isRangeInput\"\n        :id=\"(id as string | undefined)\"\n        ref=\"inputRef\"\n        container-role=\"combobox\"\n        :model-value=\"(displayValue as string)\"\n        :name=\"name\"\n        :size=\"pickerSize\"\n        :disabled=\"pickerDisabled\"\n        :placeholder=\"placeholder\"\n        :class=\"[nsDate.b('editor'), nsDate.bm('editor', type), $attrs.class]\"\n        :style=\"$attrs.style\"\n        :readonly=\"\n          !editable ||\n          readonly ||\n          isDatesPicker ||\n          isMonthsPicker ||\n          isYearsPicker ||\n          type === 'week'\n        \"\n        :aria-label=\"ariaLabel\"\n        :tabindex=\"tabindex\"\n        :validate-event=\"false\"\n        @input=\"onUserInput\"\n        @focus=\"handleFocusInput\"\n        @blur=\"handleBlurInput\"\n        @keydown=\"\n          //\n          handleKeydownInput as any\n        \"\n        @change=\"handleChange\"\n        @mousedown=\"onMouseDownInput\"\n        @mouseenter=\"onMouseEnter\"\n        @mouseleave=\"onMouseLeave\"\n        @touchstart.passive=\"onTouchStartInput\"\n        @click.stop\n      >\n        <template #prefix>\n          <el-icon\n            v-if=\"triggerIcon\"\n            :class=\"nsInput.e('icon')\"\n            @mousedown.prevent=\"onMouseDownInput\"\n            @touchstart.passive=\"onTouchStartInput\"\n          >\n            <component :is=\"triggerIcon\" />\n          </el-icon>\n        </template>\n        <template #suffix>\n          <el-icon\n            v-if=\"showClose && clearIcon\"\n            :class=\"`${nsInput.e('icon')} clear-icon`\"\n            @click.stop=\"onClearIconClick\"\n          >\n            <component :is=\"clearIcon\" />\n          </el-icon>\n        </template>\n      </el-input>\n      <div\n        v-else\n        ref=\"inputRef\"\n        :class=\"rangeInputKls\"\n        :style=\"($attrs.style as any)\"\n        @click=\"handleFocusInput\"\n        @mouseenter=\"onMouseEnter\"\n        @mouseleave=\"onMouseLeave\"\n        @touchstart.passive=\"onTouchStartInput\"\n        @keydown=\"handleKeydownInput\"\n      >\n        <el-icon\n          v-if=\"triggerIcon\"\n          :class=\"[nsInput.e('icon'), nsRange.e('icon')]\"\n          @mousedown.prevent=\"onMouseDownInput\"\n          @touchstart.passive=\"onTouchStartInput\"\n        >\n          <component :is=\"triggerIcon\" />\n        </el-icon>\n        <input\n          :id=\"id && id[0]\"\n          autocomplete=\"off\"\n          :name=\"name && name[0]\"\n          :placeholder=\"startPlaceholder\"\n          :value=\"displayValue && displayValue[0]\"\n          :disabled=\"pickerDisabled\"\n          :readonly=\"!editable || readonly\"\n          :class=\"nsRange.b('input')\"\n          @mousedown=\"onMouseDownInput\"\n          @input=\"handleStartInput\"\n          @change=\"handleStartChange\"\n          @focus=\"handleFocusInput\"\n          @blur=\"handleBlurInput\"\n        />\n        <slot name=\"range-separator\">\n          <span :class=\"nsRange.b('separator')\">{{ rangeSeparator }}</span>\n        </slot>\n        <input\n          :id=\"id && id[1]\"\n          autocomplete=\"off\"\n          :name=\"name && name[1]\"\n          :placeholder=\"endPlaceholder\"\n          :value=\"displayValue && displayValue[1]\"\n          :disabled=\"pickerDisabled\"\n          :readonly=\"!editable || readonly\"\n          :class=\"nsRange.b('input')\"\n          @mousedown=\"onMouseDownInput\"\n          @focus=\"handleFocusInput\"\n          @blur=\"handleBlurInput\"\n          @input=\"handleEndInput\"\n          @change=\"handleEndChange\"\n        />\n        <el-icon\n          v-if=\"clearIcon\"\n          :class=\"clearIconKls\"\n          @click=\"onClearIconClick\"\n        >\n          <component :is=\"clearIcon\" />\n        </el-icon>\n      </div>\n    </template>\n    <template #content>\n      <slot\n        :visible=\"pickerVisible\"\n        :actual-visible=\"pickerActualVisible\"\n        :parsed-value=\"parsedValue\"\n        :format=\"format\"\n        :date-format=\"dateFormat\"\n        :time-format=\"timeFormat\"\n        :unlink-panels=\"unlinkPanels\"\n        :type=\"type\"\n        :default-value=\"defaultValue\"\n        @pick=\"onPick\"\n        @select-range=\"setSelectionRange\"\n        @set-picker-option=\"onSetPickerOption\"\n        @calendar-change=\"onCalendarChange\"\n        @panel-change=\"onPanelChange\"\n        @keydown=\"onKeydownPopperContent\"\n        @mousedown.stop\n      />\n    </template>\n  </el-tooltip>\n</template>\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  inject,\n  nextTick,\n  onBeforeUnmount,\n  provide,\n  ref,\n  unref,\n  useAttrs,\n  watch,\n} from 'vue'\nimport { isEqual } from 'lodash-unified'\nimport { onClickOutside } from '@vueuse/core'\nimport { useEmptyValues, useLocale, useNamespace } from '@element-plus/hooks'\nimport { useFormItem, useFormSize } from '@element-plus/components/form'\nimport ElInput from '@element-plus/components/input'\nimport ElIcon from '@element-plus/components/icon'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport { debugWarn, isArray } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { Calendar, Clock } from '@element-plus/icons-vue'\nimport { formatter, parseDate, valueEquals } from '../utils'\nimport { timePickerDefaultProps } from './props'\n\nimport type { Dayjs } from 'dayjs'\nimport type { ComponentPublicInstance } from 'vue'\nimport type { Options } from '@popperjs/core'\nimport type {\n  DateModelType,\n  DateOrDates,\n  DayOrDays,\n  PickerOptions,\n  SingleOrRange,\n  TimePickerDefaultProps,\n  UserInput,\n} from './props'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\n\n// Date object and string\n\ndefineOptions({\n  name: 'Picker',\n})\n\nconst props = defineProps(timePickerDefaultProps)\nconst emit = defineEmits([\n  'update:modelValue',\n  'change',\n  'focus',\n  'blur',\n  'clear',\n  'calendar-change',\n  'panel-change',\n  'visible-change',\n  'keydown',\n])\nconst attrs = useAttrs()\n\nconst { lang } = useLocale()\n\nconst nsDate = useNamespace('date')\nconst nsInput = useNamespace('input')\nconst nsRange = useNamespace('range')\n\nconst { form, formItem } = useFormItem()\nconst elPopperOptions = inject('ElPopperOptions', {} as Options)\nconst { valueOnClear } = useEmptyValues(props, null)\n\nconst refPopper = ref<TooltipInstance>()\nconst inputRef = ref<HTMLElement | ComponentPublicInstance>()\nconst pickerVisible = ref(false)\nconst pickerActualVisible = ref(false)\nconst valueOnOpen = ref<TimePickerDefaultProps['modelValue'] | null>(null)\n\nlet hasJustTabExitedInput = false\nlet ignoreFocusEvent = false\n\nconst rangeInputKls = computed(() => [\n  nsDate.b('editor'),\n  nsDate.bm('editor', props.type),\n  nsInput.e('wrapper'),\n  nsDate.is('disabled', pickerDisabled.value),\n  nsDate.is('active', pickerVisible.value),\n  nsRange.b('editor'),\n  pickerSize ? nsRange.bm('editor', pickerSize.value) : '',\n  attrs.class,\n])\n\nconst clearIconKls = computed(() => [\n  nsInput.e('icon'),\n  nsRange.e('close-icon'),\n  !showClose.value ? nsRange.e('close-icon--hidden') : '',\n])\n\nwatch(pickerVisible, (val) => {\n  if (!val) {\n    userInput.value = null\n    nextTick(() => {\n      emitChange(props.modelValue)\n    })\n  } else {\n    nextTick(() => {\n      if (val) {\n        valueOnOpen.value = props.modelValue\n      }\n    })\n  }\n})\nconst emitChange = (\n  val: TimePickerDefaultProps['modelValue'] | null,\n  isClear?: boolean\n) => {\n  // determine user real change only\n  if (isClear || !valueEquals(val, valueOnOpen.value)) {\n    emit('change', val)\n    props.validateEvent &&\n      formItem?.validate('change').catch((err) => debugWarn(err))\n  }\n}\nconst emitInput = (input: SingleOrRange<DateModelType | Dayjs> | null) => {\n  if (!valueEquals(props.modelValue, input)) {\n    let formatted\n    if (isArray(input)) {\n      formatted = input.map((item) =>\n        formatter(item, props.valueFormat, lang.value)\n      )\n    } else if (input) {\n      formatted = formatter(input, props.valueFormat, lang.value)\n    }\n    emit('update:modelValue', input ? formatted : input, lang.value)\n  }\n}\nconst emitKeydown = (e: KeyboardEvent) => {\n  emit('keydown', e)\n}\n\nconst refInput = computed<HTMLInputElement[]>(() => {\n  if (inputRef.value) {\n    const _r = isRangeInput.value\n      ? inputRef.value\n      : (inputRef.value as any as ComponentPublicInstance).$el\n    return Array.from<HTMLInputElement>(_r.querySelectorAll('input'))\n  }\n  return []\n})\n\nconst setSelectionRange = (start: number, end: number, pos?: 'min' | 'max') => {\n  const _inputs = refInput.value\n  if (!_inputs.length) return\n  if (!pos || pos === 'min') {\n    _inputs[0].setSelectionRange(start, end)\n    _inputs[0].focus()\n  } else if (pos === 'max') {\n    _inputs[1].setSelectionRange(start, end)\n    _inputs[1].focus()\n  }\n}\nconst focusOnInputBox = () => {\n  focus(true, true)\n  nextTick(() => {\n    ignoreFocusEvent = false\n  })\n}\n\nconst onPick = (date: any = '', visible = false) => {\n  if (!visible) {\n    ignoreFocusEvent = true\n  }\n  pickerVisible.value = visible\n  let result\n  if (isArray(date)) {\n    result = date.map((_) => _.toDate())\n  } else {\n    // clear btn emit null\n    result = date ? date.toDate() : date\n  }\n  userInput.value = null\n  emitInput(result)\n}\n\nconst onBeforeShow = () => {\n  pickerActualVisible.value = true\n}\n\nconst onShow = () => {\n  emit('visible-change', true)\n}\n\nconst onKeydownPopperContent = (event: KeyboardEvent) => {\n  if ((event as KeyboardEvent)?.key === EVENT_CODE.esc) {\n    focus(true, true)\n  }\n}\n\nconst onHide = () => {\n  pickerActualVisible.value = false\n  pickerVisible.value = false\n  ignoreFocusEvent = false\n  emit('visible-change', false)\n}\n\nconst handleOpen = () => {\n  pickerVisible.value = true\n}\n\nconst handleClose = () => {\n  pickerVisible.value = false\n}\n\nconst focus = (focusStartInput = true, isIgnoreFocusEvent = false) => {\n  ignoreFocusEvent = isIgnoreFocusEvent\n  const [leftInput, rightInput] = unref(refInput)\n  let input = leftInput\n  if (!focusStartInput && isRangeInput.value) {\n    input = rightInput\n  }\n  if (input) {\n    input.focus()\n  }\n}\n\nconst handleFocusInput = (e?: FocusEvent) => {\n  if (\n    props.readonly ||\n    pickerDisabled.value ||\n    pickerVisible.value ||\n    ignoreFocusEvent\n  ) {\n    return\n  }\n  pickerVisible.value = true\n  emit('focus', e)\n}\n\nlet currentHandleBlurDeferCallback:\n  | (() => Promise<void> | undefined)\n  | undefined = undefined\n\n// Check if document.activeElement is inside popper or any input before popper close\nconst handleBlurInput = (e?: FocusEvent) => {\n  const handleBlurDefer = async () => {\n    setTimeout(() => {\n      if (currentHandleBlurDeferCallback === handleBlurDefer) {\n        if (\n          !(\n            refPopper.value?.isFocusInsideContent() && !hasJustTabExitedInput\n          ) &&\n          refInput.value.filter((input) => {\n            return input.contains(document.activeElement)\n          }).length === 0\n        ) {\n          handleChange()\n          pickerVisible.value = false\n          emit('blur', e)\n          props.validateEvent &&\n            formItem?.validate('blur').catch((err) => debugWarn(err))\n        }\n        hasJustTabExitedInput = false\n      }\n    }, 0)\n  }\n  currentHandleBlurDeferCallback = handleBlurDefer\n  handleBlurDefer()\n}\n\nconst pickerDisabled = computed(() => {\n  return props.disabled || form?.disabled\n})\n\nconst parsedValue = computed(() => {\n  let dayOrDays: DayOrDays\n  if (valueIsEmpty.value) {\n    if (pickerOptions.value.getDefaultValue) {\n      dayOrDays = pickerOptions.value.getDefaultValue()\n    }\n  } else {\n    if (isArray(props.modelValue)) {\n      dayOrDays = props.modelValue.map((d) =>\n        parseDate(d, props.valueFormat, lang.value)\n      ) as [Dayjs, Dayjs]\n    } else {\n      dayOrDays = parseDate(props.modelValue, props.valueFormat, lang.value)!\n    }\n  }\n\n  if (pickerOptions.value.getRangeAvailableTime) {\n    const availableResult = pickerOptions.value.getRangeAvailableTime(\n      dayOrDays!\n    )\n    if (!isEqual(availableResult, dayOrDays!)) {\n      dayOrDays = availableResult\n\n      // The result is corrected only when model-value exists\n      if (!valueIsEmpty.value) {\n        emitInput(\n          (isArray(dayOrDays)\n            ? dayOrDays.map((_) => _.toDate())\n            : dayOrDays.toDate()) as SingleOrRange<Date>\n        )\n      }\n    }\n  }\n  if (isArray(dayOrDays!) && dayOrDays.some((day) => !day)) {\n    dayOrDays = [] as unknown as DayOrDays\n  }\n  return dayOrDays!\n})\n\nconst displayValue = computed<UserInput>(() => {\n  if (!pickerOptions.value.panelReady) return ''\n  const formattedValue = formatDayjsToString(parsedValue.value)\n  if (isArray(userInput.value)) {\n    return [\n      userInput.value[0] || (formattedValue && formattedValue[0]) || '',\n      userInput.value[1] || (formattedValue && formattedValue[1]) || '',\n    ]\n  } else if (userInput.value !== null) {\n    return userInput.value\n  }\n  if (!isTimePicker.value && valueIsEmpty.value) return ''\n  if (!pickerVisible.value && valueIsEmpty.value) return ''\n  if (formattedValue) {\n    return isDatesPicker.value || isMonthsPicker.value || isYearsPicker.value\n      ? (formattedValue as Array<string>).join(', ')\n      : formattedValue\n  }\n  return ''\n})\n\nconst isTimeLikePicker = computed(() => props.type.includes('time'))\n\nconst isTimePicker = computed(() => props.type.startsWith('time'))\n\nconst isDatesPicker = computed(() => props.type === 'dates')\n\nconst isMonthsPicker = computed(() => props.type === 'months')\n\nconst isYearsPicker = computed(() => props.type === 'years')\n\nconst triggerIcon = computed(\n  () => props.prefixIcon || (isTimeLikePicker.value ? Clock : Calendar)\n)\n\nconst showClose = ref(false)\n\nconst onClearIconClick = (event: MouseEvent) => {\n  if (props.readonly || pickerDisabled.value) return\n  if (showClose.value) {\n    event.stopPropagation()\n    focusOnInputBox()\n    // When the handleClear Function was provided, emit null will be executed inside it\n    // There is no need for us to execute emit null twice. #14752\n    if (pickerOptions.value.handleClear) {\n      pickerOptions.value.handleClear()\n    } else {\n      emitInput(valueOnClear.value)\n    }\n    emitChange(valueOnClear.value, true)\n    showClose.value = false\n    onHide()\n  }\n  emit('clear')\n}\n\nconst valueIsEmpty = computed(() => {\n  const { modelValue } = props\n  return (\n    !modelValue || (isArray(modelValue) && !modelValue.filter(Boolean).length)\n  )\n})\n\nconst onMouseDownInput = async (event: MouseEvent) => {\n  if (props.readonly || pickerDisabled.value) return\n  if (\n    (event.target as HTMLElement)?.tagName !== 'INPUT' ||\n    refInput.value.includes(document.activeElement as HTMLInputElement)\n  ) {\n    pickerVisible.value = true\n  }\n}\nconst onMouseEnter = () => {\n  if (props.readonly || pickerDisabled.value) return\n  if (!valueIsEmpty.value && props.clearable) {\n    showClose.value = true\n  }\n}\nconst onMouseLeave = () => {\n  showClose.value = false\n}\nconst onTouchStartInput = (event: TouchEvent) => {\n  if (props.readonly || pickerDisabled.value) return\n  if (\n    (event.touches[0].target as HTMLElement)?.tagName !== 'INPUT' ||\n    refInput.value.includes(document.activeElement as HTMLInputElement)\n  ) {\n    pickerVisible.value = true\n  }\n}\nconst isRangeInput = computed(() => {\n  return props.type.includes('range')\n})\n\nconst pickerSize = useFormSize()\n\nconst popperEl = computed(() => unref(refPopper)?.popperRef?.contentRef)\nconst actualInputRef = computed(() => {\n  if (unref(isRangeInput)) {\n    return unref(inputRef)\n  }\n\n  return (unref(inputRef) as ComponentPublicInstance)?.$el\n})\n\nconst stophandle = onClickOutside(actualInputRef, (e: PointerEvent) => {\n  const unrefedPopperEl = unref(popperEl)\n  const inputEl = unref(actualInputRef)\n  if (\n    (unrefedPopperEl &&\n      (e.target === unrefedPopperEl ||\n        e.composedPath().includes(unrefedPopperEl))) ||\n    e.target === inputEl ||\n    e.composedPath().includes(inputEl)\n  )\n    return\n  pickerVisible.value = false\n})\n\nonBeforeUnmount(() => {\n  stophandle?.()\n})\n\nconst userInput = ref<UserInput>(null)\n\nconst handleChange = () => {\n  if (userInput.value) {\n    const value = parseUserInputToDayjs(displayValue.value)\n    if (value) {\n      if (isValidValue(value)) {\n        emitInput(\n          (isArray(value)\n            ? value.map((_) => _.toDate())\n            : value.toDate()) as DateOrDates\n        )\n        userInput.value = null\n      }\n    }\n  }\n  if (userInput.value === '') {\n    emitInput(valueOnClear.value)\n    emitChange(valueOnClear.value)\n    userInput.value = null\n  }\n}\n\nconst parseUserInputToDayjs = (value: UserInput) => {\n  if (!value) return null\n  return pickerOptions.value.parseUserInput!(value)\n}\n\nconst formatDayjsToString = (value: DayOrDays) => {\n  if (!value) return null\n  return pickerOptions.value.formatToString!(value)\n}\n\nconst isValidValue = (value: DayOrDays) => {\n  return pickerOptions.value.isValidValue!(value)\n}\n\nconst handleKeydownInput = async (event: KeyboardEvent) => {\n  if (props.readonly || pickerDisabled.value) return\n\n  const { code } = event\n  emitKeydown(event)\n  if (code === EVENT_CODE.esc) {\n    if (pickerVisible.value === true) {\n      pickerVisible.value = false\n      event.preventDefault()\n      event.stopPropagation()\n    }\n    return\n  }\n\n  if (code === EVENT_CODE.down) {\n    if (pickerOptions.value.handleFocusPicker) {\n      event.preventDefault()\n      event.stopPropagation()\n    }\n    if (pickerVisible.value === false) {\n      pickerVisible.value = true\n      await nextTick()\n    }\n    if (pickerOptions.value.handleFocusPicker) {\n      pickerOptions.value.handleFocusPicker()\n      return\n    }\n  }\n\n  if (code === EVENT_CODE.tab) {\n    hasJustTabExitedInput = true\n    return\n  }\n\n  if (code === EVENT_CODE.enter || code === EVENT_CODE.numpadEnter) {\n    if (\n      userInput.value === null ||\n      userInput.value === '' ||\n      isValidValue(parseUserInputToDayjs(displayValue.value) as DayOrDays)\n    ) {\n      handleChange()\n      pickerVisible.value = false\n    }\n    event.stopPropagation()\n    return\n  }\n\n  // if user is typing, do not let picker handle key input\n  if (userInput.value) {\n    event.stopPropagation()\n    return\n  }\n  if (pickerOptions.value.handleKeydownInput) {\n    pickerOptions.value.handleKeydownInput(event)\n  }\n}\nconst onUserInput = (e: string) => {\n  userInput.value = e\n  // Temporary fix when the picker is dismissed and the input box\n  // is focused, just mimic the behavior of antdesign.\n  if (!pickerVisible.value) {\n    pickerVisible.value = true\n  }\n}\n\nconst handleStartInput = (event: Event) => {\n  const target = event.target as HTMLInputElement\n  if (userInput.value) {\n    userInput.value = [target.value, userInput.value[1]]\n  } else {\n    userInput.value = [target.value, null]\n  }\n}\n\nconst handleEndInput = (event: Event) => {\n  const target = event.target as HTMLInputElement\n  if (userInput.value) {\n    userInput.value = [userInput.value[0], target.value]\n  } else {\n    userInput.value = [null, target.value]\n  }\n}\n\nconst handleStartChange = () => {\n  const values = userInput.value as string[]\n  const value = parseUserInputToDayjs(values && values[0]) as Dayjs\n  const parsedVal = unref(parsedValue) as [Dayjs, Dayjs]\n  if (value && value.isValid()) {\n    userInput.value = [\n      formatDayjsToString(value) as string,\n      displayValue.value?.[1] || null,\n    ]\n    const newValue = [value, parsedVal && (parsedVal[1] || null)] as DayOrDays\n    if (isValidValue(newValue)) {\n      emitInput(newValue)\n      userInput.value = null\n    }\n  }\n}\n\nconst handleEndChange = () => {\n  const values = unref(userInput) as string[]\n  const value = parseUserInputToDayjs(values && values[1]) as Dayjs\n  const parsedVal = unref(parsedValue) as [Dayjs, Dayjs]\n  if (value && value.isValid()) {\n    userInput.value = [\n      unref(displayValue)?.[0] || null,\n      formatDayjsToString(value) as string,\n    ]\n    const newValue = [parsedVal && parsedVal[0], value] as DayOrDays\n    if (isValidValue(newValue)) {\n      emitInput(newValue)\n      userInput.value = null\n    }\n  }\n}\n\nconst pickerOptions = ref<Partial<PickerOptions>>({})\nconst onSetPickerOption = <T extends keyof PickerOptions>(\n  e: [T, PickerOptions[T]]\n) => {\n  pickerOptions.value[e[0]] = e[1]\n  pickerOptions.value.panelReady = true\n}\n\nconst onCalendarChange = (e: [Date, null | Date]) => {\n  emit('calendar-change', e)\n}\n\nconst onPanelChange = (\n  value: [Dayjs, Dayjs],\n  mode: 'month' | 'year',\n  view: unknown\n) => {\n  emit('panel-change', value, mode, view)\n}\n\nprovide('EP_PICKER_BASE', {\n  props,\n})\n\ndefineExpose({\n  /**\n   * @description focus input box.\n   */\n  focus,\n  /**\n   * @description emit focus event\n   */\n  handleFocusInput,\n  /**\n   * @description emit blur event\n   */\n  handleBlurInput,\n  /**\n   * @description opens picker\n   */\n  handleOpen,\n  /**\n   * @description closes picker\n   */\n  handleClose,\n  /**\n   * @description pick item manually\n   */\n  onPick,\n})\n</script>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { timePanelSharedProps } from './shared'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport const panelTimePickerProps = buildProps({\n  ...timePanelSharedProps,\n  datetimeRole: String,\n  parsedValue: {\n    type: definePropType<Dayjs>(Object),\n  },\n} as const)\n\nexport type PanelTimePickerProps = ExtractPropTypes<typeof panelTimePickerProps>\n", "import type { Dayjs } from 'dayjs'\n\nimport type {\n  GetDisabledHoursState,\n  GetDisabledMinutesState,\n  GetDisabledSecondsState,\n} from '../types'\n\ntype UseTimePanelProps = {\n  getAvailableHours: GetDisabledHoursState\n  getAvailableMinutes: GetDisabledMinutesState\n  getAvailableSeconds: GetDisabledSecondsState\n}\n\nexport const useTimePanel = ({\n  getAvailableHours,\n  getAvailableMinutes,\n  getAvailableSeconds,\n}: UseTimePanelProps) => {\n  const getAvailableTime = (\n    date: Dayjs,\n    role: string,\n    first: boolean,\n    compareDate?: Dayjs\n  ) => {\n    const availableTimeGetters = {\n      hour: getAvailableHours,\n      minute: getAvailableMinutes,\n      second: getAvailableSeconds,\n    } as const\n    let result = date\n    ;(['hour', 'minute', 'second'] as const).forEach((type) => {\n      if (availableTimeGetters[type]) {\n        let availableTimeSlots: number[]\n        const method = availableTimeGetters[type]\n        switch (type) {\n          case 'minute': {\n            availableTimeSlots = (method as typeof getAvailableMinutes)(\n              result.hour(),\n              role,\n              compareDate\n            )\n            break\n          }\n          case 'second': {\n            availableTimeSlots = (method as typeof getAvailableSeconds)(\n              result.hour(),\n              result.minute(),\n              role,\n              compareDate\n            )\n            break\n          }\n          default: {\n            availableTimeSlots = (method as typeof getAvailableHours)(\n              role,\n              compareDate\n            )\n            break\n          }\n        }\n\n        if (\n          availableTimeSlots?.length &&\n          !availableTimeSlots.includes(result[type]())\n        ) {\n          const pos = first ? 0 : availableTimeSlots.length - 1\n          result = result[type](availableTimeSlots[pos]) as unknown as Dayjs\n        }\n      }\n    })\n    return result\n  }\n\n  const timePickerOptions: Record<string, (...args: any[]) => void> = {}\n\n  const onSetOption = ([key, val]: [string, (...args: any[]) => void]) => {\n    timePickerOptions[key] = val\n  }\n\n  return {\n    timePickerOptions,\n\n    getAvailableTime,\n    onSetOption,\n  }\n}\n", "import { ref, watch } from 'vue'\nimport { makeList } from '../utils'\n\nimport type { Dayjs } from 'dayjs'\nimport type {\n  GetDisabledHoursState,\n  GetDisabledMinutesState,\n  GetDisabledSecondsState,\n} from '../types'\nimport type {\n  GetDisabledHours,\n  GetDisabledMinutes,\n  GetDisabledSeconds,\n} from '../props/shared'\n\nconst makeAvailableArr = (disabledList: boolean[]): number[] => {\n  const trueOrNumber = (isDisabled: boolean, index: number) =>\n    isDisabled || index\n\n  const getNumber = (predicate: number | true): predicate is number =>\n    predicate !== true\n\n  return disabledList.map(trueOrNumber).filter(getNumber)\n}\n\nexport const getTimeLists = (\n  disabledHours?: GetDisabledHours,\n  disabledMinutes?: GetDisabledMinutes,\n  disabledSeconds?: GetDisabledSeconds\n) => {\n  const getHoursList = (role: string, compare?: Dayjs) => {\n    return makeList(24, disabledHours && (() => disabledHours?.(role, compare)))\n  }\n\n  const getMinutesList = (hour: number, role: string, compare?: Dayjs) => {\n    return makeList(\n      60,\n      disabledMinutes && (() => disabledMinutes?.(hour, role, compare))\n    )\n  }\n\n  const getSecondsList = (\n    hour: number,\n    minute: number,\n    role: string,\n    compare?: Dayjs\n  ) => {\n    return makeList(\n      60,\n      disabledSeconds && (() => disabledSeconds?.(hour, minute, role, compare))\n    )\n  }\n\n  return {\n    getHoursList,\n    getMinutesList,\n    getSecondsList,\n  }\n}\n\nexport const buildAvailableTimeSlotGetter = (\n  disabledHours: GetDisabledHours,\n  disabledMinutes: GetDisabledMinutes,\n  disabledSeconds: GetDisabledSeconds\n) => {\n  const { getHoursList, getMinutesList, getSecondsList } = getTimeLists(\n    disabledHours,\n    disabledMinutes,\n    disabledSeconds\n  )\n\n  const getAvailableHours: GetDisabledHoursState = (role, compare?) => {\n    return makeAvailableArr(getHoursList(role, compare))\n  }\n\n  const getAvailableMinutes: GetDisabledMinutesState = (\n    hour,\n    role,\n    compare?\n  ) => {\n    return makeAvailableArr(getMinutesList(hour, role, compare))\n  }\n\n  const getAvailableSeconds: GetDisabledSecondsState = (\n    hour,\n    minute,\n    role,\n    compare?\n  ) => {\n    return makeAvailableArr(getSecondsList(hour, minute, role, compare))\n  }\n\n  return {\n    getAvailableHours,\n    getAvailableMinutes,\n    getAvailableSeconds,\n  }\n}\n\nexport const useOldValue = (props: {\n  parsedValue?: string | Dayjs | Dayjs[]\n  visible: boolean\n}) => {\n  const oldValue = ref(props.parsedValue)\n\n  watch(\n    () => props.visible,\n    (val) => {\n      if (!val) {\n        oldValue.value = props.parsedValue\n      }\n    }\n  )\n\n  return oldValue\n}\n", "import { isClient, isElement } from '@element-plus/utils'\n\nimport type {\n  ComponentPublicInstance,\n  DirectiveBinding,\n  ObjectDirective,\n} from 'vue'\n\ntype DocumentHandler = <T extends MouseEvent>(mouseup: T, mousedown: T) => void\ntype FlushList = Map<\n  HTMLElement,\n  {\n    documentHandler: DocumentHandler\n    bindingFn: (...args: unknown[]) => unknown\n  }[]\n>\n\nconst nodeList: FlushList = new Map()\n\nif (isClient) {\n  let startClick: MouseEvent | undefined\n  document.addEventListener('mousedown', (e: MouseEvent) => (startClick = e))\n  document.addEventListener('mouseup', (e: MouseEvent) => {\n    if (startClick) {\n      for (const handlers of nodeList.values()) {\n        for (const { documentHandler } of handlers) {\n          documentHandler(e as MouseEvent, startClick)\n        }\n      }\n      startClick = undefined\n    }\n  })\n}\n\nfunction createDocumentHandler(\n  el: HTMLElement,\n  binding: DirectiveBinding\n): DocumentHandler {\n  let excludes: HTMLElement[] = []\n  if (Array.isArray(binding.arg)) {\n    excludes = binding.arg\n  } else if (isElement(binding.arg)) {\n    // due to current implementation on binding type is wrong the type casting is necessary here\n    excludes.push(binding.arg as unknown as HTMLElement)\n  }\n  return function (mouseup, mousedown) {\n    const popperRef = (\n      binding.instance as ComponentPublicInstance<{\n        popperRef: HTMLElement\n      }>\n    ).popperRef\n    const mouseUpTarget = mouseup.target as Node\n    const mouseDownTarget = mousedown?.target as Node\n    const isBound = !binding || !binding.instance\n    const isTargetExists = !mouseUpTarget || !mouseDownTarget\n    const isContainedByEl =\n      el.contains(mouseUpTarget) || el.contains(mouseDownTarget)\n    const isSelf = el === mouseUpTarget\n\n    const isTargetExcluded =\n      (excludes.length &&\n        excludes.some((item) => item?.contains(mouseUpTarget))) ||\n      (excludes.length && excludes.includes(mouseDownTarget as HTMLElement))\n    const isContainedByPopper =\n      popperRef &&\n      (popperRef.contains(mouseUpTarget) || popperRef.contains(mouseDownTarget))\n    if (\n      isBound ||\n      isTargetExists ||\n      isContainedByEl ||\n      isSelf ||\n      isTargetExcluded ||\n      isContainedByPopper\n    ) {\n      return\n    }\n    binding.value(mouseup, mousedown)\n  }\n}\n\nconst ClickOutside: ObjectDirective = {\n  beforeMount(el: HTMLElement, binding: DirectiveBinding) {\n    // there could be multiple handlers on the element\n    if (!nodeList.has(el)) {\n      nodeList.set(el, [])\n    }\n\n    nodeList.get(el)!.push({\n      documentHandler: createDocumentHandler(el, binding),\n      bindingFn: binding.value,\n    })\n  },\n  updated(el: HTMLElement, binding: DirectiveBinding) {\n    if (!nodeList.has(el)) {\n      nodeList.set(el, [])\n    }\n\n    const handlers = nodeList.get(el)!\n    const oldHandlerIndex = handlers.findIndex(\n      (item) => item.bindingFn === binding.oldValue\n    )\n    const newHandler = {\n      documentHandler: createDocumentHandler(el, binding),\n      bindingFn: binding.value,\n    }\n\n    if (oldHandlerIndex >= 0) {\n      // replace the old handler to the new handler\n      handlers.splice(oldHandlerIndex, 1, newHandler)\n    } else {\n      handlers.push(newHandler)\n    }\n  },\n  unmounted(el: HTMLElement) {\n    // remove all listeners when a component unmounted\n    nodeList.delete(el)\n  },\n}\n\nexport default ClickOutside\n", "import { isFunction } from '@element-plus/utils'\n\nimport type { ObjectDirective } from 'vue'\n\nexport const REPEAT_INTERVAL = 100\nexport const REPEAT_DELAY = 600\n\nexport interface RepeatClickOptions {\n  interval?: number\n  delay?: number\n  handler: (...args: unknown[]) => unknown\n}\n\nexport const vRepeatClick: ObjectDirective<\n  HTMLElement,\n  RepeatClickOptions | RepeatClickOptions['handler']\n> = {\n  beforeMount(el, binding) {\n    const value = binding.value\n    const { interval = REPEAT_INTERVAL, delay = REPEAT_DELAY } = isFunction(\n      value\n    )\n      ? {}\n      : value\n\n    let intervalId: ReturnType<typeof setInterval> | undefined\n    let delayId: ReturnType<typeof setTimeout> | undefined\n\n    const handler = () => (isFunction(value) ? value() : value.handler())\n\n    const clear = () => {\n      if (delayId) {\n        clearTimeout(delayId)\n        delayId = undefined\n      }\n      if (intervalId) {\n        clearInterval(intervalId)\n        intervalId = undefined\n      }\n    }\n\n    el.addEventListener('mousedown', (evt: MouseEvent) => {\n      if (evt.button !== 0) return\n      clear()\n      handler()\n\n      document.addEventListener('mouseup', () => clear(), {\n        once: true,\n      })\n\n      delayId = setTimeout(() => {\n        intervalId = setInterval(() => {\n          handler()\n        }, interval)\n      }, delay)\n    })\n  },\n}\n", "import { nextTick } from 'vue'\nimport { obtainAllFocusableElements } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport type { ObjectDirective } from 'vue'\n\nexport const FOCUSABLE_CHILDREN = '_trap-focus-children'\nexport const TRAP_FOCUS_HANDLER = '_trap-focus-handler'\n\nexport interface TrapFocusElement extends HTMLElement {\n  [FOCUSABLE_CHILDREN]: HTMLElement[]\n  [TRAP_FOCUS_HANDLER]: (e: KeyboardEvent) => void\n}\n\nconst FOCUS_STACK: TrapFocusElement[] = []\n\nconst FOCUS_HANDLER = (e: KeyboardEvent) => {\n  // Getting the top layer.\n  if (FOCUS_STACK.length === 0) return\n  const focusableElement =\n    FOCUS_STACK[FOCUS_STACK.length - 1][FOCUSABLE_CHILDREN]\n  if (focusableElement.length > 0 && e.code === EVENT_CODE.tab) {\n    if (focusableElement.length === 1) {\n      e.preventDefault()\n      if (document.activeElement !== focusableElement[0]) {\n        focusableElement[0].focus()\n      }\n      return\n    }\n    const goingBackward = e.shiftKey\n    const isFirst = e.target === focusableElement[0]\n    const isLast = e.target === focusableElement[focusableElement.length - 1]\n    if (isFirst && goingBackward) {\n      e.preventDefault()\n      focusableElement[focusableElement.length - 1].focus()\n    }\n    if (isLast && !goingBackward) {\n      e.preventDefault()\n      focusableElement[0].focus()\n    }\n\n    // the is critical since jsdom did not implement user actions, you can only mock it\n    // DELETE ME: when testing env switches to puppeteer\n    if (process.env.NODE_ENV === 'test') {\n      const index = focusableElement.indexOf(e.target as HTMLElement)\n      if (index !== -1) {\n        focusableElement[goingBackward ? index - 1 : index + 1]?.focus()\n      }\n    }\n  }\n}\n\nconst TrapFocus: ObjectDirective = {\n  beforeMount(el: TrapFocusElement) {\n    el[FOCUSABLE_CHILDREN] = obtainAllFocusableElements(el)\n    FOCUS_STACK.push(el)\n    if (FOCUS_STACK.length <= 1) {\n      document.addEventListener('keydown', FOCUS_HANDLER)\n    }\n  },\n  updated(el: TrapFocusElement) {\n    nextTick(() => {\n      el[FOCUSABLE_CHILDREN] = obtainAllFocusableElements(el)\n    })\n  },\n  unmounted() {\n    FOCUS_STACK.shift()\n    if (FOCUS_STACK.length === 0) {\n      document.removeEventListener('keydown', FOCUS_HANDLER)\n    }\n  },\n}\n\nexport default TrapFocus\n", "/**\n * Copyright 2004-present Facebook. All Rights Reserved.\n *\n * @providesModule UserAgent_DEPRECATED\n */\n\n/**\n *  Provides entirely client-side User Agent and OS detection. You should prefer\n *  the non-deprecated UserAgent module when possible, which exposes our\n *  authoritative server-side PHP-based detection to the client.\n *\n *  Usage is straightforward:\n *\n *    if (UserAgent_DEPRECATED.ie()) {\n *      //  IE\n *    }\n *\n *  You can also do version checks:\n *\n *    if (UserAgent_DEPRECATED.ie() >= 7) {\n *      //  IE7 or better\n *    }\n *\n *  The browser functions will return NaN if the browser does not match, so\n *  you can also do version compares the other way:\n *\n *    if (UserAgent_DEPRECATED.ie() < 7) {\n *      //  IE6 or worse\n *    }\n *\n *  Note that the version is a float and may include a minor version number,\n *  so you should always use range operators to perform comparisons, not\n *  strict equality.\n *\n *  **Note:** You should **strongly** prefer capability detection to browser\n *  version detection where it's reasonable:\n *\n *    http://www.quirksmode.org/js/support.html\n *\n *  Further, we have a large number of mature wrapper functions and classes\n *  which abstract away many browser irregularities. Check the documentation,\n *  grep for things, or ask on javascript@lists.facebook.com before writing yet\n *  another copy of \"event || window.event\".\n *\n */\n\nvar _populated = false;\n\n// Browsers\nvar _ie, _firefox, _opera, _webkit, _chrome;\n\n// Actual IE browser for compatibility mode\nvar _ie_real_version;\n\n// Platforms\nvar _osx, _windows, _linux, _android;\n\n// Architectures\nvar _win64;\n\n// Devices\nvar _iphone, _ipad, _native;\n\nvar _mobile;\n\nfunction _populate() {\n  if (_populated) {\n    return;\n  }\n\n  _populated = true;\n\n  // To work around buggy JS libraries that can't handle multi-digit\n  // version numbers, Opera 10's user agent string claims it's Opera\n  // 9, then later includes a Version/X.Y field:\n  //\n  // Opera/9.80 (foo) Presto/2.2.15 Version/10.10\n  var uas = navigator.userAgent;\n  var agent =\n    /(?:MSIE.(\\d+\\.\\d+))|(?:(?:Firefox|GranParadiso|Iceweasel).(\\d+\\.\\d+))|(?:Opera(?:.+Version.|.)(\\d+\\.\\d+))|(?:AppleWebKit.(\\d+(?:\\.\\d+)?))|(?:Trident\\/\\d+\\.\\d+.*rv:(\\d+\\.\\d+))/.exec(\n      uas\n    );\n  var os = /(Mac OS X)|(Windows)|(Linux)/.exec(uas);\n\n  _iphone = /\\b(iPhone|iP[ao]d)/.exec(uas);\n  _ipad = /\\b(iP[ao]d)/.exec(uas);\n  _android = /Android/i.exec(uas);\n  _native = /FBAN\\/\\w+;/i.exec(uas);\n  _mobile = /Mobile/i.exec(uas);\n\n  // Note that the IE team blog would have you believe you should be checking\n  // for 'Win64; x64'.  But MSDN then reveals that you can actually be coming\n  // from either x64 or ia64;  so ultimately, you should just check for Win64\n  // as in indicator of whether you're in 64-bit IE.  32-bit IE on 64-bit\n  // Windows will send 'WOW64' instead.\n  _win64 = !!/Win64/.exec(uas);\n\n  if (agent) {\n    _ie = agent[1]\n      ? parseFloat(agent[1])\n      : agent[5]\n      ? parseFloat(agent[5])\n      : NaN;\n    // IE compatibility mode\n    if (_ie && document && document.documentMode) {\n      _ie = document.documentMode;\n    }\n    // grab the \"true\" ie version from the trident token if available\n    var trident = /(?:Trident\\/(\\d+.\\d+))/.exec(uas);\n    _ie_real_version = trident ? parseFloat(trident[1]) + 4 : _ie;\n\n    _firefox = agent[2] ? parseFloat(agent[2]) : NaN;\n    _opera = agent[3] ? parseFloat(agent[3]) : NaN;\n    _webkit = agent[4] ? parseFloat(agent[4]) : NaN;\n    if (_webkit) {\n      // We do not add the regexp to the above test, because it will always\n      // match 'safari' only since 'AppleWebKit' appears before 'Chrome' in\n      // the userAgent string.\n      agent = /(?:Chrome\\/(\\d+\\.\\d+))/.exec(uas);\n      _chrome = agent && agent[1] ? parseFloat(agent[1]) : NaN;\n    } else {\n      _chrome = NaN;\n    }\n  } else {\n    _ie = _firefox = _opera = _chrome = _webkit = NaN;\n  }\n\n  if (os) {\n    if (os[1]) {\n      // Detect OS X version.  If no version number matches, set _osx to true.\n      // Version examples:  10, 10_6_1, 10.7\n      // Parses version number as a float, taking only first two sets of\n      // digits.  If only one set of digits is found, returns just the major\n      // version number.\n      var ver = /(?:Mac OS X (\\d+(?:[._]\\d+)?))/.exec(uas);\n\n      _osx = ver ? parseFloat(ver[1].replace('_', '.')) : true;\n    } else {\n      _osx = false;\n    }\n    _windows = !!os[2];\n    _linux = !!os[3];\n  } else {\n    _osx = _windows = _linux = false;\n  }\n}\n\nvar UserAgent_DEPRECATED = {\n  /**\n   *  Check if the UA is Internet Explorer.\n   *\n   *\n   *  @return float|NaN Version number (if match) or NaN.\n   */\n  ie: function () {\n    return _populate() || _ie;\n  },\n\n  /**\n   * Check if we're in Internet Explorer compatibility mode.\n   *\n   * @return bool true if in compatibility mode, false if\n   * not compatibility mode or not ie\n   */\n  ieCompatibilityMode: function () {\n    return _populate() || _ie_real_version > _ie;\n  },\n\n  /**\n   * Whether the browser is 64-bit IE.  Really, this is kind of weak sauce;  we\n   * only need this because Skype can't handle 64-bit IE yet.  We need to remove\n   * this when we don't need it -- tracked by #601957.\n   */\n  ie64: function () {\n    return UserAgent_DEPRECATED.ie() && _win64;\n  },\n\n  /**\n   *  Check if the UA is Firefox.\n   *\n   *\n   *  @return float|NaN Version number (if match) or NaN.\n   */\n  firefox: function () {\n    return _populate() || _firefox;\n  },\n\n  /**\n   *  Check if the UA is Opera.\n   *\n   *\n   *  @return float|NaN Version number (if match) or NaN.\n   */\n  opera: function () {\n    return _populate() || _opera;\n  },\n\n  /**\n   *  Check if the UA is WebKit.\n   *\n   *\n   *  @return float|NaN Version number (if match) or NaN.\n   */\n  webkit: function () {\n    return _populate() || _webkit;\n  },\n\n  /**\n   *  For Push\n   *  WILL BE REMOVED VERY SOON. Use UserAgent_DEPRECATED.webkit\n   */\n  safari: function () {\n    return UserAgent_DEPRECATED.webkit();\n  },\n\n  /**\n   *  Check if the UA is a Chrome browser.\n   *\n   *\n   *  @return float|NaN Version number (if match) or NaN.\n   */\n  chrome: function () {\n    return _populate() || _chrome;\n  },\n\n  /**\n   *  Check if the user is running Windows.\n   *\n   *  @return bool `true' if the user's OS is Windows.\n   */\n  windows: function () {\n    return _populate() || _windows;\n  },\n\n  /**\n   *  Check if the user is running Mac OS X.\n   *\n   *  @return float|bool   Returns a float if a version number is detected,\n   *                       otherwise true/false.\n   */\n  osx: function () {\n    return _populate() || _osx;\n  },\n\n  /**\n   * Check if the user is running Linux.\n   *\n   * @return bool `true' if the user's OS is some flavor of Linux.\n   */\n  linux: function () {\n    return _populate() || _linux;\n  },\n\n  /**\n   * Check if the user is running on an iPhone or iPod platform.\n   *\n   * @return bool `true' if the user is running some flavor of the\n   *    iPhone OS.\n   */\n  iphone: function () {\n    return _populate() || _iphone;\n  },\n\n  mobile: function () {\n    return _populate() || _iphone || _ipad || _android || _mobile;\n  },\n\n  nativeApp: function () {\n    // webviews inside of the native apps\n    return _populate() || _native;\n  },\n\n  android: function () {\n    return _populate() || _android;\n  },\n\n  ipad: function () {\n    return _populate() || _ipad;\n  },\n};\n\nexport default UserAgent_DEPRECATED;\n", "/**\n * Copyright (c) 2015, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n *\n * @providesModule ExecutionEnvironment\n */\n\n/*jslint evil: true */\n\nvar canUseDOM = !!(\n  typeof window !== 'undefined' &&\n  window.document &&\n  window.document.createElement\n);\n\n/**\n * Simple, lightweight module assisting with the detection and context of\n * Worker. Helps avoid circular dependencies and allows code to reason about\n * whether or not they are in a Worker, even if they never include the main\n * `ReactWorker` dependency.\n */\nvar ExecutionEnvironment = {\n  canUseDOM: canUseDOM,\n\n  canUseWorkers: typeof Worker !== 'undefined',\n\n  canUseEventListeners:\n    canUseDOM && !!(window.addEventListener || window.attachEvent),\n\n  canUseViewport: canUseDOM && !!window.screen,\n\n  isInWorker: !canUseDOM, // For now, this is true - might change in the future.\n};\n\nexport default ExecutionEnvironment;\n", "/**\n * Copyright 2013-2015, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n *\n * @providesModule isEventSupported\n */\n\nimport ExecutionEnvironment from './ExecutionEnvironment';\n\nvar useHasFeature;\nif (ExecutionEnvironment.canUseDOM) {\n  useHasFeature =\n    document.implementation &&\n    document.implementation.hasFeature &&\n    // always returns true in newer browsers as per the standard.\n    // @see http://dom.spec.whatwg.org/#dom-domimplementation-hasfeature\n    document.implementation.hasFeature('', '') !== true;\n}\n\n/**\n * Checks if an event is supported in the current execution environment.\n *\n * NOTE: This will not work correctly for non-generic events such as `change`,\n * `reset`, `load`, `error`, and `select`.\n *\n * Borrows from Modernizr.\n *\n * @param {string} eventNameSuffix Event name, e.g. \"click\".\n * @param {?boolean} capture Check if the capture phase is supported.\n * @return {boolean} True if the event is supported.\n * @internal\n * @license Modernizr 3.0.0pre (Custom Build) | MIT\n */\nfunction isEventSupported(eventNameSuffix, capture) {\n  if (\n    !ExecutionEnvironment.canUseDOM ||\n    (capture && !('addEventListener' in document))\n  ) {\n    return false;\n  }\n\n  var eventName = 'on' + eventNameSuffix;\n  var isSupported = eventName in document;\n\n  if (!isSupported) {\n    var element = document.createElement('div');\n    element.setAttribute(eventName, 'return;');\n    isSupported = typeof element[eventName] === 'function';\n  }\n\n  if (!isSupported && useHasFeature && eventNameSuffix === 'wheel') {\n    // This is the only way to test support for the `wheel` event in IE9+.\n    isSupported = document.implementation.hasFeature('Events.wheel', '3.0');\n  }\n\n  return isSupported;\n}\n\nexport default isEventSupported;\n", "/**\n * Copyright (c) 2015, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n *\n * @providesModule normalizeWheel\n * @typechecks\n */\n\nimport UserAgent_DEPRECATED from './UserAgent_DEPRECATED';\n\nimport isEventSupported from './isEventSupported';\n\n// Reasonable defaults\nvar PIXEL_STEP = 10;\nvar LINE_HEIGHT = 40;\nvar PAGE_HEIGHT = 800;\n\n/**\n * Mouse wheel (and 2-finger trackpad) support on the web sucks.  It is\n * complicated, thus this doc is long and (hopefully) detailed enough to answer\n * your questions.\n *\n * If you need to react to the mouse wheel in a predictable way, this code is\n * like your bestest friend. * hugs *\n *\n * As of today, there are 4 DOM event types you can listen to:\n *\n *   'wheel'                -- Chrome(31+), FF(17+), IE(9+)\n *   'mousewheel'           -- Chrome, IE(6+), Opera, Safari\n *   'MozMousePixelScroll'  -- FF(3.5 only!) (2010-2013) -- don't bother!\n *   'DOMMouseScroll'       -- FF(0.9.7+) since 2003\n *\n * So what to do?  The is the best:\n *\n *   normalizeWheel.getEventType();\n *\n * In your event callback, use this code to get sane interpretation of the\n * deltas.  This code will return an object with properties:\n *\n *   spinX   -- normalized spin speed (use for zoom) - x plane\n *   spinY   -- \" - y plane\n *   pixelX  -- normalized distance (to pixels) - x plane\n *   pixelY  -- \" - y plane\n *\n * Wheel values are provided by the browser assuming you are using the wheel to\n * scroll a web page by a number of lines or pixels (or pages).  Values can vary\n * significantly on different platforms and browsers, forgetting that you can\n * scroll at different speeds.  Some devices (like trackpads) emit more events\n * at smaller increments with fine granularity, and some emit massive jumps with\n * linear speed or acceleration.\n *\n * This code does its best to normalize the deltas for you:\n *\n *   - spin is trying to normalize how far the wheel was spun (or trackpad\n *     dragged).  This is super useful for zoom support where you want to\n *     throw away the chunky scroll steps on the PC and make those equal to\n *     the slow and smooth tiny steps on the Mac. Key data: This code tries to\n *     resolve a single slow step on a wheel to 1.\n *\n *   - pixel is normalizing the desired scroll delta in pixel units.  You'll\n *     get the crazy differences between browsers, but at least it'll be in\n *     pixels!\n *\n *   - positive value indicates scrolling DOWN/RIGHT, negative UP/LEFT.  This\n *     should translate to positive value zooming IN, negative zooming OUT.\n *     This matches the newer 'wheel' event.\n *\n * Why are there spinX, spinY (or pixels)?\n *\n *   - spinX is a 2-finger side drag on the trackpad, and a shift + wheel turn\n *     with a mouse.  It results in side-scrolling in the browser by default.\n *\n *   - spinY is what you expect -- it's the classic axis of a mouse wheel.\n *\n *   - I dropped spinZ/pixelZ.  It is supported by the DOM 3 'wheel' event and\n *     probably is by browsers in conjunction with fancy 3D controllers .. but\n *     you know.\n *\n * Implementation info:\n *\n * Examples of 'wheel' event if you scroll slowly (down) by one step with an\n * average mouse:\n *\n *   OS X + Chrome  (mouse)     -    4   pixel delta  (wheelDelta -120)\n *   OS X + Safari  (mouse)     -  N/A   pixel delta  (wheelDelta  -12)\n *   OS X + Firefox (mouse)     -    0.1 line  delta  (wheelDelta  N/A)\n *   Win8 + Chrome  (mouse)     -  100   pixel delta  (wheelDelta -120)\n *   Win8 + Firefox (mouse)     -    3   line  delta  (wheelDelta -120)\n *\n * On the trackpad:\n *\n *   OS X + Chrome  (trackpad)  -    2   pixel delta  (wheelDelta   -6)\n *   OS X + Firefox (trackpad)  -    1   pixel delta  (wheelDelta  N/A)\n *\n * On other/older browsers.. it's more complicated as there can be multiple and\n * also missing delta values.\n *\n * The 'wheel' event is more standard:\n *\n * http://www.w3.org/TR/DOM-Level-3-Events/#events-wheelevents\n *\n * The basics is that it includes a unit, deltaMode (pixels, lines, pages), and\n * deltaX, deltaY and deltaZ.  Some browsers provide other values to maintain\n * backward compatibility with older events.  Those other values help us\n * better normalize spin speed.  Example of what the browsers provide:\n *\n *                          | event.wheelDelta | event.detail\n *        ------------------+------------------+--------------\n *          Safari v5/OS X  |       -120       |       0\n *          Safari v5/Win7  |       -120       |       0\n *         Chrome v17/OS X  |       -120       |       0\n *         Chrome v17/Win7  |       -120       |       0\n *                IE9/Win7  |       -120       |   undefined\n *         Firefox v4/OS X  |     undefined    |       1\n *         Firefox v4/Win7  |     undefined    |       3\n *\n */\nfunction normalizeWheel(/*object*/ event) /*object*/ {\n  var sX = 0,\n    sY = 0, // spinX, spinY\n    pX = 0,\n    pY = 0; // pixelX, pixelY\n\n  // Legacy\n  if ('detail' in event) {\n    sY = event.detail;\n  }\n  if ('wheelDelta' in event) {\n    sY = -event.wheelDelta / 120;\n  }\n  if ('wheelDeltaY' in event) {\n    sY = -event.wheelDeltaY / 120;\n  }\n  if ('wheelDeltaX' in event) {\n    sX = -event.wheelDeltaX / 120;\n  }\n\n  // side scrolling on FF with DOMMouseScroll\n  if ('axis' in event && event.axis === event.HORIZONTAL_AXIS) {\n    sX = sY;\n    sY = 0;\n  }\n\n  pX = sX * PIXEL_STEP;\n  pY = sY * PIXEL_STEP;\n\n  if ('deltaY' in event) {\n    pY = event.deltaY;\n  }\n  if ('deltaX' in event) {\n    pX = event.deltaX;\n  }\n\n  if ((pX || pY) && event.deltaMode) {\n    if (event.deltaMode == 1) {\n      // delta in LINE units\n      pX *= LINE_HEIGHT;\n      pY *= LINE_HEIGHT;\n    } else {\n      // delta in PAGE units\n      pX *= PAGE_HEIGHT;\n      pY *= PAGE_HEIGHT;\n    }\n  }\n\n  // Fall-back if spin cannot be determined\n  if (pX && !sX) {\n    sX = pX < 1 ? -1 : 1;\n  }\n  if (pY && !sY) {\n    sY = pY < 1 ? -1 : 1;\n  }\n\n  return { spinX: sX, spinY: sY, pixelX: pX, pixelY: pY };\n}\n\n/**\n * The best combination if you prefer spinX + spinY normalization.  It favors\n * the older DOMMouseScroll for Firefox, as FF does not include wheelDelta with\n * 'wheel' event, making spin speed determination impossible.\n */\nnormalizeWheel.getEventType = function () /*string*/ {\n  return UserAgent_DEPRECATED.firefox()\n    ? 'DOMMouseScroll'\n    : isEventSupported('wheel')\n    ? 'wheel'\n    : 'mousewheel';\n};\n\nexport default normalizeWheel;\n", "import normalizeWheel from 'normalize-wheel-es'\n\nimport type { DirectiveBinding, ObjectDirective } from 'vue'\nimport type { NormalizedWheelEvent } from 'normalize-wheel-es'\n\nconst mousewheel = function (\n  element: HTMLElement,\n  callback: (e: WheelEvent, normalized: NormalizedWheelEvent) => void\n) {\n  if (element && element.addEventListener) {\n    const fn = function (this: HTMLElement, event: WheelEvent) {\n      const normalized = normalizeWheel(event)\n      callback && Reflect.apply(callback, this, [event, normalized])\n    }\n    element.addEventListener('wheel', fn, { passive: true })\n  }\n}\n\nconst Mousewheel: ObjectDirective = {\n  beforeMount(el: HTMLElement, binding: DirectiveBinding) {\n    mousewheel(el, binding.value)\n  },\n}\n\nexport default Mousewheel\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { disabledTimeListsProps } from '../props/shared'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport const basicTimeSpinnerProps = buildProps({\n  role: {\n    type: String,\n    required: true,\n  },\n  spinnerDate: {\n    type: definePropType<Dayjs>(Object),\n    required: true,\n  },\n  showSeconds: {\n    type: Boolean,\n    default: true,\n  },\n  arrowControl: Boolean,\n  amPmMode: {\n    // 'a': am/pm; 'A': AM/PM\n    type: definePropType<'a' | 'A' | ''>(String),\n    default: '',\n  },\n  ...disabledTimeListsProps,\n} as const)\n\nexport type BasicTimeSpinnerProps = ExtractPropTypes<\n  typeof basicTimeSpinnerProps\n>\n", "<template>\n  <div :class=\"[ns.b('spinner'), { 'has-seconds': showSeconds }]\">\n    <template v-if=\"!arrowControl\">\n      <el-scrollbar\n        v-for=\"item in spinnerItems\"\n        :key=\"item\"\n        :ref=\"(scrollbar: unknown) => setRef(scrollbar as any, item)\"\n        :class=\"ns.be('spinner', 'wrapper')\"\n        wrap-style=\"max-height: inherit;\"\n        :view-class=\"ns.be('spinner', 'list')\"\n        noresize\n        tag=\"ul\"\n        @mouseenter=\"emitSelectRange(item)\"\n        @mousemove=\"adjustCurrentSpinner(item)\"\n      >\n        <li\n          v-for=\"(disabled, key) in timeList[item]\"\n          :key=\"key\"\n          :class=\"[\n            ns.be('spinner', 'item'),\n            ns.is('active', key === timePartials[item]),\n            ns.is('disabled', disabled),\n          ]\"\n          @click=\"handleClick(item, { value: key, disabled })\"\n        >\n          <template v-if=\"item === 'hours'\">\n            {{ ('0' + (amPmMode ? key % 12 || 12 : key)).slice(-2)\n            }}{{ getAmPmFlag(key) }}\n          </template>\n          <template v-else>\n            {{ ('0' + key).slice(-2) }}\n          </template>\n        </li>\n      </el-scrollbar>\n    </template>\n    <template v-if=\"arrowControl\">\n      <div\n        v-for=\"item in spinnerItems\"\n        :key=\"item\"\n        :class=\"[ns.be('spinner', 'wrapper'), ns.is('arrow')]\"\n        @mouseenter=\"emitSelectRange(item)\"\n      >\n        <el-icon\n          v-repeat-click=\"onDecrement\"\n          :class=\"['arrow-up', ns.be('spinner', 'arrow')]\"\n        >\n          <arrow-up />\n        </el-icon>\n        <el-icon\n          v-repeat-click=\"onIncrement\"\n          :class=\"['arrow-down', ns.be('spinner', 'arrow')]\"\n        >\n          <arrow-down />\n        </el-icon>\n        <ul :class=\"ns.be('spinner', 'list')\">\n          <li\n            v-for=\"(time, key) in arrowControlTimeList[item]\"\n            :key=\"key\"\n            :class=\"[\n              ns.be('spinner', 'item'),\n              ns.is('active', time === timePartials[item]),\n              ns.is('disabled', timeList[item][time!]),\n            ]\"\n          >\n            <template v-if=\"typeof time === 'number'\">\n              <template v-if=\"item === 'hours'\">\n                {{ ('0' + (amPmMode ? time % 12 || 12 : time)).slice(-2)\n                }}{{ getAmPmFlag(time) }}\n              </template>\n              <template v-else>\n                {{ ('0' + time).slice(-2) }}\n              </template>\n            </template>\n          </li>\n        </ul>\n      </div>\n    </template>\n  </div>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, nextTick, onMounted, ref, unref, watch } from 'vue'\nimport { debounce } from 'lodash-unified'\nimport { vRepeatClick } from '@element-plus/directives'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElIcon from '@element-plus/components/icon'\nimport { ArrowDown, ArrowUp } from '@element-plus/icons-vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { getStyle } from '@element-plus/utils'\nimport { timeUnits } from '../constants'\nimport { buildTimeList } from '../utils'\nimport { basicTimeSpinnerProps } from '../props/basic-time-spinner'\nimport { getTimeLists } from '../composables/use-time-picker'\n\nimport type { Ref } from 'vue'\nimport type { ScrollbarInstance } from '@element-plus/components/scrollbar'\nimport type { TimeUnit } from '../constants'\nimport type { TimeList } from '../utils'\n\nconst props = defineProps(basicTimeSpinnerProps)\nconst emit = defineEmits(['change', 'select-range', 'set-option'])\n\nconst ns = useNamespace('time')\n\nconst { getHoursList, getMinutesList, getSecondsList } = getTimeLists(\n  props.disabledHours,\n  props.disabledMinutes,\n  props.disabledSeconds\n)\n\n// data\nlet isScrolling = false\n\nconst currentScrollbar = ref<TimeUnit>()\nconst listHoursRef = ref<ScrollbarInstance>()\nconst listMinutesRef = ref<ScrollbarInstance>()\nconst listSecondsRef = ref<ScrollbarInstance>()\nconst listRefsMap: Record<TimeUnit, Ref<ScrollbarInstance | undefined>> = {\n  hours: listHoursRef,\n  minutes: listMinutesRef,\n  seconds: listSecondsRef,\n}\n\n// computed\nconst spinnerItems = computed(() => {\n  return props.showSeconds ? timeUnits : timeUnits.slice(0, 2)\n})\n\nconst timePartials = computed<Record<TimeUnit, number>>(() => {\n  const { spinnerDate } = props\n  const hours = spinnerDate.hour()\n  const minutes = spinnerDate.minute()\n  const seconds = spinnerDate.second()\n  return { hours, minutes, seconds }\n})\n\nconst timeList = computed(() => {\n  const { hours, minutes } = unref(timePartials)\n  return {\n    hours: getHoursList(props.role),\n    minutes: getMinutesList(hours, props.role),\n    seconds: getSecondsList(hours, minutes, props.role),\n  }\n})\n\nconst arrowControlTimeList = computed<Record<TimeUnit, TimeList>>(() => {\n  const { hours, minutes, seconds } = unref(timePartials)\n\n  return {\n    hours: buildTimeList(hours, 23),\n    minutes: buildTimeList(minutes, 59),\n    seconds: buildTimeList(seconds, 59),\n  }\n})\n\nconst debouncedResetScroll = debounce((type) => {\n  isScrolling = false\n  adjustCurrentSpinner(type)\n}, 200)\n\nconst getAmPmFlag = (hour: number) => {\n  const shouldShowAmPm = !!props.amPmMode\n  if (!shouldShowAmPm) return ''\n  const isCapital = props.amPmMode === 'A'\n  // todo locale\n  let content = hour < 12 ? ' am' : ' pm'\n  if (isCapital) content = content.toUpperCase()\n  return content\n}\n\nconst emitSelectRange = (type: TimeUnit) => {\n  let range\n\n  switch (type) {\n    case 'hours':\n      range = [0, 2]\n      break\n    case 'minutes':\n      range = [3, 5]\n      break\n    case 'seconds':\n      range = [6, 8]\n      break\n  }\n  const [left, right] = range\n\n  emit('select-range', left, right)\n  currentScrollbar.value = type\n}\n\nconst adjustCurrentSpinner = (type: TimeUnit) => {\n  adjustSpinner(type, unref(timePartials)[type])\n}\n\nconst adjustSpinners = () => {\n  adjustCurrentSpinner('hours')\n  adjustCurrentSpinner('minutes')\n  adjustCurrentSpinner('seconds')\n}\n\nconst getScrollbarElement = (el: HTMLElement) =>\n  el.querySelector(`.${ns.namespace.value}-scrollbar__wrap`) as HTMLElement\n\nconst adjustSpinner = (type: TimeUnit, value: number) => {\n  if (props.arrowControl) return\n  const scrollbar = unref(listRefsMap[type])\n  if (scrollbar && scrollbar.$el) {\n    getScrollbarElement(scrollbar.$el).scrollTop = Math.max(\n      0,\n      value * typeItemHeight(type)\n    )\n  }\n}\n\nconst typeItemHeight = (type: TimeUnit): number => {\n  const scrollbar = unref(listRefsMap[type])\n  const listItem = scrollbar?.$el.querySelector('li')\n  if (listItem) {\n    return Number.parseFloat(getStyle(listItem, 'height')) || 0\n  }\n  return 0\n}\n\nconst onIncrement = () => {\n  scrollDown(1)\n}\n\nconst onDecrement = () => {\n  scrollDown(-1)\n}\n\nconst scrollDown = (step: number) => {\n  if (!currentScrollbar.value) {\n    emitSelectRange('hours')\n  }\n\n  const label = currentScrollbar.value!\n  const now = unref(timePartials)[label]\n  const total = currentScrollbar.value === 'hours' ? 24 : 60\n  const next = findNextUnDisabled(label, now, step, total)\n\n  modifyDateField(label, next)\n  adjustSpinner(label, next)\n  nextTick(() => emitSelectRange(label))\n}\n\nconst findNextUnDisabled = (\n  type: TimeUnit,\n  now: number,\n  step: number,\n  total: number\n) => {\n  let next = (now + step + total) % total\n  const list = unref(timeList)[type]\n  while (list[next] && next !== now) {\n    next = (next + step + total) % total\n  }\n  return next\n}\n\nconst modifyDateField = (type: TimeUnit, value: number) => {\n  const list = unref(timeList)[type]\n  const isDisabled = list[value]\n  if (isDisabled) return\n\n  const { hours, minutes, seconds } = unref(timePartials)\n\n  let changeTo\n  switch (type) {\n    case 'hours':\n      changeTo = props.spinnerDate.hour(value).minute(minutes).second(seconds)\n      break\n    case 'minutes':\n      changeTo = props.spinnerDate.hour(hours).minute(value).second(seconds)\n      break\n    case 'seconds':\n      changeTo = props.spinnerDate.hour(hours).minute(minutes).second(value)\n      break\n  }\n  emit('change', changeTo)\n}\n\nconst handleClick = (\n  type: TimeUnit,\n  { value, disabled }: { value: number; disabled: boolean }\n) => {\n  if (!disabled) {\n    modifyDateField(type, value)\n    emitSelectRange(type)\n    adjustSpinner(type, value)\n  }\n}\n\nconst handleScroll = (type: TimeUnit) => {\n  isScrolling = true\n  debouncedResetScroll(type)\n  const value = Math.min(\n    Math.round(\n      (getScrollbarElement(unref(listRefsMap[type])!.$el).scrollTop -\n        (scrollBarHeight(type) * 0.5 - 10) / typeItemHeight(type) +\n        3) /\n        typeItemHeight(type)\n    ),\n    type === 'hours' ? 23 : 59\n  )\n  modifyDateField(type, value)\n}\n\nconst scrollBarHeight = (type: TimeUnit) => {\n  return unref(listRefsMap[type])!.$el.offsetHeight\n}\n\nconst bindScrollEvent = () => {\n  const bindFunction = (type: TimeUnit) => {\n    const scrollbar = unref(listRefsMap[type])\n    if (scrollbar && scrollbar.$el) {\n      getScrollbarElement(scrollbar.$el).onscroll = () => {\n        // TODO: scroll is emitted when set scrollTop programmatically\n        // should find better solutions in the future!\n        handleScroll(type)\n      }\n    }\n  }\n  bindFunction('hours')\n  bindFunction('minutes')\n  bindFunction('seconds')\n}\n\nonMounted(() => {\n  nextTick(() => {\n    !props.arrowControl && bindScrollEvent()\n    adjustSpinners()\n    // set selection on the first hour part\n    if (props.role === 'start') emitSelectRange('hours')\n  })\n})\n\nconst setRef = (scrollbar: ScrollbarInstance, type: TimeUnit) => {\n  listRefsMap[type].value = scrollbar\n}\n\nemit('set-option', [`${props.role}_scrollDown`, scrollDown])\nemit('set-option', [`${props.role}_emitSelectRange`, emitSelectRange])\n\nwatch(\n  () => props.spinnerDate,\n  () => {\n    if (isScrolling) return\n    adjustSpinners()\n  }\n)\n</script>\n", "<template>\n  <transition :name=\"transitionName\">\n    <div v-if=\"actualVisible || visible\" :class=\"ns.b('panel')\">\n      <div :class=\"[ns.be('panel', 'content'), { 'has-seconds': showSeconds }]\">\n        <time-spinner\n          ref=\"spinner\"\n          :role=\"datetimeRole || 'start'\"\n          :arrow-control=\"arrowControl\"\n          :show-seconds=\"showSeconds\"\n          :am-pm-mode=\"amPmMode\"\n          :spinner-date=\"(parsedValue as any)\"\n          :disabled-hours=\"disabledHours\"\n          :disabled-minutes=\"disabledMinutes\"\n          :disabled-seconds=\"disabledSeconds\"\n          @change=\"handleChange\"\n          @set-option=\"onSetOption\"\n          @select-range=\"setSelectionRange\"\n        />\n      </div>\n      <div :class=\"ns.be('panel', 'footer')\">\n        <button\n          type=\"button\"\n          :class=\"[ns.be('panel', 'btn'), 'cancel']\"\n          @click=\"handleCancel\"\n        >\n          {{ t('el.datepicker.cancel') }}\n        </button>\n        <button\n          type=\"button\"\n          :class=\"[ns.be('panel', 'btn'), 'confirm']\"\n          @click=\"handleConfirm()\"\n        >\n          {{ t('el.datepicker.confirm') }}\n        </button>\n      </div>\n    </div>\n  </transition>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, ref } from 'vue'\nimport dayjs from 'dayjs'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { isUndefined } from '@element-plus/utils'\nimport { panelTimePickerProps } from '../props/panel-time-picker'\nimport { useTimePanel } from '../composables/use-time-panel'\nimport {\n  buildAvailableTimeSlotGetter,\n  useOldValue,\n} from '../composables/use-time-picker'\nimport TimeSpinner from './basic-time-spinner.vue'\n\nimport type { Dayjs } from 'dayjs'\n\nconst props = defineProps(panelTimePickerProps)\nconst emit = defineEmits(['pick', 'select-range', 'set-picker-option'])\n\n// Injections\nconst pickerBase = inject('EP_PICKER_BASE') as any\nconst {\n  arrowControl,\n  disabledHours,\n  disabledMinutes,\n  disabledSeconds,\n  defaultValue,\n} = pickerBase.props\nconst { getAvailableHours, getAvailableMinutes, getAvailableSeconds } =\n  buildAvailableTimeSlotGetter(disabledHours, disabledMinutes, disabledSeconds)\n\nconst ns = useNamespace('time')\nconst { t, lang } = useLocale()\n// data\nconst selectionRange = ref([0, 2])\nconst oldValue = useOldValue(props)\n// computed\nconst transitionName = computed(() => {\n  return isUndefined(props.actualVisible)\n    ? `${ns.namespace.value}-zoom-in-top`\n    : ''\n})\nconst showSeconds = computed(() => {\n  return props.format.includes('ss')\n})\nconst amPmMode = computed(() => {\n  if (props.format.includes('A')) return 'A'\n  if (props.format.includes('a')) return 'a'\n  return ''\n})\n// method\nconst isValidValue = (_date: Dayjs) => {\n  const parsedDate = dayjs(_date).locale(lang.value)\n  const result = getRangeAvailableTime(parsedDate)\n  return parsedDate.isSame(result)\n}\nconst handleCancel = () => {\n  emit('pick', oldValue.value, false)\n}\nconst handleConfirm = (visible = false, first = false) => {\n  if (first) return\n  emit('pick', props.parsedValue, visible)\n}\nconst handleChange = (_date: Dayjs) => {\n  // visible avoids edge cases, when use scrolls during panel closing animation\n  if (!props.visible) {\n    return\n  }\n  const result = getRangeAvailableTime(_date).millisecond(0)\n  emit('pick', result, true)\n}\n\nconst setSelectionRange = (start: number, end: number) => {\n  emit('select-range', start, end)\n  selectionRange.value = [start, end]\n}\n\nconst changeSelectionRange = (step: number) => {\n  const list = [0, 3].concat(showSeconds.value ? [6] : [])\n  const mapping = ['hours', 'minutes'].concat(\n    showSeconds.value ? ['seconds'] : []\n  )\n  const index = list.indexOf(selectionRange.value[0])\n  const next = (index + step + list.length) % list.length\n  timePickerOptions['start_emitSelectRange'](mapping[next])\n}\n\nconst handleKeydown = (event: KeyboardEvent) => {\n  const code = event.code\n\n  const { left, right, up, down } = EVENT_CODE\n\n  if ([left, right].includes(code)) {\n    const step = code === left ? -1 : 1\n    changeSelectionRange(step)\n    event.preventDefault()\n    return\n  }\n\n  if ([up, down].includes(code)) {\n    const step = code === up ? -1 : 1\n    timePickerOptions['start_scrollDown'](step)\n    event.preventDefault()\n    return\n  }\n}\n\nconst { timePickerOptions, onSetOption, getAvailableTime } = useTimePanel({\n  getAvailableHours,\n  getAvailableMinutes,\n  getAvailableSeconds,\n})\n\nconst getRangeAvailableTime = (date: Dayjs) => {\n  return getAvailableTime(date, props.datetimeRole || '', true)\n}\n\nconst parseUserInput = (value: Dayjs) => {\n  if (!value) return null\n  return dayjs(value, props.format).locale(lang.value)\n}\n\nconst formatToString = (value: Dayjs) => {\n  if (!value) return null\n  return value.format(props.format)\n}\n\nconst getDefaultValue = () => {\n  return dayjs(defaultValue).locale(lang.value)\n}\n\nemit('set-picker-option', ['isValidValue', isValidValue])\nemit('set-picker-option', ['formatToString', formatToString])\nemit('set-picker-option', ['parseUserInput', parseUserInput])\nemit('set-picker-option', ['handleKeydownInput', handleKeydown])\nemit('set-picker-option', ['getRangeAvailableTime', getRangeAvailableTime])\nemit('set-picker-option', ['getDefaultValue', getDefaultValue])\n</script>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { timePanelSharedProps } from './shared'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport const panelTimeRangeProps = buildProps({\n  ...timePanelSharedProps,\n  parsedValue: {\n    type: definePropType<[Dayjs, Dayjs]>(Array),\n  },\n} as const)\n\nexport type PanelTimeRangeProps = ExtractPropTypes<typeof panelTimeRangeProps>\n", "<template>\n  <div\n    v-if=\"actualVisible\"\n    :class=\"[nsTime.b('range-picker'), nsPicker.b('panel')]\"\n  >\n    <div :class=\"nsTime.be('range-picker', 'content')\">\n      <div :class=\"nsTime.be('range-picker', 'cell')\">\n        <div :class=\"nsTime.be('range-picker', 'header')\">\n          {{ t('el.datepicker.startTime') }}\n        </div>\n        <div :class=\"startContainerKls\">\n          <time-spinner\n            ref=\"minSpinner\"\n            role=\"start\"\n            :show-seconds=\"showSeconds\"\n            :am-pm-mode=\"amPmMode\"\n            :arrow-control=\"arrowControl\"\n            :spinner-date=\"startTime\"\n            :disabled-hours=\"disabledHours_\"\n            :disabled-minutes=\"disabledMinutes_\"\n            :disabled-seconds=\"disabledSeconds_\"\n            @change=\"handleMinChange\"\n            @set-option=\"onSetOption\"\n            @select-range=\"setMinSelectionRange\"\n          />\n        </div>\n      </div>\n      <div :class=\"nsTime.be('range-picker', 'cell')\">\n        <div :class=\"nsTime.be('range-picker', 'header')\">\n          {{ t('el.datepicker.endTime') }}\n        </div>\n        <div :class=\"endContainerKls\">\n          <time-spinner\n            ref=\"maxSpinner\"\n            role=\"end\"\n            :show-seconds=\"showSeconds\"\n            :am-pm-mode=\"amPmMode\"\n            :arrow-control=\"arrowControl\"\n            :spinner-date=\"endTime\"\n            :disabled-hours=\"disabledHours_\"\n            :disabled-minutes=\"disabledMinutes_\"\n            :disabled-seconds=\"disabledSeconds_\"\n            @change=\"handleMaxChange\"\n            @set-option=\"onSetOption\"\n            @select-range=\"setMaxSelectionRange\"\n          />\n        </div>\n      </div>\n    </div>\n    <div :class=\"nsTime.be('panel', 'footer')\">\n      <button\n        type=\"button\"\n        :class=\"[nsTime.be('panel', 'btn'), 'cancel']\"\n        @click=\"handleCancel()\"\n      >\n        {{ t('el.datepicker.cancel') }}\n      </button>\n      <button\n        type=\"button\"\n        :class=\"[nsTime.be('panel', 'btn'), 'confirm']\"\n        :disabled=\"btnConfirmDisabled\"\n        @click=\"handleConfirm()\"\n      >\n        {{ t('el.datepicker.confirm') }}\n      </button>\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, ref, unref } from 'vue'\nimport dayjs from 'dayjs'\nimport { union } from 'lodash-unified'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { isArray } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { panelTimeRangeProps } from '../props/panel-time-range'\nimport { useTimePanel } from '../composables/use-time-panel'\nimport {\n  buildAvailableTimeSlotGetter,\n  useOldValue,\n} from '../composables/use-time-picker'\nimport TimeSpinner from './basic-time-spinner.vue'\n\nimport type { Dayjs } from 'dayjs'\n\nconst props = defineProps(panelTimeRangeProps)\nconst emit = defineEmits(['pick', 'select-range', 'set-picker-option'])\n\nconst makeSelectRange = (start: number, end: number) => {\n  const result: number[] = []\n  for (let i = start; i <= end; i++) {\n    result.push(i)\n  }\n  return result\n}\n\nconst { t, lang } = useLocale()\nconst nsTime = useNamespace('time')\nconst nsPicker = useNamespace('picker')\nconst pickerBase = inject('EP_PICKER_BASE') as any\nconst {\n  arrowControl,\n  disabledHours,\n  disabledMinutes,\n  disabledSeconds,\n  defaultValue,\n} = pickerBase.props\n\nconst startContainerKls = computed(() => [\n  nsTime.be('range-picker', 'body'),\n  nsTime.be('panel', 'content'),\n  nsTime.is('arrow', arrowControl),\n  showSeconds.value ? 'has-seconds' : '',\n])\nconst endContainerKls = computed(() => [\n  nsTime.be('range-picker', 'body'),\n  nsTime.be('panel', 'content'),\n  nsTime.is('arrow', arrowControl),\n  showSeconds.value ? 'has-seconds' : '',\n])\n\nconst startTime = computed(() => props.parsedValue![0])\nconst endTime = computed(() => props.parsedValue![1])\nconst oldValue = useOldValue(props)\nconst handleCancel = () => {\n  emit('pick', oldValue.value, false)\n}\nconst showSeconds = computed(() => {\n  return props.format.includes('ss')\n})\nconst amPmMode = computed(() => {\n  if (props.format.includes('A')) return 'A'\n  if (props.format.includes('a')) return 'a'\n  return ''\n})\n\nconst handleConfirm = (visible = false) => {\n  emit('pick', [startTime.value, endTime.value], visible)\n}\n\nconst handleMinChange = (date: Dayjs) => {\n  handleChange(date.millisecond(0), endTime.value)\n}\nconst handleMaxChange = (date: Dayjs) => {\n  handleChange(startTime.value, date.millisecond(0))\n}\n\nconst isValidValue = (_date: Dayjs[]) => {\n  const parsedDate = _date.map((_) => dayjs(_).locale(lang.value))\n  const result = getRangeAvailableTime(parsedDate)\n  return parsedDate[0].isSame(result[0]) && parsedDate[1].isSame(result[1])\n}\n\nconst handleChange = (start: Dayjs, end: Dayjs) => {\n  // todo getRangeAvailableTime(_date).millisecond(0)\n  emit('pick', [start, end], true)\n}\nconst btnConfirmDisabled = computed(() => {\n  return startTime.value > endTime.value\n})\n\nconst selectionRange = ref([0, 2])\nconst setMinSelectionRange = (start: number, end: number) => {\n  emit('select-range', start, end, 'min')\n  selectionRange.value = [start, end]\n}\n\nconst offset = computed(() => (showSeconds.value ? 11 : 8))\nconst setMaxSelectionRange = (start: number, end: number) => {\n  emit('select-range', start, end, 'max')\n  const _offset = unref(offset)\n  selectionRange.value = [start + _offset, end + _offset]\n}\n\nconst changeSelectionRange = (step: number) => {\n  const list = showSeconds.value ? [0, 3, 6, 11, 14, 17] : [0, 3, 8, 11]\n  const mapping = ['hours', 'minutes'].concat(\n    showSeconds.value ? ['seconds'] : []\n  )\n  const index = list.indexOf(selectionRange.value[0])\n  const next = (index + step + list.length) % list.length\n  const half = list.length / 2\n  if (next < half) {\n    timePickerOptions['start_emitSelectRange'](mapping[next])\n  } else {\n    timePickerOptions['end_emitSelectRange'](mapping[next - half])\n  }\n}\n\nconst handleKeydown = (event: KeyboardEvent) => {\n  const code = event.code\n\n  const { left, right, up, down } = EVENT_CODE\n\n  if ([left, right].includes(code)) {\n    const step = code === left ? -1 : 1\n    changeSelectionRange(step)\n    event.preventDefault()\n    return\n  }\n\n  if ([up, down].includes(code)) {\n    const step = code === up ? -1 : 1\n    const role = selectionRange.value[0] < offset.value ? 'start' : 'end'\n    timePickerOptions[`${role}_scrollDown`](step)\n    event.preventDefault()\n    return\n  }\n}\n\nconst disabledHours_ = (role: string, compare?: Dayjs) => {\n  const defaultDisable = disabledHours ? disabledHours(role) : []\n  const isStart = role === 'start'\n  const compareDate = compare || (isStart ? endTime.value : startTime.value)\n  const compareHour = compareDate.hour()\n  const nextDisable = isStart\n    ? makeSelectRange(compareHour + 1, 23)\n    : makeSelectRange(0, compareHour - 1)\n  return union(defaultDisable, nextDisable)\n}\nconst disabledMinutes_ = (hour: number, role: string, compare?: Dayjs) => {\n  const defaultDisable = disabledMinutes ? disabledMinutes(hour, role) : []\n  const isStart = role === 'start'\n  const compareDate = compare || (isStart ? endTime.value : startTime.value)\n  const compareHour = compareDate.hour()\n  if (hour !== compareHour) {\n    return defaultDisable\n  }\n  const compareMinute = compareDate.minute()\n  const nextDisable = isStart\n    ? makeSelectRange(compareMinute + 1, 59)\n    : makeSelectRange(0, compareMinute - 1)\n  return union(defaultDisable, nextDisable)\n}\nconst disabledSeconds_ = (\n  hour: number,\n  minute: number,\n  role: string,\n  compare?: Dayjs\n) => {\n  const defaultDisable = disabledSeconds\n    ? disabledSeconds(hour, minute, role)\n    : []\n  const isStart = role === 'start'\n  const compareDate = compare || (isStart ? endTime.value : startTime.value)\n  const compareHour = compareDate.hour()\n  const compareMinute = compareDate.minute()\n  if (hour !== compareHour || minute !== compareMinute) {\n    return defaultDisable\n  }\n  const compareSecond = compareDate.second()\n  const nextDisable = isStart\n    ? makeSelectRange(compareSecond + 1, 59)\n    : makeSelectRange(0, compareSecond - 1)\n  return union(defaultDisable, nextDisable)\n}\n\nconst getRangeAvailableTime = ([start, end]: Array<Dayjs>) => {\n  return [\n    getAvailableTime(start, 'start', true, end),\n    getAvailableTime(end, 'end', false, start),\n  ] as const\n}\n\nconst { getAvailableHours, getAvailableMinutes, getAvailableSeconds } =\n  buildAvailableTimeSlotGetter(\n    disabledHours_,\n    disabledMinutes_,\n    disabledSeconds_\n  )\n\nconst {\n  timePickerOptions,\n\n  getAvailableTime,\n  onSetOption,\n} = useTimePanel({\n  getAvailableHours,\n  getAvailableMinutes,\n  getAvailableSeconds,\n})\n\nconst parseUserInput = (days: Dayjs[] | Dayjs) => {\n  if (!days) return null\n  if (isArray(days)) {\n    return days.map((d) => dayjs(d, props.format).locale(lang.value))\n  }\n  return dayjs(days, props.format).locale(lang.value)\n}\n\nconst formatToString = (days: Dayjs[] | Dayjs) => {\n  if (!days) return null\n  if (isArray(days)) {\n    return days.map((d) => d.format(props.format))\n  }\n  return days.format(props.format)\n}\n\nconst getDefaultValue = () => {\n  if (isArray(defaultValue)) {\n    return defaultValue.map((d: Date) => dayjs(d).locale(lang.value))\n  }\n  const defaultDay = dayjs(defaultValue).locale(lang.value)\n  return [defaultDay, defaultDay.add(60, 'm')]\n}\n\nemit('set-picker-option', ['formatToString', formatToString])\nemit('set-picker-option', ['parseUserInput', parseUserInput])\nemit('set-picker-option', ['isValidValue', isValidValue])\nemit('set-picker-option', ['handleKeydownInput', handleKeydown])\nemit('set-picker-option', ['getDefaultValue', getDefaultValue])\nemit('set-picker-option', ['getRangeAvailableTime', getRangeAvailableTime])\n</script>\n", "import { defineComponent, provide, ref } from 'vue'\nimport dayjs from 'dayjs'\nimport customParseFormat from 'dayjs/plugin/customParseFormat.js'\nimport { DEFAULT_FORMATS_TIME } from './constants'\nimport Picker from './common/picker.vue'\nimport TimePickPanel from './time-picker-com/panel-time-pick.vue'\nimport TimeRangePanel from './time-picker-com/panel-time-range.vue'\nimport { timePickerDefaultProps } from './common/props'\ndayjs.extend(customParseFormat)\n\nexport default defineComponent({\n  name: 'ElTimePicker',\n  install: null,\n  props: {\n    ...timePickerDefaultProps,\n    /**\n     * @description whether to pick a time range\n     */\n    isRange: {\n      type: Boolean,\n      default: false,\n    },\n  },\n  emits: ['update:modelValue'],\n  setup(props, ctx) {\n    const commonPicker = ref<InstanceType<typeof Picker>>()\n    const [type, Panel] = props.isRange\n      ? ['timerange', TimeRangePanel]\n      : ['time', TimePickPanel]\n\n    const modelUpdater = (value: any) => ctx.emit('update:modelValue', value)\n    provide('ElPopperOptions', props.popperOptions)\n    ctx.expose({\n      /**\n       * @description focus the Input component\n       */\n      focus: (e: FocusEvent | undefined) => {\n        commonPicker.value?.handleFocusInput(e)\n      },\n      /**\n       * @description blur the Input component\n       */\n      blur: (e: FocusEvent | undefined) => {\n        commonPicker.value?.handleBlurInput(e)\n      },\n      /**\n       * @description open the TimePicker popper\n       */\n      handleOpen: () => {\n        commonPicker.value?.handleOpen()\n      },\n      /**\n       * @description close the TimePicker popper\n       */\n      handleClose: () => {\n        commonPicker.value?.handleClose()\n      },\n    })\n\n    return () => {\n      const format = props.format ?? DEFAULT_FORMATS_TIME\n\n      return (\n        <Picker\n          {...props}\n          ref={commonPicker}\n          type={type}\n          format={format}\n          onUpdate:modelValue={modelUpdater}\n        >\n          {{\n            default: (props: any) => <Panel {...props} />,\n          }}\n        </Picker>\n      )\n    }\n  },\n})\n", "import { withInstall } from '@element-plus/utils'\nimport TimePicker from './src/time-picker'\nimport CommonPicker from './src/common/picker.vue'\nimport TimePickPanel from './src/time-picker-com/panel-time-pick.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport * from './src/utils'\nexport * from './src/constants'\nexport * from './src/common/props'\n\nexport const ElTimePicker: SFCWithInstall<typeof TimePicker> =\n  withInstall(TimePicker)\n\nexport { CommonPicker, TimePickPanel }\nexport default ElTimePicker\n", "import { buildProps, definePropType, isObject } from '@element-plus/utils'\nimport { rangeArr } from '@element-plus/components/time-picker'\nimport type { ExtractPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport type CalendarDateCellType = 'next' | 'prev' | 'current'\nexport type CalendarDateCell = {\n  text: number\n  type: CalendarDateCellType\n}\n\nexport const getPrevMonthLastDays = (date: Dayjs, count: number) => {\n  const lastDay = date.subtract(1, 'month').endOf('month').date()\n  return rangeArr(count).map((_, index) => lastDay - (count - index - 1))\n}\n\nexport const getMonthDays = (date: Dayjs) => {\n  const days = date.daysInMonth()\n  return rangeArr(days).map((_, index) => index + 1)\n}\n\nexport const toNestedArr = (days: CalendarDateCell[]) =>\n  rangeArr(days.length / 7).map((index) => {\n    const start = index * 7\n    return days.slice(start, start + 7)\n  })\n\nexport const dateTableProps = buildProps({\n  selectedDay: {\n    type: definePropType<Dayjs>(Object),\n  },\n  range: {\n    type: definePropType<[Dayjs, Dayjs]>(Array),\n  },\n  date: {\n    type: definePropType<Dayjs>(Object),\n    required: true,\n  },\n  hideHeader: {\n    type: Boolean,\n  },\n} as const)\nexport type DateTableProps = ExtractPropTypes<typeof dateTableProps>\n\nexport const dateTableEmits = {\n  pick: (value: Dayjs) => isObject(value),\n}\nexport type DateTableEmits = typeof dateTableEmits\n", "import { computed } from 'vue'\nimport dayjs from 'dayjs'\nimport localeData from 'dayjs/plugin/localeData.js'\nimport { useLocale } from '@element-plus/hooks'\nimport { rangeArr } from '@element-plus/components/time-picker'\nimport { WEEK_DAYS } from '@element-plus/constants'\nimport { getMonthDays, getPrevMonthLastDays, toNestedArr } from './date-table'\n\nimport type { SetupContext } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type {\n  CalendarDateCell,\n  CalendarDateCellType,\n  DateTableEmits,\n  DateTableProps,\n} from './date-table'\n\nexport const useDateTable = (\n  props: DateTableProps,\n  emit: SetupContext<DateTableEmits>['emit']\n) => {\n  dayjs.extend(localeData)\n  // https://day.js.org/docs/en/i18n/locale-data\n  const firstDayOfWeek: number = dayjs.localeData().firstDayOfWeek()\n\n  const { t, lang } = useLocale()\n  const now = dayjs().locale(lang.value)\n\n  const isInRange = computed(() => !!props.range && !!props.range.length)\n\n  const rows = computed(() => {\n    let days: CalendarDateCell[] = []\n    if (isInRange.value) {\n      const [start, end] = props.range!\n      const currentMonthRange: CalendarDateCell[] = rangeArr(\n        end.date() - start.date() + 1\n      ).map((index) => ({\n        text: start.date() + index,\n        type: 'current',\n      }))\n\n      let remaining = currentMonthRange.length % 7\n      remaining = remaining === 0 ? 0 : 7 - remaining\n      const nextMonthRange: CalendarDateCell[] = rangeArr(remaining).map(\n        (_, index) => ({\n          text: index + 1,\n          type: 'next',\n        })\n      )\n      days = currentMonthRange.concat(nextMonthRange)\n    } else {\n      const firstDay = props.date.startOf('month').day()\n      const prevMonthDays: CalendarDateCell[] = getPrevMonthLastDays(\n        props.date,\n        (firstDay - firstDayOfWeek + 7) % 7\n      ).map((day) => ({\n        text: day,\n        type: 'prev',\n      }))\n      const currentMonthDays: CalendarDateCell[] = getMonthDays(props.date).map(\n        (day) => ({\n          text: day,\n          type: 'current',\n        })\n      )\n      days = [...prevMonthDays, ...currentMonthDays]\n      const remaining = 7 - (days.length % 7 || 7)\n      const nextMonthDays: CalendarDateCell[] = rangeArr(remaining).map(\n        (_, index) => ({\n          text: index + 1,\n          type: 'next',\n        })\n      )\n      days = days.concat(nextMonthDays)\n    }\n    return toNestedArr(days)\n  })\n\n  const weekDays = computed(() => {\n    const start = firstDayOfWeek\n    if (start === 0) {\n      return WEEK_DAYS.map((_) => t(`el.datepicker.weeks.${_}`))\n    } else {\n      return WEEK_DAYS.slice(start)\n        .concat(WEEK_DAYS.slice(0, start))\n        .map((_) => t(`el.datepicker.weeks.${_}`))\n    }\n  })\n\n  const getFormattedDate = (day: number, type: CalendarDateCellType): Dayjs => {\n    switch (type) {\n      case 'prev':\n        return props.date.startOf('month').subtract(1, 'month').date(day)\n      case 'next':\n        return props.date.startOf('month').add(1, 'month').date(day)\n      case 'current':\n        return props.date.date(day)\n    }\n  }\n\n  const handlePickDay = ({ text, type }: CalendarDateCell) => {\n    const date = getFormattedDate(text, type)\n    emit('pick', date)\n  }\n\n  const getSlotData = ({ text, type }: CalendarDateCell) => {\n    const day = getFormattedDate(text, type)\n    return {\n      isSelected: day.isSame(props.selectedDay),\n      type: `${type}-month`,\n      day: day.format('YYYY-MM-DD'),\n      date: day.toDate(),\n    }\n  }\n\n  return {\n    now,\n    isInRange,\n    rows,\n    weekDays,\n    getFormattedDate,\n    handlePickDay,\n    getSlotData,\n  }\n}\n", "<template>\n  <table\n    :class=\"[nsTable.b(), nsTable.is('range', isInRange)]\"\n    cellspacing=\"0\"\n    cellpadding=\"0\"\n  >\n    <thead v-if=\"!hideHeader\">\n      <th v-for=\"day in weekDays\" :key=\"day\">{{ day }}</th>\n    </thead>\n\n    <tbody>\n      <tr\n        v-for=\"(row, index) in rows\"\n        :key=\"index\"\n        :class=\"{\n          [nsTable.e('row')]: true,\n          [nsTable.em('row', 'hide-border')]: index === 0 && hideHeader,\n        }\"\n      >\n        <td\n          v-for=\"(cell, key) in row\"\n          :key=\"key\"\n          :class=\"getCellClass(cell)\"\n          @click=\"handlePickDay(cell)\"\n        >\n          <div :class=\"nsDay.b()\">\n            <slot name=\"date-cell\" :data=\"getSlotData(cell)\">\n              <span>{{ cell.text }}</span>\n            </slot>\n          </div>\n        </td>\n      </tr>\n    </tbody>\n  </table>\n</template>\n\n<script lang=\"ts\" setup>\nimport { useNamespace } from '@element-plus/hooks'\nimport { dateTableEmits, dateTableProps } from './date-table'\nimport { useDateTable } from './use-date-table'\n\nimport type { CalendarDateCell } from './date-table'\n\ndefineOptions({\n  name: 'DateTable',\n})\n\nconst props = defineProps(dateTableProps)\nconst emit = defineEmits(dateTableEmits)\n\nconst {\n  isInRange,\n  now,\n  rows,\n  weekDays,\n  getFormattedDate,\n  handlePickDay,\n  getSlotData,\n} = useDateTable(props, emit)\n\nconst nsTable = useNamespace('calendar-table')\nconst nsDay = useNamespace('calendar-day')\n\nconst getCellClass = ({ text, type }: CalendarDateCell) => {\n  const classes: string[] = [type]\n  if (type === 'current') {\n    const date = getFormattedDate(text, type)\n    if (date.isSame(props.selectedDay, 'day')) {\n      classes.push(nsDay.is('selected'))\n    }\n    if (date.isSame(now, 'day')) {\n      classes.push(nsDay.is('today'))\n    }\n  }\n  return classes\n}\n\ndefineExpose({\n  /** @description toggle date panel */\n  getFormattedDate,\n})\n</script>\n", "import { computed, ref } from 'vue'\nimport dayjs from 'dayjs'\nimport { useLocale } from '@element-plus/hooks'\nimport { debugWarn, isArray, isDate } from '@element-plus/utils'\nimport { INPUT_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\n\nimport type { ComputedRef, SetupContext } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type { CalendarDateType, CalendarEmits, CalendarProps } from './calendar'\n\nconst adjacentMonth = (start: Dayjs, end: Dayjs): [Dayjs, Dayjs][] => {\n  const firstMonthLastDay = start.endOf('month')\n  const lastMonthFirstDay = end.startOf('month')\n\n  // Whether the last day of the first month and the first day of the last month is in the same week\n  const isSameWeek = firstMonthLastDay.isSame(lastMonthFirstDay, 'week')\n  const lastMonthStartDay = isSameWeek\n    ? lastMonthFirstDay.add(1, 'week')\n    : lastMonthFirstDay\n\n  return [\n    [start, firstMonthLastDay],\n    [lastMonthStartDay.startOf('week'), end],\n  ]\n}\n\nconst threeConsecutiveMonth = (start: Dayjs, end: Dayjs): [Dayjs, Dayjs][] => {\n  const firstMonthLastDay = start.endOf('month')\n  const secondMonthFirstDay = start.add(1, 'month').startOf('month')\n\n  // Whether the last day of the first month and the second month is in the same week\n  const secondMonthStartDay = firstMonthLastDay.isSame(\n    secondMonthFirstDay,\n    'week'\n  )\n    ? secondMonthFirstDay.add(1, 'week')\n    : secondMonthFirstDay\n\n  const secondMonthLastDay = secondMonthStartDay.endOf('month')\n  const lastMonthFirstDay = end.startOf('month')\n\n  // Whether the last day of the second month and the last day of the last month is in the same week\n  const lastMonthStartDay = secondMonthLastDay.isSame(lastMonthFirstDay, 'week')\n    ? lastMonthFirstDay.add(1, 'week')\n    : lastMonthFirstDay\n\n  return [\n    [start, firstMonthLastDay],\n    [secondMonthStartDay.startOf('week'), secondMonthLastDay],\n    [lastMonthStartDay.startOf('week'), end],\n  ]\n}\n\nexport const useCalendar = (\n  props: CalendarProps,\n  emit: SetupContext<CalendarEmits>['emit'],\n  componentName: string\n) => {\n  const { lang } = useLocale()\n\n  const selectedDay = ref<Dayjs>()\n  const now = dayjs().locale(lang.value)\n\n  const realSelectedDay = computed<Dayjs | undefined>({\n    get() {\n      if (!props.modelValue) return selectedDay.value\n      return date.value\n    },\n    set(val) {\n      if (!val) return\n      selectedDay.value = val\n      const result = val.toDate()\n\n      emit(INPUT_EVENT, result)\n      emit(UPDATE_MODEL_EVENT, result)\n    },\n  })\n\n  // if range is valid, we get a two-digit array\n  const validatedRange = computed(() => {\n    if (\n      !props.range ||\n      !isArray(props.range) ||\n      props.range.length !== 2 ||\n      props.range.some((item) => !isDate(item))\n    )\n      return []\n    const rangeArrDayjs = props.range.map((_) => dayjs(_).locale(lang.value))\n    const [startDayjs, endDayjs] = rangeArrDayjs\n    if (startDayjs.isAfter(endDayjs)) {\n      debugWarn(componentName, 'end time should be greater than start time')\n      return []\n    }\n    if (startDayjs.isSame(endDayjs, 'month')) {\n      // same month\n      return calculateValidatedDateRange(startDayjs, endDayjs)\n    } else {\n      // two months\n      if (startDayjs.add(1, 'month').month() !== endDayjs.month()) {\n        debugWarn(\n          componentName,\n          'start time and end time interval must not exceed two months'\n        )\n        return []\n      }\n      return calculateValidatedDateRange(startDayjs, endDayjs)\n    }\n  })\n\n  const date: ComputedRef<Dayjs> = computed(() => {\n    if (!props.modelValue) {\n      return (\n        realSelectedDay.value ||\n        (validatedRange.value.length ? validatedRange.value[0][0] : now)\n      )\n    } else {\n      return dayjs(props.modelValue).locale(lang.value)\n    }\n  })\n  const prevMonthDayjs = computed(() => date.value.subtract(1, 'month').date(1))\n  const nextMonthDayjs = computed(() => date.value.add(1, 'month').date(1))\n  const prevYearDayjs = computed(() => date.value.subtract(1, 'year').date(1))\n  const nextYearDayjs = computed(() => date.value.add(1, 'year').date(1))\n\n  // https://github.com/element-plus/element-plus/issues/3155\n  // Calculate the validate date range according to the start and end dates\n  const calculateValidatedDateRange = (\n    startDayjs: Dayjs,\n    endDayjs: Dayjs\n  ): [Dayjs, Dayjs][] => {\n    const firstDay = startDayjs.startOf('week')\n    const lastDay = endDayjs.endOf('week')\n    const firstMonth = firstDay.get('month')\n    const lastMonth = lastDay.get('month')\n\n    // Current mouth\n    if (firstMonth === lastMonth) {\n      return [[firstDay, lastDay]]\n    }\n    // Two adjacent months\n    else if ((firstMonth + 1) % 12 === lastMonth) {\n      return adjacentMonth(firstDay, lastDay)\n    }\n    // Three consecutive months (compatible: 2021-01-30 to 2021-02-28)\n    else if (\n      firstMonth + 2 === lastMonth ||\n      (firstMonth + 1) % 11 === lastMonth\n    ) {\n      return threeConsecutiveMonth(firstDay, lastDay)\n    }\n    // Other cases\n    else {\n      debugWarn(\n        componentName,\n        'start time and end time interval must not exceed two months'\n      )\n      return []\n    }\n  }\n\n  const pickDay = (day: Dayjs) => {\n    realSelectedDay.value = day\n  }\n\n  const selectDate = (type: CalendarDateType) => {\n    const dateMap: Record<CalendarDateType, Dayjs> = {\n      'prev-month': prevMonthDayjs.value,\n      'next-month': nextMonthDayjs.value,\n      'prev-year': prevYearDayjs.value,\n      'next-year': nextYearDayjs.value,\n      today: now,\n    }\n\n    const day = dateMap[type]\n\n    if (!day.isSame(date.value, 'day')) {\n      pickDay(day)\n    }\n  }\n\n  return {\n    calculateValidatedDateRange,\n    date,\n    realSelectedDay,\n    pickDay,\n    selectDate,\n    validatedRange,\n  }\n}\n", "import {\n  buildProps,\n  definePropType,\n  isArray,\n  isDate,\n} from '@element-plus/utils'\nimport { INPUT_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport type { ExtractPropTypes } from 'vue'\n\nexport type CalendarDateType =\n  | 'prev-month'\n  | 'next-month'\n  | 'prev-year'\n  | 'next-year'\n  | 'today'\n\nconst isValidRange = (range: unknown): range is [Date, Date] =>\n  isArray(range) && range.length === 2 && range.every((item) => isDate(item))\n\nexport const calendarProps = buildProps({\n  /**\n   * @description binding value\n   */\n  modelValue: {\n    type: Date,\n  },\n  /**\n   * @description time range, including start time and end time.\n   *   Start time must be start day of week, end time must be end day of week, the time span cannot exceed two months.\n   */\n  range: {\n    type: definePropType<[Date, Date]>(Array),\n    validator: isValidRange,\n  },\n} as const)\nexport type CalendarProps = ExtractPropTypes<typeof calendarProps>\n\nexport const calendarEmits = {\n  [UPDATE_MODEL_EVENT]: (value: Date) => isDate(value),\n  [INPUT_EVENT]: (value: Date) => isDate(value),\n}\nexport type CalendarEmits = typeof calendarEmits\n", "<template>\n  <div :class=\"ns.b()\">\n    <div :class=\"ns.e('header')\">\n      <slot name=\"header\" :date=\"i18nDate\">\n        <div :class=\"ns.e('title')\">{{ i18nDate }}</div>\n        <div v-if=\"validatedRange.length === 0\" :class=\"ns.e('button-group')\">\n          <el-button-group>\n            <el-button size=\"small\" @click=\"selectDate('prev-month')\">\n              {{ t('el.datepicker.prevMonth') }}\n            </el-button>\n            <el-button size=\"small\" @click=\"selectDate('today')\">\n              {{ t('el.datepicker.today') }}\n            </el-button>\n            <el-button size=\"small\" @click=\"selectDate('next-month')\">\n              {{ t('el.datepicker.nextMonth') }}\n            </el-button>\n          </el-button-group>\n        </div>\n      </slot>\n    </div>\n    <div v-if=\"validatedRange.length === 0\" :class=\"ns.e('body')\">\n      <date-table :date=\"date\" :selected-day=\"realSelectedDay\" @pick=\"pickDay\">\n        <template v-if=\"$slots['date-cell']\" #date-cell=\"data\">\n          <slot name=\"date-cell\" v-bind=\"data\" />\n        </template>\n      </date-table>\n    </div>\n    <div v-else :class=\"ns.e('body')\">\n      <date-table\n        v-for=\"(range_, index) in validatedRange\"\n        :key=\"index\"\n        :date=\"range_[0]\"\n        :selected-day=\"realSelectedDay\"\n        :range=\"range_\"\n        :hide-header=\"index !== 0\"\n        @pick=\"pickDay\"\n      >\n        <template v-if=\"$slots['date-cell']\" #date-cell=\"data\">\n          <slot name=\"date-cell\" v-bind=\"data\" />\n        </template>\n      </date-table>\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { ElButton, ElButtonGroup } from '@element-plus/components/button'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\n\nimport DateTable from './date-table.vue'\nimport { useCalendar } from './use-calendar'\nimport { calendarEmits, calendarProps } from './calendar'\n\nconst ns = useNamespace('calendar')\n\nconst COMPONENT_NAME = 'ElCalendar'\ndefineOptions({\n  name: COMPONENT_NAME,\n})\n\nconst props = defineProps(calendarProps)\nconst emit = defineEmits(calendarEmits)\n\nconst {\n  calculateValidatedDateRange,\n  date,\n  pickDay,\n  realSelectedDay,\n  selectDate,\n  validatedRange,\n} = useCalendar(props, emit, COMPONENT_NAME)\n\nconst { t } = useLocale()\n\nconst i18nDate = computed(() => {\n  const pickedMonth = `el.datepicker.month${date.value.format('M')}`\n  return `${date.value.year()} ${t('el.datepicker.year')} ${t(pickedMonth)}`\n})\n\ndefineExpose({\n  /** @description currently selected date */\n  selectedDay: realSelectedDay,\n  /** @description select a specific date */\n  pickDay,\n  /** @description select date */\n  selectDate,\n  /** @description Calculate the validate date range according to the start and end dates */\n  calculateValidatedDateRange,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Calendar from './src/calendar.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCalendar: SFCWithInstall<typeof Calendar> = withInstall(Calendar)\nexport default ElCalendar\n\nexport * from './src/calendar'\nexport type {\n  CalendarDateTableInstance,\n  DateTableInstance,\n  CalendarInstance,\n} from './src/instance'\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport type { ExtractPropTypes, StyleValue } from 'vue'\n\nexport const cardProps = buildProps({\n  /**\n   * @description title of the card. Also accepts a DOM passed by `slot#header`\n   */\n  header: {\n    type: String,\n    default: '',\n  },\n  footer: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description CSS style of card body\n   */\n  bodyStyle: {\n    type: definePropType<StyleValue>([String, Object, Array]),\n    default: '',\n  },\n  /**\n   * @description custom class name of card body\n   */\n  bodyClass: String,\n  /**\n   * @description when to show card shadows\n   */\n  shadow: {\n    type: String,\n    values: ['always', 'hover', 'never'],\n    default: 'always',\n  },\n} as const)\nexport type CardProps = ExtractPropTypes<typeof cardProps>\n", "<template>\n  <div :class=\"[ns.b(), ns.is(`${shadow}-shadow`)]\">\n    <div v-if=\"$slots.header || header\" :class=\"ns.e('header')\">\n      <slot name=\"header\">{{ header }}</slot>\n    </div>\n    <div :class=\"[ns.e('body'), bodyClass]\" :style=\"bodyStyle\">\n      <slot />\n    </div>\n    <div v-if=\"$slots.footer || footer\" :class=\"ns.e('footer')\">\n      <slot name=\"footer\">{{ footer }}</slot>\n    </div>\n  </div>\n</template>\n<script lang=\"ts\" setup>\nimport { useNamespace } from '@element-plus/hooks'\nimport { cardProps } from './card'\n\ndefineOptions({\n  name: 'ElCard',\n})\n\ndefineProps(cardProps)\n\nconst ns = useNamespace('card')\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Card from './src/card.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCard: SFCWithInstall<typeof Card> = withInstall(Card)\nexport default ElCard\n\nexport * from './src/card'\nexport type { CardInstance } from './src/instance'\n", "import { buildProps, isNumber } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const carouselProps = buildProps({\n  /**\n   * @description index of the initially active slide (starting from 0)\n   */\n  initialIndex: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description height of the carousel\n   */\n  height: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description how indicators are triggered\n   */\n  trigger: {\n    type: String,\n    values: ['hover', 'click'],\n    default: 'hover',\n  },\n  /**\n   * @description whether automatically loop the slides\n   */\n  autoplay: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description interval of the auto loop, in milliseconds\n   */\n  interval: {\n    type: Number,\n    default: 3000,\n  },\n  /**\n   * @description position of the indicators\n   */\n  indicatorPosition: {\n    type: String,\n    values: ['', 'none', 'outside'],\n    default: '',\n  },\n  /**\n   * @description when arrows are shown\n   */\n  arrow: {\n    type: String,\n    values: ['always', 'hover', 'never'],\n    default: 'hover',\n  },\n  /**\n   * @description type of the Carousel\n   */\n  type: {\n    type: String,\n    values: ['', 'card'],\n    default: '',\n  },\n  /**\n   * @description when type is card, scaled size of secondary cards\n   */\n  cardScale: {\n    type: Number,\n    default: 0.83,\n  },\n  /**\n   * @description display the items in loop\n   */\n  loop: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description display direction\n   */\n  direction: {\n    type: String,\n    values: ['horizontal', 'vertical'],\n    default: 'horizontal',\n  },\n  /**\n   * @description pause autoplay when hover\n   */\n  pauseOnHover: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description infuse dynamism and smoothness into the carousel\n   */\n  motionBlur: Boolean,\n} as const)\n\nexport const carouselEmits = {\n  /**\n   * @description triggers when the active slide switches\n   * @param current index of the new active slide\n   * @param prev index of the old active slide\n   */\n  change: (current: number, prev: number) => [current, prev].every(isNumber),\n}\n\nexport type CarouselProps = ExtractPropTypes<typeof carouselProps>\nexport type CarouselEmits = typeof carouselEmits\n", "import type { InjectionKey, Ref } from 'vue'\n\nimport type { CarouselItemProps } from './carousel-item'\n\nexport type CarouselItemStates = {\n  hover: boolean\n  translate: number\n  scale: number\n  active: boolean\n  ready: boolean\n  inStage: boolean\n  animating: boolean\n}\n\nexport type CarouselItemContext = {\n  props: CarouselItemProps\n  states: CarouselItemStates\n  uid: number\n  translateItem: (index: number, activeIndex: number, oldIndex?: number) => void\n}\n\nexport type CarouselContext = {\n  root: Ref<HTMLElement | undefined>\n  items: Ref<CarouselItemContext[]>\n  isCardType: Ref<boolean>\n  isVertical: Ref<boolean>\n  loop: boolean\n  cardScale: number\n  addItem: (item: CarouselItemContext) => void\n  removeItem: (uid: number) => void\n  setActiveItem: (index: number) => void\n  setContainerHeight: (height: number) => void\n}\n\nexport const carouselContextKey: InjectionKey<CarouselContext> =\n  Symbol('carouselContextKey')\n\nexport const CAROUSEL_ITEM_NAME = 'ElCarouselItem'\n", "import {\n  computed,\n  getCurrentInstance,\n  isVNode,\n  onBeforeUnmount,\n  onMounted,\n  provide,\n  ref,\n  shallowRef,\n  unref,\n  useSlots,\n  watch,\n} from 'vue'\nimport { throttle } from 'lodash-unified'\nimport { useResizeObserver } from '@vueuse/core'\nimport { debugWarn, flattedChildren, isString } from '@element-plus/utils'\nimport { useOrderedChildren } from '@element-plus/hooks'\nimport { CAROUSEL_ITEM_NAME, carouselContextKey } from './constants'\n\nimport type { SetupContext } from 'vue'\nimport type { CarouselItemContext } from './constants'\nimport type { CarouselEmits, CarouselProps } from './carousel'\n\nconst THROTTLE_TIME = 300\n\nexport const useCarousel = (\n  props: CarouselProps,\n  emit: SetupContext<CarouselEmits>['emit'],\n  componentName: string\n) => {\n  const {\n    children: items,\n    addChild: addItem,\n    removeChild: removeItem,\n  } = useOrderedChildren<CarouselItemContext>(\n    getCurrentInstance()!,\n    CAROUSEL_ITEM_NAME\n  )\n\n  const slots = useSlots()\n\n  // refs\n  const activeIndex = ref(-1)\n  const timer = ref<ReturnType<typeof setInterval> | null>(null)\n  const hover = ref(false)\n  const root = ref<HTMLDivElement>()\n  const containerHeight = ref<number>(0)\n  const isItemsTwoLength = ref(true)\n  const isFirstCall = ref(true)\n  const isTransitioning = ref(false)\n\n  // computed\n  const arrowDisplay = computed(\n    () => props.arrow !== 'never' && !unref(isVertical)\n  )\n\n  const hasLabel = computed(() => {\n    return items.value.some((item) => item.props.label.toString().length > 0)\n  })\n\n  const isCardType = computed(() => props.type === 'card')\n  const isVertical = computed(() => props.direction === 'vertical')\n\n  const containerStyle = computed(() => {\n    if (props.height !== 'auto') {\n      return {\n        height: props.height,\n      }\n    }\n    return {\n      height: `${containerHeight.value}px`,\n      overflow: 'hidden',\n    }\n  })\n\n  // methods\n  const throttledArrowClick = throttle(\n    (index: number) => {\n      setActiveItem(index)\n    },\n    THROTTLE_TIME,\n    { trailing: true }\n  )\n\n  const throttledIndicatorHover = throttle((index: number) => {\n    handleIndicatorHover(index)\n  }, THROTTLE_TIME)\n\n  const isTwoLengthShow = (index: number) => {\n    if (!isItemsTwoLength.value) return true\n    return activeIndex.value <= 1 ? index <= 1 : index > 1\n  }\n\n  function pauseTimer() {\n    if (timer.value) {\n      clearInterval(timer.value)\n      timer.value = null\n    }\n  }\n\n  function startTimer() {\n    if (props.interval <= 0 || !props.autoplay || timer.value) return\n    timer.value = setInterval(() => playSlides(), props.interval)\n  }\n\n  const playSlides = () => {\n    if (!isFirstCall.value) {\n      isTransitioning.value = true\n    }\n    isFirstCall.value = false\n\n    if (activeIndex.value < items.value.length - 1) {\n      activeIndex.value = activeIndex.value + 1\n    } else if (props.loop) {\n      activeIndex.value = 0\n    } else {\n      isTransitioning.value = false\n    }\n  }\n\n  function setActiveItem(index: number | string) {\n    if (!isFirstCall.value) {\n      isTransitioning.value = true\n    }\n    isFirstCall.value = false\n\n    if (isString(index)) {\n      const filteredItems = items.value.filter(\n        (item) => item.props.name === index\n      )\n      if (filteredItems.length > 0) {\n        index = items.value.indexOf(filteredItems[0])\n      }\n    }\n    index = Number(index)\n    if (Number.isNaN(index) || index !== Math.floor(index)) {\n      debugWarn(componentName, 'index must be integer.')\n      return\n    }\n    const itemCount = items.value.length\n    const oldIndex = activeIndex.value\n    if (index < 0) {\n      activeIndex.value = props.loop ? itemCount - 1 : 0\n    } else if (index >= itemCount) {\n      activeIndex.value = props.loop ? 0 : itemCount - 1\n    } else {\n      activeIndex.value = index\n    }\n    if (oldIndex === activeIndex.value) {\n      resetItemPosition(oldIndex)\n    }\n    resetTimer()\n  }\n\n  function resetItemPosition(oldIndex?: number) {\n    items.value.forEach((item, index) => {\n      item.translateItem(index, activeIndex.value, oldIndex)\n    })\n  }\n\n  function itemInStage(item: CarouselItemContext, index: number) {\n    const _items = unref(items)\n    const itemCount = _items.length\n    if (itemCount === 0 || !item.states.inStage) return false\n    const nextItemIndex = index + 1\n    const prevItemIndex = index - 1\n    const lastItemIndex = itemCount - 1\n    const isLastItemActive = _items[lastItemIndex].states.active\n    const isFirstItemActive = _items[0].states.active\n    const isNextItemActive = _items[nextItemIndex]?.states?.active\n    const isPrevItemActive = _items[prevItemIndex]?.states?.active\n\n    if ((index === lastItemIndex && isFirstItemActive) || isNextItemActive) {\n      return 'left'\n    } else if ((index === 0 && isLastItemActive) || isPrevItemActive) {\n      return 'right'\n    }\n    return false\n  }\n\n  function handleMouseEnter() {\n    hover.value = true\n    if (props.pauseOnHover) {\n      pauseTimer()\n    }\n  }\n\n  function handleMouseLeave() {\n    hover.value = false\n    startTimer()\n  }\n\n  function handleTransitionEnd() {\n    isTransitioning.value = false\n  }\n\n  function handleButtonEnter(arrow: 'left' | 'right') {\n    if (unref(isVertical)) return\n    items.value.forEach((item, index) => {\n      if (arrow === itemInStage(item, index)) {\n        item.states.hover = true\n      }\n    })\n  }\n\n  function handleButtonLeave() {\n    if (unref(isVertical)) return\n    items.value.forEach((item) => {\n      item.states.hover = false\n    })\n  }\n\n  function handleIndicatorClick(index: number) {\n    if (index !== activeIndex.value) {\n      if (!isFirstCall.value) {\n        isTransitioning.value = true\n      }\n    }\n    activeIndex.value = index\n  }\n\n  function handleIndicatorHover(index: number) {\n    if (props.trigger === 'hover' && index !== activeIndex.value) {\n      activeIndex.value = index\n      if (!isFirstCall.value) {\n        isTransitioning.value = true\n      }\n    }\n  }\n\n  function prev() {\n    setActiveItem(activeIndex.value - 1)\n  }\n\n  function next() {\n    setActiveItem(activeIndex.value + 1)\n  }\n\n  function resetTimer() {\n    pauseTimer()\n    if (!props.pauseOnHover) startTimer()\n  }\n\n  function setContainerHeight(height: number) {\n    if (props.height !== 'auto') return\n    containerHeight.value = height\n  }\n\n  function PlaceholderItem() {\n    // fix: https://github.com/element-plus/element-plus/issues/12139\n    const defaultSlots = slots.default?.()\n    if (!defaultSlots) return null\n\n    const flatSlots = flattedChildren(defaultSlots)\n\n    const normalizeSlots = flatSlots.filter((slot) => {\n      return isVNode(slot) && (slot.type as any).name === CAROUSEL_ITEM_NAME\n    })\n\n    if (normalizeSlots?.length === 2 && props.loop && !isCardType.value) {\n      isItemsTwoLength.value = true\n      return normalizeSlots\n    }\n    isItemsTwoLength.value = false\n    return null\n  }\n\n  // watch\n  watch(\n    () => activeIndex.value,\n    (current, prev) => {\n      resetItemPosition(prev)\n      if (isItemsTwoLength.value) {\n        current = current % 2\n        prev = prev % 2\n      }\n      if (prev > -1) {\n        emit('change', current, prev)\n      }\n    }\n  )\n  watch(\n    () => props.autoplay,\n    (autoplay) => {\n      autoplay ? startTimer() : pauseTimer()\n    }\n  )\n  watch(\n    () => props.loop,\n    () => {\n      setActiveItem(activeIndex.value)\n    }\n  )\n\n  watch(\n    () => props.interval,\n    () => {\n      resetTimer()\n    }\n  )\n\n  const resizeObserver = shallowRef<ReturnType<typeof useResizeObserver>>()\n  // lifecycle\n  onMounted(() => {\n    watch(\n      () => items.value,\n      () => {\n        if (items.value.length > 0) setActiveItem(props.initialIndex)\n      },\n      {\n        immediate: true,\n      }\n    )\n\n    resizeObserver.value = useResizeObserver(root.value, () => {\n      resetItemPosition()\n    })\n    startTimer()\n  })\n\n  onBeforeUnmount(() => {\n    pauseTimer()\n    if (root.value && resizeObserver.value) resizeObserver.value.stop()\n  })\n\n  // provide\n  provide(carouselContextKey, {\n    root,\n    isCardType,\n    isVertical,\n    items,\n    loop: props.loop,\n    cardScale: props.cardScale,\n    addItem,\n    removeItem,\n    setActiveItem,\n    setContainerHeight,\n  })\n\n  return {\n    root,\n    activeIndex,\n    arrowDisplay,\n    hasLabel,\n    hover,\n    isCardType,\n    isTransitioning,\n    items,\n    isVertical,\n    containerStyle,\n    isItemsTwoLength,\n    handleButtonEnter,\n    handleTransitionEnd,\n    handleButtonLeave,\n    handleIndicatorClick,\n    handleMouseEnter,\n    handleMouseLeave,\n    setActiveItem,\n    prev,\n    next,\n    PlaceholderItem,\n    isTwoLengthShow,\n    throttledArrowClick,\n    throttledIndicatorHover,\n  }\n}\n", "<template>\n  <div\n    ref=\"root\"\n    :class=\"carouselClasses\"\n    @mouseenter.stop=\"handleMouseEnter\"\n    @mouseleave.stop=\"handleMouseLeave\"\n  >\n    <transition v-if=\"arrowDisplay\" name=\"carousel-arrow-left\">\n      <button\n        v-show=\"\n          (arrow === 'always' || hover) && (props.loop || activeIndex > 0)\n        \"\n        type=\"button\"\n        :class=\"[ns.e('arrow'), ns.em('arrow', 'left')]\"\n        :aria-label=\"t('el.carousel.leftArrow')\"\n        @mouseenter=\"handleButtonEnter('left')\"\n        @mouseleave=\"handleButtonLeave\"\n        @click.stop=\"throttledArrowClick(activeIndex - 1)\"\n      >\n        <ElIcon>\n          <ArrowLeft />\n        </ElIcon>\n      </button>\n    </transition>\n    <transition v-if=\"arrowDisplay\" name=\"carousel-arrow-right\">\n      <button\n        v-show=\"\n          (arrow === 'always' || hover) &&\n          (props.loop || activeIndex < items.length - 1)\n        \"\n        type=\"button\"\n        :class=\"[ns.e('arrow'), ns.em('arrow', 'right')]\"\n        :aria-label=\"t('el.carousel.rightArrow')\"\n        @mouseenter=\"handleButtonEnter('right')\"\n        @mouseleave=\"handleButtonLeave\"\n        @click.stop=\"throttledArrowClick(activeIndex + 1)\"\n      >\n        <ElIcon>\n          <ArrowRight />\n        </ElIcon>\n      </button>\n    </transition>\n    <div\n      :class=\"carouselContainer\"\n      :style=\"containerStyle\"\n      @transitionend=\"handleTransitionEnd\"\n    >\n      <PlaceholderItem />\n      <slot />\n    </div>\n    <ul v-if=\"indicatorPosition !== 'none'\" :class=\"indicatorsClasses\">\n      <li\n        v-for=\"(item, index) in items\"\n        v-show=\"isTwoLengthShow(index)\"\n        :key=\"index\"\n        :class=\"[\n          ns.e('indicator'),\n          ns.em('indicator', direction),\n          ns.is('active', index === activeIndex),\n        ]\"\n        @mouseenter=\"throttledIndicatorHover(index)\"\n        @click.stop=\"handleIndicatorClick(index)\"\n      >\n        <button\n          :class=\"ns.e('button')\"\n          :aria-label=\"t('el.carousel.indicator', { index: index + 1 })\"\n        >\n          <span v-if=\"hasLabel\">{{ item.props.label }}</span>\n        </button>\n      </li>\n    </ul>\n    <svg\n      v-if=\"props.motionBlur\"\n      xmlns=\"http://www.w3.org/2000/svg\"\n      version=\"1.1\"\n      style=\"display: none\"\n    >\n      <defs>\n        <filter id=\"elCarouselHorizontal\">\n          <feGaussianBlur in=\"SourceGraphic\" stdDeviation=\"12,0\" />\n        </filter>\n        <filter id=\"elCarouselVertical\">\n          <feGaussianBlur in=\"SourceGraphic\" stdDeviation=\"0,10\" />\n        </filter>\n      </defs>\n    </svg>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, unref } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { ArrowLeft, ArrowRight } from '@element-plus/icons-vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { carouselEmits, carouselProps } from './carousel'\nimport { useCarousel } from './use-carousel'\n\nconst COMPONENT_NAME = 'ElCarousel'\ndefineOptions({\n  name: COMPONENT_NAME,\n})\n\nconst props = defineProps(carouselProps)\nconst emit = defineEmits(carouselEmits)\nconst {\n  root,\n  activeIndex,\n  arrowDisplay,\n  hasLabel,\n  hover,\n  isCardType,\n  items,\n  isVertical,\n  containerStyle,\n  handleButtonEnter,\n  handleButtonLeave,\n  isTransitioning,\n  handleIndicatorClick,\n  handleMouseEnter,\n  handleMouseLeave,\n  handleTransitionEnd,\n  setActiveItem,\n  prev,\n  next,\n  PlaceholderItem,\n  isTwoLengthShow,\n  throttledArrowClick,\n  throttledIndicatorHover,\n} = useCarousel(props, emit, COMPONENT_NAME)\nconst ns = useNamespace('carousel')\n\nconst { t } = useLocale()\n\nconst carouselClasses = computed(() => {\n  const classes = [ns.b(), ns.m(props.direction)]\n  if (unref(isCardType)) {\n    classes.push(ns.m('card'))\n  }\n  return classes\n})\n\nconst carouselContainer = computed(() => {\n  const classes = [ns.e('container')]\n  if (props.motionBlur && unref(isTransitioning) && items.value.length > 1) {\n    classes.push(\n      unref(isVertical)\n        ? `${ns.namespace.value}-transitioning-vertical`\n        : `${ns.namespace.value}-transitioning`\n    )\n  }\n  return classes\n})\n\nconst indicatorsClasses = computed(() => {\n  const classes = [ns.e('indicators'), ns.em('indicators', props.direction)]\n  if (unref(hasLabel)) {\n    classes.push(ns.em('indicators', 'labels'))\n  }\n  if (props.indicatorPosition === 'outside') {\n    classes.push(ns.em('indicators', 'outside'))\n  }\n  if (unref(isVertical)) {\n    classes.push(ns.em('indicators', 'right'))\n  }\n  return classes\n})\n\ndefineExpose({\n  /** @description active slide index */\n  activeIndex,\n  /** @description manually switch slide, index of the slide to be switched to, starting from 0; or the `name` of corresponding `el-carousel-item` */\n  setActiveItem,\n  /** @description switch to the previous slide */\n  prev,\n  /** @description switch to the next slide */\n  next,\n})\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const carouselItemProps = buildProps({\n  /**\n   * @description name of the item, can be used in `setActiveItem`\n   */\n  name: { type: String, default: '' },\n  /**\n   * @description text content for the corresponding indicator\n   */\n  label: {\n    type: [String, Number],\n    default: '',\n  },\n} as const)\n\nexport type CarouselItemProps = ExtractPropTypes<typeof carouselItemProps>\n", "import {\n  getCurrentInstance,\n  inject,\n  onMounted,\n  onUnmounted,\n  reactive,\n  ref,\n  unref,\n} from 'vue'\nimport { debugWarn, isUndefined } from '@element-plus/utils'\nimport { CAROUSEL_ITEM_NAME, carouselContextKey } from './constants'\n\nimport type { CarouselItemProps } from './carousel-item'\n\nexport const useCarouselItem = (props: CarouselItemProps) => {\n  const carouselContext = inject(carouselContextKey)!\n  // instance\n  const instance = getCurrentInstance()!\n  if (!carouselContext) {\n    debugWarn(\n      CAROUSEL_ITEM_NAME,\n      'usage: <el-carousel></el-carousel-item></el-carousel>'\n    )\n  }\n\n  if (!instance) {\n    debugWarn(\n      CAROUSEL_ITEM_NAME,\n      'compositional hook can only be invoked inside setups'\n    )\n  }\n\n  const carouselItemRef = ref<HTMLElement>()\n  const hover = ref(false)\n  const translate = ref(0)\n  const scale = ref(1)\n  const active = ref(false)\n  const ready = ref(false)\n  const inStage = ref(false)\n  const animating = ref(false)\n\n  // computed\n  const { isCardType, isVertical, cardScale } = carouselContext\n\n  // methods\n\n  function processIndex(index: number, activeIndex: number, length: number) {\n    const lastItemIndex = length - 1\n    const prevItemIndex = activeIndex - 1\n    const nextItemIndex = activeIndex + 1\n    const halfItemIndex = length / 2\n\n    if (activeIndex === 0 && index === lastItemIndex) {\n      return -1\n    } else if (activeIndex === lastItemIndex && index === 0) {\n      return length\n    } else if (index < prevItemIndex && activeIndex - index >= halfItemIndex) {\n      return length + 1\n    } else if (index > nextItemIndex && index - activeIndex >= halfItemIndex) {\n      return -2\n    }\n    return index\n  }\n\n  function calcCardTranslate(index: number, activeIndex: number) {\n    const parentWidth = unref(isVertical)\n      ? carouselContext.root.value?.offsetHeight || 0\n      : carouselContext.root.value?.offsetWidth || 0\n\n    if (inStage.value) {\n      return (parentWidth * ((2 - cardScale) * (index - activeIndex) + 1)) / 4\n    } else if (index < activeIndex) {\n      return (-(1 + cardScale) * parentWidth) / 4\n    } else {\n      return ((3 + cardScale) * parentWidth) / 4\n    }\n  }\n\n  function calcTranslate(\n    index: number,\n    activeIndex: number,\n    isVertical: boolean\n  ) {\n    const rootEl = carouselContext.root.value\n    if (!rootEl) return 0\n\n    const distance =\n      (isVertical ? rootEl.offsetHeight : rootEl.offsetWidth) || 0\n    return distance * (index - activeIndex)\n  }\n\n  const translateItem = (\n    index: number,\n    activeIndex: number,\n    oldIndex?: number\n  ) => {\n    const _isCardType = unref(isCardType)\n    const carouselItemLength = carouselContext.items.value.length ?? Number.NaN\n\n    const isActive = index === activeIndex\n    if (!_isCardType && !isUndefined(oldIndex)) {\n      animating.value = isActive || index === oldIndex\n    }\n\n    if (!isActive && carouselItemLength > 2 && carouselContext.loop) {\n      index = processIndex(index, activeIndex, carouselItemLength)\n    }\n\n    const _isVertical = unref(isVertical)\n    active.value = isActive\n\n    if (_isCardType) {\n      inStage.value = Math.round(Math.abs(index - activeIndex)) <= 1\n      translate.value = calcCardTranslate(index, activeIndex)\n      scale.value = unref(active) ? 1 : cardScale\n    } else {\n      translate.value = calcTranslate(index, activeIndex, _isVertical)\n    }\n\n    ready.value = true\n\n    if (isActive && carouselItemRef.value) {\n      carouselContext.setContainerHeight(carouselItemRef.value.offsetHeight)\n    }\n  }\n\n  function handleItemClick() {\n    if (carouselContext && unref(isCardType)) {\n      const index = carouselContext.items.value.findIndex(\n        ({ uid }) => uid === instance.uid\n      )\n      carouselContext.setActiveItem(index)\n    }\n  }\n\n  // lifecycle\n  onMounted(() => {\n    carouselContext.addItem({\n      props,\n      states: reactive({\n        hover,\n        translate,\n        scale,\n        active,\n        ready,\n        inStage,\n        animating,\n      }),\n      uid: instance.uid,\n      translateItem,\n    })\n  })\n\n  onUnmounted(() => {\n    carouselContext.removeItem(instance.uid)\n  })\n\n  return {\n    carouselItemRef,\n    active,\n    animating,\n    hover,\n    inStage,\n    isVertical,\n    translate,\n    isCardType,\n    scale,\n    ready,\n    handleItemClick,\n  }\n}\n", "<template>\n  <div\n    v-show=\"ready\"\n    ref=\"carouselItemRef\"\n    :class=\"itemKls\"\n    :style=\"itemStyle\"\n    @click=\"handleItemClick\"\n  >\n    <div v-if=\"isCardType\" v-show=\"!active\" :class=\"ns.e('mask')\" />\n    <slot />\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, unref } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { carouselItemProps } from './carousel-item'\nimport { useCarouselItem } from './use-carousel-item'\nimport { CAROUSEL_ITEM_NAME } from './constants'\n\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: CAROUSEL_ITEM_NAME,\n})\n\nconst props = defineProps(carouselItemProps)\nconst ns = useNamespace('carousel')\n\n// inject\nconst {\n  carouselItemRef,\n  active,\n  animating,\n  hover,\n  inStage,\n  isVertical,\n  translate,\n  isCardType,\n  scale,\n  ready,\n  handleItemClick,\n} = useCarouselItem(props)\n\nconst itemKls = computed(() => [\n  ns.e('item'),\n  ns.is('active', active.value),\n  ns.is('in-stage', inStage.value),\n  ns.is('hover', hover.value),\n  ns.is('animating', animating.value),\n  {\n    [ns.em('item', 'card')]: isCardType.value,\n    [ns.em('item', 'card-vertical')]: isCardType.value && isVertical.value,\n  },\n])\n\nconst itemStyle = computed<CSSProperties>(() => {\n  const translateType = `translate${unref(isVertical) ? 'Y' : 'X'}`\n  const _translate = `${translateType}(${unref(translate)}px)`\n  const _scale = `scale(${unref(scale)})`\n  const transform = [_translate, _scale].join(' ')\n\n  return {\n    transform,\n  }\n})\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Carousel from './src/carousel.vue'\nimport CarouselItem from './src/carousel-item.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCarousel: SFCWithInstall<typeof Carousel> & {\n  CarouselItem: typeof CarouselItem\n} = withInstall(Carousel, {\n  CarouselItem,\n})\n\nexport default ElCarousel\n\nexport const ElCarouselItem: SFCWithInstall<typeof CarouselItem> =\n  withNoopInstall(CarouselItem)\n\nexport * from './src/carousel'\nexport * from './src/carousel-item'\nexport * from './src/constants'\n\nexport type { CarouselInstance, CarouselItemInstance } from './src/instance'\n", "import { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport { isBoolean, isNumber, isString } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Checkbox from './checkbox.vue'\n\nexport type CheckboxValueType = string | number | boolean\n\nexport const checkboxProps = {\n  /**\n   * @description binding value\n   */\n  modelValue: {\n    type: [Number, String, Boolean],\n    default: undefined,\n  },\n  /**\n   * @description label of the Checkbox when used inside a `checkbox-group`\n   */\n  label: {\n    type: [String, Boolean, Number, Object],\n    default: undefined,\n  },\n  /**\n   * @description value of the Checkbox when used inside a `checkbox-group`\n   */\n  value: {\n    type: [String, Boolean, Number, Object],\n    default: undefined,\n  },\n  /**\n   * @description Set indeterminate state, only responsible for style control\n   */\n  indeterminate: Boolean,\n  /**\n   * @description whether the Checkbox is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description if the Checkbox is checked\n   */\n  checked: Boolean,\n  /**\n   * @description native 'name' attribute\n   */\n  name: {\n    type: String,\n    default: undefined,\n  },\n  /**\n   * @description value of the Checkbox if it's checked\n   */\n  trueValue: {\n    type: [String, Number],\n    default: undefined,\n  },\n  /**\n   * @description value of the Checkbox if it's not checked\n   */\n  falseValue: {\n    type: [String, Number],\n    default: undefined,\n  },\n  /**\n   * @deprecated use `trueValue` instead\n   * @description value of the Checkbox if it's checked\n   */\n  trueLabel: {\n    type: [String, Number],\n    default: undefined,\n  },\n  /**\n   * @deprecated use `falseValue` instead\n   * @description value of the Checkbox if it's not checked\n   */\n  falseLabel: {\n    type: [String, Number],\n    default: undefined,\n  },\n  /**\n   * @description input id\n   */\n  id: {\n    type: String,\n    default: undefined,\n  },\n  /**\n   * @description whether to add a border around Checkbox\n   */\n  border: Boolean,\n  /**\n   * @description size of the Checkbox\n   */\n  size: useSizeProp,\n  /**\n   * @description input tabindex\n   */\n  tabindex: [String, Number],\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  ...useAriaProps(['ariaControls']),\n}\n\nexport const checkboxEmits = {\n  [UPDATE_MODEL_EVENT]: (val: CheckboxValueType) =>\n    isString(val) || isNumber(val) || isBoolean(val),\n  change: (val: CheckboxValueType) =>\n    isString(val) || isNumber(val) || isBoolean(val),\n}\n\nexport type CheckboxProps = ExtractPropTypes<typeof checkboxProps>\nexport type CheckboxEmits = typeof checkboxEmits\nexport type CheckboxInstance = InstanceType<typeof Checkbox>\n", "import type { InjectionKey, ToRefs, WritableComputedRef } from 'vue'\nimport type { CheckboxGroupProps } from './checkbox-group'\n\ntype CheckboxGroupContext = {\n  modelValue?: WritableComputedRef<any>\n  changeEvent?: (...args: any) => any\n} & ToRefs<\n  Pick<\n    CheckboxGroupProps,\n    'size' | 'min' | 'max' | 'disabled' | 'validateEvent' | 'fill' | 'textColor'\n  >\n>\n\nexport const checkboxGroupContextKey: InjectionKey<CheckboxGroupContext> =\n  Symbol('checkboxGroupContextKey')\n", "import { computed, inject } from 'vue'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport { isUndefined } from '@element-plus/utils'\nimport { checkboxGroupContextKey } from '../constants'\n\nimport type { CheckboxModel, CheckboxStatus } from '../composables'\n\nexport const useCheckboxDisabled = ({\n  model,\n  isChecked,\n}: Pick<CheckboxModel, 'model'> & Pick<CheckboxStatus, 'isChecked'>) => {\n  const checkboxGroup = inject(checkboxGroupContextKey, undefined)\n\n  const isLimitDisabled = computed(() => {\n    const max = checkboxGroup?.max?.value\n    const min = checkboxGroup?.min?.value\n    return (\n      (!isUndefined(max) && model.value.length >= max && !isChecked.value) ||\n      (!isUndefined(min) && model.value.length <= min && isChecked.value)\n    )\n  })\n\n  const isDisabled = useFormDisabled(\n    computed(() => checkboxGroup?.disabled.value || isLimitDisabled.value)\n  )\n\n  return {\n    isDisabled,\n    isLimitDisabled,\n  }\n}\n\nexport type CheckboxDisabled = ReturnType<typeof useCheckboxDisabled>\n", "import { computed, getCurrentInstance, inject, nextTick, watch } from 'vue'\nimport { useFormItem } from '@element-plus/components/form'\nimport { debugWarn } from '@element-plus/utils'\nimport { checkboxGroupContextKey } from '../constants'\n\nimport type { useFormItemInputId } from '@element-plus/components/form'\nimport type { CheckboxProps } from '../checkbox'\nimport type {\n  CheckboxDisabled,\n  CheckboxModel,\n  CheckboxStatus,\n} from '../composables'\n\nexport const useCheckboxEvent = (\n  props: CheckboxProps,\n  {\n    model,\n    isLimitExceeded,\n    hasOwnLabel,\n    isDisabled,\n    isLabeledByFormItem,\n  }: Pick<CheckboxModel, 'model' | 'isLimitExceeded'> &\n    Pick<CheckboxStatus, 'hasOwnLabel'> &\n    Pick<CheckboxDisabled, 'isDisabled'> &\n    Pick<ReturnType<typeof useFormItemInputId>, 'isLabeledByFormItem'>\n) => {\n  const checkboxGroup = inject(checkboxGroupContextKey, undefined)\n  const { formItem } = useFormItem()\n  const { emit } = getCurrentInstance()!\n\n  function getLabeledValue(value: string | number | boolean) {\n    return [true, props.trueValue, props.trueLabel].includes(value)\n      ? props.trueValue ?? props.trueLabel ?? true\n      : props.falseValue ?? props.falseLabel ?? false\n  }\n\n  function emitChangeEvent(\n    checked: string | number | boolean,\n    e: InputEvent | MouseEvent\n  ) {\n    emit('change', getLabeledValue(checked), e)\n  }\n\n  function handleChange(e: Event) {\n    if (isLimitExceeded.value) return\n\n    const target = e.target as HTMLInputElement\n    emit('change', getLabeledValue(target.checked), e)\n  }\n\n  async function onClickRoot(e: MouseEvent) {\n    if (isLimitExceeded.value) return\n\n    if (!hasOwnLabel.value && !isDisabled.value && isLabeledByFormItem.value) {\n      // fix: https://github.com/element-plus/element-plus/issues/9981\n      const eventTargets: EventTarget[] = e.composedPath()\n      const hasLabel = eventTargets.some(\n        (item) => (item as HTMLElement).tagName === 'LABEL'\n      )\n      if (!hasLabel) {\n        model.value = getLabeledValue(\n          [false, props.falseValue, props.falseLabel].includes(model.value)\n        )\n        await nextTick()\n        emitChangeEvent(model.value, e)\n      }\n    }\n  }\n\n  const validateEvent = computed(\n    () => checkboxGroup?.validateEvent || props.validateEvent\n  )\n\n  watch(\n    () => props.modelValue,\n    () => {\n      if (validateEvent.value) {\n        formItem?.validate('change').catch((err) => debugWarn(err))\n      }\n    }\n  )\n\n  return {\n    handleChange,\n    onClickRoot,\n  }\n}\n", "import { computed, getCurrentInstance, inject, ref } from 'vue'\nimport { isArray, isUndefined } from '@element-plus/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { checkboxGroupContextKey } from '../constants'\n\nimport type { CheckboxProps } from '../checkbox'\n\nexport const useCheckboxModel = (props: CheckboxProps) => {\n  const selfModel = ref<unknown>(false)\n  const { emit } = getCurrentInstance()!\n  const checkboxGroup = inject(checkboxGroupContextKey, undefined)\n  const isGroup = computed(() => isUndefined(checkboxGroup) === false)\n  const isLimitExceeded = ref(false)\n  const model = computed({\n    get() {\n      return isGroup.value\n        ? checkboxGroup?.modelValue?.value\n        : props.modelValue ?? selfModel.value\n    },\n\n    set(val: unknown) {\n      if (isGroup.value && isArray(val)) {\n        isLimitExceeded.value =\n          checkboxGroup?.max?.value !== undefined &&\n          val.length > checkboxGroup?.max.value &&\n          val.length > model.value.length\n        isLimitExceeded.value === false && checkboxGroup?.changeEvent?.(val)\n      } else {\n        emit(UPDATE_MODEL_EVENT, val)\n        selfModel.value = val\n      }\n    },\n  })\n\n  return {\n    model,\n    isGroup,\n    isLimitExceeded,\n  }\n}\n\nexport type CheckboxModel = ReturnType<typeof useCheckboxModel>\n", "import { computed, inject, ref, toRaw } from 'vue'\nimport { isEqual } from 'lodash-unified'\nimport { useFormSize } from '@element-plus/components/form'\nimport { isArray, isBoolean, isObject, isPropAbsent } from '@element-plus/utils'\nimport { checkboxGroupContextKey } from '../constants'\n\nimport type { ComponentInternalInstance } from 'vue'\nimport type { CheckboxProps } from '../checkbox'\nimport type { CheckboxModel } from '../composables'\n\nexport const useCheckboxStatus = (\n  props: CheckboxProps,\n  slots: ComponentInternalInstance['slots'],\n  { model }: Pick<CheckboxModel, 'model'>\n) => {\n  const checkboxGroup = inject(checkboxGroupContextKey, undefined)\n  const isFocused = ref(false)\n  const actualValue = computed(() => {\n    // In version 2.x, if there's no props.value, props.label will act as props.value\n    // In version 3.x, remove this computed value, use props.value instead.\n    if (!isPropAbsent(props.value)) {\n      return props.value\n    }\n    return props.label\n  })\n  const isChecked = computed<boolean>(() => {\n    const value = model.value\n    if (isBoolean(value)) {\n      return value\n    } else if (isArray(value)) {\n      if (isObject(actualValue.value)) {\n        return value.map(toRaw).some((o) => isEqual(o, actualValue.value))\n      } else {\n        return value.map(toRaw).includes(actualValue.value)\n      }\n    } else if (value !== null && value !== undefined) {\n      return value === props.trueValue || value === props.trueLabel\n    } else {\n      return !!value\n    }\n  })\n\n  const checkboxButtonSize = useFormSize(\n    computed(() => checkboxGroup?.size?.value),\n    {\n      prop: true,\n    }\n  )\n  const checkboxSize = useFormSize(computed(() => checkboxGroup?.size?.value))\n\n  const hasOwnLabel = computed<boolean>(() => {\n    return !!slots.default || !isPropAbsent(actualValue.value)\n  })\n\n  return {\n    checkboxButtonSize,\n    isChecked,\n    isFocused,\n    checkboxSize,\n    hasOwnLabel,\n    actualValue,\n  }\n}\n\nexport type CheckboxStatus = ReturnType<typeof useCheckboxStatus>\n", "import { computed } from 'vue'\nimport { useFormItem, useFormItemInputId } from '@element-plus/components/form'\nimport { isArray, isPropAbsent } from '@element-plus/utils'\nimport { useDeprecated } from '@element-plus/hooks'\nimport { useCheckboxDisabled } from './use-checkbox-disabled'\nimport { useCheckboxEvent } from './use-checkbox-event'\nimport { useCheckboxModel } from './use-checkbox-model'\nimport { useCheckboxStatus } from './use-checkbox-status'\nimport type { ComponentInternalInstance } from 'vue'\n\nimport type { CheckboxProps } from '../checkbox'\n\nexport const useCheckbox = (\n  props: CheckboxProps,\n  slots: ComponentInternalInstance['slots']\n) => {\n  const { formItem: elFormItem } = useFormItem()\n  const { model, isGroup, isLimitExceeded } = useCheckboxModel(props)\n  const {\n    isFocused,\n    isChecked,\n    checkboxButtonSize,\n    checkboxSize,\n    hasOwnLabel,\n    actualValue,\n  } = useCheckboxStatus(props, slots, { model })\n  const { isDisabled } = useCheckboxDisabled({ model, isChecked })\n  const { inputId, isLabeledByFormItem } = useFormItemInputId(props, {\n    formItemContext: elFormItem,\n    disableIdGeneration: hasOwnLabel,\n    disableIdManagement: isGroup,\n  })\n  const { handleChange, onClickRoot } = useCheckboxEvent(props, {\n    model,\n    isLimitExceeded,\n    hasOwnLabel,\n    isDisabled,\n    isLabeledByFormItem,\n  })\n\n  const setStoreValue = () => {\n    function addToStore() {\n      if (isArray(model.value) && !model.value.includes(actualValue.value)) {\n        model.value.push(actualValue.value)\n      } else {\n        model.value = props.trueValue ?? props.trueLabel ?? true\n      }\n    }\n    props.checked && addToStore()\n  }\n\n  setStoreValue()\n\n  useDeprecated(\n    {\n      from: 'label act as value',\n      replacement: 'value',\n      version: '3.0.0',\n      scope: 'el-checkbox',\n      ref: 'https://element-plus.org/en-US/component/checkbox.html',\n    },\n    computed(() => isGroup.value && isPropAbsent(props.value))\n  )\n\n  useDeprecated(\n    {\n      from: 'true-label',\n      replacement: 'true-value',\n      version: '3.0.0',\n      scope: 'el-checkbox',\n      ref: 'https://element-plus.org/en-US/component/checkbox.html',\n    },\n    computed(() => !!props.trueLabel)\n  )\n\n  useDeprecated(\n    {\n      from: 'false-label',\n      replacement: 'false-value',\n      version: '3.0.0',\n      scope: 'el-checkbox',\n      ref: 'https://element-plus.org/en-US/component/checkbox.html',\n    },\n    computed(() => !!props.falseLabel)\n  )\n\n  return {\n    inputId,\n    isLabeledByFormItem,\n    isChecked,\n    isDisabled,\n    isFocused,\n    checkboxButtonSize,\n    checkboxSize,\n    hasOwnLabel,\n    model,\n    actualValue,\n    handleChange,\n    onClickRoot,\n  }\n}\n", "<template>\n  <component\n    :is=\"!hasOwnLabel && isLabeledByFormItem ? 'span' : 'label'\"\n    :class=\"compKls\"\n    :aria-controls=\"indeterminate ? ariaControls : null\"\n    @click=\"onClickRoot\"\n  >\n    <span :class=\"spanKls\">\n      <input\n        v-if=\"trueValue || falseValue || trueLabel || falseLabel\"\n        :id=\"inputId\"\n        v-model=\"model\"\n        :class=\"ns.e('original')\"\n        type=\"checkbox\"\n        :indeterminate=\"indeterminate\"\n        :name=\"name\"\n        :tabindex=\"tabindex\"\n        :disabled=\"isDisabled\"\n        :true-value=\"trueValue ?? trueLabel ?? true\"\n        :false-value=\"falseValue ?? falseLabel ?? false\"\n        @change=\"handleChange\"\n        @focus=\"isFocused = true\"\n        @blur=\"isFocused = false\"\n        @click.stop\n      />\n      <input\n        v-else\n        :id=\"inputId\"\n        v-model=\"model\"\n        :class=\"ns.e('original')\"\n        type=\"checkbox\"\n        :indeterminate=\"indeterminate\"\n        :disabled=\"isDisabled\"\n        :value=\"actualValue\"\n        :name=\"name\"\n        :tabindex=\"tabindex\"\n        @change=\"handleChange\"\n        @focus=\"isFocused = true\"\n        @blur=\"isFocused = false\"\n        @click.stop\n      />\n      <span :class=\"ns.e('inner')\" />\n    </span>\n    <span v-if=\"hasOwnLabel\" :class=\"ns.e('label')\">\n      <slot />\n      <template v-if=\"!$slots.default\">{{ label }}</template>\n    </span>\n  </component>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, useSlots } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { checkboxEmits, checkboxProps } from './checkbox'\nimport { useCheckbox } from './composables'\n\ndefineOptions({\n  name: 'ElCheckbox',\n})\n\nconst props = defineProps(checkboxProps)\ndefineEmits(checkboxEmits)\nconst slots = useSlots()\n\nconst {\n  inputId,\n  isLabeledByFormItem,\n  isChecked,\n  isDisabled,\n  isFocused,\n  checkboxSize,\n  hasOwnLabel,\n  model,\n  actualValue,\n  handleChange,\n  onClickRoot,\n} = useCheckbox(props, slots)\n\nconst ns = useNamespace('checkbox')\n\nconst compKls = computed(() => {\n  return [\n    ns.b(),\n    ns.m(checkboxSize.value),\n    ns.is('disabled', isDisabled.value),\n    ns.is('bordered', props.border),\n    ns.is('checked', isChecked.value),\n  ]\n})\n\nconst spanKls = computed(() => {\n  return [\n    ns.e('input'),\n    ns.is('disabled', isDisabled.value),\n    ns.is('checked', isChecked.value),\n    ns.is('indeterminate', props.indeterminate),\n    ns.is('focus', isFocused.value),\n  ]\n})\n</script>\n", "<template>\n  <label :class=\"labelKls\">\n    <input\n      v-if=\"trueValue || falseValue || trueLabel || falseLabel\"\n      v-model=\"model\"\n      :class=\"ns.be('button', 'original')\"\n      type=\"checkbox\"\n      :name=\"name\"\n      :tabindex=\"tabindex\"\n      :disabled=\"isDisabled\"\n      :true-value=\"trueValue ?? trueLabel ?? true\"\n      :false-value=\"falseValue ?? falseLabel ?? false\"\n      @change=\"handleChange\"\n      @focus=\"isFocused = true\"\n      @blur=\"isFocused = false\"\n      @click.stop\n    />\n    <input\n      v-else\n      v-model=\"model\"\n      :class=\"ns.be('button', 'original')\"\n      type=\"checkbox\"\n      :name=\"name\"\n      :tabindex=\"tabindex\"\n      :disabled=\"isDisabled\"\n      :value=\"actualValue\"\n      @change=\"handleChange\"\n      @focus=\"isFocused = true\"\n      @blur=\"isFocused = false\"\n      @click.stop\n    />\n\n    <span\n      v-if=\"$slots.default || label\"\n      :class=\"ns.be('button', 'inner')\"\n      :style=\"isChecked ? activeStyle : undefined\"\n    >\n      <slot>{{ label }}</slot>\n    </span>\n  </label>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, useSlots } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { checkboxGroupContextKey } from './constants'\nimport { useCheckbox } from './composables'\nimport { checkboxEmits, checkboxProps } from './checkbox'\n\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElCheckboxButton',\n})\n\nconst props = defineProps(checkboxProps)\ndefineEmits(checkboxEmits)\nconst slots = useSlots()\n\nconst {\n  isFocused,\n  isChecked,\n  isDisabled,\n  checkboxButtonSize,\n  model,\n  actualValue,\n  handleChange,\n} = useCheckbox(props, slots)\nconst checkboxGroup = inject(checkboxGroupContextKey, undefined)\nconst ns = useNamespace('checkbox')\n\nconst activeStyle = computed<CSSProperties>(() => {\n  const fillValue = checkboxGroup?.fill?.value ?? ''\n  return {\n    backgroundColor: fillValue,\n    borderColor: fillValue,\n    color: checkboxGroup?.textColor?.value ?? '',\n    boxShadow: fillValue ? `-1px 0 0 0 ${fillValue}` : undefined,\n  }\n})\n\nconst labelKls = computed(() => {\n  return [\n    ns.b('button'),\n    ns.bm('button', checkboxButtonSize.value),\n    ns.is('disabled', isDisabled.value),\n    ns.is('checked', isChecked.value),\n    ns.is('focus', isFocused.value),\n  ]\n})\n</script>\n", "import { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport { buildProps, definePropType, isArray } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type checkboxGroup from './checkbox-group.vue'\nimport type { CheckboxValueType } from './checkbox'\n\nexport type CheckboxGroupValueType = Exclude<CheckboxValueType, boolean>[]\n\nexport const checkboxGroupProps = buildProps({\n  /**\n   * @description binding value\n   */\n  modelValue: {\n    type: definePropType<CheckboxGroupValueType>(Array),\n    default: () => [],\n  },\n  /**\n   * @description whether the nesting checkboxes are disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description minimum number of checkbox checked\n   */\n  min: Number,\n  /**\n   * @description maximum number of checkbox checked\n   */\n  max: Number,\n  /**\n   * @description size of checkbox\n   */\n  size: useSizeProp,\n  /**\n   * @description border and background color when button is active\n   */\n  fill: String,\n  /**\n   * @description font color when button is active\n   */\n  textColor: String,\n  /**\n   * @description element tag of the checkbox group\n   */\n  tag: {\n    type: String,\n    default: 'div',\n  },\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  ...useAriaProps(['ariaLabel']),\n} as const)\n\nexport const checkboxGroupEmits = {\n  [UPDATE_MODEL_EVENT]: (val: CheckboxGroupValueType) => isArray(val),\n  change: (val: CheckboxValueType[]) => isArray(val),\n}\n\nexport type CheckboxGroupProps = ExtractPropTypes<typeof checkboxGroupProps>\nexport type CheckboxGroupEmits = typeof checkboxGroupEmits\nexport type CheckboxGroupInstance = InstanceType<typeof checkboxGroup>\n", "<template>\n  <component\n    :is=\"tag\"\n    :id=\"groupId\"\n    :class=\"ns.b('group')\"\n    role=\"group\"\n    :aria-label=\"\n      !isLabeledByFormItem ? ariaLabel || 'checkbox-group' : undefined\n    \"\n    :aria-labelledby=\"isLabeledByFormItem ? formItem?.labelId : undefined\"\n  >\n    <slot />\n  </component>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, nextTick, provide, toRefs, watch } from 'vue'\nimport { pick } from 'lodash-unified'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { debugWarn } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormItem, useFormItemInputId } from '@element-plus/components/form'\nimport { checkboxGroupEmits, checkboxGroupProps } from './checkbox-group'\nimport { checkboxGroupContextKey } from './constants'\n\nimport type { CheckboxGroupValueType } from './checkbox-group'\n\ndefineOptions({\n  name: 'ElCheckboxGroup',\n})\n\nconst props = defineProps(checkboxGroupProps)\nconst emit = defineEmits(checkboxGroupEmits)\nconst ns = useNamespace('checkbox')\n\nconst { formItem } = useFormItem()\nconst { inputId: groupId, isLabeledByFormItem } = useFormItemInputId(props, {\n  formItemContext: formItem,\n})\n\nconst changeEvent = async (value: CheckboxGroupValueType) => {\n  emit(UPDATE_MODEL_EVENT, value)\n  await nextTick()\n  emit('change', value)\n}\n\nconst modelValue = computed({\n  get() {\n    return props.modelValue\n  },\n  set(val: CheckboxGroupValueType) {\n    changeEvent(val)\n  },\n})\n\nprovide(checkboxGroupContextKey, {\n  ...pick(toRefs(props), [\n    'size',\n    'min',\n    'max',\n    'disabled',\n    'validateEvent',\n    'fill',\n    'textColor',\n  ]),\n  modelValue,\n  changeEvent,\n})\n\nwatch(\n  () => props.modelValue,\n  () => {\n    if (props.validateEvent) {\n      formItem?.validate('change').catch((err) => debugWarn(err))\n    }\n  }\n)\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\n\nimport Checkbox from './src/checkbox.vue'\nimport CheckboxButton from './src/checkbox-button.vue'\nimport CheckboxGroup from './src/checkbox-group.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCheckbox: SFCWithInstall<typeof Checkbox> & {\n  CheckboxButton: typeof CheckboxButton\n  CheckboxGroup: typeof CheckboxGroup\n} = withInstall(Checkbox, {\n  CheckboxButton,\n  CheckboxGroup,\n})\nexport default ElCheckbox\n\nexport const ElCheckboxButton: SFCWithInstall<typeof CheckboxButton> =\n  withNoopInstall(CheckboxButton)\nexport const ElCheckboxGroup: SFCWithInstall<typeof CheckboxGroup> =\n  withNoopInstall(CheckboxGroup)\n\nexport * from './src/checkbox-group'\nexport * from './src/checkbox'\nexport * from './src/constants'\n", "import { buildProps, isBoolean, isNumber, isString } from '@element-plus/utils'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { useSizeProp } from '@element-plus/hooks'\nimport type { ExtractPropTypes } from 'vue'\nimport type Radio from './radio.vue'\n\nexport const radioPropsBase = buildProps({\n  /**\n   * @description binding value\n   */\n  modelValue: {\n    type: [String, Number, Boolean],\n    default: undefined,\n  },\n  /**\n   * @description size of the Radio\n   */\n  size: useSizeProp,\n  /**\n   * @description whether Radio is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description the label of Radio\n   */\n  label: {\n    type: [String, Number, Boolean],\n    default: undefined,\n  },\n  /**\n   * @description the value of Radio\n   */\n  value: {\n    type: [String, Number, Boolean],\n    default: undefined,\n  },\n  /**\n   * @description native `name` attribute\n   */\n  name: {\n    type: String,\n    default: undefined,\n  },\n})\n\nexport const radioProps = buildProps({\n  ...radioPropsBase,\n  /**\n   * @description whether to add a border around Radio\n   */\n  border: Boolean,\n} as const)\n\nexport const radioEmits = {\n  [UPDATE_MODEL_EVENT]: (val: string | number | boolean | undefined) =>\n    isString(val) || isNumber(val) || isBoolean(val),\n  [CHANGE_EVENT]: (val: string | number | boolean | undefined) =>\n    isString(val) || isNumber(val) || isBoolean(val),\n}\n\nexport type RadioProps = ExtractPropTypes<typeof radioProps>\nexport type RadioEmits = typeof radioEmits\nexport type RadioInstance = InstanceType<typeof Radio>\n", "import type { InjectionKey } from 'vue'\nimport type { RadioGroupProps } from './radio-group'\n\nexport interface RadioGroupContext extends RadioGroupProps {\n  changeEvent: (val: RadioGroupProps['modelValue']) => void\n}\n\nexport const radioGroupKey: InjectionKey<RadioGroupContext> =\n  Symbol('radioGroupKey')\n", "import { computed, inject, ref } from 'vue'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { useFormDisabled, useFormSize } from '@element-plus/components/form'\nimport { useDeprecated } from '@element-plus/hooks'\nimport { isPropAbsent } from '@element-plus/utils'\nimport { radioGroupKey } from './constants'\n\nimport type { RadioButtonProps } from './radio-button'\nimport type { SetupContext } from 'vue'\nimport type { RadioEmits, RadioProps } from './radio'\nexport const useRadio = (\n  props: RadioProps | RadioButtonProps,\n  emit?: SetupContext<RadioEmits>['emit']\n) => {\n  const radioRef = ref<HTMLInputElement>()\n  const radioGroup = inject(radioGroupKey, undefined)\n  const isGroup = computed(() => !!radioGroup)\n  const actualValue = computed(() => {\n    // In version 2.x, if there's no props.value, props.label will act as props.value\n    // In version 3.x, remove this computed value, use props.value instead.\n    if (!isPropAbsent(props.value)) {\n      return props.value\n    }\n    return props.label\n  })\n  const modelValue = computed<RadioProps['modelValue']>({\n    get() {\n      return isGroup.value ? radioGroup!.modelValue : props.modelValue!\n    },\n    set(val) {\n      if (isGroup.value) {\n        radioGroup!.changeEvent(val)\n      } else {\n        emit && emit(UPDATE_MODEL_EVENT, val)\n      }\n      radioRef.value!.checked = props.modelValue === actualValue.value\n    },\n  })\n\n  const size = useFormSize(computed(() => radioGroup?.size))\n  const disabled = useFormDisabled(computed(() => radioGroup?.disabled))\n  const focus = ref(false)\n  const tabIndex = computed(() => {\n    return disabled.value ||\n      (isGroup.value && modelValue.value !== actualValue.value)\n      ? -1\n      : 0\n  })\n\n  useDeprecated(\n    {\n      from: 'label act as value',\n      replacement: 'value',\n      version: '3.0.0',\n      scope: 'el-radio',\n      ref: 'https://element-plus.org/en-US/component/radio.html',\n    },\n    computed(() => isGroup.value && isPropAbsent(props.value))\n  )\n\n  return {\n    radioRef,\n    isGroup,\n    radioGroup,\n    focus,\n    size,\n    disabled,\n    tabIndex,\n    modelValue,\n    actualValue,\n  }\n}\n", "<template>\n  <label\n    :class=\"[\n      ns.b(),\n      ns.is('disabled', disabled),\n      ns.is('focus', focus),\n      ns.is('bordered', border),\n      ns.is('checked', modelValue === actualValue),\n      ns.m(size),\n    ]\"\n  >\n    <span\n      :class=\"[\n        ns.e('input'),\n        ns.is('disabled', disabled),\n        ns.is('checked', modelValue === actualValue),\n      ]\"\n    >\n      <input\n        ref=\"radioRef\"\n        v-model=\"modelValue\"\n        :class=\"ns.e('original')\"\n        :value=\"actualValue\"\n        :name=\"name || radioGroup?.name\"\n        :disabled=\"disabled\"\n        :checked=\"modelValue === actualValue\"\n        type=\"radio\"\n        @focus=\"focus = true\"\n        @blur=\"focus = false\"\n        @change=\"handleChange\"\n        @click.stop\n      />\n      <span :class=\"ns.e('inner')\" />\n    </span>\n    <span :class=\"ns.e('label')\" @keydown.stop>\n      <slot>\n        {{ label }}\n      </slot>\n    </span>\n  </label>\n</template>\n\n<script lang=\"ts\" setup>\nimport { nextTick } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { radioEmits, radioProps } from './radio'\nimport { useRadio } from './use-radio'\n\ndefineOptions({\n  name: 'ElRadio',\n})\n\nconst props = defineProps(radioProps)\nconst emit = defineEmits(radioEmits)\n\nconst ns = useNamespace('radio')\nconst { radioRef, radioGroup, focus, size, disabled, modelValue, actualValue } =\n  useRadio(props, emit)\n\nfunction handleChange() {\n  nextTick(() => emit('change', modelValue.value))\n}\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport { radioPropsBase } from './radio'\nimport type { ExtractPropTypes } from 'vue'\nimport type RadioButton from './radio-button.vue'\n\nexport const radioButtonProps = buildProps({\n  ...radioPropsBase,\n} as const)\n\nexport type RadioButtonProps = ExtractPropTypes<typeof radioButtonProps>\nexport type RadioButtonInstance = InstanceType<typeof RadioButton>\n", "<template>\n  <label\n    :class=\"[\n      ns.b('button'),\n      ns.is('active', modelValue === actualValue),\n      ns.is('disabled', disabled),\n      ns.is('focus', focus),\n      ns.bm('button', size),\n    ]\"\n  >\n    <input\n      ref=\"radioRef\"\n      v-model=\"modelValue\"\n      :class=\"ns.be('button', 'original-radio')\"\n      :value=\"actualValue\"\n      type=\"radio\"\n      :name=\"name || radioGroup?.name\"\n      :disabled=\"disabled\"\n      @focus=\"focus = true\"\n      @blur=\"focus = false\"\n      @click.stop\n    />\n    <span\n      :class=\"ns.be('button', 'inner')\"\n      :style=\"modelValue === actualValue ? activeStyle : {}\"\n      @keydown.stop\n    >\n      <slot>\n        {{ label }}\n      </slot>\n    </span>\n  </label>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useRadio } from './use-radio'\nimport { radioButtonProps } from './radio-button'\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElRadioButton',\n})\n\nconst props = defineProps(radioButtonProps)\n\nconst ns = useNamespace('radio')\nconst { radioRef, focus, size, disabled, modelValue, radioGroup, actualValue } =\n  useRadio(props)\n\nconst activeStyle = computed<CSSProperties>(() => {\n  return {\n    backgroundColor: radioGroup?.fill || '',\n    borderColor: radioGroup?.fill || '',\n    boxShadow: radioGroup?.fill ? `-1px 0 0 0 ${radioGroup.fill}` : '',\n    color: radioGroup?.textColor || '',\n  }\n})\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport { radioEmits } from './radio'\nimport type { ExtractPropTypes } from '@vue/runtime-core'\nimport type RadioGroup from './radio-group.vue'\n\nexport const radioGroupProps = buildProps({\n  /**\n   * @description native `id` attribute\n   */\n  id: {\n    type: String,\n    default: undefined,\n  },\n  /**\n   * @description the size of radio buttons or bordered radios\n   */\n  size: useSizeProp,\n  /**\n   * @description whether the nesting radios are disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description binding value\n   */\n  modelValue: {\n    type: [String, Number, Boolean],\n    default: undefined,\n  },\n  /**\n   * @description border and background color when button is active\n   */\n  fill: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description font color when button is active\n   */\n  textColor: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description native `name` attribute\n   */\n  name: {\n    type: String,\n    default: undefined,\n  },\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  ...useAriaProps(['ariaLabel']),\n} as const)\nexport type RadioGroupProps = ExtractPropTypes<typeof radioGroupProps>\n\nexport const radioGroupEmits = radioEmits\nexport type RadioGroupEmits = typeof radioGroupEmits\nexport type RadioGroupInstance = InstanceType<typeof RadioGroup>\n", "<template>\n  <div\n    :id=\"groupId\"\n    ref=\"radioGroupRef\"\n    :class=\"ns.b('group')\"\n    role=\"radiogroup\"\n    :aria-label=\"!isLabeledByFormItem ? ariaLabel || 'radio-group' : undefined\"\n    :aria-labelledby=\"isLabeledByFormItem ? formItem!.labelId : undefined\"\n  >\n    <slot />\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  nextTick,\n  onMounted,\n  provide,\n  reactive,\n  ref,\n  toRefs,\n  watch,\n} from 'vue'\nimport { useFormItem, useFormItemInputId } from '@element-plus/components/form'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport { debugWarn } from '@element-plus/utils'\nimport { radioGroupEmits, radioGroupProps } from './radio-group'\nimport { radioGroupKey } from './constants'\n\nimport type { RadioGroupProps } from './radio-group'\n\ndefineOptions({\n  name: 'ElRadioGroup',\n})\n\nconst props = defineProps(radioGroupProps)\nconst emit = defineEmits(radioGroupEmits)\n\nconst ns = useNamespace('radio')\nconst radioId = useId()\nconst radioGroupRef = ref<HTMLDivElement>()\nconst { formItem } = useFormItem()\nconst { inputId: groupId, isLabeledByFormItem } = useFormItemInputId(props, {\n  formItemContext: formItem,\n})\n\nconst changeEvent = (value: RadioGroupProps['modelValue']) => {\n  emit(UPDATE_MODEL_EVENT, value)\n  nextTick(() => emit('change', value))\n}\n\nonMounted(() => {\n  const radios =\n    radioGroupRef.value!.querySelectorAll<HTMLInputElement>('[type=radio]')\n  const firstLabel = radios[0]\n  if (!Array.from(radios).some((radio) => radio.checked) && firstLabel) {\n    firstLabel.tabIndex = 0\n  }\n})\n\nconst name = computed(() => {\n  return props.name || radioId.value\n})\n\nprovide(\n  radioGroupKey,\n  reactive({\n    ...toRefs(props),\n    changeEvent,\n    name,\n  })\n)\n\nwatch(\n  () => props.modelValue,\n  () => {\n    if (props.validateEvent) {\n      formItem?.validate('change').catch((err) => debugWarn(err))\n    }\n  }\n)\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\n\nimport Radio from './src/radio.vue'\nimport RadioButton from './src/radio-button.vue'\nimport RadioGroup from './src/radio-group.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElRadio: SFCWithInstall<typeof Radio> & {\n  RadioButton: typeof RadioButton\n  RadioGroup: typeof RadioGroup\n} = withInstall(Radio, {\n  RadioButton,\n  RadioGroup,\n})\nexport default ElRadio\nexport const ElRadioGroup: SFCWithInstall<typeof RadioGroup> =\n  withNoopInstall(RadioGroup)\nexport const ElRadioButton: SFCWithInstall<typeof RadioButton> =\n  withNoopInstall(RadioButton)\n\nexport * from './src/radio'\nexport * from './src/radio-group'\nexport * from './src/radio-button'\nexport * from './src/constants'\n", "// @ts-nocheck\nimport { defineComponent, h } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nexport default defineComponent({\n  name: 'NodeContent',\n  setup() {\n    const ns = useNamespace('cascader-node')\n    return {\n      ns,\n    }\n  },\n  render() {\n    const { ns } = this\n    const { node, panel } = this.$parent\n    const { data, label } = node\n    const { renderLabelFn } = panel\n    return h(\n      'span',\n      { class: ns.e('label') },\n      renderLabelFn ? renderLabelFn({ node, data }) : label\n    )\n  },\n})\n", "// @ts-nocheck\nimport type { InjectionKey, VNode } from 'vue'\nimport type { Nullable } from '@element-plus/utils'\nimport type {\n  default as CascaderNode,\n  CascaderOption,\n  CascaderProps,\n  ExpandTrigger,\n} from './node'\n\nexport type { CascaderNode, CascaderOption, CascaderProps, ExpandTrigger }\n\nexport type CascaderNodeValue = string | number\nexport type CascaderNodePathValue = CascaderNodeValue[]\nexport type CascaderValue =\n  | CascaderNodeValue\n  | CascaderNodePathValue\n  | (CascaderNodeValue | CascaderNodePathValue)[]\nexport type CascaderConfig = Required<CascaderProps>\nexport type isDisabled = (data: CascaderOption, node: CascaderNode) => boolean\nexport type isLeaf = (data: CascaderOption, node: CascaderNode) => boolean\nexport type Resolve = (dataList?: CascaderOption[]) => void\nexport type LazyLoad = (node: CascaderNode, resolve: Resolve) => void\nexport type RenderLabel = ({\n  node: CascaderNode,\n  data: CascaderOption,\n}) => VNode | VNode[]\n\nexport interface Tag {\n  node?: CascaderNode\n  key: number\n  text: string\n  hitState?: boolean\n  closable: boolean\n  isCollapseTag: boolean\n}\n\nexport interface ElCascaderPanelContext {\n  config: CascaderConfig\n  expandingNode: Nullable<CascaderNode>\n  checkedNodes: CascaderNode[]\n  isHoverMenu: boolean\n  initialLoaded: boolean\n  renderLabelFn: RenderLabel\n  lazyLoad: (\n    node?: CascaderNode,\n    cb?: (dataList: CascaderOption[]) => void\n  ) => void\n  expandNode: (node: CascaderNode, silent?: boolean) => void\n  handleCheckChange: (\n    node: CascaderNode,\n    checked: boolean,\n    emitClose?: boolean\n  ) => void\n}\n\nexport const CASCADER_PANEL_INJECTION_KEY: InjectionKey<ElCascaderPanelContext> =\n  Symbol()\n", "<template>\n  <li\n    :id=\"`${menuId}-${node.uid}`\"\n    role=\"menuitem\"\n    :aria-haspopup=\"!isLeaf\"\n    :aria-owns=\"isLeaf ? null : menuId\"\n    :aria-expanded=\"inExpandingPath\"\n    :tabindex=\"expandable ? -1 : undefined\"\n    :class=\"[\n      ns.b(),\n      ns.is('selectable', checkStrictly),\n      ns.is('active', node.checked),\n      ns.is('disabled', !expandable),\n      inExpandingPath && 'in-active-path',\n      inCheckedPath && 'in-checked-path',\n    ]\"\n    @mouseenter=\"handleHoverExpand\"\n    @focus=\"handleHoverExpand\"\n    @click=\"handleClick\"\n  >\n    <!-- prefix -->\n    <el-checkbox\n      v-if=\"multiple\"\n      :model-value=\"node.checked\"\n      :indeterminate=\"node.indeterminate\"\n      :disabled=\"isDisabled\"\n      @click.stop\n      @update:model-value=\"handleSelectCheck\"\n    />\n    <el-radio\n      v-else-if=\"checkStrictly\"\n      :model-value=\"checkedNodeId\"\n      :label=\"node.uid\"\n      :disabled=\"isDisabled\"\n      @update:model-value=\"handleSelectCheck\"\n      @click.stop\n    >\n      <!--\n        Add an empty element to avoid render label,\n        do not use empty fragment here for https://github.com/vuejs/vue-next/pull/2485\n      -->\n      <span />\n    </el-radio>\n    <el-icon v-else-if=\"isLeaf && node.checked\" :class=\"ns.e('prefix')\">\n      <check />\n    </el-icon>\n\n    <!-- content -->\n    <node-content />\n\n    <!-- postfix -->\n    <template v-if=\"!isLeaf\">\n      <el-icon v-if=\"node.loading\" :class=\"[ns.is('loading'), ns.e('postfix')]\">\n        <loading />\n      </el-icon>\n      <el-icon v-else :class=\"['arrow-right', ns.e('postfix')]\">\n        <arrow-right />\n      </el-icon>\n    </template>\n  </li>\n</template>\n\n<script lang=\"ts\">\n// @ts-nocheck\nimport { computed, defineComponent, inject } from 'vue'\nimport ElCheckbox from '@element-plus/components/checkbox'\nimport ElRadio from '@element-plus/components/radio'\nimport ElIcon from '@element-plus/components/icon'\nimport { useNamespace } from '@element-plus/hooks'\nimport { ArrowRight, Check, Loading } from '@element-plus/icons-vue'\nimport NodeContent from './node-content'\nimport { CASCADER_PANEL_INJECTION_KEY } from './types'\nimport type { default as CascaderNode } from './node'\n\nimport type { PropType } from 'vue'\n\nexport default defineComponent({\n  name: 'ElCascaderNode',\n\n  components: {\n    ElCheckbox,\n    ElRadio,\n    NodeContent,\n    ElIcon,\n    Check,\n    Loading,\n    ArrowRight,\n  },\n\n  props: {\n    node: {\n      type: Object as PropType<CascaderNode>,\n      required: true,\n    },\n    menuId: String,\n  },\n\n  emits: ['expand'],\n\n  setup(props, { emit }) {\n    const panel = inject(CASCADER_PANEL_INJECTION_KEY)!\n\n    const ns = useNamespace('cascader-node')\n    const isHoverMenu = computed(() => panel.isHoverMenu)\n    const multiple = computed(() => panel.config.multiple)\n    const checkStrictly = computed(() => panel.config.checkStrictly)\n    const checkedNodeId = computed(() => panel.checkedNodes[0]?.uid)\n    const isDisabled = computed(() => props.node.isDisabled)\n    const isLeaf = computed(() => props.node.isLeaf)\n    const expandable = computed(\n      () => (checkStrictly.value && !isLeaf.value) || !isDisabled.value\n    )\n    const inExpandingPath = computed(() => isInPath(panel.expandingNode!))\n    // only useful in check-strictly mode\n    const inCheckedPath = computed(\n      () => checkStrictly.value && panel.checkedNodes.some(isInPath)\n    )\n\n    const isInPath = (node: CascaderNode) => {\n      const { level, uid } = props.node\n      return node?.pathNodes[level - 1]?.uid === uid\n    }\n\n    const doExpand = () => {\n      if (inExpandingPath.value) return\n      panel.expandNode(props.node)\n    }\n\n    const doCheck = (checked: boolean) => {\n      const { node } = props\n      if (checked === node.checked) return\n      panel.handleCheckChange(node, checked)\n    }\n\n    const doLoad = () => {\n      panel.lazyLoad(props.node, () => {\n        if (!isLeaf.value) doExpand()\n      })\n    }\n\n    const handleHoverExpand = (e: Event) => {\n      if (!isHoverMenu.value) return\n      handleExpand()\n      !isLeaf.value && emit('expand', e)\n    }\n\n    const handleExpand = () => {\n      const { node } = props\n      // do not exclude leaf node because the menus expanded might have to reset\n      if (!expandable.value || node.loading) return\n      node.loaded ? doExpand() : doLoad()\n    }\n\n    const handleClick = () => {\n      if (isHoverMenu.value && !isLeaf.value) return\n\n      if (\n        isLeaf.value &&\n        !isDisabled.value &&\n        !checkStrictly.value &&\n        !multiple.value\n      ) {\n        handleCheck(true)\n      } else {\n        handleExpand()\n      }\n    }\n\n    const handleSelectCheck = (checked: boolean) => {\n      if (checkStrictly.value) {\n        doCheck(checked)\n        if (props.node.loaded) {\n          doExpand()\n        }\n      } else {\n        handleCheck(checked)\n      }\n    }\n\n    const handleCheck = (checked: boolean) => {\n      if (!props.node.loaded) {\n        doLoad()\n      } else {\n        doCheck(checked)\n        !checkStrictly.value && doExpand()\n      }\n    }\n\n    return {\n      panel,\n      isHoverMenu,\n      multiple,\n      checkStrictly,\n      checkedNodeId,\n      isDisabled,\n      isLeaf,\n      expandable,\n      inExpandingPath,\n      inCheckedPath,\n      ns,\n      handleHoverExpand,\n      handleExpand,\n      handleClick,\n      handleCheck,\n      handleSelectCheck,\n    }\n  },\n})\n</script>\n", "<template>\n  <el-scrollbar\n    :key=\"menuId\"\n    tag=\"ul\"\n    role=\"menu\"\n    :class=\"ns.b()\"\n    :wrap-class=\"ns.e('wrap')\"\n    :view-class=\"[ns.e('list'), ns.is('empty', isEmpty)]\"\n    @mousemove=\"handleMouseMove\"\n    @mouseleave=\"clearHoverZone\"\n  >\n    <el-cascader-node\n      v-for=\"node in nodes\"\n      :key=\"node.uid\"\n      :node=\"node\"\n      :menu-id=\"menuId\"\n      @expand=\"handleExpand\"\n    />\n    <div v-if=\"isLoading\" :class=\"ns.e('empty-text')\">\n      <el-icon size=\"14\" :class=\"ns.is('loading')\">\n        <loading />\n      </el-icon>\n      {{ t('el.cascader.loading') }}\n    </div>\n    <div v-else-if=\"isEmpty\" :class=\"ns.e('empty-text')\">\n      <slot name=\"empty\">{{ t('el.cascader.noData') }}</slot>\n    </div>\n    <svg\n      v-else-if=\"panel?.isHoverMenu\"\n      ref=\"hoverZone\"\n      :class=\"ns.e('hover-zone')\"\n    />\n  </el-scrollbar>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, getCurrentInstance, inject, ref } from 'vue'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport { useId, useLocale, useNamespace } from '@element-plus/hooks'\nimport { Loading } from '@element-plus/icons-vue'\nimport ElIcon from '@element-plus/components/icon'\nimport ElCascaderNode from './node.vue'\nimport { CASCADER_PANEL_INJECTION_KEY } from './types'\n\nimport type { default as CascaderNode } from './node'\nimport type { PropType } from 'vue'\nimport type { Nullable } from '@element-plus/utils'\n\nexport default defineComponent({\n  name: 'ElCascaderMenu',\n\n  components: {\n    Loading,\n    ElIcon,\n    ElScrollbar,\n    ElCascaderNode,\n  },\n\n  props: {\n    nodes: {\n      type: Array as PropType<CascaderNode[]>,\n      required: true,\n    },\n    index: {\n      type: Number,\n      required: true,\n    },\n  },\n\n  setup(props) {\n    const instance = getCurrentInstance()!\n    const ns = useNamespace('cascader-menu')\n\n    const { t } = useLocale()\n    const id = useId()\n    let activeNode: Nullable<HTMLElement> = null\n    let hoverTimer: Nullable<number> = null\n\n    const panel = inject(CASCADER_PANEL_INJECTION_KEY)!\n\n    const hoverZone = ref<null | SVGSVGElement>(null)\n\n    const isEmpty = computed(() => !props.nodes.length)\n    const isLoading = computed(() => !panel.initialLoaded)\n    const menuId = computed(() => `${id.value}-${props.index}`)\n\n    const handleExpand = (e: MouseEvent) => {\n      activeNode = e.target as HTMLElement\n    }\n\n    const handleMouseMove = (e: MouseEvent) => {\n      if (!panel.isHoverMenu || !activeNode || !hoverZone.value) return\n\n      if (activeNode.contains(e.target as HTMLElement)) {\n        clearHoverTimer()\n\n        const el = instance.vnode.el as HTMLElement\n        const { left } = el.getBoundingClientRect()\n        const { offsetWidth, offsetHeight } = el\n        const startX = e.clientX - left\n        const top = activeNode.offsetTop\n        const bottom = top + activeNode.offsetHeight\n\n        hoverZone.value.innerHTML = `\n          <path style=\"pointer-events: auto;\" fill=\"transparent\" d=\"M${startX} ${top} L${offsetWidth} 0 V${top} Z\" />\n          <path style=\"pointer-events: auto;\" fill=\"transparent\" d=\"M${startX} ${bottom} L${offsetWidth} ${offsetHeight} V${bottom} Z\" />\n        `\n      } else if (!hoverTimer) {\n        hoverTimer = window.setTimeout(\n          clearHoverZone,\n          panel.config.hoverThreshold\n        )\n      }\n    }\n\n    const clearHoverTimer = () => {\n      if (!hoverTimer) return\n      clearTimeout(hoverTimer)\n      hoverTimer = null\n    }\n\n    const clearHoverZone = () => {\n      if (!hoverZone.value) return\n      hoverZone.value.innerHTML = ''\n      clearHoverTimer()\n    }\n    return {\n      ns,\n      panel,\n      hoverZone,\n      isEmpty,\n      isLoading,\n      menuId,\n      t,\n      handleExpand,\n      handleMouseMove,\n      clearHoverZone,\n    }\n  },\n})\n</script>\n", "// @ts-nocheck\nimport {\n  capitalize,\n  isEmpty,\n  isFunction,\n  isUndefined,\n} from '@element-plus/utils'\nimport type { VNode } from 'vue'\n\nexport type CascaderNodeValue = string | number\nexport type CascaderNodePathValue = CascaderNodeValue[]\nexport type CascaderValue =\n  | CascaderNodeValue\n  | CascaderNodePathValue\n  | (CascaderNodeValue | CascaderNodePathValue)[]\nexport type CascaderConfig = Required<CascaderProps>\nexport type ExpandTrigger = 'click' | 'hover'\nexport type isDisabled = (data: CascaderOption, node: Node) => boolean\nexport type isLeaf = (data: CascaderOption, node: Node) => boolean\nexport type Resolve = (dataList?: CascaderOption[]) => void\nexport type LazyLoad = (node: Node, resolve: Resolve) => void\nexport type RenderLabel = ({\n  node: Node,\n  data: CascaderOption,\n}) => VNode | VNode[]\nexport interface CascaderOption extends Record<string, unknown> {\n  label?: string\n  value?: CascaderNodeValue\n  children?: CascaderOption[]\n  disabled?: boolean\n  leaf?: boolean\n}\n\nexport interface CascaderProps {\n  expandTrigger?: ExpandTrigger\n  multiple?: boolean\n  checkStrictly?: boolean\n  emitPath?: boolean\n  lazy?: boolean\n  lazyLoad?: LazyLoad\n  value?: string\n  label?: string\n  children?: string\n  disabled?: string | isDisabled\n  leaf?: string | isLeaf\n  hoverThreshold?: number\n}\n\nexport type Nullable<T> = null | T\n\ntype ChildrenData = CascaderOption[] | undefined\n\nlet uid = 0\n\nconst calculatePathNodes = (node: Node) => {\n  const nodes = [node]\n  let { parent } = node\n\n  while (parent) {\n    nodes.unshift(parent)\n    parent = parent.parent\n  }\n\n  return nodes\n}\n\nclass Node {\n  readonly uid: number = uid++\n  readonly level: number\n  readonly value: CascaderNodeValue\n  readonly label: string\n  readonly pathNodes: Node[]\n  readonly pathValues: CascaderNodePathValue\n  readonly pathLabels: string[]\n\n  childrenData: ChildrenData\n  children: Node[]\n  text: string\n  loaded: boolean\n  /**\n   * Is it checked\n   *\n   * @default false\n   */\n  checked = false\n  /**\n   * Used to indicate the intermediate state of unchecked and fully checked child nodes\n   *\n   * @default false\n   */\n  indeterminate = false\n  /**\n   * Loading Status\n   *\n   * @default false\n   */\n  loading = false\n\n  constructor(\n    readonly data: Nullable<CascaderOption>,\n    readonly config: CascaderConfig,\n    readonly parent?: Node,\n    readonly root = false\n  ) {\n    const { value: valueKey, label: labelKey, children: childrenKey } = config\n\n    const childrenData = data[childrenKey] as ChildrenData\n    const pathNodes = calculatePathNodes(this)\n\n    this.level = root ? 0 : parent ? parent.level + 1 : 1\n    this.value = data[valueKey] as CascaderNodeValue\n    this.label = data[labelKey] as string\n    this.pathNodes = pathNodes\n    this.pathValues = pathNodes.map((node) => node.value)\n    this.pathLabels = pathNodes.map((node) => node.label)\n    this.childrenData = childrenData\n    this.children = (childrenData || []).map(\n      (child) => new Node(child, config, this)\n    )\n    this.loaded = !config.lazy || this.isLeaf || !isEmpty(childrenData)\n  }\n\n  get isDisabled(): boolean {\n    const { data, parent, config } = this\n    const { disabled, checkStrictly } = config\n    const isDisabled = isFunction(disabled)\n      ? disabled(data, this)\n      : !!data[disabled]\n    return isDisabled || (!checkStrictly && parent?.isDisabled)\n  }\n\n  get isLeaf(): boolean {\n    const { data, config, childrenData, loaded } = this\n    const { lazy, leaf } = config\n    const isLeaf = isFunction(leaf) ? leaf(data, this) : data[leaf]\n\n    return isUndefined(isLeaf)\n      ? lazy && !loaded\n        ? false\n        : !(Array.isArray(childrenData) && childrenData.length)\n      : !!isLeaf\n  }\n\n  get valueByOption() {\n    return this.config.emitPath ? this.pathValues : this.value\n  }\n\n  appendChild(childData: CascaderOption) {\n    const { childrenData, children } = this\n    const node = new Node(childData, this.config, this)\n\n    if (Array.isArray(childrenData)) {\n      childrenData.push(childData)\n    } else {\n      this.childrenData = [childData]\n    }\n\n    children.push(node)\n\n    return node\n  }\n\n  calcText(allLevels: boolean, separator: string) {\n    const text = allLevels ? this.pathLabels.join(separator) : this.label\n    this.text = text\n    return text\n  }\n\n  broadcast(event: string, ...args: unknown[]) {\n    const handlerName = `onParent${capitalize(event)}`\n    this.children.forEach((child) => {\n      if (child) {\n        // bottom up\n        child.broadcast(event, ...args)\n        child[handlerName] && child[handlerName](...args)\n      }\n    })\n  }\n\n  emit(event: string, ...args: unknown[]) {\n    const { parent } = this\n    const handlerName = `onChild${capitalize(event)}`\n    if (parent) {\n      parent[handlerName] && parent[handlerName](...args)\n      parent.emit(event, ...args)\n    }\n  }\n\n  onParentCheck(checked: boolean) {\n    if (!this.isDisabled) {\n      this.setCheckState(checked)\n    }\n  }\n\n  onChildCheck() {\n    const { children } = this\n    const validChildren = children.filter((child) => !child.isDisabled)\n    const checked = validChildren.length\n      ? validChildren.every((child) => child.checked)\n      : false\n\n    this.setCheckState(checked)\n  }\n\n  setCheckState(checked: boolean) {\n    const totalNum = this.children.length\n    const checkedNum = this.children.reduce((c, p) => {\n      const num = p.checked ? 1 : p.indeterminate ? 0.5 : 0\n      return c + num\n    }, 0)\n\n    this.checked =\n      this.loaded &&\n      this.children\n        .filter((child) => !child.isDisabled)\n        .every((child) => child.loaded && child.checked) &&\n      checked\n    this.indeterminate =\n      this.loaded && checkedNum !== totalNum && checkedNum > 0\n  }\n\n  doCheck(checked: boolean) {\n    if (this.checked === checked) return\n\n    const { checkStrictly, multiple } = this.config\n\n    if (checkStrictly || !multiple) {\n      this.checked = checked\n    } else {\n      // bottom up to unify the calculation of the indeterminate state\n      this.broadcast('check', checked)\n      this.setCheckState(checked)\n      this.emit('check')\n    }\n  }\n}\n\nexport default Node\n", "import { isEqual } from 'lodash-unified'\nimport Node from './node'\n\nimport type { Nullable } from '@element-plus/utils'\nimport type {\n  CascaderConfig,\n  CascaderNodePathValue,\n  CascaderNodeValue,\n  CascaderOption,\n} from './node'\n\nconst flatNodes = (nodes: Node[], leafOnly: boolean) => {\n  return nodes.reduce((res, node) => {\n    if (node.isLeaf) {\n      res.push(node)\n    } else {\n      !leafOnly && res.push(node)\n      res = res.concat(flatNodes(node.children, leafOnly))\n    }\n    return res\n  }, [] as Node[])\n}\n\nexport default class Store {\n  readonly nodes: Node[]\n  readonly allNodes: Node[]\n  readonly leafNodes: Node[]\n\n  constructor(data: CascaderOption[], readonly config: CascaderConfig) {\n    const nodes = (data || []).map(\n      (nodeData) => new Node(nodeData, this.config)\n    )\n    this.nodes = nodes\n    this.allNodes = flatNodes(nodes, false)\n    this.leafNodes = flatNodes(nodes, true)\n  }\n\n  getNodes() {\n    return this.nodes\n  }\n\n  getFlattedNodes(leafOnly: boolean) {\n    return leafOnly ? this.leafNodes : this.allNodes\n  }\n\n  appendNode(nodeData: CascaderOption, parentNode?: Node) {\n    const node = parentNode\n      ? parentNode.appendChild(nodeData)\n      : new Node(nodeData, this.config)\n\n    if (!parentNode) this.nodes.push(node)\n\n    this.allNodes.push(node)\n    node.isLeaf && this.leafNodes.push(node)\n  }\n\n  appendNodes(nodeDataList: CascaderOption[], parentNode: Node) {\n    nodeDataList.forEach((nodeData) => this.appendNode(nodeData, parentNode))\n  }\n\n  // when checkStrictly, leaf node first\n  getNodeByValue(\n    value: CascaderNodeValue | CascaderNodePathValue,\n    leafOnly = false\n  ): Nullable<Node> {\n    if (!value && value !== 0) return null\n\n    const node = this.getFlattedNodes(leafOnly).find(\n      (node) => isEqual(node.value, value) || isEqual(node.pathValues, value)\n    )\n\n    return node || null\n  }\n\n  getSameNode(node: Node): Nullable<Node> {\n    if (!node) return null\n\n    const node_ = this.getFlattedNodes(false).find(\n      ({ value, level }) => isEqual(node.value, value) && node.level === level\n    )\n\n    return node_ || null\n  }\n}\n", "import { computed } from 'vue'\nimport { NOOP, buildProps, definePropType } from '@element-plus/utils'\nimport type {\n  CascaderConfig,\n  CascaderOption,\n  CascaderProps,\n  CascaderValue,\n} from './node'\n\nexport const CommonProps = buildProps({\n  /**\n   * @description specify which key of node object is used as the node's value\n   */\n  modelValue: {\n    type: definePropType<CascaderValue>([Number, String, Array]),\n  },\n  /**\n   * @description data of the options, the key of `value` and `label` can be customize by `CascaderProps`.\n   */\n  options: {\n    type: definePropType<CascaderOption[]>(Array),\n    default: () => [] as CascaderOption[],\n  },\n  /**\n   * @description configuration options, see the following `CascaderProps` table.\n   */\n  props: {\n    type: definePropType<CascaderProps>(Object),\n    default: () => ({} as CascaderProps),\n  },\n} as const)\n\nexport const DefaultProps: CascaderConfig = {\n  /**\n   * @description trigger mode of expanding options\n   */\n  expandTrigger: 'click',\n  /**\n   * @description whether multiple selection is enabled\n   */\n  multiple: false,\n  /**\n   * @description whether checked state of a node not affects its parent and child nodes\n   */\n  checkStrictly: false, // whether all nodes can be selected\n  /**\n   * @description when checked nodes change, whether to emit an array of node's path, if false, only emit the value of node.\n   */\n  emitPath: true, // wether to emit an array of all levels value in which node is located\n  /**\n   * @description whether to dynamic load child nodes, use with `lazyload` attribute\n   */\n  lazy: false,\n  /**\n   * @description method for loading child nodes data, only works when `lazy` is true\n   */\n  lazyLoad: NOOP,\n  /**\n   * @description specify which key of node object is used as the node's value\n   */\n  value: 'value',\n  /**\n   * @description specify which key of node object is used as the node's label\n   */\n  label: 'label',\n  /**\n   * @description specify which key of node object is used as the node's children\n   */\n  children: 'children',\n  /**\n   * @description specify which key of node object is used as the node's leaf\n   */\n  leaf: 'leaf',\n  /**\n   * @description specify which key of node object is used as the node's disabled\n   */\n  disabled: 'disabled',\n  /**\n   * @description hover threshold of expanding options\n   */\n  hoverThreshold: 500,\n}\n\nexport const useCascaderConfig = (props: { props: CascaderProps }) => {\n  return computed(() => ({\n    ...DefaultProps,\n    ...props.props,\n  }))\n}\n", "import { isLeaf } from '@element-plus/utils'\nimport type { default as CascaderNode } from './node'\n\nexport const getMenuIndex = (el: HTMLElement) => {\n  if (!el) return 0\n  const pieces = el.id.split('-')\n  return Number(pieces[pieces.length - 2])\n}\n\nexport const checkNode = (el: HTMLElement) => {\n  if (!el) return\n\n  const input = el.querySelector('input')\n  if (input) {\n    input.click()\n  } else if (isLeaf(el)) {\n    el.click()\n  }\n}\n\nexport const sortByOriginalOrder = (\n  oldNodes: CascaderNode[],\n  newNodes: CascaderNode[]\n) => {\n  const newNodesCopy = newNodes.slice(0)\n  const newIds = newNodesCopy.map((node) => node.uid)\n  const res = oldNodes.reduce((acc, item) => {\n    const index = newIds.indexOf(item.uid)\n    if (index > -1) {\n      acc.push(item)\n      newNodesCopy.splice(index, 1)\n      newIds.splice(index, 1)\n    }\n    return acc\n  }, [] as CascaderNode[])\n\n  res.push(...newNodesCopy)\n\n  return res\n}\n", "<template>\n  <div\n    :class=\"[ns.b('panel'), ns.is('bordered', border)]\"\n    @keydown=\"handleKeyDown\"\n  >\n    <el-cascader-menu\n      v-for=\"(menu, index) in menus\"\n      :key=\"index\"\n      :ref=\"(item) => (menuList[index] = item)\"\n      :index=\"index\"\n      :nodes=\"[...menu]\"\n    >\n      <template #empty>\n        <slot name=\"empty\" />\n      </template>\n    </el-cascader-menu>\n  </div>\n</template>\n\n<script lang=\"ts\">\n// @ts-nocheck\nimport {\n  computed,\n  defineComponent,\n  nextTick,\n  onBeforeUpdate,\n  onMounted,\n  provide,\n  reactive,\n  ref,\n  watch,\n} from 'vue'\nimport { cloneDeep, flattenDeep, isEqual } from 'lodash-unified'\nimport {\n  castArray,\n  focusNode,\n  getSibling,\n  isClient,\n  isEmpty,\n  scrollIntoView,\n  unique,\n} from '@element-plus/utils'\nimport {\n  CHANGE_EVENT,\n  EVENT_CODE,\n  UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { useNamespace } from '@element-plus/hooks'\n\nimport ElCascaderMenu from './menu.vue'\nimport Store from './store'\nimport Node from './node'\nimport { CommonProps, useCascaderConfig } from './config'\nimport { checkNode, getMenuIndex, sortByOriginalOrder } from './utils'\nimport { CASCADER_PANEL_INJECTION_KEY } from './types'\n\nimport type { PropType } from 'vue'\nimport type { Nullable } from '@element-plus/utils'\nimport type {\n  default as CascaderNode,\n  CascaderNodeValue,\n  CascaderOption,\n  CascaderValue,\n  RenderLabel,\n} from './node'\n\nimport type { ElCascaderPanelContext } from './types'\n\nexport default defineComponent({\n  name: 'ElCascaderPanel',\n\n  components: {\n    ElCascaderMenu,\n  },\n\n  props: {\n    ...CommonProps,\n    border: {\n      type: Boolean,\n      default: true,\n    },\n    renderLabel: Function as PropType<RenderLabel>,\n  },\n\n  emits: [UPDATE_MODEL_EVENT, CHANGE_EVENT, 'close', 'expand-change'],\n\n  setup(props, { emit, slots }) {\n    // for interrupt sync check status in lazy mode\n    let manualChecked = false\n\n    const ns = useNamespace('cascader')\n    const config = useCascaderConfig(props)\n\n    let store: Nullable<Store> = null\n    const initialLoaded = ref(true)\n    const menuList = ref<any[]>([])\n    const checkedValue = ref<Nullable<CascaderValue>>(null)\n    const menus = ref<CascaderNode[][]>([])\n    const expandingNode = ref<Nullable<CascaderNode>>(null)\n    const checkedNodes = ref<CascaderNode[]>([])\n\n    const isHoverMenu = computed(() => config.value.expandTrigger === 'hover')\n    const renderLabelFn = computed(() => props.renderLabel || slots.default)\n\n    const initStore = () => {\n      const { options } = props\n      const cfg = config.value\n\n      manualChecked = false\n      store = new Store(options, cfg)\n      menus.value = [store.getNodes()]\n\n      if (cfg.lazy && isEmpty(props.options)) {\n        initialLoaded.value = false\n        lazyLoad(undefined, (list) => {\n          if (list) {\n            store = new Store(list, cfg)\n            menus.value = [store.getNodes()]\n          }\n          initialLoaded.value = true\n          syncCheckedValue(false, true)\n        })\n      } else {\n        syncCheckedValue(false, true)\n      }\n    }\n\n    const lazyLoad: ElCascaderPanelContext['lazyLoad'] = (node, cb) => {\n      const cfg = config.value\n      node! = node || new Node({}, cfg, undefined, true)\n      node.loading = true\n\n      const resolve = (dataList: CascaderOption[]) => {\n        const _node = node as Node\n        const parent = _node.root ? null : _node\n        dataList && store?.appendNodes(dataList, parent as any)\n        _node.loading = false\n        _node.loaded = true\n        _node.childrenData = _node.childrenData || []\n        cb && cb(dataList)\n      }\n\n      cfg.lazyLoad(node, resolve as any)\n    }\n\n    const expandNode: ElCascaderPanelContext['expandNode'] = (node, silent) => {\n      const { level } = node\n      const newMenus = menus.value.slice(0, level)\n      let newExpandingNode: Nullable<CascaderNode>\n\n      if (node.isLeaf) {\n        newExpandingNode = node.pathNodes[level - 2]\n      } else {\n        newExpandingNode = node\n        newMenus.push(node.children)\n      }\n\n      if (expandingNode.value?.uid !== newExpandingNode?.uid) {\n        expandingNode.value = node\n        menus.value = newMenus\n        !silent && emit('expand-change', node?.pathValues || [])\n      }\n    }\n\n    const handleCheckChange: ElCascaderPanelContext['handleCheckChange'] = (\n      node,\n      checked,\n      emitClose = true\n    ) => {\n      const { checkStrictly, multiple } = config.value\n      const oldNode = checkedNodes.value[0]\n      manualChecked = true\n\n      !multiple && oldNode?.doCheck(false)\n      node.doCheck(checked)\n      calculateCheckedValue()\n      emitClose && !multiple && !checkStrictly && emit('close')\n      !emitClose && !multiple && !checkStrictly && expandParentNode(node)\n    }\n\n    const expandParentNode = (node) => {\n      if (!node) return\n      node = node.parent\n      expandParentNode(node)\n      node && expandNode(node)\n    }\n\n    const getFlattedNodes = (leafOnly: boolean) => {\n      return store?.getFlattedNodes(leafOnly)\n    }\n\n    const getCheckedNodes = (leafOnly: boolean) => {\n      return getFlattedNodes(leafOnly)?.filter((node) => node.checked !== false)\n    }\n\n    const clearCheckedNodes = () => {\n      checkedNodes.value.forEach((node) => node.doCheck(false))\n      calculateCheckedValue()\n      menus.value = menus.value.slice(0, 1)\n      expandingNode.value = null\n      emit('expand-change', [])\n    }\n\n    const calculateCheckedValue = () => {\n      const { checkStrictly, multiple } = config.value\n      const oldNodes = checkedNodes.value\n      const newNodes = getCheckedNodes(!checkStrictly)!\n      // ensure the original order\n      const nodes = sortByOriginalOrder(oldNodes, newNodes)\n      const values = nodes.map((node) => node.valueByOption)\n      checkedNodes.value = nodes\n      checkedValue.value = multiple ? values : values[0] ?? null\n    }\n\n    const syncCheckedValue = (loaded = false, forced = false) => {\n      const { modelValue } = props\n      const { lazy, multiple, checkStrictly } = config.value\n      const leafOnly = !checkStrictly\n\n      if (\n        !initialLoaded.value ||\n        manualChecked ||\n        (!forced && isEqual(modelValue, checkedValue.value))\n      )\n        return\n\n      if (lazy && !loaded) {\n        const values: CascaderNodeValue[] = unique(\n          flattenDeep(castArray(modelValue))\n        )\n        const nodes = values\n          .map((val) => store?.getNodeByValue(val))\n          .filter((node) => !!node && !node.loaded && !node.loading) as Node[]\n\n        if (nodes.length) {\n          nodes.forEach((node) => {\n            lazyLoad(node, () => syncCheckedValue(false, forced))\n          })\n        } else {\n          syncCheckedValue(true, forced)\n        }\n      } else {\n        const values = multiple ? castArray(modelValue) : [modelValue]\n        const nodes = unique(\n          values.map((val) => store?.getNodeByValue(val, leafOnly))\n        ) as Node[]\n        syncMenuState(nodes, forced)\n        checkedValue.value = cloneDeep(modelValue)\n      }\n    }\n\n    const syncMenuState = (\n      newCheckedNodes: CascaderNode[],\n      reserveExpandingState = true\n    ) => {\n      const { checkStrictly } = config.value\n      const oldNodes = checkedNodes.value\n      const newNodes = newCheckedNodes.filter(\n        (node) => !!node && (checkStrictly || node.isLeaf)\n      )\n      const oldExpandingNode = store?.getSameNode(expandingNode.value!)\n      const newExpandingNode =\n        (reserveExpandingState && oldExpandingNode) || newNodes[0]\n\n      if (newExpandingNode) {\n        newExpandingNode.pathNodes.forEach((node) => expandNode(node, true))\n      } else {\n        expandingNode.value = null\n      }\n\n      oldNodes.forEach((node) => node.doCheck(false))\n      reactive(newNodes).forEach((node) => node.doCheck(true))\n      checkedNodes.value = newNodes\n      nextTick(scrollToExpandingNode)\n    }\n\n    const scrollToExpandingNode = () => {\n      if (!isClient) return\n\n      menuList.value.forEach((menu) => {\n        const menuElement = menu?.$el\n        if (menuElement) {\n          const container = menuElement.querySelector(\n            `.${ns.namespace.value}-scrollbar__wrap`\n          )\n          const activeNode =\n            menuElement.querySelector(`.${ns.b('node')}.${ns.is('active')}`) ||\n            menuElement.querySelector(`.${ns.b('node')}.in-active-path`)\n          scrollIntoView(container, activeNode)\n        }\n      })\n    }\n\n    const handleKeyDown = (e: KeyboardEvent) => {\n      const target = e.target as HTMLElement\n      const { code } = e\n\n      switch (code) {\n        case EVENT_CODE.up:\n        case EVENT_CODE.down: {\n          e.preventDefault()\n          const distance = code === EVENT_CODE.up ? -1 : 1\n          focusNode(\n            getSibling(target, distance, `.${ns.b('node')}[tabindex=\"-1\"]`)\n          )\n          break\n        }\n        case EVENT_CODE.left: {\n          e.preventDefault()\n          const preMenu = menuList.value[getMenuIndex(target) - 1]\n          const expandedNode = preMenu?.$el.querySelector(\n            `.${ns.b('node')}[aria-expanded=\"true\"]`\n          )\n          focusNode(expandedNode)\n          break\n        }\n        case EVENT_CODE.right: {\n          e.preventDefault()\n          const nextMenu = menuList.value[getMenuIndex(target) + 1]\n          const firstNode = nextMenu?.$el.querySelector(\n            `.${ns.b('node')}[tabindex=\"-1\"]`\n          )\n          focusNode(firstNode)\n          break\n        }\n        case EVENT_CODE.enter:\n          checkNode(target)\n          break\n      }\n    }\n\n    provide(\n      CASCADER_PANEL_INJECTION_KEY,\n      reactive({\n        config,\n        expandingNode,\n        checkedNodes,\n        isHoverMenu,\n        initialLoaded,\n        renderLabelFn,\n        lazyLoad,\n        expandNode,\n        handleCheckChange,\n      })\n    )\n\n    watch([config, () => props.options], initStore, {\n      deep: true,\n      immediate: true,\n    })\n\n    watch(\n      () => props.modelValue,\n      () => {\n        manualChecked = false\n        syncCheckedValue()\n      },\n      {\n        deep: true,\n      }\n    )\n\n    watch(\n      () => checkedValue.value,\n      (val) => {\n        if (!isEqual(val, props.modelValue)) {\n          emit(UPDATE_MODEL_EVENT, val)\n          emit(CHANGE_EVENT, val)\n        }\n      }\n    )\n\n    onBeforeUpdate(() => (menuList.value = []))\n\n    onMounted(() => !isEmpty(props.modelValue) && syncCheckedValue())\n\n    return {\n      ns,\n      menuList,\n      menus,\n      checkedNodes,\n      handleKeyDown,\n      handleCheckChange,\n      getFlattedNodes,\n      /**\n       * @description get an array of currently selected node,(leafOnly) whether only return the leaf checked nodes, default is `false`\n       */\n      getCheckedNodes,\n      /**\n       * @description clear checked nodes\n       */\n      clearCheckedNodes,\n      calculateCheckedValue,\n      scrollToExpandingNode,\n    }\n  },\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport CascaderPanel from './src/index.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCascaderPanel: SFCWithInstall<typeof CascaderPanel> =\n  withInstall(CascaderPanel)\n\nexport default ElCascaderPanel\nexport * from './src/types'\nexport * from './src/config'\nexport * from './src/instance'\n", "import { buildProps } from '@element-plus/utils'\nimport { componentSizes } from '@element-plus/constants'\nimport type Tag from './tag.vue'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const tagProps = buildProps({\n  /**\n   * @description type of Tag\n   */\n  type: {\n    type: String,\n    values: ['primary', 'success', 'info', 'warning', 'danger'],\n    default: 'primary',\n  },\n  /**\n   * @description whether Tag can be removed\n   */\n  closable: Boolean,\n  /**\n   * @description whether to disable animations\n   */\n  disableTransitions: Boolean,\n  /**\n   * @description whether Tag has a highlighted border\n   */\n  hit: Boolean,\n  /**\n   * @description background color of the Tag\n   */\n  color: String,\n  /**\n   * @description size of Tag\n   */\n  size: {\n    type: String,\n    values: componentSizes,\n  },\n  /**\n   * @description theme of Tag\n   */\n  effect: {\n    type: String,\n    values: ['dark', 'light', 'plain'],\n    default: 'light',\n  },\n  /**\n   * @description whether Tag is rounded\n   */\n  round: Boolean,\n} as const)\nexport type TagProps = ExtractPropTypes<typeof tagProps>\n\nexport const tagEmits = {\n  close: (evt: MouseEvent) => evt instanceof MouseEvent,\n  click: (evt: MouseEvent) => evt instanceof MouseEvent,\n}\nexport type TagEmits = typeof tagEmits\n\nexport type TagInstance = InstanceType<typeof Tag>\n", "<template>\n  <span\n    v-if=\"disableTransitions\"\n    :class=\"containerKls\"\n    :style=\"{ backgroundColor: color }\"\n    @click=\"handleClick\"\n  >\n    <span :class=\"ns.e('content')\">\n      <slot />\n    </span>\n    <el-icon v-if=\"closable\" :class=\"ns.e('close')\" @click.stop=\"handleClose\">\n      <Close />\n    </el-icon>\n  </span>\n  <transition\n    v-else\n    :name=\"`${ns.namespace.value}-zoom-in-center`\"\n    appear\n    @vue:mounted=\"handleVNodeMounted\"\n  >\n    <span\n      :class=\"containerKls\"\n      :style=\"{ backgroundColor: color }\"\n      @click=\"handleClick\"\n    >\n      <span :class=\"ns.e('content')\">\n        <slot />\n      </span>\n      <el-icon v-if=\"closable\" :class=\"ns.e('close')\" @click.stop=\"handleClose\">\n        <Close />\n      </el-icon>\n    </span>\n  </transition>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport ElIcon from '@element-plus/components/icon'\nimport { Close } from '@element-plus/icons-vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormSize } from '@element-plus/components/form'\n\nimport { tagEmits, tagProps } from './tag'\nimport type { VNode } from 'vue'\n\ndefineOptions({\n  name: 'ElTag',\n})\nconst props = defineProps(tagProps)\nconst emit = defineEmits(tagEmits)\n\nconst tagSize = useFormSize()\nconst ns = useNamespace('tag')\nconst containerKls = computed(() => {\n  const { type, hit, effect, closable, round } = props\n  return [\n    ns.b(),\n    ns.is('closable', closable),\n    ns.m(type || 'primary'),\n    ns.m(tagSize.value),\n    ns.m(effect),\n    ns.is('hit', hit),\n    ns.is('round', round),\n  ]\n})\n\n// methods\nconst handleClose = (event: MouseEvent) => {\n  emit('close', event)\n}\n\nconst handleClick = (event: MouseEvent) => {\n  emit('click', event)\n}\n\nconst handleVNodeMounted = (vnode: VNode) => {\n  // @ts-ignore\n  vnode.component.subTree.component.bum = null\n}\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Tag from './src/tag.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTag: SFCWithInstall<typeof Tag> = withInstall(Tag)\nexport default ElTag\n\nexport * from './src/tag'\n", "import { placements } from '@popperjs/core'\nimport { CommonProps } from '@element-plus/components/cascader-panel'\nimport { buildProps, definePropType, isBoolean } from '@element-plus/utils'\nimport { useEmptyValuesProps, useSizeProp } from '@element-plus/hooks'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport { tagProps } from '@element-plus/components/tag'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport type {\n  CascaderNode,\n  CascaderValue,\n} from '@element-plus/components/cascader-panel'\nimport type { Placement } from '@element-plus/components/popper'\n\nexport const cascaderProps = buildProps({\n  ...CommonProps,\n  /**\n   * @description size of input\n   */\n  size: useSizeProp,\n  /**\n   * @description placeholder of input\n   */\n  placeholder: String,\n  /**\n   * @description whether Cascader is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description whether selected value can be cleared\n   */\n  clearable: Boolean,\n  /**\n   * @description whether the options can be searched\n   */\n  filterable: Boolean,\n  /**\n   * @description customize search logic, the first parameter is `node`, the second is `keyword`, and need return a boolean value indicating whether it hits.\n   */\n  filterMethod: {\n    type: definePropType<(node: CascaderNode, keyword: string) => boolean>(\n      Function\n    ),\n    default: (node: CascaderNode, keyword: string) =>\n      node.text.includes(keyword),\n  },\n  /**\n   * @description option label separator\n   */\n  separator: {\n    type: String,\n    default: ' / ',\n  },\n  /**\n   * @description whether to display all levels of the selected value in the input\n   */\n  showAllLevels: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether to collapse tags in multiple selection mode\n   */\n  collapseTags: Boolean,\n  /**\n   * @description The max tags number to be shown. To use this, collapse-tags must be true\n   */\n  maxCollapseTags: {\n    type: Number,\n    default: 1,\n  },\n  /**\n   * @description native input id\n   */\n  collapseTagsTooltip: {\n    type: Boolean,\n    default: false,\n  },\n  /**\n   * @description debounce delay when typing filter keyword, in milliseconds\n   */\n  debounce: {\n    type: Number,\n    default: 300,\n  },\n  /**\n   * @description hook function before filtering with the value to be filtered as its parameter. If `false` is returned or a `Promise` is returned and then is rejected, filtering will be aborted\n   */\n  beforeFilter: {\n    type: definePropType<(value: string) => boolean | Promise<any>>(Function),\n    default: () => true,\n  },\n  /**\n   * @description position of dropdown\n   */\n  placement: {\n    type: definePropType<Placement>(String),\n    values: placements,\n    default: 'bottom-start',\n  },\n  /**\n   * @description list of possible positions for dropdown\n   */\n  fallbackPlacements: {\n    type: definePropType<Placement[]>(Array),\n    default: ['bottom-start', 'bottom', 'top-start', 'top', 'right', 'left'],\n  },\n  /**\n   * @description custom class name for Cascader's dropdown\n   */\n  popperClass: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description whether cascader popup is teleported\n   */\n  teleported: useTooltipContentProps.teleported,\n  /**\n   * @description tag type\n   */\n  // eslint-disable-next-line vue/require-prop-types\n  tagType: { ...tagProps.type, default: 'info' },\n  /**\n   * @description tag effect\n   */\n  tagEffect: { ...tagProps.effect, default: 'light' },\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description when dropdown is inactive and `persistent` is `false`, dropdown will be destroyed\n   */\n  persistent: {\n    type: Boolean,\n    default: true,\n  },\n  ...useEmptyValuesProps,\n})\n\nexport const cascaderEmits = {\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  [UPDATE_MODEL_EVENT]: (_: CascaderValue) => true,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  [CHANGE_EVENT]: (_: CascaderValue) => true,\n  focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n  blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n  clear: () => true,\n  visibleChange: (val: boolean) => isBoolean(val),\n  expandChange: (val: CascaderValue) => !!val,\n  removeTag: (val: CascaderNode['valueByOption']) => !!val,\n}\n\n// Type name is taken(cascader-panel/src/node), needs discussion\n// export type CascaderProps = ExtractPropTypes<typeof cascaderProps>\n\nexport type CascaderEmits = typeof cascaderEmits\n", "<template>\n  <el-tooltip\n    ref=\"tooltipRef\"\n    :visible=\"popperVisible\"\n    :teleported=\"teleported\"\n    :popper-class=\"[nsCascader.e('dropdown'), popperClass]\"\n    :popper-options=\"popperOptions\"\n    :fallback-placements=\"fallbackPlacements\"\n    :stop-popper-mouse-event=\"false\"\n    :gpu-acceleration=\"false\"\n    :placement=\"placement\"\n    :transition=\"`${nsCascader.namespace.value}-zoom-in-top`\"\n    effect=\"light\"\n    pure\n    :persistent=\"persistent\"\n    @hide=\"hideSuggestionPanel\"\n  >\n    <template #default>\n      <div\n        v-clickoutside:[contentRef]=\"() => togglePopperVisible(false)\"\n        :class=\"cascaderKls\"\n        :style=\"cascaderStyle\"\n        @click=\"() => togglePopperVisible(readonly ? undefined : true)\"\n        @keydown=\"handleKeyDown\"\n        @mouseenter=\"inputHover = true\"\n        @mouseleave=\"inputHover = false\"\n      >\n        <el-input\n          ref=\"input\"\n          v-model=\"inputValue\"\n          :placeholder=\"currentPlaceholder\"\n          :readonly=\"readonly\"\n          :disabled=\"isDisabled\"\n          :validate-event=\"false\"\n          :size=\"realSize\"\n          :class=\"inputClass\"\n          :tabindex=\"multiple && filterable && !isDisabled ? -1 : undefined\"\n          @compositionstart=\"handleComposition\"\n          @compositionupdate=\"handleComposition\"\n          @compositionend=\"handleComposition\"\n          @focus=\"handleFocus\"\n          @blur=\"handleBlur\"\n          @input=\"handleInput\"\n        >\n          <template #suffix>\n            <el-icon\n              v-if=\"clearBtnVisible\"\n              key=\"clear\"\n              :class=\"[nsInput.e('icon'), 'icon-circle-close']\"\n              @click.stop=\"handleClear\"\n            >\n              <circle-close />\n            </el-icon>\n            <el-icon\n              v-else\n              key=\"arrow-down\"\n              :class=\"cascaderIconKls\"\n              @click.stop=\"togglePopperVisible()\"\n            >\n              <arrow-down />\n            </el-icon>\n          </template>\n        </el-input>\n\n        <div\n          v-if=\"multiple\"\n          ref=\"tagWrapper\"\n          :class=\"[\n            nsCascader.e('tags'),\n            nsCascader.is('validate', Boolean(validateState)),\n          ]\"\n        >\n          <el-tag\n            v-for=\"tag in presentTags\"\n            :key=\"tag.key\"\n            :type=\"tagType\"\n            :size=\"tagSize\"\n            :effect=\"tagEffect\"\n            :hit=\"tag.hitState\"\n            :closable=\"tag.closable\"\n            disable-transitions\n            @close=\"deleteTag(tag)\"\n          >\n            <template v-if=\"tag.isCollapseTag === false\">\n              <span>{{ tag.text }}</span>\n            </template>\n            <template v-else>\n              <el-tooltip\n                :disabled=\"popperVisible || !collapseTagsTooltip\"\n                :fallback-placements=\"['bottom', 'top', 'right', 'left']\"\n                placement=\"bottom\"\n                effect=\"light\"\n              >\n                <template #default>\n                  <span>{{ tag.text }}</span>\n                </template>\n                <template #content>\n                  <div :class=\"nsCascader.e('collapse-tags')\">\n                    <div\n                      v-for=\"(tag2, idx) in allPresentTags.slice(\n                        maxCollapseTags\n                      )\"\n                      :key=\"idx\"\n                      :class=\"nsCascader.e('collapse-tag')\"\n                    >\n                      <el-tag\n                        :key=\"tag2.key\"\n                        class=\"in-tooltip\"\n                        :type=\"tagType\"\n                        :size=\"tagSize\"\n                        :effect=\"tagEffect\"\n                        :hit=\"tag2.hitState\"\n                        :closable=\"tag2.closable\"\n                        disable-transitions\n                        @close=\"deleteTag(tag2)\"\n                      >\n                        <span>{{ tag2.text }}</span>\n                      </el-tag>\n                    </div>\n                  </div>\n                </template>\n              </el-tooltip>\n            </template>\n          </el-tag>\n          <input\n            v-if=\"filterable && !isDisabled\"\n            v-model=\"searchInputValue\"\n            type=\"text\"\n            :class=\"nsCascader.e('search-input')\"\n            :placeholder=\"presentText ? '' : inputPlaceholder\"\n            @input=\"(e) => handleInput(searchInputValue, e as KeyboardEvent)\"\n            @click.stop=\"togglePopperVisible(true)\"\n            @keydown.delete=\"handleDelete\"\n            @compositionstart=\"handleComposition\"\n            @compositionupdate=\"handleComposition\"\n            @compositionend=\"handleComposition\"\n            @focus=\"handleFocus\"\n            @blur=\"handleBlur\"\n          />\n        </div>\n      </div>\n    </template>\n\n    <template #content>\n      <el-cascader-panel\n        v-show=\"!filtering\"\n        ref=\"cascaderPanelRef\"\n        v-model=\"checkedValue\"\n        :options=\"options\"\n        :props=\"props.props\"\n        :border=\"false\"\n        :render-label=\"$slots.default\"\n        @expand-change=\"handleExpandChange\"\n        @close=\"$nextTick(() => togglePopperVisible(false))\"\n      >\n        <template #empty>\n          <slot name=\"empty\" />\n        </template>\n      </el-cascader-panel>\n      <el-scrollbar\n        v-if=\"filterable\"\n        v-show=\"filtering\"\n        ref=\"suggestionPanel\"\n        tag=\"ul\"\n        :class=\"nsCascader.e('suggestion-panel')\"\n        :view-class=\"nsCascader.e('suggestion-list')\"\n        @keydown=\"handleSuggestionKeyDown\"\n      >\n        <template v-if=\"suggestions.length\">\n          <li\n            v-for=\"item in suggestions\"\n            :key=\"item.uid\"\n            :class=\"[\n              nsCascader.e('suggestion-item'),\n              nsCascader.is('checked', item.checked),\n            ]\"\n            :tabindex=\"-1\"\n            @click=\"handleSuggestionClick(item)\"\n          >\n            <span>{{ item.text }}</span>\n            <el-icon v-if=\"item.checked\">\n              <check />\n            </el-icon>\n          </li>\n        </template>\n        <slot v-else name=\"empty\">\n          <li :class=\"nsCascader.e('empty-text')\">\n            {{ t('el.cascader.noMatch') }}\n          </li>\n        </slot>\n      </el-scrollbar>\n    </template>\n  </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, nextTick, onMounted, ref, useAttrs, watch } from 'vue'\nimport { cloneDeep, debounce } from 'lodash-unified'\nimport { useCssVar, useResizeObserver } from '@vueuse/core'\nimport {\n  debugWarn,\n  focusNode,\n  getSibling,\n  isClient,\n  isPromise,\n} from '@element-plus/utils'\nimport ElCascaderPanel from '@element-plus/components/cascader-panel'\nimport ElInput from '@element-plus/components/input'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTag from '@element-plus/components/tag'\nimport ElIcon from '@element-plus/components/icon'\nimport { useFormItem, useFormSize } from '@element-plus/components/form'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport {\n  useComposition,\n  useEmptyValues,\n  useLocale,\n  useNamespace,\n} from '@element-plus/hooks'\nimport {\n  CHANGE_EVENT,\n  EVENT_CODE,\n  UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { ArrowDown, Check, CircleClose } from '@element-plus/icons-vue'\nimport { cascaderEmits, cascaderProps } from './cascader'\n\nimport type { Options } from '@element-plus/components/popper'\nimport type { ComputedRef, Ref, StyleValue } from 'vue'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { InputInstance } from '@element-plus/components/input'\nimport type { ScrollbarInstance } from '@element-plus/components/scrollbar'\nimport type {\n  CascaderNode,\n  CascaderPanelInstance,\n  CascaderValue,\n  Tag,\n} from '@element-plus/components/cascader-panel'\n\nconst popperOptions: Partial<Options> = {\n  modifiers: [\n    {\n      name: 'arrowPosition',\n      enabled: true,\n      phase: 'main',\n      fn: ({ state }) => {\n        const { modifiersData, placement } = state as any\n        if (['right', 'left', 'bottom', 'top'].includes(placement)) return\n        modifiersData.arrow.x = 35\n      },\n      requires: ['arrow'],\n    },\n  ],\n}\nconst COMPONENT_NAME = 'ElCascader'\n\ndefineOptions({\n  name: COMPONENT_NAME,\n})\n\nconst props = defineProps(cascaderProps)\nconst emit = defineEmits(cascaderEmits)\nconst attrs = useAttrs()\n\nlet inputInitialHeight = 0\nlet pressDeleteCount = 0\n\nconst nsCascader = useNamespace('cascader')\nconst nsInput = useNamespace('input')\n\nconst { t } = useLocale()\nconst { form, formItem } = useFormItem()\nconst { valueOnClear } = useEmptyValues(props)\nconst { isComposing, handleComposition } = useComposition({\n  afterComposition(event) {\n    const text = (event.target as HTMLInputElement)?.value\n    handleInput(text)\n  },\n})\n\nconst tooltipRef: Ref<TooltipInstance | null> = ref(null)\nconst input: Ref<InputInstance | null> = ref(null)\nconst tagWrapper = ref(null)\nconst cascaderPanelRef: Ref<CascaderPanelInstance | null> = ref(null)\nconst suggestionPanel: Ref<ScrollbarInstance | null> = ref(null)\nconst popperVisible = ref(false)\nconst inputHover = ref(false)\nconst filtering = ref(false)\nconst filterFocus = ref(false)\nconst inputValue = ref('')\nconst searchInputValue = ref('')\nconst presentTags: Ref<Tag[]> = ref([])\nconst allPresentTags: Ref<Tag[]> = ref([])\nconst suggestions: Ref<CascaderNode[]> = ref([])\n\nconst cascaderStyle = computed<StyleValue>(() => {\n  return attrs.style as StyleValue\n})\n\nconst isDisabled = computed(() => props.disabled || form?.disabled)\nconst inputPlaceholder = computed(\n  () => props.placeholder || t('el.cascader.placeholder')\n)\nconst currentPlaceholder = computed(() =>\n  searchInputValue.value || presentTags.value.length > 0 || isComposing.value\n    ? ''\n    : inputPlaceholder.value\n)\nconst realSize = useFormSize()\nconst tagSize = computed(() =>\n  ['small'].includes(realSize.value) ? 'small' : 'default'\n)\nconst multiple = computed(() => !!props.props.multiple)\nconst readonly = computed(() => !props.filterable || multiple.value)\nconst searchKeyword = computed(() =>\n  multiple.value ? searchInputValue.value : inputValue.value\n)\nconst checkedNodes: ComputedRef<CascaderNode[]> = computed(\n  () => cascaderPanelRef.value?.checkedNodes || []\n)\nconst clearBtnVisible = computed(() => {\n  if (\n    !props.clearable ||\n    isDisabled.value ||\n    filtering.value ||\n    !inputHover.value\n  )\n    return false\n\n  return !!checkedNodes.value.length\n})\nconst presentText = computed(() => {\n  const { showAllLevels, separator } = props\n  const nodes = checkedNodes.value\n  return nodes.length\n    ? multiple.value\n      ? ''\n      : nodes[0].calcText(showAllLevels, separator)\n    : ''\n})\n\nconst validateState = computed(() => formItem?.validateState || '')\n\nconst checkedValue = computed<CascaderValue>({\n  get() {\n    return cloneDeep(props.modelValue) as CascaderValue\n  },\n  set(val) {\n    // https://github.com/element-plus/element-plus/issues/17647\n    const value = val ?? valueOnClear.value\n    emit(UPDATE_MODEL_EVENT, value)\n    emit(CHANGE_EVENT, value)\n    if (props.validateEvent) {\n      formItem?.validate('change').catch((err) => debugWarn(err))\n    }\n  },\n})\n\nconst cascaderKls = computed(() => {\n  return [\n    nsCascader.b(),\n    nsCascader.m(realSize.value),\n    nsCascader.is('disabled', isDisabled.value),\n    attrs.class,\n  ]\n})\n\nconst cascaderIconKls = computed(() => {\n  return [\n    nsInput.e('icon'),\n    'icon-arrow-down',\n    nsCascader.is('reverse', popperVisible.value),\n  ]\n})\n\nconst inputClass = computed(() => {\n  return nsCascader.is('focus', popperVisible.value || filterFocus.value)\n})\n\nconst contentRef = computed(() => {\n  return tooltipRef.value?.popperRef?.contentRef\n})\n\nconst togglePopperVisible = (visible?: boolean) => {\n  if (isDisabled.value) return\n\n  visible = visible ?? !popperVisible.value\n\n  if (visible !== popperVisible.value) {\n    popperVisible.value = visible\n    input.value?.input?.setAttribute('aria-expanded', `${visible}`)\n\n    if (visible) {\n      updatePopperPosition()\n      nextTick(cascaderPanelRef.value?.scrollToExpandingNode)\n    } else if (props.filterable) {\n      syncPresentTextValue()\n    }\n\n    emit('visibleChange', visible)\n  }\n}\n\nconst updatePopperPosition = () => {\n  nextTick(() => {\n    tooltipRef.value?.updatePopper()\n  })\n}\n\nconst hideSuggestionPanel = () => {\n  filtering.value = false\n}\n\nconst genTag = (node: CascaderNode): Tag => {\n  const { showAllLevels, separator } = props\n  return {\n    node,\n    key: node.uid,\n    text: node.calcText(showAllLevels, separator),\n    hitState: false,\n    closable: !isDisabled.value && !node.isDisabled,\n    isCollapseTag: false,\n  }\n}\n\nconst deleteTag = (tag: Tag) => {\n  const node = tag.node as CascaderNode\n  node.doCheck(false)\n  cascaderPanelRef.value?.calculateCheckedValue()\n  emit('removeTag', node.valueByOption)\n}\n\nconst calculatePresentTags = () => {\n  if (!multiple.value) return\n\n  const nodes = checkedNodes.value\n  const tags: Tag[] = []\n\n  const allTags: Tag[] = []\n  nodes.forEach((node) => allTags.push(genTag(node)))\n  allPresentTags.value = allTags\n\n  if (nodes.length) {\n    nodes\n      .slice(0, props.maxCollapseTags)\n      .forEach((node) => tags.push(genTag(node)))\n    const rest = nodes.slice(props.maxCollapseTags)\n    const restCount = rest.length\n\n    if (restCount) {\n      if (props.collapseTags) {\n        tags.push({\n          key: -1,\n          text: `+ ${restCount}`,\n          closable: false,\n          isCollapseTag: true,\n        })\n      } else {\n        rest.forEach((node) => tags.push(genTag(node)))\n      }\n    }\n  }\n\n  presentTags.value = tags\n}\n\nconst calculateSuggestions = () => {\n  const { filterMethod, showAllLevels, separator } = props\n  const res = cascaderPanelRef.value\n    ?.getFlattedNodes(!props.props.checkStrictly)\n    ?.filter((node) => {\n      if (node.isDisabled) return false\n      node.calcText(showAllLevels, separator)\n      return filterMethod(node, searchKeyword.value)\n    })\n\n  if (multiple.value) {\n    presentTags.value.forEach((tag) => {\n      tag.hitState = false\n    })\n    allPresentTags.value.forEach((tag) => {\n      tag.hitState = false\n    })\n  }\n\n  filtering.value = true\n  suggestions.value = res!\n  updatePopperPosition()\n}\n\nconst focusFirstNode = () => {\n  let firstNode!: HTMLElement\n\n  if (filtering.value && suggestionPanel.value) {\n    firstNode = suggestionPanel.value.$el.querySelector(\n      `.${nsCascader.e('suggestion-item')}`\n    )\n  } else {\n    firstNode = cascaderPanelRef.value?.$el.querySelector(\n      `.${nsCascader.b('node')}[tabindex=\"-1\"]`\n    )\n  }\n\n  if (firstNode) {\n    firstNode.focus()\n    !filtering.value && firstNode.click()\n  }\n}\n\nconst updateStyle = () => {\n  const inputInner = input.value?.input\n  const tagWrapperEl = tagWrapper.value\n  const suggestionPanelEl = suggestionPanel.value?.$el\n\n  if (!isClient || !inputInner) return\n\n  if (suggestionPanelEl) {\n    const suggestionList = suggestionPanelEl.querySelector(\n      `.${nsCascader.e('suggestion-list')}`\n    )\n    suggestionList.style.minWidth = `${inputInner.offsetWidth}px`\n  }\n\n  if (tagWrapperEl) {\n    const { offsetHeight } = tagWrapperEl\n    const height =\n      presentTags.value.length > 0\n        ? `${Math.max(offsetHeight + 6, inputInitialHeight)}px`\n        : `${inputInitialHeight}px`\n    inputInner.style.height = height\n    updatePopperPosition()\n  }\n}\n\nconst getCheckedNodes = (leafOnly: boolean) => {\n  return cascaderPanelRef.value?.getCheckedNodes(leafOnly)\n}\n\nconst handleExpandChange = (value: CascaderValue) => {\n  updatePopperPosition()\n  emit('expandChange', value)\n}\n\nconst handleKeyDown = (e: KeyboardEvent) => {\n  if (isComposing.value) return\n\n  switch (e.code) {\n    case EVENT_CODE.enter:\n      togglePopperVisible()\n      break\n    case EVENT_CODE.down:\n      togglePopperVisible(true)\n      nextTick(focusFirstNode)\n      e.preventDefault()\n      break\n    case EVENT_CODE.esc:\n      if (popperVisible.value === true) {\n        e.preventDefault()\n        e.stopPropagation()\n        togglePopperVisible(false)\n      }\n      break\n    case EVENT_CODE.tab:\n      togglePopperVisible(false)\n      break\n  }\n}\n\nconst handleClear = () => {\n  cascaderPanelRef.value?.clearCheckedNodes()\n  if (!popperVisible.value && props.filterable) {\n    syncPresentTextValue()\n  }\n  togglePopperVisible(false)\n  emit('clear')\n}\n\nconst syncPresentTextValue = () => {\n  const { value } = presentText\n  inputValue.value = value\n  searchInputValue.value = value\n}\n\nconst handleSuggestionClick = (node: CascaderNode) => {\n  const { checked } = node\n\n  if (multiple.value) {\n    cascaderPanelRef.value?.handleCheckChange(node, !checked, false)\n  } else {\n    !checked && cascaderPanelRef.value?.handleCheckChange(node, true, false)\n    togglePopperVisible(false)\n  }\n}\n\nconst handleSuggestionKeyDown = (e: KeyboardEvent) => {\n  const target = e.target as HTMLElement\n  const { code } = e\n\n  switch (code) {\n    case EVENT_CODE.up:\n    case EVENT_CODE.down: {\n      const distance = code === EVENT_CODE.up ? -1 : 1\n      focusNode(\n        getSibling(\n          target,\n          distance,\n          `.${nsCascader.e('suggestion-item')}[tabindex=\"-1\"]`\n        ) as HTMLElement\n      )\n      break\n    }\n    case EVENT_CODE.enter:\n      target.click()\n      break\n  }\n}\n\nconst handleDelete = () => {\n  const tags = presentTags.value\n  const lastTag = tags[tags.length - 1]\n  pressDeleteCount = searchInputValue.value ? 0 : pressDeleteCount + 1\n\n  if (!lastTag || !pressDeleteCount || (props.collapseTags && tags.length > 1))\n    return\n\n  if (lastTag.hitState) {\n    deleteTag(lastTag)\n  } else {\n    lastTag.hitState = true\n  }\n}\n\nconst handleFocus = (e: FocusEvent) => {\n  const el = e.target as HTMLInputElement\n  const name = nsCascader.e('search-input')\n  if (el.className === name) {\n    filterFocus.value = true\n  }\n  emit('focus', e)\n}\n\nconst handleBlur = (e: FocusEvent) => {\n  filterFocus.value = false\n  emit('blur', e)\n}\n\nconst handleFilter = debounce(() => {\n  const { value } = searchKeyword\n\n  if (!value) return\n\n  const passed = props.beforeFilter(value)\n\n  if (isPromise(passed)) {\n    passed.then(calculateSuggestions).catch(() => {\n      /* prevent log error */\n    })\n  } else if (passed !== false) {\n    calculateSuggestions()\n  } else {\n    hideSuggestionPanel()\n  }\n}, props.debounce)\n\nconst handleInput = (val: string, e?: KeyboardEvent) => {\n  !popperVisible.value && togglePopperVisible(true)\n\n  if (e?.isComposing) return\n\n  val ? handleFilter() : hideSuggestionPanel()\n}\n\nconst getInputInnerHeight = (inputInner: HTMLElement): number =>\n  Number.parseFloat(\n    useCssVar(nsInput.cssVarName('input-height'), inputInner).value\n  ) - 2\n\nwatch(filtering, updatePopperPosition)\n\nwatch(\n  [checkedNodes, isDisabled, () => props.collapseTags],\n  calculatePresentTags\n)\n\nwatch(presentTags, () => {\n  nextTick(() => updateStyle())\n})\n\nwatch(realSize, async () => {\n  await nextTick()\n  const inputInner = input.value!.input!\n  inputInitialHeight = getInputInnerHeight(inputInner) || inputInitialHeight\n  updateStyle()\n})\n\nwatch(presentText, syncPresentTextValue, { immediate: true })\n\nonMounted(() => {\n  const inputInner = input.value!.input!\n\n  const inputInnerHeight = getInputInnerHeight(inputInner)\n\n  inputInitialHeight = inputInner.offsetHeight || inputInnerHeight\n  useResizeObserver(inputInner, updateStyle)\n})\n\ndefineExpose({\n  /**\n   * @description get an array of currently selected node,(leafOnly) whether only return the leaf checked nodes, default is `false`\n   */\n  getCheckedNodes,\n  /**\n   * @description cascader panel ref\n   */\n  cascaderPanelRef,\n  /**\n   * @description toggle the visible of popper\n   */\n  togglePopperVisible,\n  /**\n   * @description cascader content ref\n   */\n  contentRef,\n  /**\n   * @description selected content text\n   */\n  presentText,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Cascader from './src/cascader.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCascader: SFCWithInstall<typeof Cascader> = withInstall(Cascader)\n\nexport default ElCascader\n\nexport * from './src/cascader'\nexport * from './src/instances'\n", "import { buildProps, isBoolean } from '@element-plus/utils'\nimport { CHANGE_EVENT } from '@element-plus/constants'\n\nimport type CheckTag from './check-tag.vue'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const checkTagProps = buildProps({\n  /**\n   * @description is checked\n   */\n  checked: Boolean,\n  /**\n   * @description whether the check-tag is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description type of Tag\n   */\n  type: {\n    type: String,\n    values: ['primary', 'success', 'info', 'warning', 'danger'],\n    default: 'primary',\n  },\n} as const)\nexport type CheckTagProps = ExtractPropTypes<typeof checkTagProps>\n\nexport const checkTagEmits = {\n  'update:checked': (value: boolean) => isBoolean(value),\n  [CHANGE_EVENT]: (value: boolean) => isBoolean(value),\n}\nexport type CheckTagEmits = typeof checkTagEmits\n\nexport type CheckTagInstance = InstanceType<typeof CheckTag>\n", "<template>\n  <span :class=\"containerKls\" @click=\"handleChange\">\n    <slot />\n  </span>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { CHANGE_EVENT } from '@element-plus/constants'\nimport { useNamespace } from '@element-plus/hooks'\nimport { checkTagEmits, checkTagProps } from './check-tag'\n\ndefineOptions({\n  name: 'ElCheckTag',\n})\nconst props = defineProps(checkTagProps)\nconst emit = defineEmits(checkTagEmits)\n\nconst ns = useNamespace('check-tag')\nconst isDisabled = computed(() => props.disabled)\nconst containerKls = computed(() => [\n  ns.b(),\n  ns.is('checked', props.checked),\n  ns.is('disabled', isDisabled.value),\n  ns.m(props.type || 'primary'),\n])\n\nconst handleChange = () => {\n  if (isDisabled.value) return\n\n  const checked = !props.checked\n  emit(CHANGE_EVENT, checked)\n  emit('update:checked', checked)\n}\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport CheckTag from './src/check-tag.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCheckTag: SFCWithInstall<typeof CheckTag> = withInstall(CheckTag)\nexport default ElCheckTag\n\nexport * from './src/check-tag'\n", "import type { ComputedRef, InjectionKey } from 'vue'\n\ninterface RowContext {\n  gutter: ComputedRef<number>\n}\n\nexport const rowContextKey: InjectionKey<RowContext> = Symbol('rowContextKey')\n", "import { buildProps } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Row from './row.vue'\n\nexport const RowJustify = [\n  'start',\n  'center',\n  'end',\n  'space-around',\n  'space-between',\n  'space-evenly',\n] as const\n\nexport const RowAlign = ['top', 'middle', 'bottom'] as const\n\nexport const rowProps = buildProps({\n  /**\n   * @description custom element tag\n   */\n  tag: {\n    type: String,\n    default: 'div',\n  },\n  /**\n   * @description grid spacing\n   */\n  gutter: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description horizontal alignment of flex layout\n   */\n  justify: {\n    type: String,\n    values: RowJustify,\n    default: 'start',\n  },\n  /**\n   * @description vertical alignment of flex layout\n   */\n  align: {\n    type: String,\n    values: RowAlign,\n  },\n} as const)\n\nexport type RowProps = ExtractPropTypes<typeof rowProps>\nexport type RowInstance = InstanceType<typeof Row>\n", "<template>\n  <component :is=\"tag\" :class=\"rowKls\" :style=\"style\">\n    <slot />\n  </component>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, provide } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { rowContextKey } from './constants'\nimport { rowProps } from './row'\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElRow',\n})\n\nconst props = defineProps(rowProps)\n\nconst ns = useNamespace('row')\nconst gutter = computed(() => props.gutter)\n\nprovide(rowContextKey, {\n  gutter,\n})\n\nconst style = computed(() => {\n  const styles: CSSProperties = {}\n  if (!props.gutter) {\n    return styles\n  }\n\n  styles.marginRight = styles.marginLeft = `-${props.gutter / 2}px`\n  return styles\n})\n\nconst rowKls = computed(() => [\n  ns.b(),\n  ns.is(`justify-${props.justify}`, props.justify !== 'start'),\n  ns.is(`align-${props.align}`, !!props.align),\n])\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Row from './src/row.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElRow: SFCWithInstall<typeof Row> = withInstall(Row)\nexport default ElRow\n\nexport * from './src/row'\nexport * from './src/constants'\n", "import { buildProps, definePropType, mutable } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Col from './col.vue'\n\nexport type ColSizeObject = {\n  span?: number\n  offset?: number\n  pull?: number\n  push?: number\n}\nexport type ColSize = number | ColSizeObject\n\nexport const colProps = buildProps({\n  /**\n   * @description custom element tag\n   */\n  tag: {\n    type: String,\n    default: 'div',\n  },\n  /**\n   * @description number of column the grid spans\n   */\n  span: {\n    type: Number,\n    default: 24,\n  },\n  /**\n   * @description number of spacing on the left side of the grid\n   */\n  offset: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description number of columns that grid moves to the left\n   */\n  pull: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description number of columns that grid moves to the right\n   */\n  push: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description `<768px` Responsive columns or column props object\n   */\n  xs: {\n    type: definePropType<ColSize>([Number, Object]),\n    default: () => mutable({} as const),\n  },\n  /**\n   * @description `≥768px` Responsive columns or column props object\n   */\n  sm: {\n    type: definePropType<ColSize>([Number, Object]),\n    default: () => mutable({} as const),\n  },\n  /**\n   * @description `≥992px` Responsive columns or column props object\n   */\n  md: {\n    type: definePropType<ColSize>([Number, Object]),\n    default: () => mutable({} as const),\n  },\n  /**\n   * @description `≥1200px` Responsive columns or column props object\n   */\n  lg: {\n    type: definePropType<ColSize>([Number, Object]),\n    default: () => mutable({} as const),\n  },\n  /**\n   * @description `≥1920px` Responsive columns or column props object\n   */\n  xl: {\n    type: definePropType<ColSize>([Number, Object]),\n    default: () => mutable({} as const),\n  },\n} as const)\nexport type ColProps = ExtractPropTypes<typeof colProps>\nexport type ColInstance = InstanceType<typeof Col>\n", "<template>\n  <component :is=\"tag\" :class=\"colKls\" :style=\"style\">\n    <slot />\n  </component>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, inject } from 'vue'\nimport { isNumber, isObject } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { rowContextKey } from '@element-plus/components/row'\nimport { colProps } from './col'\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElCol',\n})\n\nconst props = defineProps(colProps)\n\nconst { gutter } = inject(rowContextKey, { gutter: computed(() => 0) })\nconst ns = useNamespace('col')\n\nconst style = computed(() => {\n  const styles: CSSProperties = {}\n  if (gutter.value) {\n    styles.paddingLeft = styles.paddingRight = `${gutter.value / 2}px`\n  }\n  return styles\n})\n\nconst colKls = computed(() => {\n  const classes: string[] = []\n  const pos = ['span', 'offset', 'pull', 'push'] as const\n\n  pos.forEach((prop) => {\n    const size = props[prop]\n    if (isNumber(size)) {\n      if (prop === 'span') classes.push(ns.b(`${props[prop]}`))\n      else if (size > 0) classes.push(ns.b(`${prop}-${props[prop]}`))\n    }\n  })\n\n  const sizes = ['xs', 'sm', 'md', 'lg', 'xl'] as const\n  sizes.forEach((size) => {\n    if (isNumber(props[size])) {\n      classes.push(ns.b(`${size}-${props[size]}`))\n    } else if (isObject(props[size])) {\n      Object.entries(props[size]).forEach(([prop, sizeProp]) => {\n        classes.push(\n          prop !== 'span'\n            ? ns.b(`${size}-${prop}-${sizeProp}`)\n            : ns.b(`${size}-${sizeProp}`)\n        )\n      })\n    }\n  })\n\n  // this is for the fix\n  if (gutter.value) {\n    classes.push(ns.is('guttered'))\n  }\n  return [ns.b(), classes]\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Col from './src/col.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCol: SFCWithInstall<typeof Col> = withInstall(Col)\nexport default ElCol\n\nexport * from './src/col'\n", "import {\n  buildProps,\n  definePropType,\n  isArray,\n  isNumber,\n  isString,\n  mutable,\n} from '@element-plus/utils'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport type { ExtractPropTypes } from 'vue'\nimport type { Arrayable } from '@element-plus/utils'\n\nexport type CollapseActiveName = string | number\nexport type CollapseModelValue = Arrayable<CollapseActiveName>\n\nexport const emitChangeFn = (value: CollapseModelValue) =>\n  isNumber(value) || isString(value) || isArray(value)\n\nexport const collapseProps = buildProps({\n  /**\n   * @description whether to activate accordion mode\n   */\n  accordion: Boolean,\n  /**\n   * @description currently active panel, the type is `string` in accordion mode, otherwise it is `array`\n   */\n  modelValue: {\n    type: definePropType<CollapseModelValue>([Array, String, Number]),\n    default: () => mutable([] as const),\n  },\n} as const)\nexport type CollapseProps = ExtractPropTypes<typeof collapseProps>\n\nexport const collapseEmits = {\n  [UPDATE_MODEL_EVENT]: emitChangeFn,\n  [CHANGE_EVENT]: emitChangeFn,\n}\nexport type CollapseEmits = typeof collapseEmits\n", "import type { InjectionKey, Ref } from 'vue'\nimport type { CollapseActiveName } from './collapse'\n\nexport interface CollapseContext {\n  activeNames: Ref<CollapseActiveName[]>\n  handleItemClick: (name: CollapseActiveName) => void\n}\n\nexport const collapseContextKey: InjectionKey<CollapseContext> =\n  Symbol('collapseContextKey')\n", "import { computed, provide, ref, watch } from 'vue'\nimport { ensureArray } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { collapseContextKey } from './constants'\n\nimport type { SetupContext } from 'vue'\nimport type {\n  CollapseActiveName,\n  CollapseEmits,\n  CollapseProps,\n} from './collapse'\n\nexport const useCollapse = (\n  props: CollapseProps,\n  emit: SetupContext<CollapseEmits>['emit']\n) => {\n  const activeNames = ref(ensureArray(props.modelValue))\n\n  const setActiveNames = (_activeNames: CollapseActiveName[]) => {\n    activeNames.value = _activeNames\n    const value = props.accordion ? activeNames.value[0] : activeNames.value\n    emit(UPDATE_MODEL_EVENT, value)\n    emit(CHANGE_EVENT, value)\n  }\n\n  const handleItemClick = (name: CollapseActiveName) => {\n    if (props.accordion) {\n      setActiveNames([activeNames.value[0] === name ? '' : name])\n    } else {\n      const _activeNames = [...activeNames.value]\n      const index = _activeNames.indexOf(name)\n\n      if (index > -1) {\n        _activeNames.splice(index, 1)\n      } else {\n        _activeNames.push(name)\n      }\n      setActiveNames(_activeNames)\n    }\n  }\n\n  watch(\n    () => props.modelValue,\n    () => (activeNames.value = ensureArray(props.modelValue)),\n    { deep: true }\n  )\n\n  provide(collapseContextKey, {\n    activeNames,\n    handleItemClick,\n  })\n  return {\n    activeNames,\n    setActiveNames,\n  }\n}\n\nexport const useCollapseDOM = () => {\n  const ns = useNamespace('collapse')\n\n  const rootKls = computed(() => ns.b())\n  return {\n    rootKls,\n  }\n}\n", "<template>\n  <div :class=\"rootKls\">\n    <slot />\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { collapseEmits, collapseProps } from './collapse'\nimport { useCollapse, useCollapseDOM } from './use-collapse'\n\ndefineOptions({\n  name: 'ElCollapse',\n})\nconst props = defineProps(collapseProps)\nconst emit = defineEmits(collapseEmits)\n\nconst { activeNames, setActiveNames } = useCollapse(props, emit)\n\nconst { rootKls } = useCollapseDOM()\n\ndefineExpose({\n  /** @description active names */\n  activeNames,\n  /** @description set active names */\n  setActiveNames,\n})\n</script>\n", "<template>\n  <transition :name=\"ns.b()\" v-on=\"on\">\n    <slot />\n  </transition>\n</template>\n<script lang=\"ts\" setup>\nimport { useNamespace } from '@element-plus/hooks'\nimport type { RendererElement } from '@vue/runtime-core'\n\ndefineOptions({\n  name: 'ElCollapseTransition',\n})\n\nconst ns = useNamespace('collapse-transition')\n\nconst reset = (el: RendererElement) => {\n  el.style.maxHeight = ''\n  el.style.overflow = el.dataset.oldOverflow\n  el.style.paddingTop = el.dataset.oldPaddingTop\n  el.style.paddingBottom = el.dataset.oldPaddingBottom\n}\n\nconst on = {\n  beforeEnter(el: RendererElement) {\n    if (!el.dataset) el.dataset = {}\n\n    el.dataset.oldPaddingTop = el.style.paddingTop\n    el.dataset.oldPaddingBottom = el.style.paddingBottom\n    if (el.style.height) el.dataset.elExistsHeight = el.style.height\n\n    el.style.maxHeight = 0\n    el.style.paddingTop = 0\n    el.style.paddingBottom = 0\n  },\n\n  enter(el: RendererElement) {\n    requestAnimationFrame(() => {\n      el.dataset.oldOverflow = el.style.overflow\n      if (el.dataset.elExistsHeight) {\n        el.style.maxHeight = el.dataset.elExistsHeight\n      } else if (el.scrollHeight !== 0) {\n        el.style.maxHeight = `${el.scrollHeight}px`\n      } else {\n        el.style.maxHeight = 0\n      }\n\n      el.style.paddingTop = el.dataset.oldPaddingTop\n      el.style.paddingBottom = el.dataset.oldPaddingBottom\n      el.style.overflow = 'hidden'\n    })\n  },\n\n  afterEnter(el: RendererElement) {\n    el.style.maxHeight = ''\n    el.style.overflow = el.dataset.oldOverflow\n  },\n\n  enterCancelled(el: RendererElement) {\n    reset(el)\n  },\n\n  beforeLeave(el: RendererElement) {\n    if (!el.dataset) el.dataset = {}\n    el.dataset.oldPaddingTop = el.style.paddingTop\n    el.dataset.oldPaddingBottom = el.style.paddingBottom\n    el.dataset.oldOverflow = el.style.overflow\n\n    el.style.maxHeight = `${el.scrollHeight}px`\n    el.style.overflow = 'hidden'\n  },\n\n  leave(el: RendererElement) {\n    if (el.scrollHeight !== 0) {\n      el.style.maxHeight = 0\n      el.style.paddingTop = 0\n      el.style.paddingBottom = 0\n    }\n  },\n\n  afterLeave(el: RendererElement) {\n    reset(el)\n  },\n\n  leaveCancelled(el: RendererElement) {\n    reset(el)\n  },\n}\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport CollapseTransition from './src/collapse-transition.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCollapseTransition: SFCWithInstall<typeof CollapseTransition> =\n  withInstall(CollapseTransition)\n\nexport default ElCollapseTransition\n", "import { buildProps, definePropType, iconPropType } from '@element-plus/utils'\nimport { ArrowRight } from '@element-plus/icons-vue'\nimport type { ExtractPropTypes } from 'vue'\nimport type { CollapseActiveName } from './collapse'\n\nexport const collapseItemProps = buildProps({\n  /**\n   * @description title of the panel\n   */\n  title: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description unique identification of the panel\n   */\n  name: {\n    type: definePropType<CollapseActiveName>([String, Number]),\n    default: undefined,\n  },\n  /**\n   * @description icon of the collapse item\n   */\n  icon: {\n    type: iconPropType,\n    default: ArrowRight,\n  },\n  /**\n   * @description disable the collapse item\n   */\n  disabled: Boolean,\n} as const)\nexport type CollapseItemProps = ExtractPropTypes<typeof collapseItemProps>\n", "import { computed, inject, ref, unref } from 'vue'\nimport { useIdInjection, useNamespace } from '@element-plus/hooks'\nimport { collapseContextKey } from './constants'\n\nimport type { CollapseItemProps } from './collapse-item'\n\nexport const useCollapseItem = (props: CollapseItemProps) => {\n  const collapse = inject(collapseContextKey)\n  const { namespace } = useNamespace('collapse')\n\n  const focusing = ref(false)\n  const isClick = ref(false)\n  const idInjection = useIdInjection()\n  const id = computed(() => idInjection.current++)\n  const name = computed(() => {\n    return (\n      props.name ?? `${namespace.value}-id-${idInjection.prefix}-${unref(id)}`\n    )\n  })\n\n  const isActive = computed(() =>\n    collapse?.activeNames.value.includes(unref(name))\n  )\n\n  const handleFocus = () => {\n    setTimeout(() => {\n      if (!isClick.value) {\n        focusing.value = true\n      } else {\n        isClick.value = false\n      }\n    }, 50)\n  }\n\n  const handleHeaderClick = () => {\n    if (props.disabled) return\n    collapse?.handleItemClick(unref(name))\n    focusing.value = false\n    isClick.value = true\n  }\n\n  const handleEnterClick = () => {\n    collapse?.handleItemClick(unref(name))\n  }\n\n  return {\n    focusing,\n    id,\n    isActive,\n    handleFocus,\n    handleHeaderClick,\n    handleEnterClick,\n  }\n}\n\nexport const useCollapseItemDOM = (\n  props: CollapseItemProps,\n  { focusing, isActive, id }: Partial<ReturnType<typeof useCollapseItem>>\n) => {\n  const ns = useNamespace('collapse')\n\n  const rootKls = computed(() => [\n    ns.b('item'),\n    ns.is('active', unref(isActive)),\n    ns.is('disabled', props.disabled),\n  ])\n  const headKls = computed(() => [\n    ns.be('item', 'header'),\n    ns.is('active', unref(isActive)),\n    { focusing: unref(focusing) && !props.disabled },\n  ])\n  const arrowKls = computed(() => [\n    ns.be('item', 'arrow'),\n    ns.is('active', unref(isActive)),\n  ])\n  const itemWrapperKls = computed(() => ns.be('item', 'wrap'))\n  const itemContentKls = computed(() => ns.be('item', 'content'))\n  const scopedContentId = computed(() => ns.b(`content-${unref(id)}`))\n  const scopedHeadId = computed(() => ns.b(`head-${unref(id)}`))\n\n  return {\n    arrowKls,\n    headKls,\n    rootKls,\n    itemWrapperKls,\n    itemContentKls,\n    scopedContentId,\n    scopedHeadId,\n  }\n}\n", "<template>\n  <div :class=\"rootKls\">\n    <button\n      :id=\"scopedHeadId\"\n      :class=\"headKls\"\n      :aria-expanded=\"isActive\"\n      :aria-controls=\"scopedContentId\"\n      :aria-describedby=\"scopedContentId\"\n      :tabindex=\"disabled ? -1 : 0\"\n      type=\"button\"\n      @click=\"handleHeaderClick\"\n      @keydown.space.enter.stop.prevent=\"handleEnterClick\"\n      @focus=\"handleFocus\"\n      @blur=\"focusing = false\"\n    >\n      <slot name=\"title\">{{ title }}</slot>\n      <slot name=\"icon\" :is-active=\"isActive\">\n        <el-icon :class=\"arrowKls\">\n          <component :is=\"icon\" />\n        </el-icon>\n      </slot>\n    </button>\n\n    <el-collapse-transition>\n      <div\n        v-show=\"isActive\"\n        :id=\"scopedContentId\"\n        role=\"region\"\n        :class=\"itemWrapperKls\"\n        :aria-hidden=\"!isActive\"\n        :aria-labelledby=\"scopedHeadId\"\n      >\n        <div :class=\"itemContentKls\">\n          <slot />\n        </div>\n      </div>\n    </el-collapse-transition>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport ElCollapseTransition from '@element-plus/components/collapse-transition'\nimport ElIcon from '@element-plus/components/icon'\nimport { collapseItemProps } from './collapse-item'\nimport { useCollapseItem, useCollapseItemDOM } from './use-collapse-item'\n\ndefineOptions({\n  name: 'ElCollapseItem',\n})\n\nconst props = defineProps(collapseItemProps)\nconst {\n  focusing,\n  id,\n  isActive,\n  handleFocus,\n  handleHeaderClick,\n  handleEnterClick,\n} = useCollapseItem(props)\n\nconst {\n  arrowKls,\n  headKls,\n  rootKls,\n  itemWrapperKls,\n  itemContentKls,\n  scopedContentId,\n  scopedHeadId,\n} = useCollapseItemDOM(props, { focusing, isActive, id })\n\ndefineExpose({\n  /** @description current collapse-item whether active */\n  isActive,\n})\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\n\nimport Collapse from './src/collapse.vue'\nimport CollapseItem from './src/collapse-item.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCollapse: SFCWithInstall<typeof Collapse> & {\n  CollapseItem: typeof CollapseItem\n} = withInstall(Collapse, {\n  CollapseItem,\n})\nexport default ElCollapse\nexport const ElCollapseItem: SFCWithInstall<typeof CollapseItem> =\n  withNoopInstall(CollapseItem)\n\nexport * from './src/collapse'\nexport * from './src/collapse-item'\nexport * from './src/constants'\nexport type { CollapseInstance, CollapseItemInstance } from './src/instance'\n", "import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Color from '../utils/color'\n\nexport const alphaSliderProps = buildProps({\n  color: {\n    type: definePropType<Color>(Object),\n    required: true,\n  },\n  vertical: {\n    type: Boolean,\n    default: false,\n  },\n} as const)\n\nexport type AlphaSliderProps = ExtractPropTypes<typeof alphaSliderProps>\n", "import { isClient } from '@element-plus/utils'\n\nlet isDragging = false\n\nexport interface DraggableOptions {\n  drag?: (event: MouseEvent | TouchEvent) => void\n  start?: (event: MouseEvent | TouchEvent) => void\n  end?: (event: MouseEvent | TouchEvent) => void\n}\n\nexport function draggable(element: HTMLElement, options: DraggableOptions) {\n  if (!isClient) return\n\n  const moveFn = function (event: MouseEvent | TouchEvent) {\n    options.drag?.(event)\n  }\n\n  const upFn = function (event: MouseEvent | TouchEvent) {\n    document.removeEventListener('mousemove', moveFn)\n    document.removeEventListener('mouseup', upFn)\n    document.removeEventListener('touchmove', moveFn)\n    document.removeEventListener('touchend', upFn)\n    document.onselectstart = null\n    document.ondragstart = null\n\n    isDragging = false\n\n    options.end?.(event)\n  }\n\n  const downFn = function (event: MouseEvent | TouchEvent) {\n    if (isDragging) return\n    event.preventDefault()\n    document.onselectstart = () => false\n    document.ondragstart = () => false\n    document.addEventListener('mousemove', moveFn)\n    document.addEventListener('mouseup', upFn)\n    document.addEventListener('touchmove', moveFn)\n    document.addEventListener('touchend', upFn)\n\n    isDragging = true\n\n    options.start?.(event)\n  }\n\n  element.addEventListener('mousedown', downFn)\n  element.addEventListener('touchstart', downFn, { passive: false })\n}\n", "import {\n  computed,\n  getCurrentInstance,\n  onMounted,\n  ref,\n  shallowRef,\n  watch,\n} from 'vue'\nimport { addUnit, getClientXY } from '@element-plus/utils'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { draggable } from '../utils/draggable'\n\nimport type { AlphaSliderProps } from '../props/alpha-slider'\n\nexport const useAlphaSlider = (props: AlphaSliderProps) => {\n  const instance = getCurrentInstance()!\n  const { t } = useLocale()\n\n  const thumb = shallowRef<HTMLElement>()\n  const bar = shallowRef<HTMLElement>()\n\n  const alpha = computed(() => props.color.get('alpha'))\n  const alphaLabel = computed(() => t('el.colorpicker.alphaLabel'))\n\n  function handleClick(event: MouseEvent | TouchEvent) {\n    const target = event.target\n\n    if (target !== thumb.value) {\n      handleDrag(event)\n    }\n    thumb.value?.focus()\n  }\n\n  function handleDrag(event: MouseEvent | TouchEvent) {\n    if (!bar.value || !thumb.value) return\n\n    const el = instance.vnode.el as HTMLElement\n    const rect = el.getBoundingClientRect()\n    const { clientX, clientY } = getClientXY(event)\n\n    if (!props.vertical) {\n      let left = clientX - rect.left\n      left = Math.max(thumb.value.offsetWidth / 2, left)\n      left = Math.min(left, rect.width - thumb.value.offsetWidth / 2)\n\n      props.color.set(\n        'alpha',\n        Math.round(\n          ((left - thumb.value.offsetWidth / 2) /\n            (rect.width - thumb.value.offsetWidth)) *\n            100\n        )\n      )\n    } else {\n      let top = clientY - rect.top\n      top = Math.max(thumb.value.offsetHeight / 2, top)\n      top = Math.min(top, rect.height - thumb.value.offsetHeight / 2)\n\n      props.color.set(\n        'alpha',\n        Math.round(\n          ((top - thumb.value.offsetHeight / 2) /\n            (rect.height - thumb.value.offsetHeight)) *\n            100\n        )\n      )\n    }\n  }\n\n  function handleKeydown(event: KeyboardEvent) {\n    const { code, shiftKey } = event\n    const step = shiftKey ? 10 : 1\n\n    switch (code) {\n      case EVENT_CODE.left:\n      case EVENT_CODE.down:\n        event.preventDefault()\n        event.stopPropagation()\n        incrementPosition(-step)\n        break\n      case EVENT_CODE.right:\n      case EVENT_CODE.up:\n        event.preventDefault()\n        event.stopPropagation()\n        incrementPosition(step)\n        break\n    }\n  }\n\n  function incrementPosition(step: number) {\n    let next = alpha.value + step\n    next = next < 0 ? 0 : next > 100 ? 100 : next\n    props.color.set('alpha', next)\n  }\n\n  return {\n    thumb,\n    bar,\n    alpha,\n    alphaLabel,\n    handleDrag,\n    handleClick,\n    handleKeydown,\n  }\n}\n\nexport const useAlphaSliderDOM = (\n  props: AlphaSliderProps,\n  {\n    bar,\n    thumb,\n    handleDrag,\n  }: Pick<ReturnType<typeof useAlphaSlider>, 'bar' | 'thumb' | 'handleDrag'>\n) => {\n  const instance = getCurrentInstance()!\n\n  const ns = useNamespace('color-alpha-slider')\n  // refs\n\n  const thumbLeft = ref(0)\n  const thumbTop = ref(0)\n  const background = ref<string>()\n\n  function getThumbLeft() {\n    if (!thumb.value) return 0\n\n    if (props.vertical) return 0\n    const el = instance.vnode.el\n    const alpha = props.color.get('alpha')\n\n    if (!el) return 0\n    return Math.round(\n      (alpha * (el.offsetWidth - thumb.value.offsetWidth / 2)) / 100\n    )\n  }\n\n  function getThumbTop() {\n    if (!thumb.value) return 0\n\n    const el = instance.vnode.el\n    if (!props.vertical) return 0\n    const alpha = props.color.get('alpha')\n\n    if (!el) return 0\n    return Math.round(\n      (alpha * (el.offsetHeight - thumb.value.offsetHeight / 2)) / 100\n    )\n  }\n\n  function getBackground() {\n    if (props.color && props.color.value) {\n      const { r, g, b } = props.color.toRgb()\n      return `linear-gradient(to right, rgba(${r}, ${g}, ${b}, 0) 0%, rgba(${r}, ${g}, ${b}, 1) 100%)`\n    }\n    return ''\n  }\n\n  function update() {\n    thumbLeft.value = getThumbLeft()\n    thumbTop.value = getThumbTop()\n    background.value = getBackground()\n  }\n\n  onMounted(() => {\n    if (!bar.value || !thumb.value) return\n\n    const dragConfig = {\n      drag: (event: MouseEvent | TouchEvent) => {\n        handleDrag(event)\n      },\n      end: (event: MouseEvent | TouchEvent) => {\n        handleDrag(event)\n      },\n    }\n\n    draggable(bar.value, dragConfig)\n    draggable(thumb.value, dragConfig)\n    update()\n  })\n\n  watch(\n    () => props.color.get('alpha'),\n    () => update()\n  )\n  watch(\n    () => props.color.value,\n    () => update()\n  )\n\n  const rootKls = computed(() => [ns.b(), ns.is('vertical', props.vertical)])\n  const barKls = computed(() => ns.e('bar'))\n  const thumbKls = computed(() => ns.e('thumb'))\n  const barStyle = computed(() => ({ background: background.value }))\n  const thumbStyle = computed(() => ({\n    left: addUnit(thumbLeft.value),\n    top: addUnit(thumbTop.value),\n  }))\n\n  return { rootKls, barKls, barStyle, thumbKls, thumbStyle, update }\n}\n", "<template>\n  <div :class=\"rootKls\">\n    <div ref=\"bar\" :class=\"barKls\" :style=\"barStyle\" @click=\"handleClick\" />\n    <div\n      ref=\"thumb\"\n      :class=\"thumbKls\"\n      :style=\"thumbStyle\"\n      :aria-label=\"alphaLabel\"\n      :aria-valuenow=\"alpha\"\n      :aria-orientation=\"vertical ? 'vertical' : 'horizontal'\"\n      aria-valuemin=\"0\"\n      aria-valuemax=\"100\"\n      role=\"slider\"\n      tabindex=\"0\"\n      @keydown=\"handleKeydown\"\n    />\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { alphaSliderProps } from '../props/alpha-slider'\nimport {\n  useAlphaSlider,\n  useAlphaSliderDOM,\n} from '../composables/use-alpha-slider'\n\nconst COMPONENT_NAME = 'ElColorAlphaSlider'\n\ndefineOptions({\n  name: COMPONENT_NAME,\n})\n\nconst props = defineProps(alphaSliderProps)\n\nconst {\n  alpha,\n  alphaLabel,\n  bar,\n  thumb,\n  handleDrag,\n  handleClick,\n  handleKeydown,\n} = useAlphaSlider(props)\n\nconst { rootKls, barKls, barStyle, thumbKls, thumbStyle, update } =\n  useAlphaSliderDOM(props, {\n    bar,\n    thumb,\n    handleDrag,\n  })\n\ndefineExpose({\n  /**\n   * @description update alpha slider manually\n   * @type {Function}\n   */\n  update,\n  /**\n   * @description bar element ref\n   * @type {HTMLElement}\n   */\n  bar,\n  /**\n   * @description thumb element ref\n   * @type {HTMLElement}\n   */\n  thumb,\n})\n</script>\n", "<template>\n  <div :class=\"[ns.b(), ns.is('vertical', vertical)]\">\n    <div ref=\"bar\" :class=\"ns.e('bar')\" @click=\"handleClick\" />\n    <div\n      ref=\"thumb\"\n      :class=\"ns.e('thumb')\"\n      :style=\"{\n        left: thumbLeft + 'px',\n        top: thumbTop + 'px',\n      }\"\n    />\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport {\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  onMounted,\n  ref,\n  watch,\n} from 'vue'\nimport { getClientXY } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { draggable } from '../utils/draggable'\n\nimport type { PropType } from 'vue'\nimport type Color from '../utils/color'\n\nexport default defineComponent({\n  name: 'ElColorHueSlider',\n\n  props: {\n    color: {\n      type: Object as PropType<Color>,\n      required: true,\n    },\n\n    vertical: Boolean,\n  },\n  setup(props) {\n    const ns = useNamespace('color-hue-slider')\n    const instance = getCurrentInstance()!\n    // ref\n    const thumb = ref<HTMLElement>()\n    const bar = ref<HTMLElement>()\n    // data\n    const thumbLeft = ref(0)\n    const thumbTop = ref(0)\n    // computed\n    const hueValue = computed(() => {\n      return props.color.get('hue')\n    })\n    // watch\n    watch(\n      () => hueValue.value,\n      () => {\n        update()\n      }\n    )\n\n    // methods\n    function handleClick(event: MouseEvent | TouchEvent) {\n      const target = event.target\n\n      if (target !== thumb.value) {\n        handleDrag(event)\n      }\n    }\n\n    function handleDrag(event: MouseEvent | TouchEvent) {\n      if (!bar.value || !thumb.value) return\n\n      const el = instance.vnode.el as HTMLElement\n      const rect = el.getBoundingClientRect()\n      const { clientX, clientY } = getClientXY(event)\n      let hue\n\n      if (!props.vertical) {\n        let left = clientX - rect.left\n        left = Math.min(left, rect.width - thumb.value.offsetWidth / 2)\n        left = Math.max(thumb.value.offsetWidth / 2, left)\n\n        hue = Math.round(\n          ((left - thumb.value.offsetWidth / 2) /\n            (rect.width - thumb.value.offsetWidth)) *\n            360\n        )\n      } else {\n        let top = clientY - rect.top\n\n        top = Math.min(top, rect.height - thumb.value.offsetHeight / 2)\n        top = Math.max(thumb.value.offsetHeight / 2, top)\n        hue = Math.round(\n          ((top - thumb.value.offsetHeight / 2) /\n            (rect.height - thumb.value.offsetHeight)) *\n            360\n        )\n      }\n      props.color.set('hue', hue)\n    }\n\n    function getThumbLeft() {\n      if (!thumb.value) return 0\n\n      const el = instance.vnode.el\n\n      if (props.vertical) return 0\n      const hue = props.color.get('hue')\n\n      if (!el) return 0\n      return Math.round(\n        (hue * (el.offsetWidth - thumb.value.offsetWidth / 2)) / 360\n      )\n    }\n\n    function getThumbTop() {\n      if (!thumb.value) return 0\n\n      const el = instance.vnode.el as HTMLElement\n      if (!props.vertical) return 0\n      const hue = props.color.get('hue')\n\n      if (!el) return 0\n      return Math.round(\n        (hue * (el.offsetHeight - thumb.value.offsetHeight / 2)) / 360\n      )\n    }\n\n    function update() {\n      thumbLeft.value = getThumbLeft()\n      thumbTop.value = getThumbTop()\n    }\n\n    // mounded\n    onMounted(() => {\n      if (!bar.value || !thumb.value) return\n\n      const dragConfig = {\n        drag: (event: MouseEvent | TouchEvent) => {\n          handleDrag(event)\n        },\n        end: (event: MouseEvent | TouchEvent) => {\n          handleDrag(event)\n        },\n      }\n\n      draggable(bar.value, dragConfig)\n      draggable(thumb.value, dragConfig)\n      update()\n    })\n\n    return {\n      bar,\n      thumb,\n      thumbLeft,\n      thumbTop,\n      hueValue,\n      handleClick,\n      update,\n      ns,\n    }\n  },\n})\n</script>\n", "import { isNil } from 'lodash-unified'\nimport { buildProps, definePropType, isString } from '@element-plus/utils'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\n\nimport type { ComputedRef, ExtractPropTypes, InjectionKey } from 'vue'\nimport type ColorPicker from './color-picker.vue'\n\nexport const colorPickerProps = buildProps({\n  /**\n   * @description binding value\n   */\n  modelValue: String,\n  /**\n   * @description ColorPicker id\n   */\n  id: String,\n  /**\n   * @description whether to display the alpha slider\n   */\n  showAlpha: Boolean,\n  /**\n   * @description color format of v-model\n   */\n  colorFormat: String,\n  /**\n   * @description whether to disable the ColorPicker\n   */\n  disabled: Boolean,\n  /**\n   * @description size of ColorPicker\n   */\n  size: useSizeProp,\n  /**\n   * @description custom class name for ColorPicker's dropdown\n   */\n  popperClass: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description ColorPicker tabindex\n   */\n  tabindex: {\n    type: [String, Number],\n    default: 0,\n  },\n  /**\n   * @description whether color-picker popper is teleported to the body\n   */\n  teleported: useTooltipContentProps.teleported,\n  /**\n   * @description predefined color options\n   */\n  predefine: {\n    type: definePropType<string[]>(Array),\n  },\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  ...useAriaProps(['ariaLabel']),\n} as const)\nexport const colorPickerEmits = {\n  [UPDATE_MODEL_EVENT]: (val: string | null) => isString(val) || isNil(val),\n  [CHANGE_EVENT]: (val: string | null) => isString(val) || isNil(val),\n  activeChange: (val: string | null) => isString(val) || isNil(val),\n  focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n  blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n}\n\nexport type ColorPickerProps = ExtractPropTypes<typeof colorPickerProps>\nexport type ColorPickerEmits = typeof colorPickerEmits\nexport type ColorPickerInstance = InstanceType<typeof ColorPicker>\n\nexport interface ColorPickerContext {\n  currentColor: ComputedRef<string>\n}\n\nexport const colorPickerContextKey: InjectionKey<ColorPickerContext> = Symbol(\n  'colorPickerContextKey'\n)\n", "import { hasOwn } from '@element-plus/utils'\n\nconst hsv2hsl = function (hue: number, sat: number, val: number) {\n  return [\n    hue,\n    (sat * val) / ((hue = (2 - sat) * val) < 1 ? hue : 2 - hue) || 0,\n    hue / 2,\n  ]\n}\n\n// Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1\n// <http://stackoverflow.com/questions/7422072/javascript-how-to-detect-number-as-a-decimal-including-1-0>\nconst isOnePointZero = function (n: unknown) {\n  return typeof n === 'string' && n.includes('.') && Number.parseFloat(n) === 1\n}\n\nconst isPercentage = function (n: unknown) {\n  return typeof n === 'string' && n.includes('%')\n}\n\n// Take input from [0, n] and return it as [0, 1]\nconst bound01 = function (value: number | string, max: number | string) {\n  if (isOnePointZero(value)) value = '100%'\n\n  const processPercent = isPercentage(value)\n  value = Math.min(max as number, Math.max(0, Number.parseFloat(`${value}`)))\n\n  // Automatically convert percentage into number\n  if (processPercent) {\n    value = Number.parseInt(`${value * (max as number)}`, 10) / 100\n  }\n\n  // Handle floating point rounding errors\n  if (Math.abs(value - (max as number)) < 0.000001) {\n    return 1\n  }\n\n  // Convert into [0, 1] range if it isn't already\n  return (value % (max as number)) / Number.parseFloat(max as string)\n}\n\nconst INT_HEX_MAP: Record<string, string> = {\n  10: 'A',\n  11: 'B',\n  12: 'C',\n  13: 'D',\n  14: 'E',\n  15: 'F',\n}\n\nconst hexOne = (value: number) => {\n  value = Math.min(Math.round(value), 255)\n  const high = Math.floor(value / 16)\n  const low = value % 16\n  return `${INT_HEX_MAP[high] || high}${INT_HEX_MAP[low] || low}`\n}\n\nconst toHex = function ({ r, g, b }: { r: number; g: number; b: number }) {\n  if (Number.isNaN(+r) || Number.isNaN(+g) || Number.isNaN(+b)) return ''\n  return `#${hexOne(r)}${hexOne(g)}${hexOne(b)}`\n}\n\nconst HEX_INT_MAP: Record<string, number> = {\n  A: 10,\n  B: 11,\n  C: 12,\n  D: 13,\n  E: 14,\n  F: 15,\n}\n\nconst parseHexChannel = function (hex: string) {\n  if (hex.length === 2) {\n    return (\n      (HEX_INT_MAP[hex[0].toUpperCase()] || +hex[0]) * 16 +\n      (HEX_INT_MAP[hex[1].toUpperCase()] || +hex[1])\n    )\n  }\n\n  return HEX_INT_MAP[hex[1].toUpperCase()] || +hex[1]\n}\n\nconst hsl2hsv = function (hue: number, sat: number, light: number) {\n  sat = sat / 100\n  light = light / 100\n  let smin = sat\n  const lmin = Math.max(light, 0.01)\n  // let sv\n  // let v\n\n  light *= 2\n  sat *= light <= 1 ? light : 2 - light\n  smin *= lmin <= 1 ? lmin : 2 - lmin\n  const v = (light + sat) / 2\n  const sv =\n    light === 0 ? (2 * smin) / (lmin + smin) : (2 * sat) / (light + sat)\n\n  return {\n    h: hue,\n    s: sv * 100,\n    v: v * 100,\n  }\n}\n\n// `rgbToHsv`\n// Converts an RGB color value to HSV\n// *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1]\n// *Returns:* { h, s, v } in [0,1]\nconst rgb2hsv = (r: number, g: number, b: number) => {\n  r = bound01(r, 255)\n  g = bound01(g, 255)\n  b = bound01(b, 255)\n\n  const max = Math.max(r, g, b)\n  const min = Math.min(r, g, b)\n  let h: number\n  const v = max\n\n  const d = max - min\n  const s = max === 0 ? 0 : d / max\n\n  if (max === min) {\n    h = 0 // achromatic\n  } else {\n    switch (max) {\n      case r: {\n        h = (g - b) / d + (g < b ? 6 : 0)\n        break\n      }\n      case g: {\n        h = (b - r) / d + 2\n        break\n      }\n      case b: {\n        h = (r - g) / d + 4\n        break\n      }\n    }\n    h! /= 6\n  }\n\n  return { h: h! * 360, s: s * 100, v: v * 100 }\n}\n\n// `hsvToRgb`\n// Converts an HSV color value to RGB.\n// *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100]\n// *Returns:* { r, g, b } in the set [0, 255]\nconst hsv2rgb = function (h: number, s: number, v: number) {\n  h = bound01(h, 360) * 6\n  s = bound01(s, 100)\n  v = bound01(v, 100)\n\n  const i = Math.floor(h)\n  const f = h - i\n  const p = v * (1 - s)\n  const q = v * (1 - f * s)\n  const t = v * (1 - (1 - f) * s)\n  const mod = i % 6\n  const r = [v, q, p, p, t, v][mod]\n  const g = [t, v, v, q, p, p][mod]\n  const b = [p, p, t, v, v, q][mod]\n\n  return {\n    r: Math.round(r * 255),\n    g: Math.round(g * 255),\n    b: Math.round(b * 255),\n  }\n}\n\ninterface ColorOptions {\n  enableAlpha: boolean\n  format: string\n  value?: string\n}\n\nexport default class Color {\n  private _hue = 0\n  private _saturation = 100\n  private _value = 100\n  _alpha = 100\n  public enableAlpha = false\n  public format = 'hex'\n  public value = ''\n  public selected?: boolean\n\n  constructor(options: Partial<ColorOptions> = {}) {\n    for (const option in options) {\n      if (hasOwn(options, option)) {\n        this[option] = options[option]\n      }\n    }\n    if (options.value) {\n      this.fromString(options.value)\n    } else {\n      this.doOnChange()\n    }\n  }\n\n  set(prop: { [key: string]: any } | any, value?: number) {\n    if (arguments.length === 1 && typeof prop === 'object') {\n      for (const p in prop) {\n        if (hasOwn(prop, p)) {\n          this.set(p, prop[p])\n        }\n      }\n\n      return\n    }\n\n    ;(this as any)[`_${prop}`] = value\n    this.doOnChange()\n  }\n\n  get(prop: string) {\n    if (prop === 'alpha') {\n      return Math.floor(this[`_${prop}`])\n    }\n    return (this as any)[`_${prop}`]\n  }\n\n  toRgb() {\n    return hsv2rgb(this._hue, this._saturation, this._value)\n  }\n\n  fromString(value: string) {\n    if (!value) {\n      this._hue = 0\n      this._saturation = 100\n      this._value = 100\n\n      this.doOnChange()\n      return\n    }\n\n    const fromHSV = (h: number, s: number, v: number) => {\n      this._hue = Math.max(0, Math.min(360, h))\n      this._saturation = Math.max(0, Math.min(100, s))\n      this._value = Math.max(0, Math.min(100, v))\n\n      this.doOnChange()\n    }\n\n    if (value.includes('hsl')) {\n      const parts = value\n        .replace(/hsla|hsl|\\(|\\)/gm, '')\n        .split(/\\s|,/g)\n        .filter((val) => val !== '')\n        .map((val, index) =>\n          index > 2 ? Number.parseFloat(val) : Number.parseInt(val, 10)\n        )\n\n      if (parts.length === 4) {\n        // @ts-expect-error\n        this._alpha = Number.parseFloat(parts[3]) * 100\n      } else if (parts.length === 3) {\n        this._alpha = 100\n      }\n      if (parts.length >= 3) {\n        const { h, s, v } = hsl2hsv(parts[0], parts[1], parts[2])\n        fromHSV(h, s, v)\n      }\n    } else if (value.includes('hsv')) {\n      const parts = value\n        .replace(/hsva|hsv|\\(|\\)/gm, '')\n        .split(/\\s|,/g)\n        .filter((val) => val !== '')\n        .map((val, index) =>\n          index > 2 ? Number.parseFloat(val) : Number.parseInt(val, 10)\n        )\n\n      if (parts.length === 4) {\n        // @ts-expect-error\n        this._alpha = Number.parseFloat(parts[3]) * 100\n      } else if (parts.length === 3) {\n        this._alpha = 100\n      }\n      if (parts.length >= 3) {\n        fromHSV(parts[0], parts[1], parts[2])\n      }\n    } else if (value.includes('rgb')) {\n      const parts = value\n        .replace(/rgba|rgb|\\(|\\)/gm, '')\n        .split(/\\s|,/g)\n        .filter((val) => val !== '')\n        .map((val, index) =>\n          index > 2 ? Number.parseFloat(val) : Number.parseInt(val, 10)\n        )\n\n      if (parts.length === 4) {\n        // @ts-expect-error\n        this._alpha = Number.parseFloat(parts[3]) * 100\n      } else if (parts.length === 3) {\n        this._alpha = 100\n      }\n      if (parts.length >= 3) {\n        const { h, s, v } = rgb2hsv(parts[0], parts[1], parts[2])\n        fromHSV(h, s, v)\n      }\n    } else if (value.includes('#')) {\n      const hex = value.replace('#', '').trim()\n      if (!/^[0-9a-fA-F]{3}$|^[0-9a-fA-F]{6}$|^[0-9a-fA-F]{8}$/.test(hex))\n        return\n      let r: number, g: number, b: number\n\n      if (hex.length === 3) {\n        r = parseHexChannel(hex[0] + hex[0])\n        g = parseHexChannel(hex[1] + hex[1])\n        b = parseHexChannel(hex[2] + hex[2])\n      } else if (hex.length === 6 || hex.length === 8) {\n        r = parseHexChannel(hex.slice(0, 2))\n        g = parseHexChannel(hex.slice(2, 4))\n        b = parseHexChannel(hex.slice(4, 6))\n      }\n\n      if (hex.length === 8) {\n        this._alpha = (parseHexChannel(hex.slice(6)) / 255) * 100\n      } else if (hex.length === 3 || hex.length === 6) {\n        this._alpha = 100\n      }\n\n      const { h, s, v } = rgb2hsv(r!, g!, b!)\n      fromHSV(h, s, v)\n    }\n  }\n\n  compare(color: this) {\n    return (\n      Math.abs(color._hue - this._hue) < 2 &&\n      Math.abs(color._saturation - this._saturation) < 1 &&\n      Math.abs(color._value - this._value) < 1 &&\n      Math.abs(color._alpha - this._alpha) < 1\n    )\n  }\n\n  doOnChange() {\n    const { _hue, _saturation, _value, _alpha, format } = this\n\n    if (this.enableAlpha) {\n      switch (format) {\n        case 'hsl': {\n          const hsl = hsv2hsl(_hue, _saturation / 100, _value / 100)\n          this.value = `hsla(${_hue}, ${Math.round(\n            hsl[1] * 100\n          )}%, ${Math.round(hsl[2] * 100)}%, ${this.get('alpha') / 100})`\n          break\n        }\n        case 'hsv': {\n          this.value = `hsva(${_hue}, ${Math.round(_saturation)}%, ${Math.round(\n            _value\n          )}%, ${this.get('alpha') / 100})`\n          break\n        }\n        case 'hex': {\n          this.value = `${toHex(hsv2rgb(_hue, _saturation, _value))}${hexOne(\n            (_alpha * 255) / 100\n          )}`\n          break\n        }\n        default: {\n          const { r, g, b } = hsv2rgb(_hue, _saturation, _value)\n          this.value = `rgba(${r}, ${g}, ${b}, ${this.get('alpha') / 100})`\n        }\n      }\n    } else {\n      switch (format) {\n        case 'hsl': {\n          const hsl = hsv2hsl(_hue, _saturation / 100, _value / 100)\n          this.value = `hsl(${_hue}, ${Math.round(hsl[1] * 100)}%, ${Math.round(\n            hsl[2] * 100\n          )}%)`\n          break\n        }\n        case 'hsv': {\n          this.value = `hsv(${_hue}, ${Math.round(_saturation)}%, ${Math.round(\n            _value\n          )}%)`\n          break\n        }\n        case 'rgb': {\n          const { r, g, b } = hsv2rgb(_hue, _saturation, _value)\n          this.value = `rgb(${r}, ${g}, ${b})`\n          break\n        }\n        default: {\n          this.value = toHex(hsv2rgb(_hue, _saturation, _value))\n        }\n      }\n    }\n  }\n}\n", "<template>\n  <div :class=\"ns.b()\">\n    <div :class=\"ns.e('colors')\">\n      <div\n        v-for=\"(item, index) in rgbaColors\"\n        :key=\"colors[index]\"\n        :class=\"[\n          ns.e('color-selector'),\n          ns.is('alpha', item._alpha < 100),\n          { selected: item.selected },\n        ]\"\n        @click=\"handleSelect(index)\"\n      >\n        <div :style=\"{ backgroundColor: item.value }\" />\n      </div>\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, inject, ref, watch, watchEffect } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { colorPickerContextKey } from '../color-picker'\nimport Color from '../utils/color'\n\nimport type { PropType, Ref } from 'vue'\n\nexport default defineComponent({\n  props: {\n    colors: {\n      type: Array as PropType<string[]>,\n      required: true,\n    },\n    color: {\n      type: Object as PropType<Color>,\n      required: true,\n    },\n    enableAlpha: {\n      type: Boolean,\n      required: true,\n    },\n  },\n  setup(props) {\n    const ns = useNamespace('color-predefine')\n    const { currentColor } = inject(colorPickerContextKey)!\n\n    const rgbaColors = ref(parseColors(props.colors, props.color)) as Ref<\n      Color[]\n    >\n\n    watch(\n      () => currentColor.value,\n      (val) => {\n        const color = new Color()\n        color.fromString(val)\n\n        rgbaColors.value.forEach((item) => {\n          item.selected = color.compare(item)\n        })\n      }\n    )\n\n    watchEffect(() => {\n      rgbaColors.value = parseColors(props.colors, props.color)\n    })\n\n    function handleSelect(index: number) {\n      props.color.fromString(props.colors[index])\n    }\n\n    function parseColors(colors: string[], color: Color) {\n      return colors.map((value) => {\n        const c = new Color()\n        c.enableAlpha = props.enableAlpha\n        c.format = 'rgba'\n        c.fromString(value)\n        c.selected = c.value === color.value\n        return c\n      })\n    }\n    return {\n      rgbaColors,\n      handleSelect,\n      ns,\n    }\n  },\n})\n</script>\n", "<template>\n  <div\n    :class=\"ns.b()\"\n    :style=\"{\n      backgroundColor: background,\n    }\"\n  >\n    <div :class=\"ns.e('white')\" />\n    <div :class=\"ns.e('black')\" />\n    <div\n      :class=\"ns.e('cursor')\"\n      :style=\"{\n        top: cursorTop + 'px',\n        left: cursorLeft + 'px',\n      }\"\n    >\n      <div />\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport {\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  onMounted,\n  ref,\n  watch,\n} from 'vue'\nimport { getClientXY } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { draggable } from '../utils/draggable'\n\nimport type { PropType } from 'vue'\nimport type Color from '../utils/color'\n\nexport default defineComponent({\n  name: 'ElSlPanel',\n\n  props: {\n    color: {\n      type: Object as PropType<Color>,\n      required: true,\n    },\n  },\n\n  setup(props) {\n    const ns = useNamespace('color-svpanel')\n\n    // instance\n    const instance = getCurrentInstance()!\n\n    // data\n    const cursorTop = ref(0)\n    const cursorLeft = ref(0)\n    const background = ref('hsl(0, 100%, 50%)')\n    const colorValue = computed(() => {\n      const hue = props.color.get('hue')\n      const value = props.color.get('value')\n      return { hue, value }\n    })\n\n    // methods\n    function update() {\n      const saturation = props.color.get('saturation')\n      const value = props.color.get('value')\n\n      const el = instance.vnode.el!\n      const { clientWidth: width, clientHeight: height } = el\n\n      cursorLeft.value = (saturation * width) / 100\n      cursorTop.value = ((100 - value) * height) / 100\n\n      background.value = `hsl(${props.color.get('hue')}, 100%, 50%)`\n    }\n\n    function handleDrag(event: MouseEvent | TouchEvent) {\n      const el = instance.vnode.el!\n      const rect = el.getBoundingClientRect()\n      const { clientX, clientY } = getClientXY(event)\n\n      let left = clientX - rect.left\n      let top = clientY - rect.top\n      left = Math.max(0, left)\n      left = Math.min(left, rect.width)\n\n      top = Math.max(0, top)\n      top = Math.min(top, rect.height)\n\n      cursorLeft.value = left\n      cursorTop.value = top\n      props.color.set({\n        saturation: (left / rect.width) * 100,\n        value: 100 - (top / rect.height) * 100,\n      })\n    }\n\n    // watch\n    watch(\n      () => colorValue.value,\n      () => {\n        update()\n      }\n    )\n    // mounted\n    onMounted(() => {\n      draggable(instance.vnode.el as HTMLElement, {\n        drag: (event) => {\n          handleDrag(event)\n        },\n        end: (event) => {\n          handleDrag(event)\n        },\n      })\n\n      update()\n    })\n    return {\n      cursorTop,\n      cursorLeft,\n      background,\n      colorValue,\n      handleDrag,\n      update,\n      ns,\n    }\n  },\n})\n</script>\n", "<template>\n  <el-tooltip\n    ref=\"popper\"\n    :visible=\"showPicker\"\n    :show-arrow=\"false\"\n    :fallback-placements=\"['bottom', 'top', 'right', 'left']\"\n    :offset=\"0\"\n    :gpu-acceleration=\"false\"\n    :popper-class=\"[ns.be('picker', 'panel'), ns.b('dropdown'), popperClass]\"\n    :stop-popper-mouse-event=\"false\"\n    effect=\"light\"\n    trigger=\"click\"\n    :teleported=\"teleported\"\n    :transition=\"`${ns.namespace.value}-zoom-in-top`\"\n    persistent\n    @hide=\"setShowPicker(false)\"\n  >\n    <template #content>\n      <div v-click-outside=\"handleClickOutside\" @keydown.esc=\"handleEsc\">\n        <div :class=\"ns.be('dropdown', 'main-wrapper')\">\n          <hue-slider ref=\"hue\" class=\"hue-slider\" :color=\"color\" vertical />\n          <sv-panel ref=\"sv\" :color=\"color\" />\n        </div>\n        <alpha-slider v-if=\"showAlpha\" ref=\"alpha\" :color=\"color\" />\n        <predefine\n          v-if=\"predefine\"\n          ref=\"predefine\"\n          :enable-alpha=\"showAlpha\"\n          :color=\"color\"\n          :colors=\"predefine\"\n        />\n        <div :class=\"ns.be('dropdown', 'btns')\">\n          <span :class=\"ns.be('dropdown', 'value')\">\n            <el-input\n              ref=\"inputRef\"\n              v-model=\"customInput\"\n              :validate-event=\"false\"\n              size=\"small\"\n              @keyup.enter=\"handleConfirm\"\n              @blur=\"handleConfirm\"\n            />\n          </span>\n          <el-button\n            :class=\"ns.be('dropdown', 'link-btn')\"\n            text\n            size=\"small\"\n            @click=\"clear\"\n          >\n            {{ t('el.colorpicker.clear') }}\n          </el-button>\n          <el-button\n            plain\n            size=\"small\"\n            :class=\"ns.be('dropdown', 'btn')\"\n            @click=\"confirmValue\"\n          >\n            {{ t('el.colorpicker.confirm') }}\n          </el-button>\n        </div>\n      </div>\n    </template>\n    <template #default>\n      <div\n        :id=\"buttonId\"\n        ref=\"triggerRef\"\n        v-bind=\"$attrs\"\n        :class=\"btnKls\"\n        role=\"button\"\n        :aria-label=\"buttonAriaLabel\"\n        :aria-labelledby=\"buttonAriaLabelledby\"\n        :aria-description=\"\n          t('el.colorpicker.description', { color: modelValue || '' })\n        \"\n        :aria-disabled=\"colorDisabled\"\n        :tabindex=\"colorDisabled ? -1 : tabindex\"\n        @keydown=\"handleKeyDown\"\n        @focus=\"handleFocus\"\n        @blur=\"handleBlur\"\n      >\n        <div v-if=\"colorDisabled\" :class=\"ns.be('picker', 'mask')\" />\n        <div :class=\"ns.be('picker', 'trigger')\" @click=\"handleTrigger\">\n          <span :class=\"[ns.be('picker', 'color'), ns.is('alpha', showAlpha)]\">\n            <span\n              :class=\"ns.be('picker', 'color-inner')\"\n              :style=\"{\n                backgroundColor: displayedColor,\n              }\"\n            >\n              <el-icon\n                v-show=\"modelValue || showPanelColor\"\n                :class=\"[ns.be('picker', 'icon'), ns.is('icon-arrow-down')]\"\n              >\n                <arrow-down />\n              </el-icon>\n              <el-icon\n                v-show=\"!modelValue && !showPanelColor\"\n                :class=\"[ns.be('picker', 'empty'), ns.is('icon-close')]\"\n              >\n                <close />\n              </el-icon>\n            </span>\n          </span>\n        </div>\n      </div>\n    </template>\n  </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  nextTick,\n  onMounted,\n  provide,\n  reactive,\n  ref,\n  watch,\n} from 'vue'\nimport { debounce } from 'lodash-unified'\nimport { ElButton } from '@element-plus/components/button'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { ClickOutside as vClickOutside } from '@element-plus/directives'\nimport { ElTooltip } from '@element-plus/components/tooltip'\nimport { ElInput } from '@element-plus/components/input'\nimport {\n  useFormDisabled,\n  useFormItem,\n  useFormItemInputId,\n  useFormSize,\n} from '@element-plus/components/form'\nimport {\n  useFocusController,\n  useLocale,\n  useNamespace,\n} from '@element-plus/hooks'\nimport { EVENT_CODE, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { debugWarn } from '@element-plus/utils'\nimport { ArrowDown, Close } from '@element-plus/icons-vue'\nimport AlphaSlider from './components/alpha-slider.vue'\nimport HueSlider from './components/hue-slider.vue'\nimport Predefine from './components/predefine.vue'\nimport SvPanel from './components/sv-panel.vue'\nimport Color from './utils/color'\nimport {\n  colorPickerContextKey,\n  colorPickerEmits,\n  colorPickerProps,\n} from './color-picker'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\n\ndefineOptions({\n  name: 'ElColorPicker',\n})\nconst props = defineProps(colorPickerProps)\nconst emit = defineEmits(colorPickerEmits)\n\nconst { t } = useLocale()\nconst ns = useNamespace('color')\nconst { formItem } = useFormItem()\nconst colorSize = useFormSize()\nconst colorDisabled = useFormDisabled()\n\nconst { inputId: buttonId, isLabeledByFormItem } = useFormItemInputId(props, {\n  formItemContext: formItem,\n})\n\nconst hue = ref<InstanceType<typeof HueSlider>>()\nconst sv = ref<InstanceType<typeof SvPanel>>()\nconst alpha = ref<InstanceType<typeof AlphaSlider>>()\nconst popper = ref<TooltipInstance>()\nconst triggerRef = ref()\nconst inputRef = ref()\n\nconst { isFocused, handleFocus, handleBlur } = useFocusController(triggerRef, {\n  beforeFocus() {\n    return colorDisabled.value\n  },\n  beforeBlur(event) {\n    return popper.value?.isFocusInsideContent(event)\n  },\n  afterBlur() {\n    setShowPicker(false)\n    resetColor()\n  },\n})\n\n// active-change is used to prevent modelValue changes from triggering.\nlet shouldActiveChange = true\n\nconst color = reactive(\n  new Color({\n    enableAlpha: props.showAlpha,\n    format: props.colorFormat || '',\n    value: props.modelValue,\n  })\n) as Color\n\nconst showPicker = ref(false)\nconst showPanelColor = ref(false)\nconst customInput = ref('')\n\nconst displayedColor = computed(() => {\n  if (!props.modelValue && !showPanelColor.value) {\n    return 'transparent'\n  }\n  return displayedRgb(color, props.showAlpha)\n})\n\nconst currentColor = computed(() => {\n  return !props.modelValue && !showPanelColor.value ? '' : color.value\n})\n\nconst buttonAriaLabel = computed<string | undefined>(() => {\n  return !isLabeledByFormItem.value\n    ? props.ariaLabel || t('el.colorpicker.defaultLabel')\n    : undefined\n})\n\nconst buttonAriaLabelledby = computed<string | undefined>(() => {\n  return isLabeledByFormItem.value ? formItem?.labelId : undefined\n})\n\nconst btnKls = computed(() => {\n  return [\n    ns.b('picker'),\n    ns.is('disabled', colorDisabled.value),\n    ns.bm('picker', colorSize.value),\n    ns.is('focused', isFocused.value),\n  ]\n})\n\nfunction displayedRgb(color: Color, showAlpha: boolean) {\n  if (!(color instanceof Color)) {\n    throw new TypeError('color should be instance of _color Class')\n  }\n\n  const { r, g, b } = color.toRgb()\n  return showAlpha\n    ? `rgba(${r}, ${g}, ${b}, ${color.get('alpha') / 100})`\n    : `rgb(${r}, ${g}, ${b})`\n}\n\nfunction setShowPicker(value: boolean) {\n  showPicker.value = value\n}\n\nconst debounceSetShowPicker = debounce(setShowPicker, 100, { leading: true })\n\nfunction show() {\n  if (colorDisabled.value) return\n  setShowPicker(true)\n}\n\nfunction hide() {\n  debounceSetShowPicker(false)\n  resetColor()\n}\n\nfunction resetColor() {\n  nextTick(() => {\n    if (props.modelValue) {\n      color.fromString(props.modelValue)\n    } else {\n      color.value = ''\n      nextTick(() => {\n        showPanelColor.value = false\n      })\n    }\n  })\n}\n\nfunction handleTrigger() {\n  if (colorDisabled.value) return\n  debounceSetShowPicker(!showPicker.value)\n}\n\nfunction handleConfirm() {\n  color.fromString(customInput.value)\n}\n\nfunction confirmValue() {\n  const value = color.value\n  emit(UPDATE_MODEL_EVENT, value)\n  emit('change', value)\n  if (props.validateEvent) {\n    formItem?.validate('change').catch((err) => debugWarn(err))\n  }\n  debounceSetShowPicker(false)\n  // check if modelValue change, if not change, then reset color.\n  nextTick(() => {\n    const newColor = new Color({\n      enableAlpha: props.showAlpha,\n      format: props.colorFormat || '',\n      value: props.modelValue,\n    })\n    if (!color.compare(newColor)) {\n      resetColor()\n    }\n  })\n}\n\nfunction clear() {\n  debounceSetShowPicker(false)\n  emit(UPDATE_MODEL_EVENT, null)\n  emit('change', null)\n  if (props.modelValue !== null && props.validateEvent) {\n    formItem?.validate('change').catch((err) => debugWarn(err))\n  }\n  resetColor()\n}\n\nfunction handleClickOutside() {\n  if (!showPicker.value) return\n  hide()\n  isFocused.value && focus()\n}\n\nfunction handleEsc(event: KeyboardEvent) {\n  event.preventDefault()\n  event.stopPropagation()\n  setShowPicker(false)\n  resetColor()\n}\n\nfunction handleKeyDown(event: KeyboardEvent) {\n  switch (event.code) {\n    case EVENT_CODE.enter:\n    case EVENT_CODE.space:\n      event.preventDefault()\n      event.stopPropagation()\n      show()\n      inputRef.value.focus()\n      break\n    case EVENT_CODE.esc:\n      handleEsc(event)\n      break\n  }\n}\n\nfunction focus() {\n  triggerRef.value.focus()\n}\n\nfunction blur() {\n  triggerRef.value.blur()\n}\n\nonMounted(() => {\n  if (props.modelValue) {\n    customInput.value = currentColor.value\n  }\n})\n\nwatch(\n  () => props.modelValue,\n  (newVal) => {\n    if (!newVal) {\n      showPanelColor.value = false\n    } else if (newVal && newVal !== color.value) {\n      shouldActiveChange = false\n      color.fromString(newVal)\n    }\n  }\n)\n\nwatch(\n  () => [props.colorFormat, props.showAlpha],\n  () => {\n    color.enableAlpha = props.showAlpha\n    color.format = props.colorFormat || color.format\n    color.doOnChange()\n    emit(UPDATE_MODEL_EVENT, color.value)\n  }\n)\n\nwatch(\n  () => currentColor.value,\n  (val) => {\n    customInput.value = val\n    shouldActiveChange && emit('activeChange', val)\n    shouldActiveChange = true\n  }\n)\n\nwatch(\n  () => color.value,\n  () => {\n    if (!props.modelValue && !showPanelColor.value) {\n      showPanelColor.value = true\n    }\n  }\n)\n\nwatch(\n  () => showPicker.value,\n  () => {\n    nextTick(() => {\n      hue.value?.update()\n      sv.value?.update()\n      alpha.value?.update()\n    })\n  }\n)\n\nprovide(colorPickerContextKey, {\n  currentColor,\n})\n\ndefineExpose({\n  /**\n   * @description current color object\n   */\n  color,\n  /**\n   * @description manually show ColorPicker\n   */\n  show,\n  /**\n   * @description manually hide ColorPicker\n   */\n  hide,\n  /**\n   * @description focus the input element\n   */\n  focus,\n  /**\n   * @description blur the input element\n   */\n  blur,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport ColorPicker from './src/color-picker.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElColorPicker: SFCWithInstall<typeof ColorPicker> =\n  withInstall(ColorPicker)\nexport default ElColorPicker\n\nexport * from './src/color-picker'\n", "<template>\n  <section :class=\"[ns.b(), ns.is('vertical', isVertical)]\">\n    <slot />\n  </section>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, useSlots } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\n\nimport type { Component, VNode } from 'vue'\n\ndefineOptions({\n  name: 'ElContainer',\n})\nconst props = defineProps({\n  /**\n   * @description layout direction for child elements\n   */\n  direction: {\n    type: String,\n  },\n})\nconst slots = useSlots()\n\nconst ns = useNamespace('container')\n\nconst isVertical = computed(() => {\n  if (props.direction === 'vertical') {\n    return true\n  } else if (props.direction === 'horizontal') {\n    return false\n  }\n  if (slots && slots.default) {\n    const vNodes: VNode[] = slots.default()\n    return vNodes.some((vNode) => {\n      const tag = (vNode.type as Component).name\n      return tag === 'ElHeader' || tag === 'ElFooter'\n    })\n  } else {\n    return false\n  }\n})\n</script>\n", "<template>\n  <aside :class=\"ns.b()\" :style=\"style\">\n    <slot />\n  </aside>\n</template>\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\n\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElAside',\n})\nconst props = defineProps({\n  /**\n   * @description width of the side section\n   */\n  width: {\n    type: String,\n    default: null,\n  },\n})\n\nconst ns = useNamespace('aside')\nconst style = computed(\n  () =>\n    (props.width ? ns.cssVarBlock({ width: props.width }) : {}) as CSSProperties\n)\n</script>\n", "<template>\n  <footer :class=\"ns.b()\" :style=\"style\">\n    <slot />\n  </footer>\n</template>\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\n\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElFooter',\n})\nconst props = defineProps({\n  /**\n   * @description height of the footer\n   */\n  height: {\n    type: String,\n    default: null,\n  },\n})\n\nconst ns = useNamespace('footer')\n\nconst style = computed(\n  () =>\n    (props.height\n      ? ns.cssVarBlock({ height: props.height })\n      : {}) as CSSProperties\n)\n</script>\n", "<template>\n  <header :class=\"ns.b()\" :style=\"style\">\n    <slot />\n  </header>\n</template>\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\n\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElHeader',\n})\n\nconst props = defineProps({\n  /**\n   * @description height of the header\n   */\n  height: {\n    type: String,\n    default: null,\n  },\n})\n\nconst ns = useNamespace('header')\nconst style = computed(() => {\n  return props.height\n    ? (ns.cssVarBlock({\n        height: props.height,\n      }) as CSSProperties)\n    : {}\n})\n</script>\n", "<template>\n  <main :class=\"ns.b()\">\n    <slot />\n  </main>\n</template>\n<script lang=\"ts\" setup>\nimport { useNamespace } from '@element-plus/hooks'\n\ndefineOptions({\n  name: 'ElMain',\n})\n\nconst ns = useNamespace('main')\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\n\nimport Container from './src/container.vue'\nimport Aside from './src/aside.vue'\nimport Footer from './src/footer.vue'\nimport Header from './src/header.vue'\nimport Main from './src/main.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElContainer: SFCWithInstall<typeof Container> & {\n  Aside: typeof Aside\n  Footer: typeof Footer\n  Header: typeof Header\n  Main: typeof Main\n} = withInstall(Container, {\n  Aside,\n  Footer,\n  Header,\n  Main,\n})\n\nexport default ElContainer\nexport const ElAside: SFCWithInstall<typeof Aside> = withNoopInstall(Aside)\nexport const ElFooter: SFCWithInstall<typeof Footer> = withNoopInstall(Footer)\nexport const ElHeader: SFCWithInstall<typeof Header> = withNoopInstall(Header)\nexport const ElMain: SFCWithInstall<typeof Main> = withNoopInstall(Main)\n\nexport type ContainerInstance = InstanceType<typeof Container>\nexport type AsideInstance = InstanceType<typeof Aside>\nexport type FooterInstance = InstanceType<typeof Footer>\nexport type HeaderInstance = InstanceType<typeof Header>\nexport type MainInstance = InstanceType<typeof Main>\n", "import type { InjectionKey, SetupContext } from 'vue'\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\n\ninterface DatePickerContext {\n  slots: SetupContext['slots']\n  pickerNs: UseNamespaceReturn\n}\n\nexport const ROOT_PICKER_INJECTION_KEY: InjectionKey<DatePickerContext> =\n  Symbol()\n", "import { timePickerDefaultProps } from '@element-plus/components/time-picker'\nimport { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { IDatePickerType } from '../date-picker.type'\n\nexport const datePickerProps = buildProps({\n  ...timePickerDefaultProps,\n  /**\n   * @description type of the picker\n   */\n  type: {\n    type: definePropType<IDatePickerType>(String),\n    default: 'date',\n  },\n} as const)\n\nexport type DatePickerProps = ExtractPropTypes<typeof datePickerProps>\n", "import { buildProps, definePropType, isArray } from '@element-plus/utils'\nimport { datePickTypes } from '@element-plus/constants'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type { DatePickType } from '@element-plus/constants'\n\nconst selectionModes = [\n  'date',\n  'dates',\n  'year',\n  'years',\n  'month',\n  'months',\n  'week',\n  'range',\n]\n\nexport type RangeState = {\n  endDate: null | Dayjs\n  selecting: boolean\n}\n\nexport type DisabledDateType = (date: Date) => boolean\n\nexport const datePickerSharedProps = buildProps({\n  disabledDate: {\n    type: definePropType<DisabledDateType>(Function),\n  },\n  date: {\n    type: definePropType<Dayjs>(Object),\n    required: true,\n  },\n  minDate: {\n    type: definePropType<Dayjs | null>(Object),\n  },\n  maxDate: {\n    type: definePropType<Dayjs | null>(Object),\n  },\n  parsedValue: {\n    type: definePropType<Dayjs | Dayjs[]>([Object, Array]),\n  },\n  rangeState: {\n    type: definePropType<RangeState>(Object),\n    default: () => ({\n      endDate: null,\n      selecting: false,\n    }),\n  },\n} as const)\n\nexport const panelSharedProps = buildProps({\n  type: {\n    type: definePropType<DatePickType>(String),\n    required: true,\n    values: datePickTypes,\n  },\n  dateFormat: String,\n  timeFormat: String,\n} as const)\n\nexport const panelRangeSharedProps = buildProps({\n  unlinkPanels: Boolean,\n  parsedValue: {\n    type: definePropType<Dayjs[]>(Array),\n  },\n} as const)\n\nexport const selectionModeWithDefault = (\n  mode: typeof selectionModes[number]\n) => {\n  return {\n    type: String,\n    values: selectionModes,\n    default: mode,\n  }\n}\n\nexport const rangePickerSharedEmits = {\n  pick: (range: [Dayjs, Dayjs]) => isArray(range),\n}\n\nexport type RangePickerSharedEmits = typeof rangePickerSharedEmits\nexport type PanelRangeSharedProps = ExtractPropTypes<\n  typeof panelRangeSharedProps\n>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { panelSharedProps } from './shared'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport const panelDatePickProps = buildProps({\n  ...panelSharedProps,\n  parsedValue: {\n    type: definePropType<Dayjs | Dayjs[]>([Object, Array]),\n  },\n  visible: {\n    type: Boolean,\n  },\n  format: {\n    type: String,\n    default: '',\n  },\n} as const)\n\nexport type PanelDatePickProps = ExtractPropTypes<typeof panelDatePickProps>\n", "import dayjs from 'dayjs'\nimport { isArray } from '@element-plus/utils'\nimport { rangeArr } from '@element-plus/components/time-picker'\n\nimport type { Dayjs } from 'dayjs'\nimport type { DateCell } from './date-picker.type'\nimport type { DisabledDateType } from './props/shared'\n\ntype DayRange = [Dayjs | undefined, Dayjs | undefined]\n\nexport const isValidRange = (range: DayRange): boolean => {\n  if (!isArray(range)) return false\n\n  const [left, right] = range\n\n  return (\n    dayjs.isDayjs(left) && dayjs.isDayjs(right) && left.isSameOrBefore(right)\n  )\n}\n\ntype GetDefaultValueParams = {\n  lang: string\n  unit: 'month' | 'year'\n  unlinkPanels: boolean\n}\n\nexport type DefaultValue = [Date, Date] | Date | undefined\n\nexport const getDefaultValue = (\n  defaultValue: DefaultValue,\n  { lang, unit, unlinkPanels }: GetDefaultValueParams\n) => {\n  let start: Dayjs\n\n  if (isArray(defaultValue)) {\n    let [left, right] = defaultValue.map((d) => dayjs(d).locale(lang))\n    if (!unlinkPanels) {\n      right = left.add(1, unit)\n    }\n    return [left, right]\n  } else if (defaultValue) {\n    start = dayjs(defaultValue)\n  } else {\n    start = dayjs()\n  }\n  start = start.locale(lang)\n  return [start, start.add(1, unit)]\n}\n\ntype Dimension = {\n  row: number\n  column: number\n}\n\ntype BuildPickerTableMetadata = {\n  startDate?: Dayjs | null\n  unit: 'month' | 'day'\n  columnIndexOffset: number\n  now: Dayjs\n  nextEndDate: Dayjs | null\n  relativeDateGetter: (index: number) => Dayjs\n  setCellMetadata?: (\n    cell: DateCell,\n    dimension: { rowIndex: number; columnIndex: number }\n  ) => void\n  setRowMetadata?: (row: DateCell[]) => void\n}\n\nexport const buildPickerTable = (\n  dimension: Dimension,\n  rows: DateCell[][],\n  {\n    columnIndexOffset,\n    startDate,\n    nextEndDate,\n    now,\n    unit,\n    relativeDateGetter,\n    setCellMetadata,\n    setRowMetadata,\n  }: BuildPickerTableMetadata\n) => {\n  for (let rowIndex = 0; rowIndex < dimension.row; rowIndex++) {\n    const row = rows[rowIndex]\n    for (let columnIndex = 0; columnIndex < dimension.column; columnIndex++) {\n      let cell = row[columnIndex + columnIndexOffset]\n      if (!cell) {\n        cell = {\n          row: rowIndex,\n          column: columnIndex,\n          type: 'normal',\n          inRange: false,\n          start: false,\n          end: false,\n        }\n      }\n      const index = rowIndex * dimension.column + columnIndex\n      const nextStartDate = relativeDateGetter(index)\n      cell.dayjs = nextStartDate\n      cell.date = nextStartDate.toDate()\n      cell.timestamp = nextStartDate.valueOf()\n      cell.type = 'normal'\n\n      cell.inRange =\n        !!(\n          startDate &&\n          nextStartDate.isSameOrAfter(startDate, unit) &&\n          nextEndDate &&\n          nextStartDate.isSameOrBefore(nextEndDate, unit)\n        ) ||\n        !!(\n          startDate &&\n          nextStartDate.isSameOrBefore(startDate, unit) &&\n          nextEndDate &&\n          nextStartDate.isSameOrAfter(nextEndDate, unit)\n        )\n\n      if (startDate?.isSameOrAfter(nextEndDate)) {\n        cell.start = !!nextEndDate && nextStartDate.isSame(nextEndDate, unit)\n        cell.end = startDate && nextStartDate.isSame(startDate, unit)\n      } else {\n        cell.start = !!startDate && nextStartDate.isSame(startDate, unit)\n        cell.end = !!nextEndDate && nextStartDate.isSame(nextEndDate, unit)\n      }\n\n      const isToday = nextStartDate.isSame(now, unit)\n\n      if (isToday) {\n        cell.type = 'today'\n      }\n      setCellMetadata?.(cell, { rowIndex, columnIndex })\n      row[columnIndex + columnIndexOffset] = cell\n    }\n    setRowMetadata?.(row)\n  }\n}\n\nexport const datesInMonth = (year: number, month: number, lang: string) => {\n  const firstDay = dayjs().locale(lang).startOf('month').month(month).year(year)\n  const numOfDays = firstDay.daysInMonth()\n  return rangeArr(numOfDays).map((n) => firstDay.add(n, 'day').toDate())\n}\n\nexport const getValidDateOfMonth = (\n  year: number,\n  month: number,\n  lang: string,\n  disabledDate?: DisabledDateType\n) => {\n  const _value = dayjs().year(year).month(month).startOf('month')\n  const _date = datesInMonth(year, month, lang).find((date) => {\n    return !disabledDate?.(date)\n  })\n  if (_date) {\n    return dayjs(_date).locale(lang)\n  }\n  return _value.locale(lang)\n}\n\nexport const getValidDateOfYear = (\n  value: Dayjs,\n  lang: string,\n  disabledDate?: DisabledDateType\n) => {\n  const year = value.year()\n  if (!disabledDate?.(value.toDate())) {\n    return value.locale(lang)\n  }\n  const month = value.month()\n  if (!datesInMonth(year, month, lang).every(disabledDate)) {\n    return getValidDateOfMonth(year, month, lang, disabledDate)\n  }\n  for (let i = 0; i < 12; i++) {\n    if (!datesInMonth(year, i, lang).every(disabledDate)) {\n      return getValidDateOfMonth(year, i, lang, disabledDate)\n    }\n  }\n  return value\n}\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { datePickerSharedProps, selectionModeWithDefault } from './shared'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport const basicDateTableProps = buildProps({\n  ...datePickerSharedProps,\n  cellClassName: {\n    type: definePropType<(date: Date) => string>(Function),\n  },\n  showWeekNumber: Boolean,\n  selectionMode: selectionModeWithDefault('date'),\n} as const)\n\nexport const basicDateTableEmits = ['changerange', 'pick', 'select']\n\nexport type BasicDateTableProps = ExtractPropTypes<typeof basicDateTableProps>\nexport type BasicDateTableEmits = typeof basicDateTableEmits\n\nexport type RangePickerEmits = { minDate: Dayjs; maxDate: null }\nexport type DatePickerEmits = Dayjs\nexport type DatesPickerEmits = Dayjs[]\nexport type MonthsPickerEmits = Dayjs[]\nexport type YearsPickerEmits = Dayjs[]\nexport type WeekPickerEmits = {\n  year: number\n  week: number\n  value: string\n  date: Dayjs\n}\n\nexport type DateTableEmits =\n  | RangePickerEmits\n  | DatePickerEmits\n  | DatesPickerEmits\n  | WeekPickerEmits\n", "import { computed, nextTick, ref, unref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport { flatten } from 'lodash-unified'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { castArray } from '@element-plus/utils'\nimport { buildPickerTable } from '../utils'\n\nimport type { SetupContext } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type { DateCell } from '../date-picker.type'\nimport type {\n  BasicDateTableEmits,\n  BasicDateTableProps,\n} from '../props/basic-date-table'\n\nconst isNormalDay = (type = '') => {\n  return ['normal', 'today'].includes(type)\n}\n\nexport const useBasicDateTable = (\n  props: BasicDateTableProps,\n  emit: SetupContext<BasicDateTableEmits>['emit']\n) => {\n  const { lang } = useLocale()\n  const tbodyRef = ref<HTMLElement>()\n  const currentCellRef = ref<HTMLElement>()\n  // data\n  const lastRow = ref<number>()\n  const lastColumn = ref<number>()\n  const tableRows = ref<DateCell[][]>([[], [], [], [], [], []])\n\n  let focusWithClick = false\n\n  // todo better way to get Day.js locale object\n  const firstDayOfWeek = (props.date as any).$locale().weekStart || 7\n  const WEEKS_CONSTANT = props.date\n    .locale('en')\n    .localeData()\n    .weekdaysShort()\n    .map((_) => _.toLowerCase())\n\n  const offsetDay = computed(() => {\n    // Sunday 7(0), cal the left and right offset days, 3217654, such as Monday is -1, the is to adjust the position of the first two rows of dates\n    return firstDayOfWeek > 3 ? 7 - firstDayOfWeek : -firstDayOfWeek\n  })\n\n  const startDate = computed(() => {\n    const startDayOfMonth = props.date.startOf('month')\n    return startDayOfMonth.subtract(startDayOfMonth.day() || 7, 'day')\n  })\n\n  const WEEKS = computed(() => {\n    return WEEKS_CONSTANT.concat(WEEKS_CONSTANT).slice(\n      firstDayOfWeek,\n      firstDayOfWeek + 7\n    )\n  })\n\n  const hasCurrent = computed<boolean>(() => {\n    return flatten(unref(rows)).some((row) => {\n      return row.isCurrent\n    })\n  })\n\n  const days = computed(() => {\n    const startOfMonth = props.date.startOf('month')\n    const startOfMonthDay = startOfMonth.day() || 7 // day of first day\n    const dateCountOfMonth = startOfMonth.daysInMonth()\n\n    const dateCountOfLastMonth = startOfMonth.subtract(1, 'month').daysInMonth()\n\n    return {\n      startOfMonthDay,\n      dateCountOfMonth,\n      dateCountOfLastMonth,\n    }\n  })\n\n  const selectedDate = computed(() => {\n    return props.selectionMode === 'dates'\n      ? (castArray(props.parsedValue) as Dayjs[])\n      : ([] as Dayjs[])\n  })\n\n  // Return value indicates should the counter be incremented\n  type CellCoordinate = { columnIndex: number; rowIndex: number }\n  type CellMeta = CellCoordinate & {\n    count: number\n  }\n  const setDateText = (\n    cell: DateCell,\n    { count, rowIndex, columnIndex }: CellMeta\n  ): boolean => {\n    const { startOfMonthDay, dateCountOfMonth, dateCountOfLastMonth } =\n      unref(days)\n    const offset = unref(offsetDay)\n    if (rowIndex >= 0 && rowIndex <= 1) {\n      const numberOfDaysFromPreviousMonth =\n        startOfMonthDay + offset < 0\n          ? 7 + startOfMonthDay + offset\n          : startOfMonthDay + offset\n\n      if (columnIndex + rowIndex * 7 >= numberOfDaysFromPreviousMonth) {\n        cell.text = count\n        return true\n      } else {\n        cell.text =\n          dateCountOfLastMonth -\n          (numberOfDaysFromPreviousMonth - (columnIndex % 7)) +\n          1 +\n          rowIndex * 7\n        cell.type = 'prev-month'\n      }\n    } else {\n      if (count <= dateCountOfMonth) {\n        cell.text = count\n      } else {\n        cell.text = count - dateCountOfMonth\n        cell.type = 'next-month'\n      }\n      return true\n    }\n    return false\n  }\n\n  const setCellMetadata = (\n    cell: DateCell,\n    { columnIndex, rowIndex }: CellCoordinate,\n    count: number\n  ) => {\n    const { disabledDate, cellClassName } = props\n    const _selectedDate = unref(selectedDate)\n    const shouldIncrement = setDateText(cell, { count, rowIndex, columnIndex })\n\n    const cellDate = cell.dayjs!.toDate()\n    cell.selected = _selectedDate.find((d) => d.isSame(cell.dayjs, 'day'))\n    cell.isSelected = !!cell.selected\n    cell.isCurrent = isCurrent(cell)\n    cell.disabled = disabledDate?.(cellDate)\n    cell.customClass = cellClassName?.(cellDate)\n    return shouldIncrement\n  }\n\n  const setRowMetadata = (row: DateCell[]) => {\n    if (props.selectionMode === 'week') {\n      const [start, end] = props.showWeekNumber ? [1, 7] : [0, 6]\n      const isActive = isWeekActive(row[start + 1])\n      row[start].inRange = isActive\n      row[start].start = isActive\n      row[end].inRange = isActive\n      row[end].end = isActive\n    }\n  }\n\n  const rows = computed(() => {\n    const { minDate, maxDate, rangeState, showWeekNumber } = props\n\n    const offset = unref(offsetDay)\n    const rows_ = unref(tableRows)\n    const dateUnit = 'day'\n    let count = 1\n\n    if (showWeekNumber) {\n      for (let rowIndex = 0; rowIndex < 6; rowIndex++) {\n        if (!rows_[rowIndex][0]) {\n          rows_[rowIndex][0] = {\n            type: 'week',\n            text: unref(startDate)\n              .add(rowIndex * 7 + 1, dateUnit)\n              .week(),\n          }\n        }\n      }\n    }\n\n    buildPickerTable({ row: 6, column: 7 }, rows_, {\n      startDate: minDate,\n      columnIndexOffset: showWeekNumber ? 1 : 0,\n      nextEndDate:\n        rangeState.endDate ||\n        maxDate ||\n        (rangeState.selecting && minDate) ||\n        null,\n      now: dayjs().locale(unref(lang)).startOf(dateUnit),\n      unit: dateUnit,\n      relativeDateGetter: (idx: number) =>\n        unref(startDate).add(idx - offset, dateUnit),\n      setCellMetadata: (...args) => {\n        if (setCellMetadata(...args, count)) {\n          count += 1\n        }\n      },\n\n      setRowMetadata,\n    })\n\n    return rows_\n  })\n\n  watch(\n    () => props.date,\n    async () => {\n      if (unref(tbodyRef)?.contains(document.activeElement)) {\n        await nextTick()\n        await focus()\n        // currentCellRef.value?.focus()\n      }\n    }\n  )\n\n  const focus = async () => unref(currentCellRef)?.focus()\n\n  const isCurrent = (cell: DateCell): boolean => {\n    return (\n      props.selectionMode === 'date' &&\n      isNormalDay(cell.type) &&\n      cellMatchesDate(cell, props.parsedValue as Dayjs)\n    )\n  }\n\n  const cellMatchesDate = (cell: DateCell, date: Dayjs) => {\n    if (!date) return false\n    return dayjs(date)\n      .locale(unref(lang))\n      .isSame(props.date.date(Number(cell.text)), 'day')\n  }\n\n  const getDateOfCell = (row: number, column: number) => {\n    const offsetFromStart =\n      row * 7 + (column - (props.showWeekNumber ? 1 : 0)) - unref(offsetDay)\n    return unref(startDate).add(offsetFromStart, 'day')\n  }\n\n  const handleMouseMove = (event: MouseEvent) => {\n    if (!props.rangeState.selecting) return\n\n    let target = event.target as HTMLElement\n    if (target.tagName === 'SPAN') {\n      target = target.parentNode?.parentNode as HTMLElement\n    }\n    if (target.tagName === 'DIV') {\n      target = target.parentNode as HTMLElement\n    }\n    if (target.tagName !== 'TD') return\n\n    const row = (target.parentNode as HTMLTableRowElement).rowIndex - 1\n    const column = (target as HTMLTableCellElement).cellIndex\n\n    // can not select disabled date\n    if (unref(rows)[row][column].disabled) return\n\n    // only update rangeState when mouse moves to a new cell\n    // this avoids frequent Date object creation and improves performance\n    if (row !== unref(lastRow) || column !== unref(lastColumn)) {\n      lastRow.value = row\n      lastColumn.value = column\n      emit('changerange', {\n        selecting: true,\n        endDate: getDateOfCell(row, column),\n      })\n    }\n  }\n\n  const isSelectedCell = (cell: DateCell) => {\n    return (\n      (!unref(hasCurrent) && cell?.text === 1 && cell.type === 'normal') ||\n      cell.isCurrent\n    )\n  }\n\n  const handleFocus = (event: FocusEvent) => {\n    if (focusWithClick || unref(hasCurrent) || props.selectionMode !== 'date')\n      return\n    handlePickDate(event, true)\n  }\n\n  const handleMouseDown = (event: MouseEvent) => {\n    const target = (event.target as HTMLElement).closest('td')\n    if (!target) return\n    focusWithClick = true\n  }\n\n  const handleMouseUp = (event: MouseEvent) => {\n    const target = (event.target as HTMLElement).closest('td')\n    if (!target) return\n    focusWithClick = false\n  }\n\n  const handleRangePick = (newDate: Dayjs) => {\n    if (!props.rangeState.selecting || !props.minDate) {\n      emit('pick', { minDate: newDate, maxDate: null })\n      emit('select', true)\n    } else {\n      if (newDate >= props.minDate) {\n        emit('pick', { minDate: props.minDate, maxDate: newDate })\n      } else {\n        emit('pick', { minDate: newDate, maxDate: props.minDate })\n      }\n      emit('select', false)\n    }\n  }\n\n  const handleWeekPick = (newDate: Dayjs) => {\n    const weekNumber = newDate.week()\n    const value = `${newDate.year()}w${weekNumber}`\n    emit('pick', {\n      year: newDate.year(),\n      week: weekNumber,\n      value,\n      date: newDate.startOf('week'),\n    })\n  }\n\n  const handleDatesPick = (newDate: Dayjs, selected: boolean) => {\n    const newValue = selected\n      ? castArray(props.parsedValue).filter(\n          (d) => d?.valueOf() !== newDate.valueOf()\n        )\n      : castArray(props.parsedValue).concat([newDate])\n    emit('pick', newValue)\n  }\n\n  const handlePickDate = (\n    event: FocusEvent | MouseEvent,\n    isKeyboardMovement = false\n  ) => {\n    const target = (event.target as HTMLElement).closest('td')\n\n    if (!target) return\n\n    const row = (target.parentNode as HTMLTableRowElement).rowIndex - 1\n    const column = (target as HTMLTableCellElement).cellIndex\n    const cell = unref(rows)[row][column]\n\n    if (cell.disabled || cell.type === 'week') return\n\n    const newDate = getDateOfCell(row, column)\n\n    switch (props.selectionMode) {\n      case 'range': {\n        handleRangePick(newDate)\n        break\n      }\n      case 'date': {\n        emit('pick', newDate, isKeyboardMovement)\n        break\n      }\n      case 'week': {\n        handleWeekPick(newDate)\n        break\n      }\n      case 'dates': {\n        handleDatesPick(newDate, !!cell.selected)\n        break\n      }\n      default: {\n        break\n      }\n    }\n  }\n\n  const isWeekActive = (cell: DateCell) => {\n    if (props.selectionMode !== 'week') return false\n    let newDate = props.date.startOf('day')\n\n    if (cell.type === 'prev-month') {\n      newDate = newDate.subtract(1, 'month')\n    }\n\n    if (cell.type === 'next-month') {\n      newDate = newDate.add(1, 'month')\n    }\n\n    newDate = newDate.date(Number.parseInt(cell.text as any, 10))\n\n    if (props.parsedValue && !Array.isArray(props.parsedValue)) {\n      const dayOffset = ((props.parsedValue.day() - firstDayOfWeek + 7) % 7) - 1\n      const weekDate = props.parsedValue.subtract(dayOffset, 'day')\n      return weekDate.isSame(newDate, 'day')\n    }\n    return false\n  }\n\n  return {\n    WEEKS,\n    rows,\n    tbodyRef,\n    currentCellRef,\n\n    // cellMatchesDate,\n    // getDateOfCell,\n    focus,\n    isCurrent,\n    isWeekActive,\n    isSelectedCell,\n\n    handlePickDate,\n    handleMouseUp,\n    handleMouseDown,\n    handleMouseMove,\n    handleFocus,\n  }\n}\n\nexport const useBasicDateTableDOM = (\n  props: BasicDateTableProps,\n  {\n    isCurrent,\n    isWeekActive,\n  }: Pick<ReturnType<typeof useBasicDateTable>, 'isCurrent' | 'isWeekActive'>\n) => {\n  const ns = useNamespace('date-table')\n  const { t } = useLocale()\n\n  const tableKls = computed(() => [\n    ns.b(),\n    { 'is-week-mode': props.selectionMode === 'week' },\n  ])\n\n  const tableLabel = computed(() => t('el.datepicker.dateTablePrompt'))\n  const weekLabel = computed(() => t('el.datepicker.week'))\n\n  const getCellClasses = (cell: DateCell) => {\n    const classes: string[] = []\n    if (isNormalDay(cell.type) && !cell.disabled) {\n      classes.push('available')\n      if (cell.type === 'today') {\n        classes.push('today')\n      }\n    } else {\n      classes.push(cell.type!)\n    }\n\n    if (isCurrent(cell)) {\n      classes.push('current')\n    }\n\n    if (\n      cell.inRange &&\n      (isNormalDay(cell.type) || props.selectionMode === 'week')\n    ) {\n      classes.push('in-range')\n\n      if (cell.start) {\n        classes.push('start-date')\n      }\n\n      if (cell.end) {\n        classes.push('end-date')\n      }\n    }\n\n    if (cell.disabled) {\n      classes.push('disabled')\n    }\n\n    if (cell.selected) {\n      classes.push('selected')\n    }\n\n    if (cell.customClass) {\n      classes.push(cell.customClass)\n    }\n\n    return classes.join(' ')\n  }\n\n  const getRowKls = (cell: DateCell) => [\n    ns.e('row'),\n    { current: isWeekActive(cell) },\n  ]\n\n  return {\n    tableKls,\n    tableLabel,\n    weekLabel,\n\n    getCellClasses,\n    getRowKls,\n    t,\n  }\n}\n", "import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { DateCell } from '../date-picker.type'\n\nexport const basicCellProps = buildProps({\n  cell: {\n    type: definePropType<DateCell>(Object),\n  },\n} as const)\n\nexport type BasicCellProps = ExtractPropTypes<typeof basicCellProps>\n", "import { defineComponent, inject, renderSlot } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { ROOT_PICKER_INJECTION_KEY } from '../constants'\nimport { basicCellProps } from '../props/basic-cell'\n\nexport default defineComponent({\n  name: 'ElDatePickerCell',\n  props: basicCellProps,\n  setup(props) {\n    const ns = useNamespace('date-table-cell')\n    const { slots } = inject(ROOT_PICKER_INJECTION_KEY)!\n    return () => {\n      const { cell } = props\n\n      return renderSlot(slots, 'default', { ...cell }, () => [\n        <div class={ns.b()}>\n          <span class={ns.e('text')}>{cell?.renderText ?? cell?.text}</span>\n        </div>,\n      ])\n    }\n  },\n})\n", "<template>\n  <table\n    :aria-label=\"tableLabel\"\n    :class=\"tableKls\"\n    cellspacing=\"0\"\n    cellpadding=\"0\"\n    role=\"grid\"\n    @click=\"handlePickDate\"\n    @mousemove=\"handleMouseMove\"\n    @mousedown.prevent=\"handleMouseDown\"\n    @mouseup=\"handleMouseUp\"\n  >\n    <tbody ref=\"tbodyRef\">\n      <tr>\n        <th v-if=\"showWeekNumber\" scope=\"col\">{{ weekLabel }}</th>\n        <th\n          v-for=\"(week, key) in WEEKS\"\n          :key=\"key\"\n          :aria-label=\"t('el.datepicker.weeksFull.' + week)\"\n          scope=\"col\"\n        >\n          {{ t('el.datepicker.weeks.' + week) }}\n        </th>\n      </tr>\n      <tr\n        v-for=\"(row, rowKey) in rows\"\n        :key=\"rowKey\"\n        :class=\"getRowKls(row[1])\"\n      >\n        <td\n          v-for=\"(cell, columnKey) in row\"\n          :key=\"`${rowKey}.${columnKey}`\"\n          :ref=\"(el) => isSelectedCell(cell) && (currentCellRef = el as HTMLElement)\"\n          :class=\"getCellClasses(cell)\"\n          :aria-current=\"cell.isCurrent ? 'date' : undefined\"\n          :aria-selected=\"cell.isCurrent\"\n          :tabindex=\"isSelectedCell(cell) ? 0 : -1\"\n          @focus=\"handleFocus\"\n        >\n          <el-date-picker-cell :cell=\"cell\" />\n        </td>\n      </tr>\n    </tbody>\n  </table>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  basicDateTableEmits,\n  basicDateTableProps,\n} from '../props/basic-date-table'\nimport {\n  useBasicDateTable,\n  useBasicDateTableDOM,\n} from '../composables/use-basic-date-table'\nimport ElDatePickerCell from './basic-cell-render'\n\nconst props = defineProps(basicDateTableProps)\nconst emit = defineEmits(basicDateTableEmits)\n\nconst {\n  WEEKS,\n  rows,\n  tbodyRef,\n  currentCellRef,\n\n  focus,\n  isCurrent,\n  isWeekActive,\n  isSelectedCell,\n\n  handlePickDate,\n  handleMouseUp,\n  handleMouseDown,\n  handleMouseMove,\n  handleFocus,\n} = useBasicDateTable(props, emit)\nconst { tableLabel, tableKls, weekLabel, getCellClasses, getRowKls, t } =\n  useBasicDateTableDOM(props, {\n    isCurrent,\n    isWeekActive,\n  })\n\ndefineExpose({\n  /**\n   * @description focus on current cell\n   */\n  focus,\n})\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport { datePickerSharedProps, selectionModeWithDefault } from './shared'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const basicMonthTableProps = buildProps({\n  ...datePickerSharedProps,\n  selectionMode: selectionModeWithDefault('month'),\n})\n\nexport type BasicMonthTableProps = ExtractPropTypes<typeof basicMonthTableProps>\n", "<template>\n  <table\n    role=\"grid\"\n    :aria-label=\"t('el.datepicker.monthTablePrompt')\"\n    :class=\"ns.b()\"\n    @click=\"handleMonthTableClick\"\n    @mousemove=\"handleMouseMove\"\n  >\n    <tbody ref=\"tbodyRef\">\n      <tr v-for=\"(row, key) in rows\" :key=\"key\">\n        <td\n          v-for=\"(cell, key_) in row\"\n          :key=\"key_\"\n          :ref=\"(el) => isSelectedCell(cell) && (currentCellRef = el as HTMLElement)\"\n          :class=\"getCellStyle(cell)\"\n          :aria-selected=\"`${isSelectedCell(cell)}`\"\n          :aria-label=\"t(`el.datepicker.month${+cell.text + 1}`)\"\n          :tabindex=\"isSelectedCell(cell) ? 0 : -1\"\n          @keydown.space.prevent.stop=\"handleMonthTableClick\"\n          @keydown.enter.prevent.stop=\"handleMonthTableClick\"\n        >\n          <el-date-picker-cell\n            :cell=\"{\n              ...cell,\n              renderText: t('el.datepicker.months.' + months[cell.text]),\n            }\"\n          />\n        </td>\n      </tr>\n    </tbody>\n  </table>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, nextTick, ref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { castArray, hasClass } from '@element-plus/utils'\nimport { basicMonthTableProps } from '../props/basic-month-table'\nimport { datesInMonth, getValidDateOfMonth } from '../utils'\nimport ElDatePickerCell from './basic-cell-render'\n\ntype MonthCell = {\n  column: number\n  row: number\n  disabled: boolean\n  start: boolean\n  end: boolean\n  text: number\n  type: 'normal' | 'today'\n  inRange: boolean\n}\n\nconst props = defineProps(basicMonthTableProps)\nconst emit = defineEmits(['changerange', 'pick', 'select'])\n\nconst ns = useNamespace('month-table')\n\nconst { t, lang } = useLocale()\nconst tbodyRef = ref<HTMLElement>()\nconst currentCellRef = ref<HTMLElement>()\nconst months = ref(\n  props.date\n    .locale('en')\n    .localeData()\n    .monthsShort()\n    .map((_) => _.toLowerCase())\n)\nconst tableRows = ref<MonthCell[][]>([\n  [] as MonthCell[],\n  [] as MonthCell[],\n  [] as MonthCell[],\n])\nconst lastRow = ref<number>()\nconst lastColumn = ref<number>()\nconst rows = computed<MonthCell[][]>(() => {\n  const rows = tableRows.value\n\n  const now = dayjs().locale(lang.value).startOf('month')\n\n  for (let i = 0; i < 3; i++) {\n    const row = rows[i]\n    for (let j = 0; j < 4; j++) {\n      const cell = (row[j] ||= {\n        row: i,\n        column: j,\n        type: 'normal',\n        inRange: false,\n        start: false,\n        end: false,\n        text: -1,\n        disabled: false,\n      })\n\n      cell.type = 'normal'\n\n      const index = i * 4 + j\n      const calTime = props.date.startOf('year').month(index)\n\n      const calEndDate =\n        props.rangeState.endDate ||\n        props.maxDate ||\n        (props.rangeState.selecting && props.minDate) ||\n        null\n\n      cell.inRange =\n        !!(\n          props.minDate &&\n          calTime.isSameOrAfter(props.minDate, 'month') &&\n          calEndDate &&\n          calTime.isSameOrBefore(calEndDate, 'month')\n        ) ||\n        !!(\n          props.minDate &&\n          calTime.isSameOrBefore(props.minDate, 'month') &&\n          calEndDate &&\n          calTime.isSameOrAfter(calEndDate, 'month')\n        )\n\n      if (props.minDate?.isSameOrAfter(calEndDate)) {\n        cell.start = !!(calEndDate && calTime.isSame(calEndDate, 'month'))\n        cell.end = props.minDate && calTime.isSame(props.minDate, 'month')\n      } else {\n        cell.start = !!(props.minDate && calTime.isSame(props.minDate, 'month'))\n        cell.end = !!(calEndDate && calTime.isSame(calEndDate, 'month'))\n      }\n\n      const isToday = now.isSame(calTime)\n      if (isToday) {\n        cell.type = 'today'\n      }\n\n      cell.text = index\n      cell.disabled = props.disabledDate?.(calTime.toDate()) || false\n    }\n  }\n  return rows\n})\n\nconst focus = () => {\n  currentCellRef.value?.focus()\n}\n\nconst getCellStyle = (cell: MonthCell) => {\n  const style = {} as any\n  const year = props.date.year()\n  const today = new Date()\n  const month = cell.text\n\n  style.disabled = props.disabledDate\n    ? datesInMonth(year, month, lang.value).every(props.disabledDate)\n    : false\n  style.current =\n    castArray(props.parsedValue).findIndex(\n      (date) =>\n        dayjs.isDayjs(date) && date.year() === year && date.month() === month\n    ) >= 0\n  style.today = today.getFullYear() === year && today.getMonth() === month\n\n  if (cell.inRange) {\n    style['in-range'] = true\n\n    if (cell.start) {\n      style['start-date'] = true\n    }\n\n    if (cell.end) {\n      style['end-date'] = true\n    }\n  }\n  return style\n}\n\nconst isSelectedCell = (cell: MonthCell) => {\n  const year = props.date.year()\n  const month = cell.text\n  return (\n    castArray(props.date).findIndex(\n      (date) => date.year() === year && date.month() === month\n    ) >= 0\n  )\n}\n\nconst handleMouseMove = (event: MouseEvent) => {\n  if (!props.rangeState.selecting) return\n\n  let target = event.target as HTMLElement\n  if (target.tagName === 'SPAN') {\n    target = target.parentNode?.parentNode as HTMLElement\n  }\n  if (target.tagName === 'DIV') {\n    target = target.parentNode as HTMLElement\n  }\n  if (target.tagName !== 'TD') return\n\n  const row = (target.parentNode as HTMLTableRowElement).rowIndex\n  const column = (target as HTMLTableCellElement).cellIndex\n  // can not select disabled date\n  if (rows.value[row][column].disabled) return\n\n  // only update rangeState when mouse moves to a new cell\n  // this avoids frequent Date object creation and improves performance\n  if (row !== lastRow.value || column !== lastColumn.value) {\n    lastRow.value = row\n    lastColumn.value = column\n    emit('changerange', {\n      selecting: true,\n      endDate: props.date.startOf('year').month(row * 4 + column),\n    })\n  }\n}\nconst handleMonthTableClick = (event: MouseEvent | KeyboardEvent) => {\n  const target = (event.target as HTMLElement)?.closest(\n    'td'\n  ) as HTMLTableCellElement\n  if (target?.tagName !== 'TD') return\n  if (hasClass(target, 'disabled')) return\n  const column = target.cellIndex\n  const row = (target.parentNode as HTMLTableRowElement).rowIndex\n  const month = row * 4 + column\n  const newDate = props.date.startOf('year').month(month)\n  if (props.selectionMode === 'months') {\n    if (event.type === 'keydown') {\n      emit('pick', castArray(props.parsedValue), false)\n      return\n    }\n    const newMonth = getValidDateOfMonth(\n      props.date.year(),\n      month,\n      lang.value,\n      props.disabledDate\n    )\n    const newValue = hasClass(target, 'current')\n      ? castArray(props.parsedValue).filter(\n          (d) => d?.month() !== newMonth.month()\n        )\n      : castArray(props.parsedValue).concat([dayjs(newMonth)])\n    emit('pick', newValue)\n  } else if (props.selectionMode === 'range') {\n    if (!props.rangeState.selecting) {\n      emit('pick', { minDate: newDate, maxDate: null })\n      emit('select', true)\n    } else {\n      if (props.minDate && newDate >= props.minDate) {\n        emit('pick', { minDate: props.minDate, maxDate: newDate })\n      } else {\n        emit('pick', { minDate: newDate, maxDate: props.minDate })\n      }\n      emit('select', false)\n    }\n  } else {\n    emit('pick', month)\n  }\n}\n\nwatch(\n  () => props.date,\n  async () => {\n    if (tbodyRef.value?.contains(document.activeElement)) {\n      await nextTick()\n      currentCellRef.value?.focus()\n    }\n  }\n)\n\ndefineExpose({\n  /**\n   * @description focus current cell\n   */\n  focus,\n})\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport { datePickerSharedProps, selectionModeWithDefault } from './shared'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const basicYearTableProps = buildProps({\n  ...datePickerSharedProps,\n  selectionMode: selectionModeWithDefault('year'),\n} as const)\n\nexport type BasicYearTableProps = ExtractPropTypes<typeof basicYearTableProps>\n", "<template>\n  <table\n    role=\"grid\"\n    :aria-label=\"t('el.datepicker.yearTablePrompt')\"\n    :class=\"ns.b()\"\n    @click=\"handleYearTableClick\"\n    @mousemove=\"handleMouseMove\"\n  >\n    <tbody ref=\"tbodyRef\">\n      <tr v-for=\"(row, rowKey) in rows\" :key=\"rowKey\">\n        <td\n          v-for=\"(cell, cellKey) in row\"\n          :key=\"`${rowKey}_${cellKey}`\"\n          :ref=\"(el) => isSelectedCell(cell) && (currentCellRef = el as HTMLElement)\"\n          class=\"available\"\n          :class=\"getCellKls(cell)\"\n          :aria-selected=\"isSelectedCell(cell)\"\n          :aria-label=\"String(cell.text)\"\n          :tabindex=\"isSelectedCell(cell) ? 0 : -1\"\n          @keydown.space.prevent.stop=\"handleYearTableClick\"\n          @keydown.enter.prevent.stop=\"handleYearTableClick\"\n        >\n          <el-date-picker-cell :cell=\"cell\" />\n        </td>\n      </tr>\n    </tbody>\n  </table>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, nextTick, ref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { rangeArr } from '@element-plus/components/time-picker'\nimport { castArray, hasClass } from '@element-plus/utils'\nimport { basicYearTableProps } from '../props/basic-year-table'\nimport { getValidDateOfYear } from '../utils'\nimport ElDatePickerCell from './basic-cell-render'\n\ntype YearCell = {\n  column: number\n  row: number\n  disabled: boolean\n  start: boolean\n  end: boolean\n  text: number\n  type: 'normal' | 'today'\n  inRange: boolean\n}\n\nconst datesInYear = (year: number, lang: string) => {\n  const firstDay = dayjs(String(year)).locale(lang).startOf('year')\n  const lastDay = firstDay.endOf('year')\n  const numOfDays = lastDay.dayOfYear()\n  return rangeArr(numOfDays).map((n) => firstDay.add(n, 'day').toDate())\n}\n\nconst props = defineProps(basicYearTableProps)\nconst emit = defineEmits(['changerange', 'pick', 'select'])\n\nconst ns = useNamespace('year-table')\n\nconst { t, lang } = useLocale()\nconst tbodyRef = ref<HTMLElement>()\nconst currentCellRef = ref<HTMLElement>()\nconst startYear = computed(() => {\n  return Math.floor(props.date.year() / 10) * 10\n})\n\nconst tableRows = ref<YearCell[][]>([[], [], []])\nconst lastRow = ref<number>()\nconst lastColumn = ref<number>()\nconst rows = computed(() => {\n  const rows = tableRows.value\n  const now = dayjs().locale(lang.value).startOf('year')\n\n  for (let i = 0; i < 3; i++) {\n    const row = rows[i]\n    for (let j = 0; j < 4; j++) {\n      if (i * 4 + j >= 10) {\n        break\n      }\n      let cell = row[j]\n      if (!cell) {\n        cell = {\n          row: i,\n          column: j,\n          type: 'normal',\n          inRange: false,\n          start: false,\n          end: false,\n          text: -1,\n          disabled: false,\n        }\n      }\n      cell.type = 'normal'\n      const index = i * 4 + j + startYear.value\n      const calTime = dayjs().year(index)\n\n      const calEndDate =\n        props.rangeState.endDate ||\n        props.maxDate ||\n        (props.rangeState.selecting && props.minDate) ||\n        null\n\n      cell.inRange =\n        !!(\n          props.minDate &&\n          calTime.isSameOrAfter(props.minDate, 'year') &&\n          calEndDate &&\n          calTime.isSameOrBefore(calEndDate, 'year')\n        ) ||\n        !!(\n          props.minDate &&\n          calTime.isSameOrBefore(props.minDate, 'year') &&\n          calEndDate &&\n          calTime.isSameOrAfter(calEndDate, 'year')\n        )\n\n      if (props.minDate?.isSameOrAfter(calEndDate)) {\n        cell.start = !!(calEndDate && calTime.isSame(calEndDate, 'year'))\n        cell.end = !!(props.minDate && calTime.isSame(props.minDate, 'year'))\n      } else {\n        cell.start = !!(props.minDate && calTime.isSame(props.minDate, 'year'))\n        cell.end = !!(calEndDate && calTime.isSame(calEndDate, 'year'))\n      }\n\n      const isToday = now.isSame(calTime)\n      if (isToday) {\n        cell.type = 'today'\n      }\n      cell.text = index\n      const cellDate = calTime.toDate()\n      cell.disabled =\n        (props.disabledDate && props.disabledDate(cellDate)) || false\n      row[j] = cell\n    }\n  }\n  return rows\n})\n\nconst focus = () => {\n  currentCellRef.value?.focus()\n}\n\nconst getCellKls = (cell: YearCell) => {\n  const kls: Record<string, boolean> = {}\n  const today = dayjs().locale(lang.value)\n  const year = cell.text\n\n  kls.disabled = props.disabledDate\n    ? datesInYear(year, lang.value).every(props.disabledDate)\n    : false\n\n  kls.today = today.year() === year\n  kls.current =\n    castArray(props.parsedValue).findIndex((d) => d!.year() === year) >= 0\n\n  if (cell.inRange) {\n    kls['in-range'] = true\n\n    if (cell.start) {\n      kls['start-date'] = true\n    }\n\n    if (cell.end) {\n      kls['end-date'] = true\n    }\n  }\n  return kls\n}\n\nconst isSelectedCell = (cell: YearCell) => {\n  const year = cell.text\n  return castArray(props.date).findIndex((date) => date.year() === year) >= 0\n}\n\nconst handleYearTableClick = (event: MouseEvent | KeyboardEvent) => {\n  const target = (event.target as HTMLElement)?.closest(\n    'td'\n  ) as HTMLTableCellElement\n  if (!target || !target.textContent || hasClass(target, 'disabled')) return\n\n  const column = target.cellIndex\n  const row = (target.parentNode as HTMLTableRowElement).rowIndex\n  const selectedYear = row * 4 + column + startYear.value\n  const newDate = dayjs().year(selectedYear)\n  if (props.selectionMode === 'range') {\n    if (!props.rangeState.selecting) {\n      emit('pick', { minDate: newDate, maxDate: null })\n      emit('select', true)\n    } else {\n      if (props.minDate && newDate >= props.minDate) {\n        emit('pick', { minDate: props.minDate, maxDate: newDate })\n      } else {\n        emit('pick', { minDate: newDate, maxDate: props.minDate })\n      }\n      emit('select', false)\n    }\n  } else if (props.selectionMode === 'years') {\n    if (event.type === 'keydown') {\n      emit('pick', castArray(props.parsedValue), false)\n      return\n    }\n    const vaildYear = getValidDateOfYear(\n      newDate.startOf('year'),\n      lang.value,\n      props.disabledDate\n    )\n    const newValue = hasClass(target, 'current')\n      ? castArray(props.parsedValue).filter((d) => d?.year() !== selectedYear)\n      : castArray(props.parsedValue).concat([vaildYear])\n    emit('pick', newValue)\n  } else {\n    emit('pick', selectedYear)\n  }\n}\n\nconst handleMouseMove = (event: MouseEvent) => {\n  if (!props.rangeState.selecting) return\n  const target = (event.target as HTMLElement)?.closest(\n    'td'\n  ) as HTMLTableCellElement\n  if (!target) return\n\n  const row = (target.parentNode as HTMLTableRowElement).rowIndex\n  const column = (target as HTMLTableCellElement).cellIndex\n\n  // can not select disabled date\n  if (rows.value[row][column].disabled) return\n\n  // only update rangeState when mouse moves to a new cell\n  // this avoids frequent Date object creation and improves performance\n  if (row !== lastRow.value || column !== lastColumn.value) {\n    lastRow.value = row\n    lastColumn.value = column\n    emit('changerange', {\n      selecting: true,\n      endDate: dayjs()\n        .year(startYear.value)\n        .add(row * 4 + column, 'year'),\n    })\n  }\n}\n\nwatch(\n  () => props.date,\n  async () => {\n    if (tbodyRef.value?.contains(document.activeElement)) {\n      await nextTick()\n      currentCellRef.value?.focus()\n    }\n  }\n)\n\ndefineExpose({\n  /**\n   * @description focus on the current cell\n   */\n  focus,\n})\n</script>\n", "<template>\n  <div\n    :class=\"[\n      ppNs.b(),\n      dpNs.b(),\n      {\n        'has-sidebar': $slots.sidebar || hasShortcuts,\n        'has-time': showTime,\n      },\n    ]\"\n  >\n    <div :class=\"ppNs.e('body-wrapper')\">\n      <slot name=\"sidebar\" :class=\"ppNs.e('sidebar')\" />\n      <div v-if=\"hasShortcuts\" :class=\"ppNs.e('sidebar')\">\n        <button\n          v-for=\"(shortcut, key) in shortcuts\"\n          :key=\"key\"\n          type=\"button\"\n          :class=\"ppNs.e('shortcut')\"\n          @click=\"handleShortcutClick(shortcut)\"\n        >\n          {{ shortcut.text }}\n        </button>\n      </div>\n      <div :class=\"ppNs.e('body')\">\n        <div v-if=\"showTime\" :class=\"dpNs.e('time-header')\">\n          <span :class=\"dpNs.e('editor-wrap')\">\n            <el-input\n              :placeholder=\"t('el.datepicker.selectDate')\"\n              :model-value=\"visibleDate\"\n              size=\"small\"\n              :validate-event=\"false\"\n              @input=\"(val) => (userInputDate = val)\"\n              @change=\"handleVisibleDateChange\"\n            />\n          </span>\n          <span\n            v-click-outside=\"handleTimePickClose\"\n            :class=\"dpNs.e('editor-wrap')\"\n          >\n            <el-input\n              :placeholder=\"t('el.datepicker.selectTime')\"\n              :model-value=\"visibleTime\"\n              size=\"small\"\n              :validate-event=\"false\"\n              @focus=\"onTimePickerInputFocus\"\n              @input=\"(val) => (userInputTime = val)\"\n              @change=\"handleVisibleTimeChange\"\n            />\n            <time-pick-panel\n              :visible=\"timePickerVisible\"\n              :format=\"timeFormat\"\n              :parsed-value=\"innerDate\"\n              @pick=\"handleTimePick\"\n            />\n          </span>\n        </div>\n        <div\n          v-show=\"currentView !== 'time'\"\n          :class=\"[\n            dpNs.e('header'),\n            (currentView === 'year' || currentView === 'month') &&\n              dpNs.e('header--bordered'),\n          ]\"\n        >\n          <span :class=\"dpNs.e('prev-btn')\">\n            <button\n              type=\"button\"\n              :aria-label=\"t(`el.datepicker.prevYear`)\"\n              class=\"d-arrow-left\"\n              :class=\"ppNs.e('icon-btn')\"\n              @click=\"moveByYear(false)\"\n            >\n              <slot name=\"prev-year\">\n                <el-icon><d-arrow-left /></el-icon>\n              </slot>\n            </button>\n            <button\n              v-show=\"currentView === 'date'\"\n              type=\"button\"\n              :aria-label=\"t(`el.datepicker.prevMonth`)\"\n              :class=\"ppNs.e('icon-btn')\"\n              class=\"arrow-left\"\n              @click=\"moveByMonth(false)\"\n            >\n              <slot name=\"prev-month\">\n                <el-icon><arrow-left /></el-icon>\n              </slot>\n            </button>\n          </span>\n          <span\n            role=\"button\"\n            :class=\"dpNs.e('header-label')\"\n            aria-live=\"polite\"\n            tabindex=\"0\"\n            @keydown.enter=\"showPicker('year')\"\n            @click=\"showPicker('year')\"\n            >{{ yearLabel }}</span\n          >\n          <span\n            v-show=\"currentView === 'date'\"\n            role=\"button\"\n            aria-live=\"polite\"\n            tabindex=\"0\"\n            :class=\"[\n              dpNs.e('header-label'),\n              { active: currentView === 'month' },\n            ]\"\n            @keydown.enter=\"showPicker('month')\"\n            @click=\"showPicker('month')\"\n            >{{ t(`el.datepicker.month${month + 1}`) }}</span\n          >\n          <span :class=\"dpNs.e('next-btn')\">\n            <button\n              v-show=\"currentView === 'date'\"\n              type=\"button\"\n              :aria-label=\"t(`el.datepicker.nextMonth`)\"\n              :class=\"ppNs.e('icon-btn')\"\n              class=\"arrow-right\"\n              @click=\"moveByMonth(true)\"\n            >\n              <slot name=\"next-month\">\n                <el-icon><arrow-right /></el-icon>\n              </slot>\n            </button>\n            <button\n              type=\"button\"\n              :aria-label=\"t(`el.datepicker.nextYear`)\"\n              :class=\"ppNs.e('icon-btn')\"\n              class=\"d-arrow-right\"\n              @click=\"moveByYear(true)\"\n            >\n              <slot name=\"next-year\">\n                <el-icon><d-arrow-right /></el-icon>\n              </slot>\n            </button>\n          </span>\n        </div>\n        <div :class=\"ppNs.e('content')\" @keydown=\"handleKeydownTable\">\n          <date-table\n            v-if=\"currentView === 'date'\"\n            ref=\"currentViewRef\"\n            :selection-mode=\"selectionMode\"\n            :date=\"innerDate\"\n            :parsed-value=\"parsedValue\"\n            :disabled-date=\"disabledDate\"\n            :cell-class-name=\"cellClassName\"\n            @pick=\"handleDatePick\"\n          />\n          <year-table\n            v-if=\"currentView === 'year'\"\n            ref=\"currentViewRef\"\n            :selection-mode=\"selectionMode\"\n            :date=\"innerDate\"\n            :disabled-date=\"disabledDate\"\n            :parsed-value=\"parsedValue\"\n            @pick=\"handleYearPick\"\n          />\n          <month-table\n            v-if=\"currentView === 'month'\"\n            ref=\"currentViewRef\"\n            :selection-mode=\"selectionMode\"\n            :date=\"innerDate\"\n            :parsed-value=\"parsedValue\"\n            :disabled-date=\"disabledDate\"\n            @pick=\"handleMonthPick\"\n          />\n        </div>\n      </div>\n    </div>\n    <div v-show=\"footerVisible\" :class=\"ppNs.e('footer')\">\n      <el-button\n        v-show=\"!isMultipleType\"\n        text\n        size=\"small\"\n        :class=\"ppNs.e('link-btn')\"\n        :disabled=\"disabledNow\"\n        @click=\"changeToNow\"\n      >\n        {{ t('el.datepicker.now') }}\n      </el-button>\n      <el-button\n        plain\n        size=\"small\"\n        :class=\"ppNs.e('link-btn')\"\n        :disabled=\"disabledConfirm\"\n        @click=\"onConfirm\"\n      >\n        {{ t('el.datepicker.confirm') }}\n      </el-button>\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  inject,\n  nextTick,\n  ref,\n  toRef,\n  useAttrs,\n  useSlots,\n  watch,\n} from 'vue'\nimport dayjs from 'dayjs'\nimport ElButton from '@element-plus/components/button'\nimport { ClickOutside as vClickOutside } from '@element-plus/directives'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport ElInput from '@element-plus/components/input'\nimport {\n  TimePickPanel,\n  extractDateFormat,\n  extractTimeFormat,\n} from '@element-plus/components/time-picker'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { isArray, isFunction } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport {\n  ArrowLeft,\n  ArrowRight,\n  DArrowLeft,\n  DArrowRight,\n} from '@element-plus/icons-vue'\nimport { TOOLTIP_INJECTION_KEY } from '@element-plus/components/tooltip'\nimport { panelDatePickProps } from '../props/panel-date-pick'\nimport { getValidDateOfMonth, getValidDateOfYear } from '../utils'\nimport DateTable from './basic-date-table.vue'\nimport MonthTable from './basic-month-table.vue'\nimport YearTable from './basic-year-table.vue'\n\nimport type { SetupContext } from 'vue'\nimport type { ConfigType, Dayjs } from 'dayjs'\nimport type { PanelDatePickProps } from '../props/panel-date-pick'\nimport type {\n  DateTableEmits,\n  DatesPickerEmits,\n  MonthsPickerEmits,\n  WeekPickerEmits,\n  YearsPickerEmits,\n} from '../props/basic-date-table'\n\ntype DatePickType = PanelDatePickProps['type']\n// todo\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nconst timeWithinRange = (_: ConfigType, __: any, ___: string) => true\nconst props = defineProps(panelDatePickProps)\nconst contextEmit = defineEmits(['pick', 'set-picker-option', 'panel-change'])\nconst ppNs = useNamespace('picker-panel')\nconst dpNs = useNamespace('date-picker')\nconst attrs = useAttrs()\nconst slots = useSlots()\n\nconst { t, lang } = useLocale()\nconst pickerBase = inject('EP_PICKER_BASE') as any\nconst popper = inject(TOOLTIP_INJECTION_KEY)\nconst { shortcuts, disabledDate, cellClassName, defaultTime } = pickerBase.props\nconst defaultValue = toRef(pickerBase.props, 'defaultValue')\n\nconst currentViewRef = ref<{ focus: () => void }>()\n\nconst innerDate = ref(dayjs().locale(lang.value))\n\nconst isChangeToNow = ref(false)\n\nlet isShortcut = false\n\nconst defaultTimeD = computed(() => {\n  return dayjs(defaultTime).locale(lang.value)\n})\n\nconst month = computed(() => {\n  return innerDate.value.month()\n})\n\nconst year = computed(() => {\n  return innerDate.value.year()\n})\n\nconst selectableRange = ref([])\nconst userInputDate = ref<string | null>(null)\nconst userInputTime = ref<string | null>(null)\n// todo update to disableHour\nconst checkDateWithinRange = (date: ConfigType) => {\n  return selectableRange.value.length > 0\n    ? timeWithinRange(date, selectableRange.value, props.format || 'HH:mm:ss')\n    : true\n}\nconst formatEmit = (emitDayjs: Dayjs) => {\n  if (\n    defaultTime &&\n    !visibleTime.value &&\n    !isChangeToNow.value &&\n    !isShortcut\n  ) {\n    return defaultTimeD.value\n      .year(emitDayjs.year())\n      .month(emitDayjs.month())\n      .date(emitDayjs.date())\n  }\n  if (showTime.value) return emitDayjs.millisecond(0)\n  return emitDayjs.startOf('day')\n}\nconst emit = (value: Dayjs | Dayjs[], ...args: any[]) => {\n  if (!value) {\n    contextEmit('pick', value, ...args)\n  } else if (isArray(value)) {\n    const dates = value.map(formatEmit)\n    contextEmit('pick', dates, ...args)\n  } else {\n    contextEmit('pick', formatEmit(value), ...args)\n  }\n  userInputDate.value = null\n  userInputTime.value = null\n  isChangeToNow.value = false\n  isShortcut = false\n}\nconst handleDatePick = async (value: DateTableEmits, keepOpen?: boolean) => {\n  if (selectionMode.value === 'date') {\n    value = value as Dayjs\n    let newDate = props.parsedValue\n      ? (props.parsedValue as Dayjs)\n          .year(value.year())\n          .month(value.month())\n          .date(value.date())\n      : value\n    // change default time while out of selectableRange\n    if (!checkDateWithinRange(newDate)) {\n      newDate = (selectableRange.value[0][0] as Dayjs)\n        .year(value.year())\n        .month(value.month())\n        .date(value.date())\n    }\n    innerDate.value = newDate\n    emit(newDate, showTime.value || keepOpen)\n    // fix: https://github.com/element-plus/element-plus/issues/14728\n    if (props.type === 'datetime') {\n      await nextTick()\n      handleFocusPicker()\n    }\n  } else if (selectionMode.value === 'week') {\n    emit((value as WeekPickerEmits).date)\n  } else if (selectionMode.value === 'dates') {\n    emit(value as DatesPickerEmits, true) // set true to keep panel open\n  }\n}\n\nconst moveByMonth = (forward: boolean) => {\n  const action = forward ? 'add' : 'subtract'\n  innerDate.value = innerDate.value[action](1, 'month')\n  handlePanelChange('month')\n}\n\nconst moveByYear = (forward: boolean) => {\n  const currentDate = innerDate.value\n  const action = forward ? 'add' : 'subtract'\n\n  innerDate.value =\n    currentView.value === 'year'\n      ? currentDate[action](10, 'year')\n      : currentDate[action](1, 'year')\n\n  handlePanelChange('year')\n}\n\nconst currentView = ref('date')\n\nconst yearLabel = computed(() => {\n  const yearTranslation = t('el.datepicker.year')\n  if (currentView.value === 'year') {\n    const startYear = Math.floor(year.value / 10) * 10\n    if (yearTranslation) {\n      return `${startYear} ${yearTranslation} - ${\n        startYear + 9\n      } ${yearTranslation}`\n    }\n    return `${startYear} - ${startYear + 9}`\n  }\n  return `${year.value} ${yearTranslation}`\n})\n\ntype Shortcut = {\n  value: (() => Dayjs) | Dayjs\n  onClick?: (ctx: Omit<SetupContext, 'expose'>) => void\n}\n\nconst handleShortcutClick = (shortcut: Shortcut) => {\n  const shortcutValue = isFunction(shortcut.value)\n    ? shortcut.value()\n    : shortcut.value\n  if (shortcutValue) {\n    isShortcut = true\n    emit(dayjs(shortcutValue).locale(lang.value))\n    return\n  }\n  if (shortcut.onClick) {\n    shortcut.onClick({\n      attrs,\n      slots,\n      emit: contextEmit as SetupContext['emit'],\n    })\n  }\n}\n\nconst selectionMode = computed<DatePickType>(() => {\n  const { type } = props\n  if (['week', 'month', 'months', 'year', 'years', 'dates'].includes(type))\n    return type\n  return 'date' as DatePickType\n})\n\nconst isMultipleType = computed(() => {\n  return (\n    selectionMode.value === 'dates' ||\n    selectionMode.value === 'months' ||\n    selectionMode.value === 'years'\n  )\n})\n\nconst keyboardMode = computed<string>(() => {\n  return selectionMode.value === 'date'\n    ? currentView.value\n    : selectionMode.value\n})\n\nconst hasShortcuts = computed(() => !!shortcuts.length)\n\nconst handleMonthPick = async (\n  month: number | MonthsPickerEmits,\n  keepOpen?: boolean\n) => {\n  if (selectionMode.value === 'month') {\n    innerDate.value = getValidDateOfMonth(\n      innerDate.value.year(),\n      month as number,\n      lang.value,\n      disabledDate\n    )\n    emit(innerDate.value, false)\n  } else if (selectionMode.value === 'months') {\n    emit(month as MonthsPickerEmits, keepOpen ?? true)\n  } else {\n    innerDate.value = getValidDateOfMonth(\n      innerDate.value.year(),\n      month as number,\n      lang.value,\n      disabledDate\n    )\n    currentView.value = 'date'\n    if (['month', 'year', 'date', 'week'].includes(selectionMode.value)) {\n      emit(innerDate.value, true)\n      await nextTick()\n      handleFocusPicker()\n    }\n  }\n  handlePanelChange('month')\n}\n\nconst handleYearPick = async (\n  year: number | YearsPickerEmits,\n  keepOpen?: boolean\n) => {\n  if (selectionMode.value === 'year') {\n    const data = innerDate.value.startOf('year').year(year as number)\n    innerDate.value = getValidDateOfYear(data, lang.value, disabledDate)\n    emit(innerDate.value, false)\n  } else if (selectionMode.value === 'years') {\n    emit(year as YearsPickerEmits, keepOpen ?? true)\n  } else {\n    const data = innerDate.value.year(year as number)\n    innerDate.value = getValidDateOfYear(data, lang.value, disabledDate)\n    currentView.value = 'month'\n    if (['month', 'year', 'date', 'week'].includes(selectionMode.value)) {\n      emit(innerDate.value, true)\n      await nextTick()\n      handleFocusPicker()\n    }\n  }\n  handlePanelChange('year')\n}\n\nconst showPicker = async (view: 'month' | 'year') => {\n  currentView.value = view\n  await nextTick()\n  handleFocusPicker()\n}\n\nconst showTime = computed(\n  () => props.type === 'datetime' || props.type === 'datetimerange'\n)\n\nconst footerVisible = computed(() => {\n  const showDateFooter = showTime.value || selectionMode.value === 'dates'\n  const showYearFooter = selectionMode.value === 'years'\n  const showMonthFooter = selectionMode.value === 'months'\n  const isDateView = currentView.value === 'date'\n  const isYearView = currentView.value === 'year'\n  const isMonthView = currentView.value === 'month'\n  return (\n    (showDateFooter && isDateView) ||\n    (showYearFooter && isYearView) ||\n    (showMonthFooter && isMonthView)\n  )\n})\n\nconst disabledConfirm = computed(() => {\n  if (!disabledDate) return false\n  if (!props.parsedValue) return true\n  if (isArray(props.parsedValue)) {\n    return disabledDate(props.parsedValue[0].toDate())\n  }\n  return disabledDate(props.parsedValue.toDate())\n})\nconst onConfirm = () => {\n  if (isMultipleType.value) {\n    emit(props.parsedValue as Dayjs[])\n  } else {\n    // deal with the scenario where: user opens the date time picker, then confirm without doing anything\n    let result = props.parsedValue as Dayjs\n    if (!result) {\n      const defaultTimeD = dayjs(defaultTime).locale(lang.value)\n      const defaultValueD = getDefaultValue()\n      result = defaultTimeD\n        .year(defaultValueD.year())\n        .month(defaultValueD.month())\n        .date(defaultValueD.date())\n    }\n    innerDate.value = result\n    emit(result)\n  }\n}\n\nconst disabledNow = computed(() => {\n  if (!disabledDate) return false\n  return disabledDate(dayjs().locale(lang.value).toDate())\n})\nconst changeToNow = () => {\n  // NOTE: not a permanent solution\n  //       consider disable \"now\" button in the future\n  const now = dayjs().locale(lang.value)\n  const nowDate = now.toDate()\n  isChangeToNow.value = true\n  if (\n    (!disabledDate || !disabledDate(nowDate)) &&\n    checkDateWithinRange(nowDate)\n  ) {\n    innerDate.value = dayjs().locale(lang.value)\n    emit(innerDate.value)\n  }\n}\n\nconst timeFormat = computed(() => {\n  return props.timeFormat || extractTimeFormat(props.format)\n})\n\nconst dateFormat = computed(() => {\n  return props.dateFormat || extractDateFormat(props.format)\n})\n\nconst visibleTime = computed(() => {\n  if (userInputTime.value) return userInputTime.value\n  if (!props.parsedValue && !defaultValue.value) return\n  return ((props.parsedValue || innerDate.value) as Dayjs).format(\n    timeFormat.value\n  )\n})\n\nconst visibleDate = computed(() => {\n  if (userInputDate.value) return userInputDate.value\n  if (!props.parsedValue && !defaultValue.value) return\n  return ((props.parsedValue || innerDate.value) as Dayjs).format(\n    dateFormat.value\n  )\n})\n\nconst timePickerVisible = ref(false)\nconst onTimePickerInputFocus = () => {\n  timePickerVisible.value = true\n}\nconst handleTimePickClose = () => {\n  timePickerVisible.value = false\n}\n\nconst getUnits = (date: Dayjs) => {\n  return {\n    hour: date.hour(),\n    minute: date.minute(),\n    second: date.second(),\n    year: date.year(),\n    month: date.month(),\n    date: date.date(),\n  }\n}\n\nconst handleTimePick = (value: Dayjs, visible: boolean, first: boolean) => {\n  const { hour, minute, second } = getUnits(value)\n  const newDate = props.parsedValue\n    ? (props.parsedValue as Dayjs).hour(hour).minute(minute).second(second)\n    : value\n  innerDate.value = newDate\n  emit(innerDate.value, true)\n  if (!first) {\n    timePickerVisible.value = visible\n  }\n}\n\nconst handleVisibleTimeChange = (value: string) => {\n  const newDate = dayjs(value, timeFormat.value).locale(lang.value)\n  if (newDate.isValid() && checkDateWithinRange(newDate)) {\n    const { year, month, date } = getUnits(innerDate.value)\n    innerDate.value = newDate.year(year).month(month).date(date)\n    userInputTime.value = null\n    timePickerVisible.value = false\n    emit(innerDate.value, true)\n  }\n}\n\nconst handleVisibleDateChange = (value: string) => {\n  const newDate = dayjs(value, dateFormat.value).locale(lang.value)\n  if (newDate.isValid()) {\n    if (disabledDate && disabledDate(newDate.toDate())) {\n      return\n    }\n    const { hour, minute, second } = getUnits(innerDate.value)\n    innerDate.value = newDate.hour(hour).minute(minute).second(second)\n    userInputDate.value = null\n    emit(innerDate.value, true)\n  }\n}\n\nconst isValidValue = (date: unknown) => {\n  return (\n    dayjs.isDayjs(date) &&\n    date.isValid() &&\n    (disabledDate ? !disabledDate(date.toDate()) : true)\n  )\n}\n\nconst formatToString = (value: Dayjs | Dayjs[]) => {\n  return isArray(value)\n    ? (value as Dayjs[]).map((_) => _.format(props.format))\n    : (value as Dayjs).format(props.format)\n}\n\nconst parseUserInput = (value: Dayjs) => {\n  return dayjs(value, props.format).locale(lang.value)\n}\n\nconst getDefaultValue = () => {\n  const parseDate = dayjs(defaultValue.value).locale(lang.value)\n  if (!defaultValue.value) {\n    const defaultTimeDValue = defaultTimeD.value\n    return dayjs()\n      .hour(defaultTimeDValue.hour())\n      .minute(defaultTimeDValue.minute())\n      .second(defaultTimeDValue.second())\n      .locale(lang.value)\n  }\n  return parseDate\n}\n\nconst handleFocusPicker = async () => {\n  if (['week', 'month', 'year', 'date'].includes(selectionMode.value)) {\n    currentViewRef.value?.focus()\n    if (selectionMode.value === 'week') {\n      handleKeyControl(EVENT_CODE.down)\n    }\n  }\n}\n\nconst handleKeydownTable = (event: KeyboardEvent) => {\n  const { code } = event\n  const validCode = [\n    EVENT_CODE.up,\n    EVENT_CODE.down,\n    EVENT_CODE.left,\n    EVENT_CODE.right,\n    EVENT_CODE.home,\n    EVENT_CODE.end,\n    EVENT_CODE.pageUp,\n    EVENT_CODE.pageDown,\n  ]\n  if (validCode.includes(code)) {\n    handleKeyControl(code)\n    event.stopPropagation()\n    event.preventDefault()\n  }\n  if (\n    [EVENT_CODE.enter, EVENT_CODE.space, EVENT_CODE.numpadEnter].includes(\n      code\n    ) &&\n    userInputDate.value === null &&\n    userInputTime.value === null\n  ) {\n    event.preventDefault()\n    emit(innerDate.value, false)\n  }\n}\n\nconst handleKeyControl = (code: string) => {\n  type KeyControlMappingCallableOffset = (date: Date, step?: number) => number\n  type KeyControl = {\n    [key: string]:\n      | number\n      | KeyControlMappingCallableOffset\n      | ((date: Date, step: number) => any)\n    offset: (date: Date, step: number) => any\n  }\n  interface KeyControlMapping {\n    [key: string]: KeyControl\n  }\n\n  const { up, down, left, right, home, end, pageUp, pageDown } = EVENT_CODE\n  const mapping: KeyControlMapping = {\n    year: {\n      [up]: -4,\n      [down]: 4,\n      [left]: -1,\n      [right]: 1,\n      offset: (date: Date, step: number) =>\n        date.setFullYear(date.getFullYear() + step),\n    },\n    month: {\n      [up]: -4,\n      [down]: 4,\n      [left]: -1,\n      [right]: 1,\n      offset: (date: Date, step: number) =>\n        date.setMonth(date.getMonth() + step),\n    },\n    week: {\n      [up]: -1,\n      [down]: 1,\n      [left]: -1,\n      [right]: 1,\n      offset: (date: Date, step: number) =>\n        date.setDate(date.getDate() + step * 7),\n    },\n    date: {\n      [up]: -7,\n      [down]: 7,\n      [left]: -1,\n      [right]: 1,\n      [home]: (date: Date) => -date.getDay(),\n      [end]: (date: Date) => -date.getDay() + 6,\n      [pageUp]: (date: Date) =>\n        -new Date(date.getFullYear(), date.getMonth(), 0).getDate(),\n      [pageDown]: (date: Date) =>\n        new Date(date.getFullYear(), date.getMonth() + 1, 0).getDate(),\n      offset: (date: Date, step: number) => date.setDate(date.getDate() + step),\n    },\n  }\n\n  const newDate = innerDate.value.toDate()\n  while (Math.abs(innerDate.value.diff(newDate, 'year', true)) < 1) {\n    const map = mapping[keyboardMode.value]\n    if (!map) return\n    map.offset(\n      newDate,\n      isFunction(map[code])\n        ? (map[code] as unknown as KeyControlMappingCallableOffset)(newDate)\n        : (map[code] as number) ?? 0\n    )\n    if (disabledDate && disabledDate(newDate)) {\n      break\n    }\n    const result = dayjs(newDate).locale(lang.value)\n    innerDate.value = result\n    contextEmit('pick', result, true)\n    break\n  }\n}\n\nconst handlePanelChange = (mode: 'month' | 'year') => {\n  contextEmit('panel-change', innerDate.value.toDate(), mode, currentView.value)\n}\n\nwatch(\n  () => selectionMode.value,\n  (val) => {\n    if (['month', 'year'].includes(val)) {\n      currentView.value = val\n      return\n    } else if (val === 'years') {\n      currentView.value = 'year'\n      return\n    } else if (val === 'months') {\n      currentView.value = 'month'\n      return\n    }\n    currentView.value = 'date'\n  },\n  { immediate: true }\n)\n\nwatch(\n  () => currentView.value,\n  () => {\n    popper?.updatePopper()\n  }\n)\n\nwatch(\n  () => defaultValue.value,\n  (val) => {\n    if (val) {\n      innerDate.value = getDefaultValue()\n    }\n  },\n  { immediate: true }\n)\n\nwatch(\n  () => props.parsedValue,\n  (val) => {\n    if (val) {\n      if (isMultipleType.value) return\n      if (Array.isArray(val)) return\n      innerDate.value = val\n    } else {\n      innerDate.value = getDefaultValue()\n    }\n  },\n  { immediate: true }\n)\n\ncontextEmit('set-picker-option', ['isValidValue', isValidValue])\ncontextEmit('set-picker-option', ['formatToString', formatToString])\ncontextEmit('set-picker-option', ['parseUserInput', parseUserInput])\ncontextEmit('set-picker-option', ['handleFocusPicker', handleFocusPicker])\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport { panelRangeSharedProps, panelSharedProps } from './shared'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const panelDateRangeProps = buildProps({\n  ...panelSharedProps,\n  ...panelRangeSharedProps,\n  visible: Boolean,\n} as const)\n\nexport type PanelDateRangeProps = ExtractPropTypes<typeof panelDateRangeProps>\n", "import { getCurrentInstance, useAttrs, useSlots } from 'vue'\nimport dayjs from 'dayjs'\nimport { isFunction } from '@element-plus/utils'\n\nimport type { SetupContext } from 'vue'\nimport type { useLocale } from '@element-plus/hooks'\nimport type { RangePickerSharedEmits } from '../props/shared'\n\n// FIXME: extract this to `date-picker.ts`\nexport type Shortcut = {\n  text: string\n  value: [Date, Date] | (() => [Date, Date])\n  onClick?: (ctx: Omit<SetupContext<RangePickerSharedEmits>, 'expose'>) => void\n}\n\nexport const useShortcut = (lang: ReturnType<typeof useLocale>['lang']) => {\n  const { emit } = getCurrentInstance()!\n  const attrs = useAttrs()\n  const slots = useSlots()\n\n  const handleShortcutClick = (shortcut: Shortcut) => {\n    const shortcutValues = isFunction(shortcut.value)\n      ? shortcut.value()\n      : shortcut.value\n\n    if (shortcutValues) {\n      emit('pick', [\n        dayjs(shortcutValues[0]).locale(lang.value),\n        dayjs(shortcutValues[1]).locale(lang.value),\n      ])\n      return\n    }\n    if (shortcut.onClick) {\n      shortcut.onClick({\n        attrs,\n        slots,\n        emit,\n      })\n    }\n  }\n\n  return handleShortcutClick\n}\n", "import { getCurrentInstance, inject, ref, unref, watch } from 'vue'\nimport { isArray } from '@element-plus/utils'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { getDefaultValue, isValidRange } from '../utils'\nimport { ROOT_PICKER_INJECTION_KEY } from '../constants'\nimport { useShortcut } from './use-shortcut'\n\nimport type { Ref } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type { PanelRangeSharedProps, RangeState } from '../props/shared'\nimport type { DefaultValue } from '../utils'\n\ntype UseRangePickerProps = {\n  onParsedValueChanged: (\n    minDate: Dayjs | undefined,\n    maxDate: Dayjs | undefined\n  ) => void\n  defaultValue: Ref<DefaultValue>\n  leftDate: Ref<Dayjs>\n  rightDate: Ref<Dayjs>\n  unit: 'month' | 'year'\n}\n\nexport const useRangePicker = (\n  props: PanelRangeSharedProps,\n  {\n    defaultValue,\n    leftDate,\n    rightDate,\n    unit,\n\n    onParsedValueChanged,\n  }: UseRangePickerProps\n) => {\n  const { emit } = getCurrentInstance()!\n\n  const { pickerNs } = inject(ROOT_PICKER_INJECTION_KEY)!\n  const drpNs = useNamespace('date-range-picker')\n  const { t, lang } = useLocale()\n  const handleShortcutClick = useShortcut(lang)\n  const minDate = ref<Dayjs>()\n  const maxDate = ref<Dayjs>()\n  const rangeState = ref<RangeState>({\n    endDate: null,\n    selecting: false,\n  })\n\n  const handleChangeRange = (val: RangeState) => {\n    rangeState.value = val\n  }\n\n  const handleRangeConfirm = (visible = false) => {\n    const _minDate = unref(minDate)\n    const _maxDate = unref(maxDate)\n\n    if (isValidRange([_minDate, _maxDate])) {\n      emit('pick', [_minDate, _maxDate], visible)\n    }\n  }\n\n  const onSelect = (selecting: boolean) => {\n    rangeState.value.selecting = selecting\n    if (!selecting) {\n      rangeState.value.endDate = null\n    }\n  }\n\n  const onReset = (parsedValue: PanelRangeSharedProps['parsedValue']) => {\n    if (isArray(parsedValue) && parsedValue.length === 2) {\n      const [start, end] = parsedValue\n      minDate.value = start\n      leftDate.value = start\n      maxDate.value = end\n      onParsedValueChanged(unref(minDate), unref(maxDate))\n    } else {\n      restoreDefault()\n    }\n  }\n\n  const restoreDefault = () => {\n    const [start, end] = getDefaultValue(unref(defaultValue), {\n      lang: unref(lang),\n      unit,\n      unlinkPanels: props.unlinkPanels,\n    })\n    minDate.value = undefined\n    maxDate.value = undefined\n    leftDate.value = start\n    rightDate.value = end\n  }\n\n  watch(\n    defaultValue,\n    (val) => {\n      if (val) {\n        restoreDefault()\n      }\n    },\n    { immediate: true }\n  )\n\n  watch(() => props.parsedValue, onReset, { immediate: true })\n\n  return {\n    minDate,\n    maxDate,\n    rangeState,\n    lang,\n    ppNs: pickerNs,\n    drpNs,\n\n    handleChangeRange,\n    handleRangeConfirm,\n    handleShortcutClick,\n    onSelect,\n    onReset,\n    t,\n  }\n}\n", "<template>\n  <div\n    :class=\"[\n      ppNs.b(),\n      drpNs.b(),\n      {\n        'has-sidebar': $slots.sidebar || hasShortcuts,\n        'has-time': showTime,\n      },\n    ]\"\n  >\n    <div :class=\"ppNs.e('body-wrapper')\">\n      <slot name=\"sidebar\" :class=\"ppNs.e('sidebar')\" />\n      <div v-if=\"hasShortcuts\" :class=\"ppNs.e('sidebar')\">\n        <button\n          v-for=\"(shortcut, key) in shortcuts\"\n          :key=\"key\"\n          type=\"button\"\n          :class=\"ppNs.e('shortcut')\"\n          @click=\"handleShortcutClick(shortcut)\"\n        >\n          {{ shortcut.text }}\n        </button>\n      </div>\n      <div :class=\"ppNs.e('body')\">\n        <div v-if=\"showTime\" :class=\"drpNs.e('time-header')\">\n          <span :class=\"drpNs.e('editors-wrap')\">\n            <span :class=\"drpNs.e('time-picker-wrap')\">\n              <el-input\n                size=\"small\"\n                :disabled=\"rangeState.selecting\"\n                :placeholder=\"t('el.datepicker.startDate')\"\n                :class=\"drpNs.e('editor')\"\n                :model-value=\"minVisibleDate\"\n                :validate-event=\"false\"\n                @input=\"(val) => handleDateInput(val, 'min')\"\n                @change=\"(val) => handleDateChange(val, 'min')\"\n              />\n            </span>\n            <span\n              v-clickoutside=\"handleMinTimeClose\"\n              :class=\"drpNs.e('time-picker-wrap')\"\n            >\n              <el-input\n                size=\"small\"\n                :class=\"drpNs.e('editor')\"\n                :disabled=\"rangeState.selecting\"\n                :placeholder=\"t('el.datepicker.startTime')\"\n                :model-value=\"minVisibleTime\"\n                :validate-event=\"false\"\n                @focus=\"minTimePickerVisible = true\"\n                @input=\"(val) => handleTimeInput(val, 'min')\"\n                @change=\"(val) => handleTimeChange(val, 'min')\"\n              />\n              <time-pick-panel\n                :visible=\"minTimePickerVisible\"\n                :format=\"timeFormat\"\n                datetime-role=\"start\"\n                :parsed-value=\"leftDate\"\n                @pick=\"handleMinTimePick\"\n              />\n            </span>\n          </span>\n          <span>\n            <el-icon><arrow-right /></el-icon>\n          </span>\n          <span :class=\"drpNs.e('editors-wrap')\" class=\"is-right\">\n            <span :class=\"drpNs.e('time-picker-wrap')\">\n              <el-input\n                size=\"small\"\n                :class=\"drpNs.e('editor')\"\n                :disabled=\"rangeState.selecting\"\n                :placeholder=\"t('el.datepicker.endDate')\"\n                :model-value=\"maxVisibleDate\"\n                :readonly=\"!minDate\"\n                :validate-event=\"false\"\n                @input=\"(val) => handleDateInput(val, 'max')\"\n                @change=\"(val) => handleDateChange(val, 'max')\"\n              />\n            </span>\n            <span\n              v-clickoutside=\"handleMaxTimeClose\"\n              :class=\"drpNs.e('time-picker-wrap')\"\n            >\n              <el-input\n                size=\"small\"\n                :class=\"drpNs.e('editor')\"\n                :disabled=\"rangeState.selecting\"\n                :placeholder=\"t('el.datepicker.endTime')\"\n                :model-value=\"maxVisibleTime\"\n                :readonly=\"!minDate\"\n                :validate-event=\"false\"\n                @focus=\"minDate && (maxTimePickerVisible = true)\"\n                @input=\"(val) => handleTimeInput(val, 'max')\"\n                @change=\"(val) => handleTimeChange(val, 'max')\"\n              />\n              <time-pick-panel\n                datetime-role=\"end\"\n                :visible=\"maxTimePickerVisible\"\n                :format=\"timeFormat\"\n                :parsed-value=\"rightDate\"\n                @pick=\"handleMaxTimePick\"\n              />\n            </span>\n          </span>\n        </div>\n        <div :class=\"[ppNs.e('content'), drpNs.e('content')]\" class=\"is-left\">\n          <div :class=\"drpNs.e('header')\">\n            <button\n              type=\"button\"\n              :class=\"ppNs.e('icon-btn')\"\n              :aria-label=\"t(`el.datepicker.prevYear`)\"\n              class=\"d-arrow-left\"\n              @click=\"leftPrevYear\"\n            >\n              <slot name=\"prev-year\">\n                <el-icon><d-arrow-left /></el-icon>\n              </slot>\n            </button>\n            <button\n              type=\"button\"\n              :class=\"ppNs.e('icon-btn')\"\n              :aria-label=\"t(`el.datepicker.prevMonth`)\"\n              class=\"arrow-left\"\n              @click=\"leftPrevMonth\"\n            >\n              <slot name=\"prev-month\">\n                <el-icon><arrow-left /></el-icon>\n              </slot>\n            </button>\n            <button\n              v-if=\"unlinkPanels\"\n              type=\"button\"\n              :disabled=\"!enableYearArrow\"\n              :class=\"[ppNs.e('icon-btn'), { 'is-disabled': !enableYearArrow }]\"\n              :aria-label=\"t(`el.datepicker.nextYear`)\"\n              class=\"d-arrow-right\"\n              @click=\"leftNextYear\"\n            >\n              <slot name=\"next-year\">\n                <el-icon><d-arrow-right /></el-icon>\n              </slot>\n            </button>\n            <button\n              v-if=\"unlinkPanels\"\n              type=\"button\"\n              :disabled=\"!enableMonthArrow\"\n              :class=\"[\n                ppNs.e('icon-btn'),\n                { 'is-disabled': !enableMonthArrow },\n              ]\"\n              :aria-label=\"t(`el.datepicker.nextMonth`)\"\n              class=\"arrow-right\"\n              @click=\"leftNextMonth\"\n            >\n              <slot name=\"next-month\">\n                <el-icon><arrow-right /></el-icon>\n              </slot>\n            </button>\n            <div>{{ leftLabel }}</div>\n          </div>\n          <date-table\n            selection-mode=\"range\"\n            :date=\"leftDate\"\n            :min-date=\"minDate\"\n            :max-date=\"maxDate\"\n            :range-state=\"rangeState\"\n            :disabled-date=\"disabledDate\"\n            :cell-class-name=\"cellClassName\"\n            @changerange=\"handleChangeRange\"\n            @pick=\"handleRangePick\"\n            @select=\"onSelect\"\n          />\n        </div>\n        <div :class=\"[ppNs.e('content'), drpNs.e('content')]\" class=\"is-right\">\n          <div :class=\"drpNs.e('header')\">\n            <button\n              v-if=\"unlinkPanels\"\n              type=\"button\"\n              :disabled=\"!enableYearArrow\"\n              :class=\"[ppNs.e('icon-btn'), { 'is-disabled': !enableYearArrow }]\"\n              :aria-label=\"t(`el.datepicker.prevYear`)\"\n              class=\"d-arrow-left\"\n              @click=\"rightPrevYear\"\n            >\n              <slot name=\"prev-year\">\n                <el-icon><d-arrow-left /></el-icon>\n              </slot>\n            </button>\n            <button\n              v-if=\"unlinkPanels\"\n              type=\"button\"\n              :disabled=\"!enableMonthArrow\"\n              :class=\"[\n                ppNs.e('icon-btn'),\n                { 'is-disabled': !enableMonthArrow },\n              ]\"\n              :aria-label=\"t(`el.datepicker.prevMonth`)\"\n              class=\"arrow-left\"\n              @click=\"rightPrevMonth\"\n            >\n              <slot name=\"prev-month\">\n                <el-icon><arrow-left /></el-icon>\n              </slot>\n            </button>\n            <button\n              type=\"button\"\n              :aria-label=\"t(`el.datepicker.nextYear`)\"\n              :class=\"ppNs.e('icon-btn')\"\n              class=\"d-arrow-right\"\n              @click=\"rightNextYear\"\n            >\n              <slot name=\"next-year\">\n                <el-icon><d-arrow-right /></el-icon>\n              </slot>\n            </button>\n            <button\n              type=\"button\"\n              :class=\"ppNs.e('icon-btn')\"\n              :aria-label=\"t(`el.datepicker.nextMonth`)\"\n              class=\"arrow-right\"\n              @click=\"rightNextMonth\"\n            >\n              <slot name=\"next-month\">\n                <el-icon><arrow-right /></el-icon>\n              </slot>\n            </button>\n            <div>{{ rightLabel }}</div>\n          </div>\n          <date-table\n            selection-mode=\"range\"\n            :date=\"rightDate\"\n            :min-date=\"minDate\"\n            :max-date=\"maxDate\"\n            :range-state=\"rangeState\"\n            :disabled-date=\"disabledDate\"\n            :cell-class-name=\"cellClassName\"\n            @changerange=\"handleChangeRange\"\n            @pick=\"handleRangePick\"\n            @select=\"onSelect\"\n          />\n        </div>\n      </div>\n    </div>\n    <div v-if=\"showTime\" :class=\"ppNs.e('footer')\">\n      <el-button\n        v-if=\"clearable\"\n        text\n        size=\"small\"\n        :class=\"ppNs.e('link-btn')\"\n        @click=\"handleClear\"\n      >\n        {{ t('el.datepicker.clear') }}\n      </el-button>\n      <el-button\n        plain\n        size=\"small\"\n        :class=\"ppNs.e('link-btn')\"\n        :disabled=\"btnDisabled\"\n        @click=\"handleRangeConfirm(false)\"\n      >\n        {{ t('el.datepicker.confirm') }}\n      </el-button>\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, ref, toRef, unref, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport { isArray } from '@element-plus/utils'\nimport { useLocale } from '@element-plus/hooks'\nimport ElButton from '@element-plus/components/button'\nimport ElInput from '@element-plus/components/input'\nimport {\n  TimePickPanel,\n  extractDateFormat,\n  extractTimeFormat,\n} from '@element-plus/components/time-picker'\nimport ElIcon from '@element-plus/components/icon'\nimport {\n  ArrowLeft,\n  ArrowRight,\n  DArrowLeft,\n  DArrowRight,\n} from '@element-plus/icons-vue'\nimport { panelDateRangeProps } from '../props/panel-date-range'\nimport { useRangePicker } from '../composables/use-range-picker'\nimport { getDefaultValue, isValidRange } from '../utils'\nimport DateTable from './basic-date-table.vue'\n\nimport type { Dayjs } from 'dayjs'\n\ntype ChangeType = 'min' | 'max'\ntype UserInput = {\n  min: string | null\n  max: string | null\n}\n\nconst props = defineProps(panelDateRangeProps)\nconst emit = defineEmits([\n  'pick',\n  'set-picker-option',\n  'calendar-change',\n  'panel-change',\n])\n\nconst unit = 'month'\n// FIXME: fix the type for ep picker\nconst pickerBase = inject('EP_PICKER_BASE') as any\nconst { disabledDate, cellClassName, defaultTime, clearable } = pickerBase.props\nconst format = toRef(pickerBase.props, 'format')\nconst shortcuts = toRef(pickerBase.props, 'shortcuts')\nconst defaultValue = toRef(pickerBase.props, 'defaultValue')\nconst { lang } = useLocale()\nconst leftDate = ref<Dayjs>(dayjs().locale(lang.value))\nconst rightDate = ref<Dayjs>(dayjs().locale(lang.value).add(1, unit))\n\nconst {\n  minDate,\n  maxDate,\n  rangeState,\n  ppNs,\n  drpNs,\n\n  handleChangeRange,\n  handleRangeConfirm,\n  handleShortcutClick,\n  onSelect,\n  onReset,\n  t,\n} = useRangePicker(props, {\n  defaultValue,\n  leftDate,\n  rightDate,\n  unit,\n  onParsedValueChanged,\n})\n\nwatch(\n  () => props.visible,\n  (visible) => {\n    if (!visible && rangeState.value.selecting) {\n      onReset(props.parsedValue)\n      onSelect(false)\n    }\n  }\n)\n\nconst dateUserInput = ref<UserInput>({\n  min: null,\n  max: null,\n})\n\nconst timeUserInput = ref<UserInput>({\n  min: null,\n  max: null,\n})\n\nconst leftLabel = computed(() => {\n  return `${leftDate.value.year()} ${t('el.datepicker.year')} ${t(\n    `el.datepicker.month${leftDate.value.month() + 1}`\n  )}`\n})\n\nconst rightLabel = computed(() => {\n  return `${rightDate.value.year()} ${t('el.datepicker.year')} ${t(\n    `el.datepicker.month${rightDate.value.month() + 1}`\n  )}`\n})\n\nconst leftYear = computed(() => {\n  return leftDate.value.year()\n})\n\nconst leftMonth = computed(() => {\n  return leftDate.value.month()\n})\n\nconst rightYear = computed(() => {\n  return rightDate.value.year()\n})\n\nconst rightMonth = computed(() => {\n  return rightDate.value.month()\n})\n\nconst hasShortcuts = computed(() => !!shortcuts.value.length)\n\nconst minVisibleDate = computed(() => {\n  if (dateUserInput.value.min !== null) return dateUserInput.value.min\n  if (minDate.value) return minDate.value.format(dateFormat.value)\n  return ''\n})\n\nconst maxVisibleDate = computed(() => {\n  if (dateUserInput.value.max !== null) return dateUserInput.value.max\n  if (maxDate.value || minDate.value)\n    return (maxDate.value || minDate.value)!.format(dateFormat.value)\n  return ''\n})\n\nconst minVisibleTime = computed(() => {\n  if (timeUserInput.value.min !== null) return timeUserInput.value.min\n  if (minDate.value) return minDate.value.format(timeFormat.value)\n  return ''\n})\n\nconst maxVisibleTime = computed(() => {\n  if (timeUserInput.value.max !== null) return timeUserInput.value.max\n  if (maxDate.value || minDate.value)\n    return (maxDate.value || minDate.value)!.format(timeFormat.value)\n  return ''\n})\n\nconst timeFormat = computed(() => {\n  return props.timeFormat || extractTimeFormat(format.value)\n})\n\nconst dateFormat = computed(() => {\n  return props.dateFormat || extractDateFormat(format.value)\n})\n\nconst isValidValue = (date: [Dayjs, Dayjs]) => {\n  return (\n    isValidRange(date) &&\n    (disabledDate\n      ? !disabledDate(date[0].toDate()) && !disabledDate(date[1].toDate())\n      : true)\n  )\n}\n\nconst leftPrevYear = () => {\n  leftDate.value = leftDate.value.subtract(1, 'year')\n  if (!props.unlinkPanels) {\n    rightDate.value = leftDate.value.add(1, 'month')\n  }\n  handlePanelChange('year')\n}\n\nconst leftPrevMonth = () => {\n  leftDate.value = leftDate.value.subtract(1, 'month')\n  if (!props.unlinkPanels) {\n    rightDate.value = leftDate.value.add(1, 'month')\n  }\n  handlePanelChange('month')\n}\n\nconst rightNextYear = () => {\n  if (!props.unlinkPanels) {\n    leftDate.value = leftDate.value.add(1, 'year')\n    rightDate.value = leftDate.value.add(1, 'month')\n  } else {\n    rightDate.value = rightDate.value.add(1, 'year')\n  }\n  handlePanelChange('year')\n}\n\nconst rightNextMonth = () => {\n  if (!props.unlinkPanels) {\n    leftDate.value = leftDate.value.add(1, 'month')\n    rightDate.value = leftDate.value.add(1, 'month')\n  } else {\n    rightDate.value = rightDate.value.add(1, 'month')\n  }\n  handlePanelChange('month')\n}\n\nconst leftNextYear = () => {\n  leftDate.value = leftDate.value.add(1, 'year')\n  handlePanelChange('year')\n}\n\nconst leftNextMonth = () => {\n  leftDate.value = leftDate.value.add(1, 'month')\n  handlePanelChange('month')\n}\n\nconst rightPrevYear = () => {\n  rightDate.value = rightDate.value.subtract(1, 'year')\n  handlePanelChange('year')\n}\n\nconst rightPrevMonth = () => {\n  rightDate.value = rightDate.value.subtract(1, 'month')\n  handlePanelChange('month')\n}\n\nconst handlePanelChange = (mode: 'month' | 'year') => {\n  emit(\n    'panel-change',\n    [leftDate.value.toDate(), rightDate.value.toDate()],\n    mode\n  )\n}\n\nconst enableMonthArrow = computed(() => {\n  const nextMonth = (leftMonth.value + 1) % 12\n  const yearOffset = leftMonth.value + 1 >= 12 ? 1 : 0\n  return (\n    props.unlinkPanels &&\n    new Date(leftYear.value + yearOffset, nextMonth) <\n      new Date(rightYear.value, rightMonth.value)\n  )\n})\n\nconst enableYearArrow = computed(() => {\n  return (\n    props.unlinkPanels &&\n    rightYear.value * 12 +\n      rightMonth.value -\n      (leftYear.value * 12 + leftMonth.value + 1) >=\n      12\n  )\n})\n\nconst btnDisabled = computed(() => {\n  return !(\n    minDate.value &&\n    maxDate.value &&\n    !rangeState.value.selecting &&\n    isValidRange([minDate.value, maxDate.value])\n  )\n})\n\nconst showTime = computed(\n  () => props.type === 'datetime' || props.type === 'datetimerange'\n)\n\nconst formatEmit = (emitDayjs: Dayjs | null, index?: number) => {\n  if (!emitDayjs) return\n  if (defaultTime) {\n    const defaultTimeD = dayjs(\n      defaultTime[index as number] || defaultTime\n    ).locale(lang.value)\n    return defaultTimeD\n      .year(emitDayjs.year())\n      .month(emitDayjs.month())\n      .date(emitDayjs.date())\n  }\n  return emitDayjs\n}\n\nconst handleRangePick = (\n  val: {\n    minDate: Dayjs\n    maxDate: Dayjs | null\n  },\n  close = true\n) => {\n  const min_ = val.minDate\n  const max_ = val.maxDate\n  const minDate_ = formatEmit(min_, 0)\n  const maxDate_ = formatEmit(max_, 1)\n\n  if (maxDate.value === maxDate_ && minDate.value === minDate_) {\n    return\n  }\n  emit('calendar-change', [min_.toDate(), max_ && max_.toDate()])\n  maxDate.value = maxDate_\n  minDate.value = minDate_\n\n  if (!close || showTime.value) return\n  handleRangeConfirm()\n}\n\nconst minTimePickerVisible = ref(false)\nconst maxTimePickerVisible = ref(false)\n\nconst handleMinTimeClose = () => {\n  minTimePickerVisible.value = false\n}\n\nconst handleMaxTimeClose = () => {\n  maxTimePickerVisible.value = false\n}\n\nconst handleDateInput = (value: string | null, type: ChangeType) => {\n  dateUserInput.value[type] = value\n  const parsedValueD = dayjs(value, dateFormat.value).locale(lang.value)\n  if (parsedValueD.isValid()) {\n    if (disabledDate && disabledDate(parsedValueD.toDate())) {\n      return\n    }\n    if (type === 'min') {\n      leftDate.value = parsedValueD\n      minDate.value = (minDate.value || leftDate.value)\n        .year(parsedValueD.year())\n        .month(parsedValueD.month())\n        .date(parsedValueD.date())\n      if (\n        !props.unlinkPanels &&\n        (!maxDate.value || maxDate.value.isBefore(minDate.value))\n      ) {\n        rightDate.value = parsedValueD.add(1, 'month')\n        maxDate.value = minDate.value.add(1, 'month')\n      }\n    } else {\n      rightDate.value = parsedValueD\n      maxDate.value = (maxDate.value || rightDate.value)\n        .year(parsedValueD.year())\n        .month(parsedValueD.month())\n        .date(parsedValueD.date())\n      if (\n        !props.unlinkPanels &&\n        (!minDate.value || minDate.value.isAfter(maxDate.value))\n      ) {\n        leftDate.value = parsedValueD.subtract(1, 'month')\n        minDate.value = maxDate.value.subtract(1, 'month')\n      }\n    }\n  }\n}\n\nconst handleDateChange = (_: unknown, type: ChangeType) => {\n  dateUserInput.value[type] = null\n}\n\nconst handleTimeInput = (value: string | null, type: ChangeType) => {\n  timeUserInput.value[type] = value\n  const parsedValueD = dayjs(value, timeFormat.value).locale(lang.value)\n\n  if (parsedValueD.isValid()) {\n    if (type === 'min') {\n      minTimePickerVisible.value = true\n      minDate.value = (minDate.value || leftDate.value)\n        .hour(parsedValueD.hour())\n        .minute(parsedValueD.minute())\n        .second(parsedValueD.second())\n    } else {\n      maxTimePickerVisible.value = true\n      maxDate.value = (maxDate.value || rightDate.value)\n        .hour(parsedValueD.hour())\n        .minute(parsedValueD.minute())\n        .second(parsedValueD.second())\n      rightDate.value = maxDate.value\n    }\n  }\n}\n\nconst handleTimeChange = (value: string | null, type: ChangeType) => {\n  timeUserInput.value[type] = null\n  if (type === 'min') {\n    leftDate.value = minDate.value!\n    minTimePickerVisible.value = false\n    if (!maxDate.value || maxDate.value.isBefore(minDate.value)) {\n      maxDate.value = minDate.value\n    }\n  } else {\n    rightDate.value = maxDate.value!\n    maxTimePickerVisible.value = false\n    if (maxDate.value && maxDate.value.isBefore(minDate.value)) {\n      minDate.value = maxDate.value\n    }\n  }\n}\n\nconst handleMinTimePick = (value: Dayjs, visible: boolean, first: boolean) => {\n  if (timeUserInput.value.min) return\n  if (value) {\n    leftDate.value = value\n    minDate.value = (minDate.value || leftDate.value)\n      .hour(value.hour())\n      .minute(value.minute())\n      .second(value.second())\n  }\n\n  if (!first) {\n    minTimePickerVisible.value = visible\n  }\n\n  if (!maxDate.value || maxDate.value.isBefore(minDate.value)) {\n    maxDate.value = minDate.value\n    rightDate.value = value\n  }\n}\n\nconst handleMaxTimePick = (\n  value: Dayjs | null,\n  visible: boolean,\n  first: boolean\n) => {\n  if (timeUserInput.value.max) return\n  if (value) {\n    rightDate.value = value\n    maxDate.value = (maxDate.value || rightDate.value)\n      .hour(value.hour())\n      .minute(value.minute())\n      .second(value.second())\n  }\n\n  if (!first) {\n    maxTimePickerVisible.value = visible\n  }\n\n  if (maxDate.value && maxDate.value.isBefore(minDate.value)) {\n    minDate.value = maxDate.value\n  }\n}\n\nconst handleClear = () => {\n  leftDate.value = getDefaultValue(unref(defaultValue), {\n    lang: unref(lang),\n    unit: 'month',\n    unlinkPanels: props.unlinkPanels,\n  })[0]\n  rightDate.value = leftDate.value.add(1, 'month')\n  maxDate.value = undefined\n  minDate.value = undefined\n  emit('pick', null)\n}\n\nconst formatToString = (value: Dayjs | Dayjs[]) => {\n  return isArray(value)\n    ? value.map((_) => _.format(format.value))\n    : value.format(format.value)\n}\n\nconst parseUserInput = (value: Dayjs | Dayjs[]) => {\n  return isArray(value)\n    ? value.map((_) => dayjs(_, format.value).locale(lang.value))\n    : dayjs(value, format.value).locale(lang.value)\n}\n\nfunction onParsedValueChanged(\n  minDate: Dayjs | undefined,\n  maxDate: Dayjs | undefined\n) {\n  if (props.unlinkPanels && maxDate) {\n    const minDateYear = minDate?.year() || 0\n    const minDateMonth = minDate?.month() || 0\n    const maxDateYear = maxDate.year()\n    const maxDateMonth = maxDate.month()\n    rightDate.value =\n      minDateYear === maxDateYear && minDateMonth === maxDateMonth\n        ? maxDate.add(1, unit)\n        : maxDate\n  } else {\n    rightDate.value = leftDate.value.add(1, unit)\n    if (maxDate) {\n      rightDate.value = rightDate.value\n        .hour(maxDate.hour())\n        .minute(maxDate.minute())\n        .second(maxDate.second())\n    }\n  }\n}\n\nemit('set-picker-option', ['isValidValue', isValidValue])\nemit('set-picker-option', ['parseUserInput', parseUserInput])\nemit('set-picker-option', ['formatToString', formatToString])\nemit('set-picker-option', ['handleClear', handleClear])\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport { panelRangeSharedProps } from './shared'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const panelMonthRangeProps = buildProps({\n  ...panelRangeSharedProps,\n} as const)\n\nexport const panelMonthRangeEmits = [\n  'pick',\n  'set-picker-option',\n  'calendar-change',\n]\n\nexport type PanelMonthRangeProps = ExtractPropTypes<typeof panelMonthRangeProps>\n", "import { computed } from 'vue'\nimport { useLocale } from '@element-plus/hooks'\nimport type { Ref, ToRef } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport const useMonthRangeHeader = ({\n  unlinkPanels,\n  leftDate,\n  rightDate,\n}: {\n  unlinkPanels: ToRef<boolean>\n  leftDate: Ref<Dayjs>\n  rightDate: Ref<Dayjs>\n}) => {\n  const { t } = useLocale()\n  const leftPrevYear = () => {\n    leftDate.value = leftDate.value.subtract(1, 'year')\n    if (!unlinkPanels.value) {\n      rightDate.value = rightDate.value.subtract(1, 'year')\n    }\n  }\n\n  const rightNextYear = () => {\n    if (!unlinkPanels.value) {\n      leftDate.value = leftDate.value.add(1, 'year')\n    }\n    rightDate.value = rightDate.value.add(1, 'year')\n  }\n\n  const leftNextYear = () => {\n    leftDate.value = leftDate.value.add(1, 'year')\n  }\n\n  const rightPrevYear = () => {\n    rightDate.value = rightDate.value.subtract(1, 'year')\n  }\n  const leftLabel = computed(() => {\n    return `${leftDate.value.year()} ${t('el.datepicker.year')}`\n  })\n\n  const rightLabel = computed(() => {\n    return `${rightDate.value.year()} ${t('el.datepicker.year')}`\n  })\n\n  const leftYear = computed(() => {\n    return leftDate.value.year()\n  })\n\n  const rightYear = computed(() => {\n    return rightDate.value.year() === leftDate.value.year()\n      ? leftDate.value.year() + 1\n      : rightDate.value.year()\n  })\n\n  return {\n    leftPrevYear,\n    rightNextYear,\n    leftNextYear,\n    rightPrevYear,\n    leftLabel,\n    rightLabel,\n    leftYear,\n    rightYear,\n  }\n}\n", "<template>\n  <div\n    :class=\"[\n      ppNs.b(),\n      drpNs.b(),\n      {\n        'has-sidebar': Boolean($slots.sidebar) || hasShortcuts,\n      },\n    ]\"\n  >\n    <div :class=\"ppNs.e('body-wrapper')\">\n      <slot name=\"sidebar\" :class=\"ppNs.e('sidebar')\" />\n      <div v-if=\"hasShortcuts\" :class=\"ppNs.e('sidebar')\">\n        <button\n          v-for=\"(shortcut, key) in shortcuts\"\n          :key=\"key\"\n          type=\"button\"\n          :class=\"ppNs.e('shortcut')\"\n          @click=\"handleShortcutClick(shortcut)\"\n        >\n          {{ shortcut.text }}\n        </button>\n      </div>\n      <div :class=\"ppNs.e('body')\">\n        <div :class=\"[ppNs.e('content'), drpNs.e('content')]\" class=\"is-left\">\n          <div :class=\"drpNs.e('header')\">\n            <button\n              type=\"button\"\n              :class=\"ppNs.e('icon-btn')\"\n              class=\"d-arrow-left\"\n              @click=\"leftPrevYear\"\n            >\n              <slot name=\"prev-year\">\n                <el-icon><d-arrow-left /></el-icon>\n              </slot>\n            </button>\n            <button\n              v-if=\"unlinkPanels\"\n              type=\"button\"\n              :disabled=\"!enableYearArrow\"\n              :class=\"[\n                ppNs.e('icon-btn'),\n                { [ppNs.is('disabled')]: !enableYearArrow },\n              ]\"\n              class=\"d-arrow-right\"\n              @click=\"leftNextYear\"\n            >\n              <slot name=\"next-year\">\n                <el-icon><d-arrow-right /></el-icon>\n              </slot>\n            </button>\n            <div>{{ leftLabel }}</div>\n          </div>\n          <month-table\n            selection-mode=\"range\"\n            :date=\"leftDate\"\n            :min-date=\"minDate\"\n            :max-date=\"maxDate\"\n            :range-state=\"rangeState\"\n            :disabled-date=\"disabledDate\"\n            @changerange=\"handleChangeRange\"\n            @pick=\"handleRangePick\"\n            @select=\"onSelect\"\n          />\n        </div>\n        <div :class=\"[ppNs.e('content'), drpNs.e('content')]\" class=\"is-right\">\n          <div :class=\"drpNs.e('header')\">\n            <button\n              v-if=\"unlinkPanels\"\n              type=\"button\"\n              :disabled=\"!enableYearArrow\"\n              :class=\"[ppNs.e('icon-btn'), { 'is-disabled': !enableYearArrow }]\"\n              class=\"d-arrow-left\"\n              @click=\"rightPrevYear\"\n            >\n              <slot name=\"prev-year\">\n                <el-icon><d-arrow-left /></el-icon>\n              </slot>\n            </button>\n            <button\n              type=\"button\"\n              :class=\"ppNs.e('icon-btn')\"\n              class=\"d-arrow-right\"\n              @click=\"rightNextYear\"\n            >\n              <slot name=\"next-year\">\n                <el-icon><d-arrow-right /></el-icon>\n              </slot>\n            </button>\n            <div>{{ rightLabel }}</div>\n          </div>\n          <month-table\n            selection-mode=\"range\"\n            :date=\"rightDate\"\n            :min-date=\"minDate\"\n            :max-date=\"maxDate\"\n            :range-state=\"rangeState\"\n            :disabled-date=\"disabledDate\"\n            @changerange=\"handleChangeRange\"\n            @pick=\"handleRangePick\"\n            @select=\"onSelect\"\n          />\n        </div>\n      </div>\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, ref, toRef, unref } from 'vue'\nimport dayjs from 'dayjs'\nimport ElIcon from '@element-plus/components/icon'\nimport { isArray } from '@element-plus/utils'\nimport { useLocale } from '@element-plus/hooks'\nimport { DArrowLeft, DArrowRight } from '@element-plus/icons-vue'\nimport { getDefaultValue, isValidRange } from '../utils'\nimport {\n  panelMonthRangeEmits,\n  panelMonthRangeProps,\n} from '../props/panel-month-range'\nimport { useMonthRangeHeader } from '../composables/use-month-range-header'\nimport { useRangePicker } from '../composables/use-range-picker'\nimport MonthTable from './basic-month-table.vue'\n\nimport type { Dayjs } from 'dayjs'\n\ndefineOptions({\n  name: 'DatePickerMonthRange',\n})\n\nconst props = defineProps(panelMonthRangeProps)\nconst emit = defineEmits(panelMonthRangeEmits)\nconst unit = 'year'\n\nconst { lang } = useLocale()\nconst pickerBase = inject('EP_PICKER_BASE') as any\nconst { shortcuts, disabledDate } = pickerBase.props\nconst format = toRef(pickerBase.props, 'format')\nconst defaultValue = toRef(pickerBase.props, 'defaultValue')\nconst leftDate = ref(dayjs().locale(lang.value))\nconst rightDate = ref(dayjs().locale(lang.value).add(1, unit))\n\nconst {\n  minDate,\n  maxDate,\n  rangeState,\n  ppNs,\n  drpNs,\n\n  handleChangeRange,\n  handleRangeConfirm,\n  handleShortcutClick,\n  onSelect,\n} = useRangePicker(props, {\n  defaultValue,\n  leftDate,\n  rightDate,\n  unit,\n  onParsedValueChanged,\n})\n\nconst hasShortcuts = computed(() => !!shortcuts.length)\n\nconst {\n  leftPrevYear,\n  rightNextYear,\n  leftNextYear,\n  rightPrevYear,\n  leftLabel,\n  rightLabel,\n  leftYear,\n  rightYear,\n} = useMonthRangeHeader({\n  unlinkPanels: toRef(props, 'unlinkPanels'),\n  leftDate,\n  rightDate,\n})\n\nconst enableYearArrow = computed(() => {\n  return props.unlinkPanels && rightYear.value > leftYear.value + 1\n})\n\ntype RangePickValue = {\n  minDate: Dayjs\n  maxDate: Dayjs\n}\n\nconst handleRangePick = (val: RangePickValue, close = true) => {\n  // const defaultTime = props.defaultTime || []\n  // const minDate_ = modifyWithTimeString(val.minDate, defaultTime[0])\n  // const maxDate_ = modifyWithTimeString(val.maxDate, defaultTime[1])\n  // todo\n  const minDate_ = val.minDate\n  const maxDate_ = val.maxDate\n  if (maxDate.value === maxDate_ && minDate.value === minDate_) {\n    return\n  }\n  emit('calendar-change', [minDate_.toDate(), maxDate_ && maxDate_.toDate()])\n  maxDate.value = maxDate_\n  minDate.value = minDate_\n\n  if (!close) return\n  handleRangeConfirm()\n}\n\nconst handleClear = () => {\n  leftDate.value = getDefaultValue(unref(defaultValue), {\n    lang: unref(lang),\n    unit: 'year',\n    unlinkPanels: props.unlinkPanels,\n  })[0]\n  rightDate.value = leftDate.value.add(1, 'year')\n  emit('pick', null)\n}\n\nconst formatToString = (value: Dayjs | Dayjs[]) => {\n  return isArray(value)\n    ? value.map((_) => _.format(format.value))\n    : value.format(format.value)\n}\n\nconst parseUserInput = (value: Dayjs | Dayjs[]) => {\n  return isArray(value)\n    ? value.map((_) => dayjs(_, format.value).locale(lang.value))\n    : dayjs(value, format.value).locale(lang.value)\n}\n\nfunction onParsedValueChanged(\n  minDate: Dayjs | undefined,\n  maxDate: Dayjs | undefined\n) {\n  if (props.unlinkPanels && maxDate) {\n    const minDateYear = minDate?.year() || 0\n    const maxDateYear = maxDate.year()\n    rightDate.value =\n      minDateYear === maxDateYear ? maxDate.add(1, unit) : maxDate\n  } else {\n    rightDate.value = leftDate.value.add(1, unit)\n  }\n}\n\nemit('set-picker-option', ['isValidValue', isValidRange])\nemit('set-picker-option', ['formatToString', formatToString])\nemit('set-picker-option', ['parseUserInput', parseUserInput])\nemit('set-picker-option', ['handleClear', handleClear])\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport { panelRangeSharedProps } from './shared'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const panelYearRangeProps = buildProps({\n  ...panelRangeSharedProps,\n} as const)\n\nexport const panelYearRangeEmits = [\n  'pick',\n  'set-picker-option',\n  'calendar-change',\n]\n\nexport type PanelYearRangeProps = ExtractPropTypes<typeof panelYearRangeProps>\n", "import { computed } from 'vue'\nimport type { Ref, ToRef } from 'vue'\nimport type { Dayjs } from 'dayjs'\n\nexport const useYearRangeHeader = ({\n  unlinkPanels,\n  leftDate,\n  rightDate,\n}: {\n  unlinkPanels: ToRef<boolean>\n  leftDate: Ref<Dayjs>\n  rightDate: Ref<Dayjs>\n}) => {\n  const leftPrevYear = () => {\n    leftDate.value = leftDate.value.subtract(10, 'year')\n    if (!unlinkPanels.value) {\n      rightDate.value = rightDate.value.subtract(10, 'year')\n    }\n  }\n\n  const rightNextYear = () => {\n    if (!unlinkPanels.value) {\n      leftDate.value = leftDate.value.add(10, 'year')\n    }\n    rightDate.value = rightDate.value.add(10, 'year')\n  }\n\n  const leftNextYear = () => {\n    leftDate.value = leftDate.value.add(10, 'year')\n  }\n\n  const rightPrevYear = () => {\n    rightDate.value = rightDate.value.subtract(10, 'year')\n  }\n\n  const leftLabel = computed(() => {\n    const leftStartDate = Math.floor(leftDate.value.year() / 10) * 10\n    return `${leftStartDate}-${leftStartDate + 9}`\n  })\n\n  const rightLabel = computed(() => {\n    const rightStartDate = Math.floor(rightDate.value.year() / 10) * 10\n    return `${rightStartDate}-${rightStartDate + 9}`\n  })\n\n  const leftYear = computed(() => {\n    const leftEndDate = Math.floor(leftDate.value.year() / 10) * 10 + 9\n    return leftEndDate\n  })\n\n  const rightYear = computed(() => {\n    const rightStartDate = Math.floor(rightDate.value.year() / 10) * 10\n    return rightStartDate\n  })\n\n  return {\n    leftPrevYear,\n    rightNextYear,\n    leftNextYear,\n    rightPrevYear,\n    leftLabel,\n    rightLabel,\n    leftYear,\n    rightYear,\n  }\n}\n", "<template>\n  <div :class=\"panelKls\">\n    <div :class=\"ppNs.e('body-wrapper')\">\n      <slot name=\"sidebar\" :class=\"ppNs.e('sidebar')\" />\n      <div v-if=\"hasShortcuts\" :class=\"ppNs.e('sidebar')\">\n        <button\n          v-for=\"(shortcut, key) in shortcuts\"\n          :key=\"key\"\n          type=\"button\"\n          :class=\"ppNs.e('shortcut')\"\n          @click=\"handleShortcutClick(shortcut)\"\n        >\n          {{ shortcut.text }}\n        </button>\n      </div>\n      <div :class=\"ppNs.e('body')\">\n        <div :class=\"leftPanelKls.content\">\n          <div :class=\"drpNs.e('header')\">\n            <button\n              type=\"button\"\n              :class=\"leftPanelKls.arrowLeftBtn\"\n              @click=\"leftPrevYear\"\n            >\n              <slot name=\"prev-year\">\n                <el-icon><d-arrow-left /></el-icon>\n              </slot>\n            </button>\n            <button\n              v-if=\"unlinkPanels\"\n              type=\"button\"\n              :disabled=\"!enableYearArrow\"\n              :class=\"leftPanelKls.arrowRightBtn\"\n              @click=\"leftNextYear\"\n            >\n              <slot name=\"next-year\">\n                <el-icon><d-arrow-right /></el-icon>\n              </slot>\n            </button>\n            <div>{{ leftLabel }}</div>\n          </div>\n          <year-table\n            selection-mode=\"range\"\n            :date=\"leftDate\"\n            :min-date=\"minDate\"\n            :max-date=\"maxDate\"\n            :range-state=\"rangeState\"\n            :disabled-date=\"disabledDate\"\n            @changerange=\"handleChangeRange\"\n            @pick=\"handleRangePick\"\n            @select=\"onSelect\"\n          />\n        </div>\n        <div :class=\"rightPanelKls.content\">\n          <div :class=\"drpNs.e('header')\">\n            <button\n              v-if=\"unlinkPanels\"\n              type=\"button\"\n              :disabled=\"!enableYearArrow\"\n              :class=\"rightPanelKls.arrowLeftBtn\"\n              @click=\"rightPrevYear\"\n            >\n              <slot name=\"prev-year\">\n                <el-icon><d-arrow-left /></el-icon>\n              </slot>\n            </button>\n            <button\n              type=\"button\"\n              :class=\"rightPanelKls.arrowRightBtn\"\n              @click=\"rightNextYear\"\n            >\n              <slot name=\"next-year\">\n                <el-icon><d-arrow-right /></el-icon>\n              </slot>\n            </button>\n            <div>{{ rightLabel }}</div>\n          </div>\n          <year-table\n            selection-mode=\"range\"\n            :date=\"rightDate\"\n            :min-date=\"minDate\"\n            :max-date=\"maxDate\"\n            :range-state=\"rangeState\"\n            :disabled-date=\"disabledDate\"\n            @changerange=\"handleChangeRange\"\n            @pick=\"handleRangePick\"\n            @select=\"onSelect\"\n          />\n        </div>\n      </div>\n    </div>\n  </div>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, inject, ref, toRef, useSlots, watch } from 'vue'\nimport dayjs from 'dayjs'\nimport { isArray } from '@element-plus/utils'\nimport { DArrowLeft, DArrowRight } from '@element-plus/icons-vue'\nimport ElIcon from '@element-plus/components/icon'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport {\n  panelYearRangeEmits,\n  panelYearRangeProps,\n} from '../props/panel-year-range'\nimport { useShortcut } from '../composables/use-shortcut'\nimport { useYearRangeHeader } from '../composables/use-year-range-header'\nimport { isValidRange } from '../utils'\nimport { ROOT_PICKER_INJECTION_KEY } from '../constants'\nimport YearTable from './basic-year-table.vue'\n\nimport type { Dayjs } from 'dayjs'\nimport type { RangeState } from '../props/shared'\n\ndefineOptions({\n  name: 'DatePickerYearRange',\n})\n\nconst props = defineProps(panelYearRangeProps)\nconst emit = defineEmits(panelYearRangeEmits)\n\nconst { lang } = useLocale()\nconst leftDate = ref(dayjs().locale(lang.value))\nconst rightDate = ref(leftDate.value.add(10, 'year'))\nconst { pickerNs: ppNs } = inject(ROOT_PICKER_INJECTION_KEY)!\nconst drpNs = useNamespace('date-range-picker')\n\nconst hasShortcuts = computed(() => !!shortcuts.length)\n\nconst panelKls = computed(() => [\n  ppNs.b(),\n  drpNs.b(),\n  {\n    'has-sidebar': Boolean(useSlots().sidebar) || hasShortcuts.value,\n  },\n])\n\nconst leftPanelKls = computed(() => {\n  return {\n    content: [ppNs.e('content'), drpNs.e('content'), 'is-left'],\n    arrowLeftBtn: [ppNs.e('icon-btn'), 'd-arrow-left'],\n    arrowRightBtn: [\n      ppNs.e('icon-btn'),\n      { [ppNs.is('disabled')]: !enableYearArrow.value },\n      'd-arrow-right',\n    ],\n  }\n})\n\nconst rightPanelKls = computed(() => {\n  return {\n    content: [ppNs.e('content'), drpNs.e('content'), 'is-right'],\n    arrowLeftBtn: [\n      ppNs.e('icon-btn'),\n      { 'is-disabled': !enableYearArrow.value },\n      'd-arrow-left',\n    ],\n    arrowRightBtn: [ppNs.e('icon-btn'), 'd-arrow-right'],\n  }\n})\n\nconst handleShortcutClick = useShortcut(lang)\n\nconst {\n  leftPrevYear,\n  rightNextYear,\n  leftNextYear,\n  rightPrevYear,\n  leftLabel,\n  rightLabel,\n  leftYear,\n  rightYear,\n} = useYearRangeHeader({\n  unlinkPanels: toRef(props, 'unlinkPanels'),\n  leftDate,\n  rightDate,\n})\n\nconst enableYearArrow = computed(() => {\n  return props.unlinkPanels && rightYear.value > leftYear.value + 1\n})\n\nconst minDate = ref<Dayjs>()\nconst maxDate = ref<Dayjs>()\n\nconst rangeState = ref<RangeState>({\n  endDate: null,\n  selecting: false,\n})\n\nconst handleChangeRange = (val: RangeState) => {\n  rangeState.value = val\n}\n\ntype RangePickValue = {\n  minDate: Dayjs\n  maxDate: Dayjs\n}\nconst handleRangePick = (val: RangePickValue, close = true) => {\n  const minDate_ = val.minDate\n  const maxDate_ = val.maxDate\n  if (maxDate.value === maxDate_ && minDate.value === minDate_) {\n    return\n  }\n  emit('calendar-change', [minDate_.toDate(), maxDate_ && maxDate_.toDate()])\n  maxDate.value = maxDate_\n  minDate.value = minDate_\n\n  if (!close) return\n  handleConfirm()\n}\n\nconst handleConfirm = (visible = false) => {\n  if (isValidRange([minDate.value, maxDate.value])) {\n    emit('pick', [minDate.value, maxDate.value], visible)\n  }\n}\n\nconst onSelect = (selecting: boolean) => {\n  rangeState.value.selecting = selecting\n  if (!selecting) {\n    rangeState.value.endDate = null\n  }\n}\n\nconst pickerBase = inject('EP_PICKER_BASE') as any\nconst { shortcuts, disabledDate } = pickerBase.props\nconst format = toRef(pickerBase.props, 'format')\nconst defaultValue = toRef(pickerBase.props, 'defaultValue')\nconst unit = 'year'\n\nconst getDefaultValue = () => {\n  let start: Dayjs\n  if (isArray(defaultValue.value)) {\n    const left = dayjs(defaultValue.value[0])\n    let right = dayjs(defaultValue.value[1])\n    if (!props.unlinkPanels) {\n      right = left.add(10, unit)\n    }\n    return [left, right]\n  } else if (defaultValue.value) {\n    start = dayjs(defaultValue.value)\n  } else {\n    start = dayjs()\n  }\n  start = start.locale(lang.value)\n  return [start, start.add(10, unit)]\n}\n\nwatch(\n  () => defaultValue.value,\n  (val) => {\n    if (val) {\n      const defaultArr = getDefaultValue()\n      leftDate.value = defaultArr[0]\n      rightDate.value = defaultArr[1]\n    }\n  },\n  { immediate: true }\n)\n\nwatch(\n  () => props.parsedValue,\n  (newVal) => {\n    if (newVal && newVal.length === 2) {\n      minDate.value = newVal[0]\n      maxDate.value = newVal[1]\n      leftDate.value = minDate.value\n      if (props.unlinkPanels && maxDate.value) {\n        const minDateYear = minDate.value.year()\n        const maxDateYear = maxDate.value.year()\n        rightDate.value =\n          minDateYear === maxDateYear\n            ? maxDate.value.add(10, 'year')\n            : maxDate.value\n      } else {\n        rightDate.value = leftDate.value.add(10, 'year')\n      }\n    } else {\n      const defaultArr = getDefaultValue()\n      minDate.value = undefined\n      maxDate.value = undefined\n      leftDate.value = defaultArr[0]\n      rightDate.value = defaultArr[1]\n    }\n  },\n  { immediate: true }\n)\n\nconst parseUserInput = (value: Dayjs | Dayjs[]) => {\n  return isArray(value)\n    ? value.map((_) => dayjs(_, format.value).locale(lang.value))\n    : dayjs(value, format.value).locale(lang.value)\n}\n\nconst formatToString = (value: Dayjs[] | Dayjs) => {\n  return isArray(value)\n    ? value.map((day) => day.format(format.value))\n    : value.format(format.value)\n}\n\nconst isValidValue = (date: [Dayjs, Dayjs]) => {\n  return (\n    isValidRange(date) &&\n    (disabledDate\n      ? !disabledDate(date[0].toDate()) && !disabledDate(date[1].toDate())\n      : true)\n  )\n}\n\nconst handleClear = () => {\n  const defaultArr = getDefaultValue()\n  leftDate.value = defaultArr[0]\n  rightDate.value = defaultArr[1]\n  maxDate.value = undefined\n  minDate.value = undefined\n  emit('pick', null)\n}\n\nemit('set-picker-option', ['isValidValue', isValidValue])\nemit('set-picker-option', ['parseUserInput', parseUserInput])\nemit('set-picker-option', ['formatToString', formatToString])\nemit('set-picker-option', ['handleClear', handleClear])\n</script>\n", "import DatePickPanel from './date-picker-com/panel-date-pick.vue'\nimport DateRangePickPanel from './date-picker-com/panel-date-range.vue'\nimport MonthRangePickPanel from './date-picker-com/panel-month-range.vue'\nimport YearRangePickPanel from './date-picker-com/panel-year-range.vue'\nimport type { IDatePickerType } from './date-picker.type'\n\nexport const getPanel = function (type: IDatePickerType) {\n  switch (type) {\n    case 'daterange':\n    case 'datetimerange': {\n      return DateRangePickPanel\n    }\n    case 'monthrange': {\n      return MonthRangePickPanel\n    }\n    case 'yearrange': {\n      return YearRangePickPanel\n    }\n    default: {\n      return DatePickPanel\n    }\n  }\n}\n", "import { defineComponent, provide, reactive, ref, toRef } from 'vue'\nimport dayjs from 'dayjs'\nimport customParseFormat from 'dayjs/plugin/customParseFormat.js'\nimport advancedFormat from 'dayjs/plugin/advancedFormat.js'\nimport localeData from 'dayjs/plugin/localeData.js'\nimport weekOfYear from 'dayjs/plugin/weekOfYear.js'\nimport weekYear from 'dayjs/plugin/weekYear.js'\nimport dayOfYear from 'dayjs/plugin/dayOfYear.js'\nimport isSameOrAfter from 'dayjs/plugin/isSameOrAfter.js'\nimport isSameOrBefore from 'dayjs/plugin/isSameOrBefore.js'\nimport { useNamespace } from '@element-plus/hooks'\nimport {\n  CommonPicker,\n  DEFAULT_FORMATS_DATE,\n  DEFAULT_FORMATS_DATEPICKER,\n} from '@element-plus/components/time-picker'\nimport { ROOT_PICKER_INJECTION_KEY } from './constants'\n\nimport { datePickerProps } from './props/date-picker'\nimport { getPanel } from './panel-utils'\nimport type { DatePickerExpose } from './instance'\n\ndayjs.extend(localeData)\ndayjs.extend(advancedFormat)\ndayjs.extend(customParseFormat)\ndayjs.extend(weekOfYear)\ndayjs.extend(weekYear)\ndayjs.extend(dayOfYear)\ndayjs.extend(isSameOrAfter)\ndayjs.extend(isSameOrBefore)\n\nexport default defineComponent({\n  name: 'ElDatePicker',\n  install: null,\n  props: datePickerProps,\n  emits: ['update:modelValue'],\n  setup(props, { expose, emit, slots }) {\n    const ns = useNamespace('picker-panel')\n\n    provide('ElPopperOptions', reactive(toRef(props, 'popperOptions')))\n    provide(ROOT_PICKER_INJECTION_KEY, {\n      slots,\n      pickerNs: ns,\n    })\n\n    const commonPicker = ref<InstanceType<typeof CommonPicker>>()\n    const refProps: DatePickerExpose = {\n      focus: (focusStartInput = true) => {\n        commonPicker.value?.focus(focusStartInput)\n      },\n      handleOpen: () => {\n        commonPicker.value?.handleOpen()\n      },\n      handleClose: () => {\n        commonPicker.value?.handleClose()\n      },\n    }\n\n    expose(refProps)\n\n    const onModelValueUpdated = (val: any) => {\n      emit('update:modelValue', val)\n    }\n\n    return () => {\n      // since props always have all defined keys on it, {format, ...props} will always overwrite format\n      // pick props.format or provide default value here before spreading\n      const format =\n        props.format ??\n        (DEFAULT_FORMATS_DATEPICKER[props.type] || DEFAULT_FORMATS_DATE)\n\n      const Component = getPanel(props.type)\n\n      return (\n        <CommonPicker\n          {...props}\n          format={format}\n          type={props.type}\n          ref={commonPicker}\n          onUpdate:modelValue={onModelValueUpdated}\n        >\n          {{\n            default: (scopedProps: /**FIXME: remove any type */ any) => (\n              <Component {...scopedProps}>\n                {{\n                  'prev-month': slots['prev-month'],\n                  'next-month': slots['next-month'],\n                  'prev-year': slots['prev-year'],\n                  'next-year': slots['next-year'],\n                }}\n              </Component>\n            ),\n            'range-separator': slots['range-separator'],\n          }}\n        </CommonPicker>\n      )\n    }\n  },\n})\n", "import { withInstall } from '@element-plus/utils'\nimport DatePicker from './src/date-picker'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElDatePicker: SFCWithInstall<typeof DatePicker> =\n  withInstall(DatePicker)\n\nexport default ElDatePicker\nexport * from './src/constants'\nexport * from './src/props/date-picker'\nexport type { DatePickerInstance } from './src/instance'\n", "import type { InjectionKey } from 'vue'\nimport type { IDescriptionsInject } from './descriptions.type'\n\nexport const descriptionsKey: InjectionKey<IDescriptionsInject> =\n  Symbol('elDescriptions')\n", "import { defineComponent, h, inject, withDirectives } from 'vue'\nimport { isNil } from 'lodash-unified'\nimport { addUnit, getNormalizedProps } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { descriptionsKey } from './token'\nimport type { DirectiveArguments, PropType, VNode } from 'vue'\n\nimport type {\n  IDescriptionsInject,\n  IDescriptionsItemInject,\n} from './descriptions.type'\nimport type { DescriptionItemVNode } from './description-item'\n\nexport default defineComponent({\n  name: 'ElDescriptionsCell',\n  props: {\n    cell: {\n      type: Object as PropType<DescriptionItemVNode>,\n    },\n    tag: {\n      type: String,\n      default: 'td',\n    },\n    type: {\n      type: String,\n    },\n  },\n  setup() {\n    const descriptions = inject(descriptionsKey, {} as IDescriptionsInject)\n\n    return {\n      descriptions,\n    }\n  },\n  render() {\n    const item = getNormalizedProps(\n      this.cell as VNode\n    ) as IDescriptionsItemInject\n\n    const directives = (this.cell?.dirs || []).map((dire) => {\n      const { dir, arg, modifiers, value } = dire\n      return [dir, value, arg, modifiers]\n    }) as DirectiveArguments\n\n    const { border, direction } = this.descriptions\n    const isVertical = direction === 'vertical'\n    const renderLabel = () => this.cell?.children?.label?.() || item.label\n    const renderContent = () => this.cell?.children?.default?.()\n    const span = item.span\n    const rowspan = item.rowspan\n    const align = item.align ? `is-${item.align}` : ''\n    const labelAlign = item.labelAlign ? `is-${item.labelAlign}` : '' || align\n    const className = item.className\n    const labelClassName = item.labelClassName\n    const style = {\n      width: addUnit(item.width),\n      minWidth: addUnit(item.minWidth),\n    }\n    const ns = useNamespace('descriptions')\n\n    switch (this.type) {\n      case 'label':\n        return withDirectives(\n          h(\n            this.tag,\n            {\n              style,\n              class: [\n                ns.e('cell'),\n                ns.e('label'),\n                ns.is('bordered-label', border),\n                ns.is('vertical-label', isVertical),\n                labelAlign,\n                labelClassName,\n              ],\n              colSpan: isVertical ? span : 1,\n              rowspan: isVertical ? 1 : rowspan,\n            },\n            renderLabel()\n          ),\n          directives\n        )\n      case 'content':\n        return withDirectives(\n          h(\n            this.tag,\n            {\n              style,\n              class: [\n                ns.e('cell'),\n                ns.e('content'),\n                ns.is('bordered-content', border),\n                ns.is('vertical-content', isVertical),\n                align,\n                className,\n              ],\n              colSpan: isVertical ? span : span * 2 - 1,\n              rowspan: isVertical ? rowspan * 2 - 1 : rowspan,\n            },\n            renderContent()\n          ),\n          directives\n        )\n      default: {\n        const label = renderLabel()\n\n        return withDirectives(\n          h(\n            'td',\n            {\n              style,\n              class: [ns.e('cell'), align],\n              colSpan: span,\n              rowspan,\n            },\n            [\n              !isNil(label)\n                ? h(\n                    'span',\n                    {\n                      class: [ns.e('label'), labelClassName],\n                    },\n                    label\n                  )\n                : undefined,\n              h(\n                'span',\n                {\n                  class: [ns.e('content'), className],\n                },\n                renderContent()\n              ),\n            ]\n          ),\n          directives\n        )\n      }\n    }\n  },\n})\n", "import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { DescriptionItemVNode } from './description-item'\n\nexport const descriptionsRowProps = buildProps({\n  row: {\n    type: definePropType<DescriptionItemVNode[]>(Array),\n    default: () => [],\n  },\n} as const)\n", "<template>\n  <template v-if=\"descriptions.direction === 'vertical'\">\n    <tr>\n      <template v-for=\"(cell, _index) in row\" :key=\"`tr1-${_index}`\">\n        <el-descriptions-cell :cell=\"cell\" tag=\"th\" type=\"label\" />\n      </template>\n    </tr>\n    <tr>\n      <template v-for=\"(cell, _index) in row\" :key=\"`tr2-${_index}`\">\n        <el-descriptions-cell :cell=\"cell\" tag=\"td\" type=\"content\" />\n      </template>\n    </tr>\n  </template>\n  <tr v-else>\n    <template v-for=\"(cell, _index) in row\" :key=\"`tr3-${_index}`\">\n      <template v-if=\"descriptions.border\">\n        <el-descriptions-cell :cell=\"cell\" tag=\"td\" type=\"label\" />\n        <el-descriptions-cell :cell=\"cell\" tag=\"td\" type=\"content\" />\n      </template>\n      <el-descriptions-cell v-else :cell=\"cell\" tag=\"td\" type=\"both\" />\n    </template>\n  </tr>\n</template>\n\n<script lang=\"ts\" setup>\nimport { inject } from 'vue'\n\nimport ElDescriptionsCell from './descriptions-cell'\nimport { descriptionsKey } from './token'\nimport { descriptionsRowProps } from './descriptions-row'\n\nimport type { IDescriptionsInject } from './descriptions.type'\n\ndefineOptions({\n  name: 'ElDescriptionsRow',\n})\n\ndefineProps(descriptionsRowProps)\n\nconst descriptions = inject(descriptionsKey, {} as IDescriptionsInject)\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport { useSizeProp } from '@element-plus/hooks'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Description from './description.vue'\n\nexport const descriptionProps = buildProps({\n  /**\n   * @description with or without border\n   */\n  border: Boolean,\n  /**\n   * @description numbers of `Descriptions Item` in one line\n   */\n  column: {\n    type: Number,\n    default: 3,\n  },\n  /**\n   * @description direction of list\n   */\n  direction: {\n    type: String,\n    values: ['horizontal', 'vertical'],\n    default: 'horizontal',\n  },\n  /**\n   * @description size of list\n   */\n  size: useSizeProp,\n  /**\n   * @description title text, display on the top left\n   */\n  title: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description extra text, display on the top right\n   */\n  extra: {\n    type: String,\n    default: '',\n  },\n} as const)\n\nexport type DescriptionProps = ExtractPropTypes<typeof descriptionProps>\nexport type DescriptionInstance = InstanceType<typeof Description>\n", "<template>\n  <div :class=\"descriptionKls\">\n    <div\n      v-if=\"title || extra || $slots.title || $slots.extra\"\n      :class=\"ns.e('header')\"\n    >\n      <div :class=\"ns.e('title')\">\n        <slot name=\"title\">{{ title }}</slot>\n      </div>\n      <div :class=\"ns.e('extra')\">\n        <slot name=\"extra\">{{ extra }}</slot>\n      </div>\n    </div>\n\n    <div :class=\"ns.e('body')\">\n      <table :class=\"[ns.e('table'), ns.is('bordered', border)]\">\n        <tbody>\n          <template v-for=\"(row, _index) in getRows()\" :key=\"_index\">\n            <el-descriptions-row :row=\"row\" />\n          </template>\n        </tbody>\n      </table>\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, provide, useSlots } from 'vue'\nimport { flattedChildren } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormSize } from '@element-plus/components/form'\nimport ElDescriptionsRow from './descriptions-row.vue'\nimport { descriptionsKey } from './token'\nimport { descriptionProps } from './description'\n\nimport type { IDescriptionsInject } from './descriptions.type'\nimport type { DescriptionItemVNode } from './description-item'\n\ndefineOptions({\n  name: 'ElDescriptions',\n})\n\nconst props = defineProps(descriptionProps)\n\nconst ns = useNamespace('descriptions')\n\nconst descriptionsSize = useFormSize()\n\nconst slots = useSlots()\n\nprovide(descriptionsKey, props as IDescriptionsInject)\n\nconst descriptionKls = computed(() => [ns.b(), ns.m(descriptionsSize.value)])\n\nconst filledNode = (\n  node: DescriptionItemVNode,\n  span: number,\n  count: number,\n  isLast = false\n) => {\n  if (!node.props) {\n    node.props = {}\n  }\n  if (span > count) {\n    node.props.span = count\n  }\n  if (isLast) {\n    // set the last span\n    node.props.span = span\n  }\n  return node\n}\n\nconst getRows = () => {\n  if (!slots.default) return []\n\n  const children = flattedChildren(slots.default()).filter(\n    (node): node is DescriptionItemVNode =>\n      (node as any)?.type?.name === 'ElDescriptionsItem'\n  )\n  const rows: DescriptionItemVNode[][] = []\n  let temp: DescriptionItemVNode[] = []\n  let count = props.column\n  let totalSpan = 0 // all spans number of item\n  const rowspanTemp: number[] = [] // the number of row spans\n\n  children.forEach((node, index) => {\n    const span = node.props?.span || 1\n    const rowspan = node.props?.rowspan || 1\n    const rowNo = rows.length\n    rowspanTemp[rowNo] ||= 0\n\n    if (rowspan > 1) {\n      for (let i = 1; i < rowspan; i++) {\n        rowspanTemp[rowNo + i] ||= 0\n        rowspanTemp[rowNo + i]++\n        totalSpan++\n      }\n    }\n    if (rowspanTemp[rowNo] > 0) {\n      count -= rowspanTemp[rowNo]\n      rowspanTemp[rowNo] = 0\n    }\n    if (index < children.length - 1) {\n      totalSpan += span > count ? count : span\n    }\n\n    if (index === children.length - 1) {\n      // calculate the last item span\n      const lastSpan = props.column - (totalSpan % props.column)\n      temp.push(filledNode(node, lastSpan, count, true))\n      rows.push(temp)\n      return\n    }\n\n    if (span < count) {\n      count -= span\n      temp.push(node)\n    } else {\n      temp.push(filledNode(node, span, count))\n      rows.push(temp)\n      count = props.column\n      temp = []\n    }\n  })\n\n  return rows\n}\n</script>\n", "import { defineComponent } from 'vue'\nimport { buildProps } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, Slot, VNode } from 'vue'\n\nexport const descriptionItemProps = buildProps({\n  /**\n   * @description label text\n   */\n  label: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description colspan of column\n   */\n  span: {\n    type: Number,\n    default: 1,\n  },\n  /**\n   * @description the number of rows a cell should span\n   */\n  rowspan: {\n    type: Number,\n    default: 1,\n  },\n  /**\n   * @description column width, the width of the same column in different rows is set by the max value (If no `border`, width contains label and content)\n   */\n  width: {\n    type: [String, Number],\n    default: '',\n  },\n  /**\n   * @description column minimum width, columns with `width` has a fixed width, while columns with `min-width` has a width that is distributed in proportion (If no`border`, width contains label and content)\n   */\n  minWidth: {\n    type: [String, Number],\n    default: '',\n  },\n  /**\n   * @description column content alignment (If no `border`, effective for both label and content)\n   */\n  align: {\n    type: String,\n    default: 'left',\n  },\n  /**\n   * @description column label alignment, if omitted, the value of the above `align` attribute will be applied (If no `border`, please use `align` attribute)\n   */\n  labelAlign: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description column content custom class name\n   */\n  className: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description column label custom class name\n   */\n  labelClassName: {\n    type: String,\n    default: '',\n  },\n})\nconst DescriptionItem = defineComponent({\n  name: 'ElDescriptionsItem',\n  props: descriptionItemProps,\n})\n\nexport default DescriptionItem\n\nexport type DescriptionItemProps = ExtractPropTypes<typeof descriptionItemProps>\nexport type DescriptionItemVNode = VNode & {\n  children: { [name: string]: Slot } | null\n  props: Partial<DescriptionItemProps> | null\n}\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\n\nimport Descriptions from './src/description.vue'\nimport DescriptionsItem from './src/description-item'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElDescriptions: SFCWithInstall<typeof Descriptions> & {\n  DescriptionsItem: typeof DescriptionsItem\n} = withInstall(Descriptions, {\n  DescriptionsItem,\n})\n\nexport const ElDescriptionsItem: SFCWithInstall<typeof DescriptionsItem> =\n  withNoopInstall(DescriptionsItem)\n\nexport default ElDescriptions\n\nexport * from './src/description'\nexport * from './src/description-item'\n", "import { createVNode, defineComponent, h, renderSlot } from 'vue'\nimport { PatchFlags, buildProps, definePropType } from '@element-plus/utils'\nimport { useNamespace, useSameTarget } from '@element-plus/hooks'\n\nimport type { CSSProperties, ExtractPropTypes } from 'vue'\nimport type { ZIndexProperty } from 'csstype'\n\nexport const overlayProps = buildProps({\n  mask: {\n    type: Boolean,\n    default: true,\n  },\n  customMaskEvent: Boolean,\n  overlayClass: {\n    type: definePropType<string | string[] | Record<string, boolean>>([\n      String,\n      Array,\n      Object,\n    ]),\n  },\n  zIndex: {\n    type: definePropType<ZIndexProperty>([String, Number]),\n  },\n} as const)\nexport type OverlayProps = ExtractPropTypes<typeof overlayProps>\n\nexport const overlayEmits = {\n  click: (evt: MouseEvent) => evt instanceof MouseEvent,\n}\nexport type OverlayEmits = typeof overlayEmits\n\nconst BLOCK = 'overlay'\n\nexport default defineComponent({\n  name: 'ElOverlay',\n\n  props: overlayProps,\n  emits: overlayEmits,\n\n  setup(props, { slots, emit }) {\n    // No reactivity on this prop because when its rendering with a global\n    // component, this will be a constant flag.\n    const ns = useNamespace(BLOCK)\n\n    const onMaskClick = (e: MouseEvent) => {\n      emit('click', e)\n    }\n\n    const { onClick, onMousedown, onMouseup } = useSameTarget(\n      props.customMaskEvent ? undefined : onMaskClick\n    )\n\n    // init here\n    return () => {\n      // when the vnode meets the same structure but with different change trigger\n      // it will not automatically update, thus we simply use h function to manage updating\n      return props.mask\n        ? createVNode(\n            'div',\n            {\n              class: [ns.b(), props.overlayClass],\n              style: {\n                zIndex: props.zIndex,\n              },\n              onClick,\n              onMousedown,\n              onMouseup,\n            },\n            [renderSlot(slots, 'default')],\n            PatchFlags.STYLE | PatchFlags.CLASS | PatchFlags.PROPS,\n            ['onClick', 'onMouseup', 'onMousedown']\n          )\n        : h(\n            'div',\n            {\n              class: props.overlayClass,\n              style: {\n                zIndex: props.zIndex,\n                position: 'fixed',\n                top: '0px',\n                right: '0px',\n                bottom: '0px',\n                left: '0px',\n              } as CSSProperties,\n            },\n            [renderSlot(slots, 'default')]\n          )\n    }\n  },\n})\n", "import Overlay from './src/overlay'\n\nexport const ElOverlay = Overlay\nexport default ElOverlay\n\nexport * from './src/overlay'\n", "import type { CSSProperties, ComputedRef, InjectionKey, Ref } from 'vue'\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\n\nexport type DialogContext = {\n  dialogRef: Ref<HTMLElement | undefined>\n  headerRef: Ref<HTMLElement | undefined>\n  bodyId: Ref<string>\n  ns: UseNamespaceReturn\n  rendered: Ref<boolean>\n  style: ComputedRef<CSSProperties>\n}\n\nexport const dialogInjectionKey: InjectionKey<DialogContext> =\n  Symbol('dialogInjectionKey')\n", "import { buildProps, iconPropType } from '@element-plus/utils'\n\nexport const dialogContentProps = buildProps({\n  /**\n   * @description whether to align the header and footer in center\n   */\n  center: Boolean,\n  /**\n   * @description whether to align the dialog both horizontally and vertically\n   */\n  alignCenter: Boolean,\n  /**\n   * @description custom close icon, default is Close\n   */\n  closeIcon: {\n    type: iconPropType,\n  },\n  /**\n   * @description enable dragging feature for Dialog\n   */\n  draggable: Boolean,\n  /**\n   * @description draggable Dialog can overflow the viewport\n   */\n  overflow: Boolean,\n  /**\n   * @description whether the Dialog takes up full screen\n   */\n  fullscreen: Boolean,\n  /**\n   * @description whether to show a close button\n   */\n  showClose: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description title of Dialog. Can also be passed with a named slot (see the following table)\n   */\n  title: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description header's aria-level attribute\n   */\n  ariaLevel: {\n    type: String,\n    default: '2',\n  },\n} as const)\n\nexport const dialogContentEmits = {\n  close: () => true,\n}\n", "<template>\n  <div :ref=\"composedDialogRef\" :class=\"dialogKls\" :style=\"style\" tabindex=\"-1\">\n    <header\n      ref=\"headerRef\"\n      :class=\"[ns.e('header'), { 'show-close': showClose }]\"\n    >\n      <slot name=\"header\">\n        <span role=\"heading\" :aria-level=\"ariaLevel\" :class=\"ns.e('title')\">\n          {{ title }}\n        </span>\n      </slot>\n      <button\n        v-if=\"showClose\"\n        :aria-label=\"t('el.dialog.close')\"\n        :class=\"ns.e('headerbtn')\"\n        type=\"button\"\n        @click=\"$emit('close')\"\n      >\n        <el-icon :class=\"ns.e('close')\">\n          <component :is=\"closeIcon || Close\" />\n        </el-icon>\n      </button>\n    </header>\n    <div :id=\"bodyId\" :class=\"ns.e('body')\">\n      <slot />\n    </div>\n    <footer v-if=\"$slots.footer\" :class=\"ns.e('footer')\">\n      <slot name=\"footer\" />\n    </footer>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { FOCUS_TRAP_INJECTION_KEY } from '@element-plus/components/focus-trap'\nimport { useDraggable, useLocale } from '@element-plus/hooks'\nimport { CloseComponents, composeRefs } from '@element-plus/utils'\nimport { dialogInjectionKey } from './constants'\nimport { dialogContentEmits, dialogContentProps } from './dialog-content'\n\nconst { t } = useLocale()\nconst { Close } = CloseComponents\n\ndefineOptions({ name: 'ElDialogContent' })\nconst props = defineProps(dialogContentProps)\ndefineEmits(dialogContentEmits)\n\nconst { dialogRef, headerRef, bodyId, ns, style } = inject(dialogInjectionKey)!\nconst { focusTrapRef } = inject(FOCUS_TRAP_INJECTION_KEY)!\n\nconst dialogKls = computed(() => [\n  ns.b(),\n  ns.is('fullscreen', props.fullscreen),\n  ns.is('draggable', props.draggable),\n  ns.is('align-center', props.alignCenter),\n  { [ns.m('center')]: props.center },\n])\n\nconst composedDialogRef = composeRefs(focusTrapRef, dialogRef)\n\nconst draggable = computed(() => props.draggable)\nconst overflow = computed(() => props.overflow)\nconst { resetPosition } = useDraggable(\n  dialogRef,\n  headerRef,\n  draggable,\n  overflow\n)\n\ndefineExpose({\n  resetPosition,\n})\n</script>\n", "import { buildProps, definePropType, isBoolean } from '@element-plus/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { dialogContentProps } from './dialog-content'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Dialog from './dialog.vue'\n\ntype DoneFn = (cancel?: boolean) => void\nexport type DialogBeforeCloseFn = (done: DoneFn) => void\n\nexport const dialogProps = buildProps({\n  ...dialogContentProps,\n  /**\n   * @description whether to append Dialog itself to body. A nested Dialog should have this attribute set to `true`\n   */\n  appendToBody: Boolean,\n  /**\n   * @description which element the Dialog appends to\n   */\n  appendTo: {\n    type: definePropType<string | HTMLElement>([String, Object]),\n    default: 'body',\n  },\n  /**\n   * @description callback before Dialog closes, and it will prevent Dialog from closing, use done to close the dialog\n   */\n  beforeClose: {\n    type: definePropType<DialogBeforeCloseFn>(Function),\n  },\n  /**\n   * @description destroy elements in Dialog when closed\n   */\n  destroyOnClose: Boolean,\n  /**\n   * @description whether the Dialog can be closed by clicking the mask\n   */\n  closeOnClickModal: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether the Dialog can be closed by pressing ESC\n   */\n  closeOnPressEscape: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether scroll of body is disabled while Dialog is displayed\n   */\n  lockScroll: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether a mask is displayed\n   */\n  modal: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description the Time(milliseconds) before open\n   */\n  openDelay: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description the Time(milliseconds) before close\n   */\n  closeDelay: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description value for `margin-top` of Dialog CSS, default is 15vh\n   */\n  top: {\n    type: String,\n  },\n  /**\n   * @description visibility of Dialog\n   */\n  modelValue: Boolean,\n  /**\n   * @description custom class names for mask\n   */\n  modalClass: String,\n  /**\n   * @description width of Dialog, default is 50%\n   */\n  width: {\n    type: [String, Number],\n  },\n  /**\n   * @description same as z-index in native CSS, z-order of dialog\n   */\n  zIndex: {\n    type: Number,\n  },\n  trapFocus: Boolean,\n  /**\n   * @description header's aria-level attribute\n   */\n  headerAriaLevel: {\n    type: String,\n    default: '2',\n  },\n} as const)\n\nexport type DialogProps = ExtractPropTypes<typeof dialogProps>\n\nexport const dialogEmits = {\n  open: () => true,\n  opened: () => true,\n  close: () => true,\n  closed: () => true,\n  [UPDATE_MODEL_EVENT]: (value: boolean) => isBoolean(value),\n  openAutoFocus: () => true,\n  closeAutoFocus: () => true,\n}\nexport type DialogEmits = typeof dialogEmits\nexport type DialogInstance = InstanceType<typeof Dialog>\n", "import {\n  computed,\n  getCurrentInstance,\n  nextTick,\n  onMounted,\n  ref,\n  watch,\n} from 'vue'\nimport { useTimeoutFn } from '@vueuse/core'\n\nimport { isUndefined } from 'lodash-unified'\nimport {\n  defaultNamespace,\n  useId,\n  useLockscreen,\n  useZIndex,\n} from '@element-plus/hooks'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { addUnit, isClient } from '@element-plus/utils'\nimport { useGlobalConfig } from '@element-plus/components/config-provider'\n\nimport type { CSSProperties, Ref, SetupContext } from 'vue'\nimport type { DialogEmits, DialogProps } from './dialog'\n\nexport const useDialog = (\n  props: DialogProps,\n  targetRef: Ref<HTMLElement | undefined>\n) => {\n  const instance = getCurrentInstance()!\n  const emit = instance.emit as SetupContext<DialogEmits>['emit']\n  const { nextZIndex } = useZIndex()\n\n  let lastPosition = ''\n  const titleId = useId()\n  const bodyId = useId()\n  const visible = ref(false)\n  const closed = ref(false)\n  const rendered = ref(false) // when desctroyOnClose is true, we initialize it as false vise versa\n  const zIndex = ref(props.zIndex ?? nextZIndex())\n\n  let openTimer: (() => void) | undefined = undefined\n  let closeTimer: (() => void) | undefined = undefined\n\n  const namespace = useGlobalConfig('namespace', defaultNamespace)\n\n  const style = computed<CSSProperties>(() => {\n    const style: CSSProperties = {}\n    const varPrefix = `--${namespace.value}-dialog` as const\n    if (!props.fullscreen) {\n      if (props.top) {\n        style[`${varPrefix}-margin-top`] = props.top\n      }\n      if (props.width) {\n        style[`${varPrefix}-width`] = addUnit(props.width)\n      }\n    }\n    return style\n  })\n\n  const overlayDialogStyle = computed<CSSProperties>(() => {\n    if (props.alignCenter) {\n      return { display: 'flex' }\n    }\n    return {}\n  })\n\n  function afterEnter() {\n    emit('opened')\n  }\n\n  function afterLeave() {\n    emit('closed')\n    emit(UPDATE_MODEL_EVENT, false)\n    if (props.destroyOnClose) {\n      rendered.value = false\n    }\n  }\n\n  function beforeLeave() {\n    emit('close')\n  }\n\n  function open() {\n    closeTimer?.()\n    openTimer?.()\n\n    if (props.openDelay && props.openDelay > 0) {\n      ;({ stop: openTimer } = useTimeoutFn(() => doOpen(), props.openDelay))\n    } else {\n      doOpen()\n    }\n  }\n\n  function close() {\n    openTimer?.()\n    closeTimer?.()\n\n    if (props.closeDelay && props.closeDelay > 0) {\n      ;({ stop: closeTimer } = useTimeoutFn(() => doClose(), props.closeDelay))\n    } else {\n      doClose()\n    }\n  }\n\n  function handleClose() {\n    function hide(shouldCancel?: boolean) {\n      if (shouldCancel) return\n      closed.value = true\n      visible.value = false\n    }\n\n    if (props.beforeClose) {\n      props.beforeClose(hide)\n    } else {\n      close()\n    }\n  }\n\n  function onModalClick() {\n    if (props.closeOnClickModal) {\n      handleClose()\n    }\n  }\n\n  function doOpen() {\n    if (!isClient) return\n    visible.value = true\n  }\n\n  function doClose() {\n    visible.value = false\n  }\n\n  function onOpenAutoFocus() {\n    emit('openAutoFocus')\n  }\n\n  function onCloseAutoFocus() {\n    emit('closeAutoFocus')\n  }\n\n  function onFocusoutPrevented(event: CustomEvent) {\n    if (event.detail?.focusReason === 'pointer') {\n      event.preventDefault()\n    }\n  }\n\n  if (props.lockScroll) {\n    useLockscreen(visible)\n  }\n\n  function onCloseRequested() {\n    if (props.closeOnPressEscape) {\n      handleClose()\n    }\n  }\n\n  watch(\n    () => props.modelValue,\n    (val) => {\n      if (val) {\n        closed.value = false\n        open()\n        rendered.value = true // enables lazy rendering\n        zIndex.value = isUndefined(props.zIndex) ? nextZIndex() : zIndex.value++\n        // this.$el.addEventListener('scroll', this.updatePopper)\n        nextTick(() => {\n          emit('open')\n          if (targetRef.value) {\n            targetRef.value.scrollTop = 0\n          }\n        })\n      } else {\n        // this.$el.removeEventListener('scroll', this.updatePopper\n        if (visible.value) {\n          close()\n        }\n      }\n    }\n  )\n\n  watch(\n    () => props.fullscreen,\n    (val) => {\n      if (!targetRef.value) return\n      if (val) {\n        lastPosition = targetRef.value.style.transform\n        targetRef.value.style.transform = ''\n      } else {\n        targetRef.value.style.transform = lastPosition\n      }\n    }\n  )\n\n  onMounted(() => {\n    if (props.modelValue) {\n      visible.value = true\n      rendered.value = true // enables lazy rendering\n      open()\n    }\n  })\n\n  return {\n    afterEnter,\n    afterLeave,\n    beforeLeave,\n    handleClose,\n    onModalClick,\n    close,\n    doClose,\n    onOpenAutoFocus,\n    onCloseAutoFocus,\n    onCloseRequested,\n    onFocusoutPrevented,\n    titleId,\n    bodyId,\n    closed,\n    style,\n    overlayDialogStyle,\n    rendered,\n    visible,\n    zIndex,\n  }\n}\n", "<template>\n  <el-teleport\n    :to=\"appendTo\"\n    :disabled=\"appendTo !== 'body' ? false : !appendToBody\"\n  >\n    <transition\n      name=\"dialog-fade\"\n      @after-enter=\"afterEnter\"\n      @after-leave=\"afterLeave\"\n      @before-leave=\"beforeLeave\"\n    >\n      <el-overlay\n        v-show=\"visible\"\n        custom-mask-event\n        :mask=\"modal\"\n        :overlay-class=\"modalClass\"\n        :z-index=\"zIndex\"\n      >\n        <div\n          role=\"dialog\"\n          aria-modal=\"true\"\n          :aria-label=\"title || undefined\"\n          :aria-labelledby=\"!title ? titleId : undefined\"\n          :aria-describedby=\"bodyId\"\n          :class=\"`${ns.namespace.value}-overlay-dialog`\"\n          :style=\"overlayDialogStyle\"\n          @click=\"overlayEvent.onClick\"\n          @mousedown=\"overlayEvent.onMousedown\"\n          @mouseup=\"overlayEvent.onMouseup\"\n        >\n          <el-focus-trap\n            loop\n            :trapped=\"visible\"\n            focus-start-el=\"container\"\n            @focus-after-trapped=\"onOpenAutoFocus\"\n            @focus-after-released=\"onCloseAutoFocus\"\n            @focusout-prevented=\"onFocusoutPrevented\"\n            @release-requested=\"onCloseRequested\"\n          >\n            <el-dialog-content\n              v-if=\"rendered\"\n              ref=\"dialogContentRef\"\n              v-bind=\"$attrs\"\n              :center=\"center\"\n              :align-center=\"alignCenter\"\n              :close-icon=\"closeIcon\"\n              :draggable=\"draggable\"\n              :overflow=\"overflow\"\n              :fullscreen=\"fullscreen\"\n              :show-close=\"showClose\"\n              :title=\"title\"\n              :aria-level=\"headerAriaLevel\"\n              @close=\"handleClose\"\n            >\n              <template #header>\n                <slot\n                  v-if=\"!$slots.title\"\n                  name=\"header\"\n                  :close=\"handleClose\"\n                  :title-id=\"titleId\"\n                  :title-class=\"ns.e('title')\"\n                />\n                <slot v-else name=\"title\" />\n              </template>\n              <slot />\n              <template v-if=\"$slots.footer\" #footer>\n                <slot name=\"footer\" />\n              </template>\n            </el-dialog-content>\n          </el-focus-trap>\n        </div>\n      </el-overlay>\n    </transition>\n  </el-teleport>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, provide, ref, useSlots } from 'vue'\nimport { ElOverlay } from '@element-plus/components/overlay'\nimport { useDeprecated, useNamespace, useSameTarget } from '@element-plus/hooks'\nimport ElFocusTrap from '@element-plus/components/focus-trap'\nimport ElTeleport from '@element-plus/components/teleport'\nimport ElDialogContent from './dialog-content.vue'\nimport { dialogInjectionKey } from './constants'\nimport { dialogEmits, dialogProps } from './dialog'\nimport { useDialog } from './use-dialog'\n\ndefineOptions({\n  name: 'ElDialog',\n  inheritAttrs: false,\n})\n\nconst props = defineProps(dialogProps)\ndefineEmits(dialogEmits)\nconst slots = useSlots()\n\nuseDeprecated(\n  {\n    scope: 'el-dialog',\n    from: 'the title slot',\n    replacement: 'the header slot',\n    version: '3.0.0',\n    ref: 'https://element-plus.org/en-US/component/dialog.html#slots',\n  },\n  computed(() => !!slots.title)\n)\n\nconst ns = useNamespace('dialog')\nconst dialogRef = ref<HTMLElement>()\nconst headerRef = ref<HTMLElement>()\nconst dialogContentRef = ref()\n\nconst {\n  visible,\n  titleId,\n  bodyId,\n  style,\n  overlayDialogStyle,\n  rendered,\n  zIndex,\n  afterEnter,\n  afterLeave,\n  beforeLeave,\n  handleClose,\n  onModalClick,\n  onOpenAutoFocus,\n  onCloseAutoFocus,\n  onCloseRequested,\n  onFocusoutPrevented,\n} = useDialog(props, dialogRef)\n\nprovide(dialogInjectionKey, {\n  dialogRef,\n  headerRef,\n  bodyId,\n  ns,\n  rendered,\n  style,\n})\n\nconst overlayEvent = useSameTarget(onModalClick)\n\nconst draggable = computed(() => props.draggable && !props.fullscreen)\n\nconst resetPosition = () => {\n  dialogContentRef.value?.resetPosition()\n}\n\ndefineExpose({\n  /** @description whether the dialog is visible */\n  visible,\n  dialogContentRef,\n  resetPosition,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Dialog from './src/dialog.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElDialog: SFCWithInstall<typeof Dialog> = withInstall(Dialog)\nexport default ElDialog\n\nexport * from './src/use-dialog'\nexport * from './src/dialog'\nexport * from './src/constants'\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Divider from './divider.vue'\n\nexport type BorderStyle = CSSStyleDeclaration['borderStyle']\n\nexport const dividerProps = buildProps({\n  /**\n   * @description Set divider's direction\n   */\n  direction: {\n    type: String,\n    values: ['horizontal', 'vertical'],\n    default: 'horizontal',\n  },\n  /**\n   * @description Set the style of divider\n   */\n  contentPosition: {\n    type: String,\n    values: ['left', 'center', 'right'],\n    default: 'center',\n  },\n  /**\n   * @description the position of the customized content on the divider line\n   */\n  borderStyle: {\n    type: definePropType<BorderStyle>(String),\n    default: 'solid',\n  },\n} as const)\nexport type DividerProps = ExtractPropTypes<typeof dividerProps>\n\nexport type DividerInstance = InstanceType<typeof Divider>\n", "<template>\n  <div\n    :class=\"[ns.b(), ns.m(direction)]\"\n    :style=\"dividerStyle\"\n    role=\"separator\"\n  >\n    <div\n      v-if=\"$slots.default && direction !== 'vertical'\"\n      :class=\"[ns.e('text'), ns.is(contentPosition)]\"\n    >\n      <slot />\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { dividerProps } from './divider'\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElDivider',\n})\nconst props = defineProps(dividerProps)\nconst ns = useNamespace('divider')\nconst dividerStyle = computed(() => {\n  return ns.cssVar({\n    'border-style': props.borderStyle,\n  }) as CSSProperties\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Divider from './src/divider.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElDivider: SFCWithInstall<typeof Divider> = withInstall(Divider)\nexport default ElDivider\n\nexport * from './src/divider'\n", "import { buildProps } from '@element-plus/utils'\nimport { dialogEmits, dialogProps } from '@element-plus/components/dialog'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const drawerProps = buildProps({\n  ...dialogProps,\n  direction: {\n    type: String,\n    default: 'rtl',\n    values: ['ltr', 'rtl', 'ttb', 'btt'],\n  },\n  size: {\n    type: [String, Number],\n    default: '30%',\n  },\n  withHeader: {\n    type: Boolean,\n    default: true,\n  },\n  modalFade: {\n    type: Boolean,\n    default: true,\n  },\n  headerAriaLevel: {\n    type: String,\n    default: '2',\n  },\n} as const)\n\nexport type DrawerProps = ExtractPropTypes<typeof drawerProps>\n\nexport const drawerEmits = dialogEmits\n", "<template>\n  <el-teleport\n    :to=\"appendTo\"\n    :disabled=\"appendTo !== 'body' ? false : !appendToBody\"\n  >\n    <transition\n      :name=\"ns.b('fade')\"\n      @after-enter=\"afterEnter\"\n      @after-leave=\"afterLeave\"\n      @before-leave=\"beforeLeave\"\n    >\n      <el-overlay\n        v-show=\"visible\"\n        :mask=\"modal\"\n        :overlay-class=\"modalClass\"\n        :z-index=\"zIndex\"\n        @click=\"onModalClick\"\n      >\n        <el-focus-trap\n          loop\n          :trapped=\"visible\"\n          :focus-trap-el=\"drawerRef\"\n          :focus-start-el=\"focusStartRef\"\n          @focus-after-trapped=\"onOpenAutoFocus\"\n          @focus-after-released=\"onCloseAutoFocus\"\n          @focusout-prevented=\"onFocusoutPrevented\"\n          @release-requested=\"onCloseRequested\"\n        >\n          <div\n            ref=\"drawerRef\"\n            aria-modal=\"true\"\n            :aria-label=\"title || undefined\"\n            :aria-labelledby=\"!title ? titleId : undefined\"\n            :aria-describedby=\"bodyId\"\n            v-bind=\"$attrs\"\n            :class=\"[ns.b(), direction, visible && 'open']\"\n            :style=\"\n              isHorizontal ? 'width: ' + drawerSize : 'height: ' + drawerSize\n            \"\n            role=\"dialog\"\n            @click.stop\n          >\n            <span ref=\"focusStartRef\" :class=\"ns.e('sr-focus')\" tabindex=\"-1\" />\n            <header v-if=\"withHeader\" :class=\"ns.e('header')\">\n              <slot\n                v-if=\"!$slots.title\"\n                name=\"header\"\n                :close=\"handleClose\"\n                :title-id=\"titleId\"\n                :title-class=\"ns.e('title')\"\n              >\n                <span\n                  v-if=\"!$slots.title\"\n                  :id=\"titleId\"\n                  role=\"heading\"\n                  :aria-level=\"headerAriaLevel\"\n                  :class=\"ns.e('title')\"\n                >\n                  {{ title }}\n                </span>\n              </slot>\n              <slot v-else name=\"title\">\n                <!-- DEPRECATED SLOT -->\n              </slot>\n              <button\n                v-if=\"showClose\"\n                :aria-label=\"t('el.drawer.close')\"\n                :class=\"ns.e('close-btn')\"\n                type=\"button\"\n                @click=\"handleClose\"\n              >\n                <el-icon :class=\"ns.e('close')\"><close /></el-icon>\n              </button>\n            </header>\n            <template v-if=\"rendered\">\n              <div :id=\"bodyId\" :class=\"ns.e('body')\">\n                <slot />\n              </div>\n            </template>\n            <div v-if=\"$slots.footer\" :class=\"ns.e('footer')\">\n              <slot name=\"footer\" />\n            </div>\n          </div>\n        </el-focus-trap>\n      </el-overlay>\n    </transition>\n  </el-teleport>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, ref, useSlots } from 'vue'\nimport { Close } from '@element-plus/icons-vue'\n\nimport { ElOverlay } from '@element-plus/components/overlay'\nimport ElFocusTrap from '@element-plus/components/focus-trap'\nimport ElTeleport from '@element-plus/components/teleport'\nimport { useDialog } from '@element-plus/components/dialog'\nimport { addUnit } from '@element-plus/utils'\nimport ElIcon from '@element-plus/components/icon'\nimport { useDeprecated, useLocale, useNamespace } from '@element-plus/hooks'\nimport { drawerEmits, drawerProps } from './drawer'\n\ndefineOptions({\n  name: 'ElDrawer',\n  inheritAttrs: false,\n})\n\nconst props = defineProps(drawerProps)\ndefineEmits(drawerEmits)\nconst slots = useSlots()\n\nuseDeprecated(\n  {\n    scope: 'el-drawer',\n    from: 'the title slot',\n    replacement: 'the header slot',\n    version: '3.0.0',\n    ref: 'https://element-plus.org/en-US/component/drawer.html#slots',\n  },\n  computed(() => !!slots.title)\n)\n\nconst drawerRef = ref<HTMLElement>()\nconst focusStartRef = ref<HTMLElement>()\nconst ns = useNamespace('drawer')\nconst { t } = useLocale()\nconst {\n  afterEnter,\n  afterLeave,\n  beforeLeave,\n  visible,\n  rendered,\n  titleId,\n  bodyId,\n  zIndex,\n  onModalClick,\n  onOpenAutoFocus,\n  onCloseAutoFocus,\n  onFocusoutPrevented,\n  onCloseRequested,\n  handleClose,\n} = useDialog(props, drawerRef)\n\nconst isHorizontal = computed(\n  () => props.direction === 'rtl' || props.direction === 'ltr'\n)\nconst drawerSize = computed(() => addUnit(props.size))\n\ndefineExpose({\n  handleClose,\n  afterEnter,\n  afterLeave,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Drawer from './src/drawer.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElDrawer: SFCWithInstall<typeof Drawer> = withInstall(Drawer)\nexport default ElDrawer\n\nexport * from './src/drawer'\n", "<template>\n  <slot />\n</template>\n\n<script lang=\"ts\" setup>\ndefineOptions({\n  inheritAttrs: false,\n})\n</script>\n", "<template>\n  <slot />\n</template>\n\n<script lang=\"ts\" setup>\ndefineOptions({\n  name: 'ElCollectionItem',\n  inheritAttrs: false,\n})\n</script>\n", "import { inject, onBeforeUnmount, onMounted, provide, ref, unref } from 'vue'\nimport Collection from './collection.vue'\nimport CollectionItem from './collection-item.vue'\n\nimport type { InjectionKey } from 'vue'\nimport type { SetupContext } from '@vue/runtime-core'\nimport type {\n  ElCollectionInjectionContext,\n  ElCollectionItemInjectionContext,\n} from './tokens'\n\nexport const COLLECTION_ITEM_SIGN = `data-el-collection-item`\n\n// Make sure the first letter of name is capitalized\nexport const createCollectionWithScope = (name: string) => {\n  const COLLECTION_NAME = `El${name}Collection`\n  const COLLECTION_ITEM_NAME = `${COLLECTION_NAME}Item`\n  const COLLECTION_INJECTION_KEY: InjectionKey<ElCollectionInjectionContext> =\n    Symbol(COLLECTION_NAME)\n  const COLLECTION_ITEM_INJECTION_KEY: InjectionKey<ElCollectionItemInjectionContext> =\n    Symbol(COLLECTION_ITEM_NAME)\n\n  const ElCollection = {\n    ...Collection,\n    name: COLLECTION_NAME,\n    setup() {\n      const collectionRef = ref<HTMLElement | null>(null)\n      const itemMap: ElCollectionInjectionContext['itemMap'] = new Map()\n      const getItems = () => {\n        const collectionEl = unref(collectionRef)\n\n        if (!collectionEl) return []\n        const orderedNodes = Array.from(\n          collectionEl.querySelectorAll(`[${COLLECTION_ITEM_SIGN}]`)\n        )\n\n        const items = [...itemMap.values()]\n\n        return items.sort(\n          (a, b) => orderedNodes.indexOf(a.ref!) - orderedNodes.indexOf(b.ref!)\n        )\n      }\n\n      provide(COLLECTION_INJECTION_KEY, {\n        itemMap,\n        getItems,\n        collectionRef,\n      })\n    },\n  }\n\n  const ElCollectionItem = {\n    ...CollectionItem,\n    name: COLLECTION_ITEM_NAME,\n    setup(_: unknown, { attrs }: SetupContext) {\n      const collectionItemRef = ref<HTMLElement | null>(null)\n      const collectionInjection = inject(COLLECTION_INJECTION_KEY, undefined)!\n\n      provide(COLLECTION_ITEM_INJECTION_KEY, {\n        collectionItemRef,\n      })\n\n      onMounted(() => {\n        const collectionItemEl = unref(collectionItemRef)\n        if (collectionItemEl) {\n          collectionInjection.itemMap.set(collectionItemEl, {\n            ref: collectionItemEl,\n            ...attrs,\n          })\n        }\n      })\n\n      onBeforeUnmount(() => {\n        const collectionItemEl = unref(collectionItemRef)!\n        collectionInjection.itemMap.delete(collectionItemEl)\n      })\n    },\n  }\n\n  return {\n    COLLECTION_INJECTION_KEY,\n    COLLECTION_ITEM_INJECTION_KEY,\n    ElCollection,\n    ElCollectionItem,\n  }\n}\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { createCollectionWithScope } from '@element-plus/components/collection'\nimport type { ExtractPropTypes, HTMLAttributes, StyleValue } from 'vue'\n\nexport const rovingFocusGroupProps = buildProps({\n  style: { type: definePropType<StyleValue>([String, Array, Object]) },\n  currentTabId: {\n    type: definePropType<string | null>(String),\n  },\n  defaultCurrentTabId: String,\n  loop: Boolean,\n  dir: {\n    type: String, // left for direction support\n    values: ['ltr', 'rtl'],\n    default: 'ltr',\n  },\n  orientation: {\n    // left for orientation support\n    type: definePropType<HTMLAttributes['aria-orientation']>(String),\n  },\n\n  onBlur: Function,\n  onFocus: Function,\n  onMousedown: Function,\n})\n\nexport type ElRovingFocusGroupProps = ExtractPropTypes<\n  typeof rovingFocusGroupProps\n>\n\nconst {\n  ElCollection,\n  ElCollectionItem,\n  COLLECTION_INJECTION_KEY,\n  COLLECTION_ITEM_INJECTION_KEY,\n} = createCollectionWithScope('RovingFocusGroup')\n\nexport {\n  ElCollection,\n  ElCollectionItem,\n  COLLECTION_INJECTION_KEY as ROVING_FOCUS_COLLECTION_INJECTION_KEY,\n  COLLECTION_ITEM_INJECTION_KEY as ROVING_FOCUS_ITEM_COLLECTION_INJECTION_KEY,\n}\n", "import type { InjectionKey, Ref, StyleValue } from 'vue'\nimport type { ElRovingFocusGroupProps } from './roving-focus-group'\n\ntype EventHandler<T = Event> = (e: T) => void\n\nexport type RovingGroupInjectionContext = {\n  currentTabbedId: Ref<string | null>\n  dir: Ref<ElRovingFocusGroupProps['dir']>\n  loop: Ref<ElRovingFocusGroupProps['loop']>\n  orientation: Ref<ElRovingFocusGroupProps['orientation']>\n  tabIndex: Ref<number>\n  rovingFocusGroupRef: Ref<HTMLElement | null>\n  rovingFocusGroupRootStyle: Ref<StyleValue>\n  onBlur: EventHandler\n  onFocus: EventHandler<FocusEvent>\n  onMousedown: EventHandler\n  onItemFocus: (id: string) => void\n  onItemShiftTab: () => void\n}\n\nexport type RovingFocusGroupItemInjectionContext = {\n  rovingFocusGroupItemRef: Ref<HTMLElement | null>\n  tabIndex: Ref<number>\n  handleMousedown: EventHandler\n  handleFocus: EventHandler\n  handleKeydown: EventHandler\n}\n\nexport const ROVING_FOCUS_GROUP_INJECTION_KEY: InjectionKey<RovingGroupInjectionContext> =\n  Symbol('elRovingFocusGroup')\n\nexport const ROVING_FOCUS_GROUP_ITEM_INJECTION_KEY: InjectionKey<RovingFocusGroupItemInjectionContext> =\n  Symbol('elRovingFocusGroupItem')\n", "import { EVENT_CODE } from '@element-plus/constants'\nimport type { HTMLAttributes } from 'vue'\n\ntype Orientation = HTMLAttributes['aria-orientation']\ntype Direction = 'ltr' | 'rtl'\ntype FocusIntent = 'first' | 'last' | 'prev' | 'next'\n\nconst MAP_KEY_TO_FOCUS_INTENT: Record<string, FocusIntent> = {\n  ArrowLeft: 'prev',\n  ArrowUp: 'prev',\n  ArrowRight: 'next',\n  ArrowDown: 'next',\n  PageUp: 'first',\n  Home: 'first',\n  PageDown: 'last',\n  End: 'last',\n}\n\nconst getDirectionAwareKey = (key: string, dir?: Direction) => {\n  if (dir !== 'rtl') return key\n\n  switch (key) {\n    case EVENT_CODE.right:\n      return EVENT_CODE.left\n    case EVENT_CODE.left:\n      return EVENT_CODE.right\n    default:\n      return key\n  }\n}\n\nexport const getFocusIntent = (\n  event: KeyboardEvent,\n  orientation?: Orientation,\n  dir?: Direction\n) => {\n  const key = getDirectionAwareKey(event.key, dir)\n  if (\n    orientation === 'vertical' &&\n    [EVENT_CODE.left, EVENT_CODE.right].includes(key)\n  )\n    return undefined\n  if (\n    orientation === 'horizontal' &&\n    [EVENT_CODE.up, EVENT_CODE.down].includes(key)\n  )\n    return undefined\n  return MAP_KEY_TO_FOCUS_INTENT[key]\n}\n\nexport const reorderArray = <T>(array: T[], atIdx: number) => {\n  return array.map((_, idx) => array[(idx + atIdx) % array.length])\n}\n\nexport const focusFirst = (elements: HTMLElement[]) => {\n  const { activeElement: prevActive } = document\n\n  for (const element of elements) {\n    if (element === prevActive) return\n    element.focus()\n    if (prevActive !== document.activeElement) return\n  }\n}\n", "<template>\n  <slot />\n</template>\n\n<script lang=\"ts\">\nimport {\n  computed,\n  defineComponent,\n  inject,\n  provide,\n  readonly,\n  ref,\n  toRef,\n  unref,\n  watch,\n} from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport { composeEventHandlers } from '@element-plus/utils'\nimport {\n  ROVING_FOCUS_COLLECTION_INJECTION_KEY,\n  rovingFocusGroupProps,\n} from './roving-focus-group'\nimport { ROVING_FOCUS_GROUP_INJECTION_KEY } from './tokens'\nimport { focusFirst } from './utils'\n\nimport type { StyleValue } from 'vue'\n\nconst CURRENT_TAB_ID_CHANGE_EVT = 'currentTabIdChange'\n\nconst ENTRY_FOCUS_EVT = 'rovingFocusGroup.entryFocus'\nconst EVT_OPTS: EventInit = { bubbles: false, cancelable: true }\nexport default defineComponent({\n  name: 'ElRovingFocusGroupImpl',\n  inheritAttrs: false,\n  props: rovingFocusGroupProps,\n  emits: [CURRENT_TAB_ID_CHANGE_EVT, 'entryFocus'],\n  setup(props, { emit }) {\n    const currentTabbedId = ref<string | null>(\n      (props.currentTabId || props.defaultCurrentTabId) ?? null\n    )\n    const isBackingOut = ref(false)\n    const isClickFocus = ref(false)\n    const rovingFocusGroupRef = ref<HTMLElement | null>(null)\n    const { getItems } = inject(\n      ROVING_FOCUS_COLLECTION_INJECTION_KEY,\n      undefined\n    )!\n    const rovingFocusGroupRootStyle = computed(() => {\n      // casting to any for fix compiler error since HTMLElement.StyleValue does not\n      // support CSSProperties\n      return [\n        {\n          outline: 'none',\n        },\n        props.style as StyleValue,\n      ] as any\n    })\n\n    const onItemFocus = (tabbedId: string) => {\n      emit(CURRENT_TAB_ID_CHANGE_EVT, tabbedId)\n    }\n\n    const onItemShiftTab = () => {\n      isBackingOut.value = true\n    }\n\n    const onMousedown = composeEventHandlers(\n      (e: Event) => {\n        props.onMousedown?.(e)\n      },\n      () => {\n        isClickFocus.value = true\n      }\n    )\n\n    const onFocus = composeEventHandlers(\n      (e: FocusEvent) => {\n        props.onFocus?.(e)\n      },\n      (e) => {\n        const isKeyboardFocus = !unref(isClickFocus)\n        const { target, currentTarget } = e\n        if (\n          target === currentTarget &&\n          isKeyboardFocus &&\n          !unref(isBackingOut)\n        ) {\n          const entryFocusEvt = new Event(ENTRY_FOCUS_EVT, EVT_OPTS)\n          currentTarget?.dispatchEvent(entryFocusEvt)\n\n          if (!entryFocusEvt.defaultPrevented) {\n            const items = getItems<{\n              id: string\n              focusable: boolean\n              active: boolean\n            }>().filter((item) => item.focusable)\n            const activeItem = items.find((item) => item.active)\n            const currentItem = items.find(\n              (item) => item.id === unref(currentTabbedId)\n            )\n            const candidates = [activeItem!, currentItem!, ...items].filter(\n              Boolean\n            )\n            const candidateNodes = candidates.map((item) => item.ref!)\n            focusFirst(candidateNodes)\n          }\n        }\n\n        isClickFocus.value = false\n      }\n    )\n\n    const onBlur = composeEventHandlers(\n      (e: Event) => {\n        props.onBlur?.(e)\n      },\n      () => {\n        isBackingOut.value = false\n      }\n    )\n\n    const handleEntryFocus = (...args: any[]) => {\n      emit('entryFocus', ...args)\n    }\n\n    provide(ROVING_FOCUS_GROUP_INJECTION_KEY, {\n      currentTabbedId: readonly(currentTabbedId),\n      loop: toRef(props, 'loop'),\n      tabIndex: computed(() => {\n        return unref(isBackingOut) ? -1 : 0\n      }),\n      rovingFocusGroupRef,\n      rovingFocusGroupRootStyle,\n      orientation: toRef(props, 'orientation'),\n      dir: toRef(props, 'dir'),\n      onItemFocus,\n      onItemShiftTab,\n      onBlur,\n      onFocus,\n      onMousedown,\n    })\n\n    watch(\n      () => props.currentTabId,\n      (val) => {\n        currentTabbedId.value = val ?? null\n      }\n    )\n\n    useEventListener(rovingFocusGroupRef, ENTRY_FOCUS_EVT, handleEntryFocus)\n  },\n})\n</script>\n", "<template>\n  <el-focus-group-collection>\n    <el-roving-focus-group-impl v-bind=\"$attrs\">\n      <slot />\n    </el-roving-focus-group-impl>\n  </el-focus-group-collection>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent } from 'vue'\nimport ElRovingFocusGroupImpl from './roving-focus-group-impl.vue'\nimport { ElCollection as ElFocusGroupCollection } from './roving-focus-group'\n\nexport default defineComponent({\n  name: 'ElRovingFocusGroup',\n  components: {\n    ElFocusGroupCollection,\n    ElRovingFocusGroupImpl,\n  },\n})\n</script>\n", "<template>\n  <el-roving-focus-collection-item\n    :id=\"id\"\n    :focusable=\"focusable\"\n    :active=\"active\"\n  >\n    <slot />\n  </el-roving-focus-collection-item>\n</template>\n\n<script lang=\"ts\">\nimport {\n  computed,\n  defineComponent,\n  inject,\n  nextTick,\n  provide,\n  ref,\n  unref,\n} from 'vue'\nimport { useId } from '@element-plus/hooks'\nimport { composeEventHandlers } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport {\n  ElCollectionItem as ElRovingFocusCollectionItem,\n  ROVING_FOCUS_COLLECTION_INJECTION_KEY,\n} from './roving-focus-group'\nimport {\n  ROVING_FOCUS_GROUP_INJECTION_KEY,\n  ROVING_FOCUS_GROUP_ITEM_INJECTION_KEY,\n} from './tokens'\nimport { focusFirst, getFocusIntent, reorderArray } from './utils'\n\nexport default defineComponent({\n  components: {\n    ElRovingFocusCollectionItem,\n  },\n  props: {\n    focusable: {\n      type: Boolean,\n      default: true,\n    },\n    active: {\n      type: Boolean,\n      default: false,\n    },\n  },\n  emits: ['mousedown', 'focus', 'keydown'],\n  setup(props, { emit }) {\n    const { currentTabbedId, loop, onItemFocus, onItemShiftTab } = inject(\n      ROVING_FOCUS_GROUP_INJECTION_KEY,\n      undefined\n    )!\n\n    const { getItems } = inject(\n      ROVING_FOCUS_COLLECTION_INJECTION_KEY,\n      undefined\n    )!\n\n    const id = useId()\n    const rovingFocusGroupItemRef = ref<HTMLElement | null>(null)\n\n    const handleMousedown = composeEventHandlers(\n      (e: Event) => {\n        emit('mousedown', e)\n      },\n      (e) => {\n        if (!props.focusable) {\n          e.preventDefault()\n        } else {\n          onItemFocus(unref(id))\n        }\n      }\n    )\n\n    const handleFocus = composeEventHandlers(\n      (e: Event) => {\n        emit('focus', e)\n      },\n      () => {\n        onItemFocus(unref(id))\n      }\n    )\n\n    const handleKeydown = composeEventHandlers(\n      (e: Event) => {\n        emit('keydown', e)\n      },\n      (e) => {\n        const { key, shiftKey, target, currentTarget } = e as KeyboardEvent\n        if (key === EVENT_CODE.tab && shiftKey) {\n          onItemShiftTab()\n          return\n        }\n        if (target !== currentTarget) return\n        const focusIntent = getFocusIntent(e as KeyboardEvent)\n\n        if (focusIntent) {\n          e.preventDefault()\n          const items = getItems<typeof props>().filter(\n            (item) => item.focusable\n          )\n\n          let elements = items.map((item) => item.ref!)\n\n          switch (focusIntent) {\n            case 'last': {\n              elements.reverse()\n              break\n            }\n            case 'prev':\n            case 'next': {\n              if (focusIntent === 'prev') {\n                elements.reverse()\n              }\n              const currentIdx = elements.indexOf(currentTarget as HTMLElement)\n              elements = loop.value\n                ? reorderArray(elements, currentIdx + 1)\n                : elements.slice(currentIdx + 1)\n              break\n            }\n            default: {\n              break\n            }\n          }\n\n          nextTick(() => {\n            focusFirst(elements)\n          })\n        }\n      }\n    )\n\n    const isCurrentTab = computed(() => currentTabbedId.value === unref(id))\n\n    provide(ROVING_FOCUS_GROUP_ITEM_INJECTION_KEY, {\n      rovingFocusGroupItemRef,\n      tabIndex: computed(() => (unref(isCurrentTab) ? 0 : -1)),\n      handleMousedown,\n      handleFocus,\n      handleKeydown,\n    })\n\n    return {\n      id,\n      handleKeydown,\n      handleFocus,\n      handleMousedown,\n    }\n  },\n})\n</script>\n", "// @ts-nocheck\nimport { buildProps, definePropType, iconPropType } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { createCollectionWithScope } from '@element-plus/components/collection'\nimport {\n  useTooltipContentProps,\n  useTooltipTriggerProps,\n} from '@element-plus/components/tooltip'\n\nimport type { Options } from '@popperjs/core'\nimport type { ButtonProps, ButtonType } from '@element-plus/components/button'\nimport type { Placement } from '@element-plus/components/popper'\nimport type { ComponentInternalInstance, ComputedRef } from 'vue'\nimport type { Nullable } from '@element-plus/utils'\n\nexport interface IElDropdownInstance {\n  instance?: ComponentInternalInstance\n  dropdownSize?: ComputedRef<string>\n  handleClick?: () => void\n  commandHandler?: (...arg) => void\n  show?: () => void\n  hide?: () => void\n  trigger?: ComputedRef<string>\n  hideOnClick?: ComputedRef<boolean>\n  triggerElm?: ComputedRef<Nullable<HTMLButtonElement>>\n}\n\nexport const dropdownProps = buildProps({\n  /**\n   * @description how to trigger\n   */\n  trigger: useTooltipTriggerProps.trigger,\n  effect: {\n    ...useTooltipContentProps.effect,\n    default: 'light',\n  },\n  /**\n   * @description menu button type, refer to `Button` Component, only works when `split-button` is true\n   */\n  type: {\n    type: definePropType<ButtonType>(String),\n  },\n  /**\n   * @description placement of pop menu\n   */\n  placement: {\n    type: definePropType<Placement>(String),\n    default: 'bottom',\n  },\n  /**\n   * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n   */\n  popperOptions: {\n    type: definePropType<Partial<Options>>(Object),\n    default: () => ({}),\n  },\n  id: String,\n  /**\n   * @description menu size, also works on the split button\n   */\n  size: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description whether a button group is displayed\n   */\n  splitButton: Boolean,\n  /**\n   * @description whether to hide menu after clicking menu-item\n   */\n  hideOnClick: {\n    type: Boolean,\n    default: true,\n  },\n  loop: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description delay time before show a dropdown (only works when trigger is `hover`)\n   */\n  showTimeout: {\n    type: Number,\n    default: 150,\n  },\n  /**\n   * @description delay time before hide a dropdown (only works when trigger is `hover`)\n   */\n  hideTimeout: {\n    type: Number,\n    default: 150,\n  },\n  /**\n   * @description [tabindex](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex) of Dropdown\n   */\n  tabindex: {\n    type: definePropType<number | string>([Number, String]),\n    default: 0,\n  },\n  /**\n   * @description the max height of menu\n   */\n  maxHeight: {\n    type: definePropType<number | string>([Number, String]),\n    default: '',\n  },\n  /**\n   * @description custom class name for Dropdown's dropdown\n   */\n  popperClass: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description whether to disable\n   */\n  disabled: Boolean,\n  /**\n   * @description the ARIA role attribute for the dropdown menu. Depending on the use case, you may want to change this to 'navigation'\n   */\n  role: {\n    type: String,\n    default: 'menu',\n  },\n  buttonProps: {\n    type: definePropType<ButtonProps>(Object),\n  },\n  /**\n   * @description whether the dropdown popup is teleported to the body\n   */\n  teleported: useTooltipContentProps.teleported,\n} as const)\n\nexport const dropdownItemProps = buildProps({\n  /**\n   * @description a command to be dispatched to Dropdown's `command` callback\n   */\n  command: {\n    type: [Object, String, Number],\n    default: () => ({}),\n  },\n  /**\n   * @description whether the item is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description whether a divider is displayed\n   */\n  divided: Boolean,\n  textValue: String,\n  /**\n   * @description custom icon\n   */\n  icon: {\n    type: iconPropType,\n  },\n} as const)\n\nexport const dropdownMenuProps = buildProps({\n  onKeydown: { type: definePropType<(e: KeyboardEvent) => void>(Function) },\n})\n\nexport const FIRST_KEYS = [\n  EVENT_CODE.down,\n  EVENT_CODE.pageDown,\n  EVENT_CODE.home,\n]\n\nexport const LAST_KEYS = [EVENT_CODE.up, EVENT_CODE.pageUp, EVENT_CODE.end]\n\nexport const FIRST_LAST_KEYS = [...FIRST_KEYS, ...LAST_KEYS]\n\nconst {\n  ElCollection,\n  ElCollectionItem,\n  COLLECTION_INJECTION_KEY,\n  COLLECTION_ITEM_INJECTION_KEY,\n} = createCollectionWithScope('Dropdown')\n\nexport {\n  ElCollection,\n  ElCollectionItem,\n  COLLECTION_INJECTION_KEY as DROPDOWN_COLLECTION_INJECTION_KEY,\n  COLLECTION_ITEM_INJECTION_KEY as DROPDOWN_COLLECTION_ITEM_INJECTION_KEY,\n}\n", "import type { ComputedRef, InjectionKey, Ref } from 'vue'\n\nexport type ElDropdownInjectionContext = {\n  contentRef: Ref<HTMLElement | null>\n  role: ComputedRef<string>\n  triggerId: ComputedRef<string>\n  isUsingKeyboard: Ref<boolean>\n  onItemLeave: (e: PointerEvent) => void\n  onItemEnter: (e: PointerEvent) => void\n}\n\nexport const DROPDOWN_INJECTION_KEY: InjectionKey<ElDropdownInjectionContext> =\n  Symbol('elDropdown')\n", "<template>\n  <div :class=\"[ns.b(), ns.is('disabled', disabled)]\">\n    <el-tooltip\n      ref=\"popperRef\"\n      :role=\"role\"\n      :effect=\"effect\"\n      :fallback-placements=\"['bottom', 'top']\"\n      :popper-options=\"popperOptions\"\n      :gpu-acceleration=\"false\"\n      :hide-after=\"trigger === 'hover' ? hideTimeout : 0\"\n      :manual-mode=\"true\"\n      :placement=\"placement\"\n      :popper-class=\"[ns.e('popper'), popperClass]\"\n      :reference-element=\"referenceElementRef?.$el\"\n      :trigger=\"trigger\"\n      :trigger-keys=\"triggerKeys\"\n      :trigger-target-el=\"contentRef\"\n      :show-after=\"trigger === 'hover' ? showTimeout : 0\"\n      :stop-popper-mouse-event=\"false\"\n      :virtual-ref=\"triggeringElementRef\"\n      :virtual-triggering=\"splitButton\"\n      :disabled=\"disabled\"\n      :transition=\"`${ns.namespace.value}-zoom-in-top`\"\n      :teleported=\"teleported\"\n      pure\n      persistent\n      @before-show=\"handleBeforeShowTooltip\"\n      @show=\"handleShowTooltip\"\n      @before-hide=\"handleBeforeHideTooltip\"\n    >\n      <template #content>\n        <el-scrollbar\n          ref=\"scrollbar\"\n          :wrap-style=\"wrapStyle\"\n          tag=\"div\"\n          :view-class=\"ns.e('list')\"\n        >\n          <el-roving-focus-group\n            :loop=\"loop\"\n            :current-tab-id=\"currentTabId\"\n            orientation=\"horizontal\"\n            @current-tab-id-change=\"handleCurrentTabIdChange\"\n            @entry-focus=\"handleEntryFocus\"\n          >\n            <el-dropdown-collection>\n              <slot name=\"dropdown\" />\n            </el-dropdown-collection>\n          </el-roving-focus-group>\n        </el-scrollbar>\n      </template>\n      <template v-if=\"!splitButton\" #default>\n        <el-only-child\n          :id=\"triggerId\"\n          ref=\"triggeringElementRef\"\n          role=\"button\"\n          :tabindex=\"tabindex\"\n        >\n          <slot name=\"default\" />\n        </el-only-child>\n      </template>\n    </el-tooltip>\n    <template v-if=\"splitButton\">\n      <el-button-group>\n        <el-button\n          ref=\"referenceElementRef\"\n          v-bind=\"buttonProps\"\n          :size=\"dropdownSize\"\n          :type=\"type\"\n          :disabled=\"disabled\"\n          :tabindex=\"tabindex\"\n          @click=\"handlerMainButtonClick\"\n        >\n          <slot name=\"default\" />\n        </el-button>\n        <el-button\n          :id=\"triggerId\"\n          ref=\"triggeringElementRef\"\n          v-bind=\"buttonProps\"\n          role=\"button\"\n          :size=\"dropdownSize\"\n          :type=\"type\"\n          :class=\"ns.e('caret-button')\"\n          :disabled=\"disabled\"\n          :tabindex=\"tabindex\"\n          :aria-label=\"t('el.dropdown.toggleDropdown')\"\n        >\n          <el-icon :class=\"ns.e('icon')\"><arrow-down /></el-icon>\n        </el-button>\n      </el-button-group>\n    </template>\n  </div>\n</template>\n<script lang=\"ts\">\n// @ts-nocheck\nimport {\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  onBeforeUnmount,\n  provide,\n  ref,\n  toRef,\n  unref,\n  watch,\n} from 'vue'\nimport ElButton from '@element-plus/components/button'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElIcon from '@element-plus/components/icon'\nimport ElRovingFocusGroup from '@element-plus/components/roving-focus-group'\nimport { ElOnlyChild } from '@element-plus/components/slot'\nimport { useFormSize } from '@element-plus/components/form'\nimport { addUnit, ensureArray } from '@element-plus/utils'\nimport { ArrowDown } from '@element-plus/icons-vue'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { useId, useLocale, useNamespace } from '@element-plus/hooks'\nimport { ElCollection as ElDropdownCollection, dropdownProps } from './dropdown'\nimport { DROPDOWN_INJECTION_KEY } from './tokens'\n\nimport type { CSSProperties } from 'vue'\n\nconst { ButtonGroup: ElButtonGroup } = ElButton\n\nexport default defineComponent({\n  name: 'ElDropdown',\n  components: {\n    ElButton,\n    ElButtonGroup,\n    ElScrollbar,\n    ElDropdownCollection,\n    ElTooltip,\n    ElRovingFocusGroup,\n    ElOnlyChild,\n    ElIcon,\n    ArrowDown,\n  },\n  props: dropdownProps,\n  emits: ['visible-change', 'click', 'command'],\n  setup(props, { emit }) {\n    const _instance = getCurrentInstance()\n    const ns = useNamespace('dropdown')\n    const { t } = useLocale()\n\n    const triggeringElementRef = ref()\n    const referenceElementRef = ref()\n    const popperRef = ref<InstanceType<typeof ElTooltip> | null>(null)\n    const contentRef = ref<HTMLElement | null>(null)\n    const scrollbar = ref(null)\n    const currentTabId = ref<string | null>(null)\n    const isUsingKeyboard = ref(false)\n    const triggerKeys = [EVENT_CODE.enter, EVENT_CODE.space, EVENT_CODE.down]\n\n    const wrapStyle = computed<CSSProperties>(() => ({\n      maxHeight: addUnit(props.maxHeight),\n    }))\n    const dropdownTriggerKls = computed(() => [ns.m(dropdownSize.value)])\n    const trigger = computed(() => ensureArray(props.trigger))\n\n    const defaultTriggerId = useId().value\n    const triggerId = computed<string>(() => props.id || defaultTriggerId)\n\n    // The goal of this code is to focus on the tooltip triggering element when it is hovered.\n    // This is a temporary fix for where closing the dropdown through pointerleave event focuses on a\n    // completely different element. For a permanent solution, remove all calls to any \"element.focus()\"\n    // that are triggered through pointer enter/leave events.\n    watch(\n      [triggeringElementRef, trigger],\n      ([triggeringElement, trigger], [prevTriggeringElement]) => {\n        if (prevTriggeringElement?.$el?.removeEventListener) {\n          prevTriggeringElement.$el.removeEventListener(\n            'pointerenter',\n            onAutofocusTriggerEnter\n          )\n        }\n        if (triggeringElement?.$el?.removeEventListener) {\n          triggeringElement.$el.removeEventListener(\n            'pointerenter',\n            onAutofocusTriggerEnter\n          )\n        }\n        if (\n          triggeringElement?.$el?.addEventListener &&\n          trigger.includes('hover')\n        ) {\n          triggeringElement.$el.addEventListener(\n            'pointerenter',\n            onAutofocusTriggerEnter\n          )\n        }\n      },\n      { immediate: true }\n    )\n\n    onBeforeUnmount(() => {\n      if (triggeringElementRef.value?.$el?.removeEventListener) {\n        triggeringElementRef.value.$el.removeEventListener(\n          'pointerenter',\n          onAutofocusTriggerEnter\n        )\n      }\n    })\n\n    function handleClick() {\n      handleClose()\n    }\n\n    function handleClose() {\n      popperRef.value?.onClose()\n    }\n\n    function handleOpen() {\n      popperRef.value?.onOpen()\n    }\n\n    const dropdownSize = useFormSize()\n\n    function commandHandler(...args: any[]) {\n      emit('command', ...args)\n    }\n\n    function onAutofocusTriggerEnter() {\n      triggeringElementRef.value?.$el?.focus()\n    }\n\n    function onItemEnter() {\n      // NOOP for now\n    }\n\n    function onItemLeave() {\n      const contentEl = unref(contentRef)\n\n      trigger.value.includes('hover') && contentEl?.focus()\n      currentTabId.value = null\n    }\n\n    function handleCurrentTabIdChange(id: string) {\n      currentTabId.value = id\n    }\n\n    function handleEntryFocus(e: Event) {\n      if (!isUsingKeyboard.value) {\n        e.preventDefault()\n        e.stopImmediatePropagation()\n      }\n    }\n\n    function handleBeforeShowTooltip() {\n      emit('visible-change', true)\n    }\n\n    function handleShowTooltip(event?: Event) {\n      if (event?.type === 'keydown') {\n        contentRef.value.focus()\n      }\n    }\n\n    function handleBeforeHideTooltip() {\n      emit('visible-change', false)\n    }\n\n    provide(DROPDOWN_INJECTION_KEY, {\n      contentRef,\n      role: computed(() => props.role),\n      triggerId,\n      isUsingKeyboard,\n      onItemEnter,\n      onItemLeave,\n    })\n\n    provide('elDropdown', {\n      instance: _instance,\n      dropdownSize,\n      handleClick,\n      commandHandler,\n      trigger: toRef(props, 'trigger'),\n      hideOnClick: toRef(props, 'hideOnClick'),\n    })\n\n    const onFocusAfterTrapped = (e: Event) => {\n      e.preventDefault()\n      contentRef.value?.focus?.({\n        preventScroll: true,\n      })\n    }\n\n    const handlerMainButtonClick = (event: MouseEvent) => {\n      emit('click', event)\n    }\n\n    return {\n      t,\n      ns,\n      scrollbar,\n      wrapStyle,\n      dropdownTriggerKls,\n      dropdownSize,\n      triggerId,\n      triggerKeys,\n      currentTabId,\n      handleCurrentTabIdChange,\n      handlerMainButtonClick,\n      handleEntryFocus,\n      handleClose,\n      handleOpen,\n      handleBeforeShowTooltip,\n      handleShowTooltip,\n      handleBeforeHideTooltip,\n      onFocusAfterTrapped,\n      popperRef,\n      contentRef,\n      triggeringElementRef,\n      referenceElementRef,\n    }\n  },\n})\n</script>\n", "<template>\n  <li\n    v-if=\"divided\"\n    role=\"separator\"\n    :class=\"ns.bem('menu', 'item', 'divided')\"\n    v-bind=\"$attrs\"\n  />\n  <li\n    :ref=\"itemRef\"\n    v-bind=\"{ ...dataset, ...$attrs }\"\n    :aria-disabled=\"disabled\"\n    :class=\"[ns.be('menu', 'item'), ns.is('disabled', disabled)]\"\n    :tabindex=\"tabIndex\"\n    :role=\"role\"\n    @click=\"(e) => $emit('clickimpl', e)\"\n    @focus=\"handleFocus\"\n    @keydown.self=\"handleKeydown\"\n    @mousedown=\"handleMousedown\"\n    @pointermove=\"(e) => $emit('pointermove', e)\"\n    @pointerleave=\"(e) => $emit('pointerleave', e)\"\n  >\n    <el-icon v-if=\"icon\">\n      <component :is=\"icon\" />\n    </el-icon>\n    <slot />\n  </li>\n</template>\n\n<script lang=\"ts\">\n// @ts-nocheck\nimport { computed, defineComponent, inject } from 'vue'\nimport {\n  ROVING_FOCUS_GROUP_ITEM_INJECTION_KEY,\n  ROVING_FOCUS_ITEM_COLLECTION_INJECTION_KEY,\n} from '@element-plus/components/roving-focus-group'\nimport { COLLECTION_ITEM_SIGN } from '@element-plus/components/collection'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { useNamespace } from '@element-plus/hooks'\nimport { composeEventHandlers, composeRefs } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport {\n  DROPDOWN_COLLECTION_ITEM_INJECTION_KEY,\n  dropdownItemProps,\n} from './dropdown'\nimport { DROPDOWN_INJECTION_KEY } from './tokens'\n\nexport default defineComponent({\n  name: 'DropdownItemImpl',\n  components: {\n    ElIcon,\n  },\n  props: dropdownItemProps,\n  emits: ['pointermove', 'pointerleave', 'click', 'clickimpl'],\n  setup(_, { emit }) {\n    const ns = useNamespace('dropdown')\n\n    const { role: menuRole } = inject(DROPDOWN_INJECTION_KEY, undefined)!\n\n    const { collectionItemRef: dropdownCollectionItemRef } = inject(\n      DROPDOWN_COLLECTION_ITEM_INJECTION_KEY,\n      undefined\n    )!\n\n    const { collectionItemRef: rovingFocusCollectionItemRef } = inject(\n      ROVING_FOCUS_ITEM_COLLECTION_INJECTION_KEY,\n      undefined\n    )!\n\n    const {\n      rovingFocusGroupItemRef,\n      tabIndex,\n      handleFocus,\n      handleKeydown: handleItemKeydown,\n      handleMousedown,\n    } = inject(ROVING_FOCUS_GROUP_ITEM_INJECTION_KEY, undefined)!\n\n    const itemRef = composeRefs(\n      dropdownCollectionItemRef,\n      rovingFocusCollectionItemRef,\n      rovingFocusGroupItemRef\n    )\n\n    const role = computed<string>(() => {\n      if (menuRole.value === 'menu') {\n        return 'menuitem'\n      } else if (menuRole.value === 'navigation') {\n        return 'link'\n      }\n      return 'button'\n    })\n\n    const handleKeydown = composeEventHandlers((e: KeyboardEvent) => {\n      const { code } = e\n      if (code === EVENT_CODE.enter || code === EVENT_CODE.space) {\n        e.preventDefault()\n        e.stopImmediatePropagation()\n        emit('clickimpl', e)\n        return true\n      }\n    }, handleItemKeydown)\n\n    return {\n      ns,\n      itemRef,\n      dataset: {\n        [COLLECTION_ITEM_SIGN]: '',\n      },\n      role,\n      tabIndex,\n      handleFocus,\n      handleKeydown,\n      handleMousedown,\n    }\n  },\n})\n</script>\n", "// @ts-nocheck\nimport { computed, inject, ref } from 'vue'\nimport { addClass } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport type { Nullable } from '@element-plus/utils'\nimport type { IElDropdownInstance } from './dropdown'\n\nexport const useDropdown = () => {\n  const elDropdown = inject<IElDropdownInstance>('elDropdown', {})\n  const _elDropdownSize = computed(() => elDropdown?.dropdownSize)\n\n  return {\n    elDropdown,\n    _elDropdownSize,\n  }\n}\n\nexport const initDropdownDomEvent = (\n  dropdownChildren,\n  triggerElm,\n  _instance\n) => {\n  const ns = useNamespace('dropdown')\n  const menuItems = ref<Nullable<HTMLButtonElement[]>>(null)\n  const menuItemsArray = ref<Nullable<HTMLElement[]>>(null)\n  const dropdownElm = ref<Nullable<HTMLElement>>(null)\n  const listId = useId()\n  dropdownElm.value = dropdownChildren?.subTree.el\n\n  function removeTabindex() {\n    triggerElm.setAttribute('tabindex', '-1')\n    menuItemsArray.value?.forEach((item) => item.setAttribute('tabindex', '-1'))\n  }\n\n  function resetTabindex(ele) {\n    removeTabindex()\n    ele?.setAttribute('tabindex', '0')\n  }\n\n  function handleTriggerKeyDown(ev: KeyboardEvent) {\n    const code = ev.code\n    if ([EVENT_CODE.up, EVENT_CODE.down].includes(code)) {\n      removeTabindex()\n      resetTabindex(menuItems.value[0])\n      menuItems.value[0].focus()\n      ev.preventDefault()\n      ev.stopPropagation()\n    } else if (code === EVENT_CODE.enter) {\n      _instance.handleClick()\n    } else if ([EVENT_CODE.tab, EVENT_CODE.esc].includes(code)) {\n      _instance.hide()\n    }\n  }\n\n  function handleItemKeyDown(ev) {\n    const code = ev.code\n    const target = ev.target\n    const currentIndex = menuItemsArray.value.indexOf(target)\n    const max = menuItemsArray.value.length - 1\n    let nextIndex\n    if ([EVENT_CODE.up, EVENT_CODE.down].includes(code)) {\n      if (code === EVENT_CODE.up) {\n        nextIndex = currentIndex !== 0 ? currentIndex - 1 : 0\n      } else {\n        nextIndex = currentIndex < max ? currentIndex + 1 : max\n      }\n      removeTabindex()\n      resetTabindex(menuItems.value[nextIndex])\n      menuItems.value[nextIndex].focus()\n      ev.preventDefault()\n      ev.stopPropagation()\n    } else if (code === EVENT_CODE.enter) {\n      triggerElmFocus()\n      target.click()\n      if (_instance.props.hideOnClick) {\n        _instance.hide()\n      }\n    } else if ([EVENT_CODE.tab, EVENT_CODE.esc].includes(code)) {\n      _instance.hide()\n      triggerElmFocus()\n    }\n  }\n\n  function initAria() {\n    dropdownElm.value.setAttribute('id', listId.value)\n    triggerElm.setAttribute('aria-haspopup', 'list')\n    triggerElm.setAttribute('aria-controls', listId.value)\n    if (!_instance.props.splitButton) {\n      triggerElm.setAttribute('role', 'button')\n      triggerElm.setAttribute('tabindex', _instance.props.tabindex)\n      addClass(triggerElm, ns.b('selfdefine'))\n    }\n  }\n\n  function initEvent() {\n    triggerElm?.addEventListener('keydown', handleTriggerKeyDown)\n    dropdownElm.value?.addEventListener('keydown', handleItemKeyDown, true)\n  }\n\n  function initDomOperation() {\n    menuItems.value = dropdownElm.value.querySelectorAll(\n      \"[tabindex='-1']\"\n    ) as unknown as HTMLButtonElement[]\n    menuItemsArray.value = Array.from(menuItems.value)\n\n    initEvent()\n    initAria()\n  }\n\n  function triggerElmFocus() {\n    triggerElm.focus()\n  }\n\n  initDomOperation()\n}\n", "<template>\n  <el-dropdown-collection-item\n    :disabled=\"disabled\"\n    :text-value=\"textValue ?? textContent\"\n  >\n    <el-roving-focus-item :focusable=\"!disabled\">\n      <el-dropdown-item-impl\n        v-bind=\"propsAndAttrs\"\n        @pointerleave=\"handlePointerLeave\"\n        @pointermove=\"handlePointerMove\"\n        @clickimpl=\"handleClick\"\n      >\n        <slot />\n      </el-dropdown-item-impl>\n    </el-roving-focus-item>\n  </el-dropdown-collection-item>\n</template>\n<script lang=\"ts\">\nimport {\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  inject,\n  ref,\n  unref,\n} from 'vue'\nimport { ElRovingFocusItem } from '@element-plus/components/roving-focus-group'\nimport { composeEventHandlers, whenMouse } from '@element-plus/utils'\nimport ElDropdownItemImpl from './dropdown-item-impl.vue'\nimport { useDropdown } from './useDropdown'\nimport {\n  ElCollectionItem as ElDropdownCollectionItem,\n  dropdownItemProps,\n} from './dropdown'\nimport { DROPDOWN_INJECTION_KEY } from './tokens'\n\nexport default defineComponent({\n  name: 'ElDropdownItem',\n  components: {\n    ElDropdownCollectionItem,\n    ElRovingFocusItem,\n    ElDropdownItemImpl,\n  },\n  inheritAttrs: false,\n  props: dropdownItemProps,\n  emits: ['pointermove', 'pointerleave', 'click'],\n  setup(props, { emit, attrs }) {\n    const { elDropdown } = useDropdown()\n    const _instance = getCurrentInstance()\n    const itemRef = ref<HTMLElement | null>(null)\n    const textContent = computed(() => unref(itemRef)?.textContent ?? '')\n    const { onItemEnter, onItemLeave } = inject(\n      DROPDOWN_INJECTION_KEY,\n      undefined\n    )!\n\n    const handlePointerMove = composeEventHandlers(\n      (e: PointerEvent) => {\n        emit('pointermove', e)\n        return e.defaultPrevented\n      },\n      whenMouse((e) => {\n        if (props.disabled) {\n          onItemLeave(e)\n          return\n        }\n\n        const target = e.currentTarget as HTMLElement\n        /**\n         * This handles the following scenario:\n         *   when the item contains a form element such as input element\n         *   when the mouse is moving over the element itself which is contained by\n         *   the item, the default focusing logic should be prevented so that\n         *   it won't cause weird action.\n         */\n        if (\n          target === document.activeElement ||\n          target.contains(document.activeElement)\n        ) {\n          return\n        }\n\n        onItemEnter(e)\n        if (!e.defaultPrevented) {\n          target?.focus()\n        }\n      })\n    )\n\n    const handlePointerLeave = composeEventHandlers((e: PointerEvent) => {\n      emit('pointerleave', e)\n      return e.defaultPrevented\n    }, whenMouse(onItemLeave))\n\n    const handleClick = composeEventHandlers(\n      (e: PointerEvent) => {\n        if (props.disabled) {\n          return\n        }\n        emit('click', e)\n        return e.type !== 'keydown' && e.defaultPrevented\n      },\n      (e) => {\n        if (props.disabled) {\n          e.stopImmediatePropagation()\n          return\n        }\n        if (elDropdown?.hideOnClick?.value) {\n          elDropdown.handleClick?.()\n        }\n        elDropdown.commandHandler?.(props.command, _instance, e)\n      }\n    )\n\n    // direct usage of v-bind={ ...$props, ...$attrs } causes type errors\n    const propsAndAttrs = computed(() => ({ ...props, ...attrs }))\n\n    return {\n      handleClick,\n      handlePointerMove,\n      handlePointerLeave,\n      textContent,\n      propsAndAttrs,\n    }\n  },\n})\n</script>\n", "<template>\n  <ul\n    :ref=\"dropdownListWrapperRef\"\n    :class=\"dropdownKls\"\n    :style=\"rovingFocusGroupRootStyle\"\n    :tabindex=\"-1\"\n    :role=\"role\"\n    :aria-labelledby=\"triggerId\"\n    @blur=\"onBlur\"\n    @focus=\"onFocus\"\n    @keydown.self=\"handleKeydown\"\n    @mousedown.self=\"onMousedown\"\n  >\n    <slot />\n  </ul>\n</template>\n<script lang=\"ts\">\n// @ts-nocheck\nimport { computed, defineComponent, inject, unref } from 'vue'\nimport { composeEventHandlers, composeRefs } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { FOCUS_TRAP_INJECTION_KEY } from '@element-plus/components/focus-trap'\nimport {\n  ROVING_FOCUS_COLLECTION_INJECTION_KEY,\n  ROVING_FOCUS_GROUP_INJECTION_KEY,\n  focusFirst,\n} from '@element-plus/components/roving-focus-group'\nimport { useNamespace } from '@element-plus/hooks'\nimport { DROPDOWN_INJECTION_KEY } from './tokens'\nimport {\n  DROPDOWN_COLLECTION_INJECTION_KEY,\n  FIRST_LAST_KEYS,\n  LAST_KEYS,\n  dropdownMenuProps,\n} from './dropdown'\nimport { useDropdown } from './useDropdown'\n\nexport default defineComponent({\n  name: 'ElDropdownMenu',\n  props: dropdownMenuProps,\n  setup(props) {\n    const ns = useNamespace('dropdown')\n    const { _elDropdownSize } = useDropdown()\n    const size = _elDropdownSize.value\n\n    const { focusTrapRef, onKeydown } = inject(\n      FOCUS_TRAP_INJECTION_KEY,\n      undefined\n    )!\n\n    const { contentRef, role, triggerId } = inject(\n      DROPDOWN_INJECTION_KEY,\n      undefined\n    )!\n\n    const { collectionRef: dropdownCollectionRef, getItems } = inject(\n      DROPDOWN_COLLECTION_INJECTION_KEY,\n      undefined\n    )!\n\n    const {\n      rovingFocusGroupRef,\n      rovingFocusGroupRootStyle,\n      tabIndex,\n      onBlur,\n      onFocus,\n      onMousedown,\n    } = inject(ROVING_FOCUS_GROUP_INJECTION_KEY, undefined)!\n\n    const { collectionRef: rovingFocusGroupCollectionRef } = inject(\n      ROVING_FOCUS_COLLECTION_INJECTION_KEY,\n      undefined\n    )!\n\n    const dropdownKls = computed(() => {\n      return [ns.b('menu'), ns.bm('menu', size?.value)]\n    })\n\n    const dropdownListWrapperRef = composeRefs(\n      contentRef,\n      dropdownCollectionRef,\n      focusTrapRef,\n      rovingFocusGroupRef,\n      rovingFocusGroupCollectionRef\n    )\n\n    const composedKeydown = composeEventHandlers(\n      (e: KeyboardEvent) => {\n        props.onKeydown?.(e)\n      },\n      (e) => {\n        const { currentTarget, code, target } = e\n        const isKeydownContained = (currentTarget as Node).contains(\n          target as Node\n        )\n\n        if (isKeydownContained) {\n          // TODO: implement typeahead search\n        }\n\n        if (EVENT_CODE.tab === code) {\n          e.stopImmediatePropagation()\n        }\n\n        e.preventDefault()\n\n        if (target !== unref(contentRef) || !FIRST_LAST_KEYS.includes(code))\n          return\n        const items = getItems<{ disabled: boolean }>().filter(\n          (item) => !item.disabled\n        )\n        const targets = items.map((item) => item.ref!)\n        if (LAST_KEYS.includes(code)) {\n          targets.reverse()\n        }\n        focusFirst(targets)\n      }\n    )\n\n    const handleKeydown = (e: KeyboardEvent) => {\n      composedKeydown(e)\n      onKeydown(e)\n    }\n\n    return {\n      size,\n      rovingFocusGroupRootStyle,\n      tabIndex,\n      dropdownKls,\n      role,\n      triggerId,\n      dropdownListWrapperRef,\n      handleKeydown,\n      onBlur,\n      onFocus,\n      onMousedown,\n    }\n  },\n})\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\n\nimport Dropdown from './src/dropdown.vue'\nimport DropdownItem from './src/dropdown-item.vue'\nimport DropdownMenu from './src/dropdown-menu.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElDropdown: SFCWithInstall<typeof Dropdown> & {\n  DropdownItem: typeof DropdownItem\n  DropdownMenu: typeof DropdownMenu\n} = withInstall(Dropdown, {\n  DropdownItem,\n  DropdownMenu,\n})\nexport default ElDropdown\nexport const ElDropdownItem: SFCWithInstall<typeof DropdownItem> =\n  withNoopInstall(DropdownItem)\nexport const ElDropdownMenu: SFCWithInstall<typeof DropdownMenu> =\n  withNoopInstall(DropdownMenu)\nexport * from './src/dropdown'\nexport * from './src/instance'\nexport * from './src/tokens'\n", "<template>\n  <svg\n    viewBox=\"0 0 79 86\"\n    version=\"1.1\"\n    xmlns=\"http://www.w3.org/2000/svg\"\n    xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n  >\n    <defs>\n      <linearGradient\n        :id=\"`linearGradient-1-${id}`\"\n        x1=\"38.8503086%\"\n        y1=\"0%\"\n        x2=\"61.1496914%\"\n        y2=\"100%\"\n      >\n        <stop\n          :stop-color=\"`var(${ns.cssVarBlockName('fill-color-1')})`\"\n          offset=\"0%\"\n        />\n        <stop\n          :stop-color=\"`var(${ns.cssVarBlockName('fill-color-4')})`\"\n          offset=\"100%\"\n        />\n      </linearGradient>\n      <linearGradient\n        :id=\"`linearGradient-2-${id}`\"\n        x1=\"0%\"\n        y1=\"9.5%\"\n        x2=\"100%\"\n        y2=\"90.5%\"\n      >\n        <stop\n          :stop-color=\"`var(${ns.cssVarBlockName('fill-color-1')})`\"\n          offset=\"0%\"\n        />\n        <stop\n          :stop-color=\"`var(${ns.cssVarBlockName('fill-color-6')})`\"\n          offset=\"100%\"\n        />\n      </linearGradient>\n      <rect :id=\"`path-3-${id}`\" x=\"0\" y=\"0\" width=\"17\" height=\"36\" />\n    </defs>\n    <g\n      id=\"Illustrations\"\n      stroke=\"none\"\n      stroke-width=\"1\"\n      fill=\"none\"\n      fill-rule=\"evenodd\"\n    >\n      <g id=\"B-type\" transform=\"translate(-1268.000000, -535.000000)\">\n        <g id=\"Group-2\" transform=\"translate(1268.000000, 535.000000)\">\n          <path\n            id=\"Oval-Copy-2\"\n            d=\"M39.5,86 C61.3152476,86 79,83.9106622 79,81.3333333 C79,78.7560045 57.3152476,78 35.5,78 C13.6847524,78 0,78.7560045 0,81.3333333 C0,83.9106622 17.6847524,86 39.5,86 Z\"\n            :fill=\"`var(${ns.cssVarBlockName('fill-color-3')})`\"\n          />\n          <polygon\n            id=\"Rectangle-Copy-14\"\n            :fill=\"`var(${ns.cssVarBlockName('fill-color-7')})`\"\n            transform=\"translate(27.500000, 51.500000) scale(1, -1) translate(-27.500000, -51.500000) \"\n            points=\"13 58 53 58 42 45 2 45\"\n          />\n          <g\n            id=\"Group-Copy\"\n            transform=\"translate(34.500000, 31.500000) scale(-1, 1) rotate(-25.000000) translate(-34.500000, -31.500000) translate(7.000000, 10.000000)\"\n          >\n            <polygon\n              id=\"Rectangle-Copy-10\"\n              :fill=\"`var(${ns.cssVarBlockName('fill-color-7')})`\"\n              transform=\"translate(11.500000, 5.000000) scale(1, -1) translate(-11.500000, -5.000000) \"\n              points=\"2.84078316e-14 3 18 3 23 7 5 7\"\n            />\n            <polygon\n              id=\"Rectangle-Copy-11\"\n              :fill=\"`var(${ns.cssVarBlockName('fill-color-5')})`\"\n              points=\"-3.69149156e-15 7 38 7 38 43 -3.69149156e-15 43\"\n            />\n            <rect\n              id=\"Rectangle-Copy-12\"\n              :fill=\"`url(#linearGradient-1-${id})`\"\n              transform=\"translate(46.500000, 25.000000) scale(-1, 1) translate(-46.500000, -25.000000) \"\n              x=\"38\"\n              y=\"7\"\n              width=\"17\"\n              height=\"36\"\n            />\n            <polygon\n              id=\"Rectangle-Copy-13\"\n              :fill=\"`var(${ns.cssVarBlockName('fill-color-2')})`\"\n              transform=\"translate(39.500000, 3.500000) scale(-1, 1) translate(-39.500000, -3.500000) \"\n              points=\"24 7 41 7 55 -3.63806207e-12 38 -3.63806207e-12\"\n            />\n          </g>\n          <rect\n            id=\"Rectangle-Copy-15\"\n            :fill=\"`url(#linearGradient-2-${id})`\"\n            x=\"13\"\n            y=\"45\"\n            width=\"40\"\n            height=\"36\"\n          />\n          <g id=\"Rectangle-Copy-17\" transform=\"translate(53.000000, 45.000000)\">\n            <use\n              id=\"Mask\"\n              :fill=\"`var(${ns.cssVarBlockName('fill-color-8')})`\"\n              transform=\"translate(8.500000, 18.000000) scale(-1, 1) translate(-8.500000, -18.000000) \"\n              :xlink:href=\"`#path-3-${id}`\"\n            />\n            <polygon\n              id=\"Rectangle-Copy\"\n              :fill=\"`var(${ns.cssVarBlockName('fill-color-9')})`\"\n              :mask=\"`url(#mask-4-${id})`\"\n              transform=\"translate(12.000000, 9.000000) scale(-1, 1) translate(-12.000000, -9.000000) \"\n              points=\"7 0 24 0 20 18 7 16.5\"\n            />\n          </g>\n          <polygon\n            id=\"Rectangle-Copy-18\"\n            :fill=\"`var(${ns.cssVarBlockName('fill-color-2')})`\"\n            transform=\"translate(66.000000, 51.500000) scale(-1, 1) translate(-66.000000, -51.500000) \"\n            points=\"62 45 79 45 70 58 53 58\"\n          />\n        </g>\n      </g>\n    </g>\n  </svg>\n</template>\n\n<script lang=\"ts\" setup>\nimport { useId, useNamespace } from '@element-plus/hooks'\n\ndefineOptions({\n  name: 'ImgEmpty',\n})\n\nconst ns = useNamespace('empty')\nconst id = useId()\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const emptyProps = buildProps({\n  /**\n   * @description image URL of empty\n   */\n  image: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description image size (width) of empty\n   */\n  imageSize: Number,\n  /**\n   * @description description of empty\n   */\n  description: {\n    type: String,\n    default: '',\n  },\n} as const)\n\nexport type EmptyProps = ExtractPropTypes<typeof emptyProps>\n", "<template>\n  <div :class=\"ns.b()\">\n    <div :class=\"ns.e('image')\" :style=\"imageStyle\">\n      <img v-if=\"image\" :src=\"image\" ondragstart=\"return false\" />\n      <slot v-else name=\"image\">\n        <img-empty />\n      </slot>\n    </div>\n    <div :class=\"ns.e('description')\">\n      <slot v-if=\"$slots.description\" name=\"description\" />\n      <p v-else>{{ emptyDescription }}</p>\n    </div>\n    <div v-if=\"$slots.default\" :class=\"ns.e('bottom')\">\n      <slot />\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { addUnit } from '@element-plus/utils'\nimport ImgEmpty from './img-empty.vue'\nimport { emptyProps } from './empty'\n\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElEmpty',\n})\n\nconst props = defineProps(emptyProps)\n\nconst { t } = useLocale()\nconst ns = useNamespace('empty')\nconst emptyDescription = computed(\n  () => props.description || t('el.table.emptyText')\n)\nconst imageStyle = computed<CSSProperties>(() => ({\n  width: addUnit(props.imageSize),\n}))\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Empty from './src/empty.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElEmpty: SFCWithInstall<typeof Empty> = withInstall(Empty)\nexport default ElEmpty\n\nexport * from './src/empty'\nexport type { EmptyInstance } from './src/instance'\n", "import {\n  buildProps,\n  definePropType,\n  isNumber,\n  mutable,\n} from '@element-plus/utils'\n\nimport type { Component, ExtractPropTypes } from 'vue'\nimport type ImageViewer from './image-viewer.vue'\n\nexport type ImageViewerAction =\n  | 'zoomIn'\n  | 'zoomOut'\n  | 'clockwise'\n  | 'anticlockwise'\n\nexport const imageViewerProps = buildProps({\n  /**\n   * @description preview link list.\n   */\n  urlList: {\n    type: definePropType<string[]>(Array),\n    default: () => mutable([] as const),\n  },\n  /**\n   * @description preview backdrop z-index.\n   */\n  zIndex: {\n    type: Number,\n  },\n  /**\n   * @description the initial preview image index, less than or equal to the length of `url-list`.\n   */\n  initialIndex: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description whether preview is infinite.\n   */\n  infinite: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether user can emit close event when clicking backdrop.\n   */\n  hideOnClickModal: Boolean,\n  /**\n   * @description whether to append image itself to body. A nested parent element attribute transform should have this attribute set to `true`.\n   */\n  teleported: Boolean,\n  /**\n   * @description whether the image-viewer can be closed by pressing ESC.\n   */\n  closeOnPressEscape: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description the zoom rate of the image viewer zoom event.\n   */\n  zoomRate: {\n    type: Number,\n    default: 1.2,\n  },\n  /**\n   * @description the min scale of the image viewer zoom event.\n   */\n  minScale: {\n    type: Number,\n    default: 0.2,\n  },\n  /**\n   * @description the max scale of the image viewer zoom event.\n   */\n  maxScale: {\n    type: Number,\n    default: 7,\n  },\n  /**\n   * @description set HTML attribute: crossorigin.\n   */\n  crossorigin: {\n    type: definePropType<'anonymous' | 'use-credentials' | ''>(String),\n  },\n} as const)\nexport type ImageViewerProps = ExtractPropTypes<typeof imageViewerProps>\n\nexport const imageViewerEmits = {\n  close: () => true,\n  switch: (index: number) => isNumber(index),\n  rotate: (deg: number) => isNumber(deg),\n}\nexport type ImageViewerEmits = typeof imageViewerEmits\n\nexport interface ImageViewerMode {\n  name: string\n  icon: Component\n}\n\nexport type ImageViewerInstance = InstanceType<typeof ImageViewer>\n", "<template>\n  <el-teleport to=\"body\" :disabled=\"!teleported\">\n    <transition name=\"viewer-fade\" appear>\n      <div\n        ref=\"wrapper\"\n        :tabindex=\"-1\"\n        :class=\"ns.e('wrapper')\"\n        :style=\"{ zIndex }\"\n      >\n        <div :class=\"ns.e('mask')\" @click.self=\"hideOnClickModal && hide()\" />\n\n        <!-- CLOSE -->\n        <span :class=\"[ns.e('btn'), ns.e('close')]\" @click=\"hide\">\n          <el-icon>\n            <Close />\n          </el-icon>\n        </span>\n\n        <!-- ARROW -->\n        <template v-if=\"!isSingle\">\n          <span :class=\"arrowPrevKls\" @click=\"prev\">\n            <el-icon>\n              <ArrowLeft />\n            </el-icon>\n          </span>\n          <span :class=\"arrowNextKls\" @click=\"next\">\n            <el-icon>\n              <ArrowRight />\n            </el-icon>\n          </span>\n        </template>\n        <!-- ACTIONS -->\n        <div :class=\"[ns.e('btn'), ns.e('actions')]\">\n          <div :class=\"ns.e('actions__inner')\">\n            <el-icon @click=\"handleActions('zoomOut')\">\n              <ZoomOut />\n            </el-icon>\n            <el-icon @click=\"handleActions('zoomIn')\">\n              <ZoomIn />\n            </el-icon>\n            <i :class=\"ns.e('actions__divider')\" />\n            <el-icon @click=\"toggleMode\">\n              <component :is=\"mode.icon\" />\n            </el-icon>\n            <i :class=\"ns.e('actions__divider')\" />\n            <el-icon @click=\"handleActions('anticlockwise')\">\n              <RefreshLeft />\n            </el-icon>\n            <el-icon @click=\"handleActions('clockwise')\">\n              <RefreshRight />\n            </el-icon>\n          </div>\n        </div>\n        <!-- CANVAS -->\n        <div :class=\"ns.e('canvas')\">\n          <img\n            v-for=\"(url, i) in urlList\"\n            v-show=\"i === activeIndex\"\n            :ref=\"(el) => (imgRefs[i] = el as HTMLImageElement)\"\n            :key=\"url\"\n            :src=\"url\"\n            :style=\"imgStyle\"\n            :class=\"ns.e('img')\"\n            :crossorigin=\"crossorigin\"\n            @load=\"handleImgLoad\"\n            @error=\"handleImgError\"\n            @mousedown=\"handleMouseDown\"\n          />\n        </div>\n        <slot />\n      </div>\n    </transition>\n  </el-teleport>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  effectScope,\n  markRaw,\n  nextTick,\n  onMounted,\n  ref,\n  shallowRef,\n  watch,\n} from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport { throttle } from 'lodash-unified'\nimport { useLocale, useNamespace, useZIndex } from '@element-plus/hooks'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { keysOf } from '@element-plus/utils'\nimport ElTeleport from '@element-plus/components/teleport'\nimport ElIcon from '@element-plus/components/icon'\nimport {\n  ArrowLeft,\n  ArrowRight,\n  Close,\n  FullScreen,\n  RefreshLeft,\n  RefreshRight,\n  ScaleToOriginal,\n  ZoomIn,\n  ZoomOut,\n} from '@element-plus/icons-vue'\nimport { imageViewerEmits, imageViewerProps } from './image-viewer'\n\nimport type { CSSProperties } from 'vue'\nimport type { ImageViewerAction, ImageViewerMode } from './image-viewer'\n\nconst modes: Record<'CONTAIN' | 'ORIGINAL', ImageViewerMode> = {\n  CONTAIN: {\n    name: 'contain',\n    icon: markRaw(FullScreen),\n  },\n  ORIGINAL: {\n    name: 'original',\n    icon: markRaw(ScaleToOriginal),\n  },\n}\n\ndefineOptions({\n  name: 'ElImageViewer',\n})\n\nconst props = defineProps(imageViewerProps)\nconst emit = defineEmits(imageViewerEmits)\n\nconst { t } = useLocale()\nconst ns = useNamespace('image-viewer')\nconst { nextZIndex } = useZIndex()\nconst wrapper = ref<HTMLDivElement>()\nconst imgRefs = ref<HTMLImageElement[]>([])\n\nconst scopeEventListener = effectScope()\n\nconst loading = ref(true)\nconst activeIndex = ref(props.initialIndex)\nconst mode = shallowRef<ImageViewerMode>(modes.CONTAIN)\nconst transform = ref({\n  scale: 1,\n  deg: 0,\n  offsetX: 0,\n  offsetY: 0,\n  enableTransition: false,\n})\nconst zIndex = ref(props.zIndex ?? nextZIndex())\n\nconst isSingle = computed(() => {\n  const { urlList } = props\n  return urlList.length <= 1\n})\n\nconst isFirst = computed(() => {\n  return activeIndex.value === 0\n})\n\nconst isLast = computed(() => {\n  return activeIndex.value === props.urlList.length - 1\n})\n\nconst currentImg = computed(() => {\n  return props.urlList[activeIndex.value]\n})\n\nconst arrowPrevKls = computed(() => [\n  ns.e('btn'),\n  ns.e('prev'),\n  ns.is('disabled', !props.infinite && isFirst.value),\n])\n\nconst arrowNextKls = computed(() => [\n  ns.e('btn'),\n  ns.e('next'),\n  ns.is('disabled', !props.infinite && isLast.value),\n])\n\nconst imgStyle = computed(() => {\n  const { scale, deg, offsetX, offsetY, enableTransition } = transform.value\n  let translateX = offsetX / scale\n  let translateY = offsetY / scale\n\n  const radian = (deg * Math.PI) / 180\n  const cosRadian = Math.cos(radian)\n  const sinRadian = Math.sin(radian)\n  translateX = translateX * cosRadian + translateY * sinRadian\n  translateY = translateY * cosRadian - (offsetX / scale) * sinRadian\n\n  const style: CSSProperties = {\n    transform: `scale(${scale}) rotate(${deg}deg) translate(${translateX}px, ${translateY}px)`,\n    transition: enableTransition ? 'transform .3s' : '',\n  }\n  if (mode.value.name === modes.CONTAIN.name) {\n    style.maxWidth = style.maxHeight = '100%'\n  }\n  return style\n})\n\nfunction hide() {\n  unregisterEventListener()\n  emit('close')\n}\n\nfunction registerEventListener() {\n  const keydownHandler = throttle((e: KeyboardEvent) => {\n    switch (e.code) {\n      // ESC\n      case EVENT_CODE.esc:\n        props.closeOnPressEscape && hide()\n        break\n      // SPACE\n      case EVENT_CODE.space:\n        toggleMode()\n        break\n      // LEFT_ARROW\n      case EVENT_CODE.left:\n        prev()\n        break\n      // UP_ARROW\n      case EVENT_CODE.up:\n        handleActions('zoomIn')\n        break\n      // RIGHT_ARROW\n      case EVENT_CODE.right:\n        next()\n        break\n      // DOWN_ARROW\n      case EVENT_CODE.down:\n        handleActions('zoomOut')\n        break\n    }\n  })\n  const mousewheelHandler = throttle((e: WheelEvent) => {\n    const delta = e.deltaY || e.deltaX\n    handleActions(delta < 0 ? 'zoomIn' : 'zoomOut', {\n      zoomRate: props.zoomRate,\n      enableTransition: false,\n    })\n  })\n\n  scopeEventListener.run(() => {\n    useEventListener(document, 'keydown', keydownHandler)\n    useEventListener(document, 'wheel', mousewheelHandler)\n  })\n}\n\nfunction unregisterEventListener() {\n  scopeEventListener.stop()\n}\n\nfunction handleImgLoad() {\n  loading.value = false\n}\n\nfunction handleImgError(e: Event) {\n  loading.value = false\n  ;(e.target as HTMLImageElement).alt = t('el.image.error')\n}\n\nfunction handleMouseDown(e: MouseEvent) {\n  if (loading.value || e.button !== 0 || !wrapper.value) return\n  transform.value.enableTransition = false\n\n  const { offsetX, offsetY } = transform.value\n  const startX = e.pageX\n  const startY = e.pageY\n\n  const dragHandler = throttle((ev: MouseEvent) => {\n    transform.value = {\n      ...transform.value,\n      offsetX: offsetX + ev.pageX - startX,\n      offsetY: offsetY + ev.pageY - startY,\n    }\n  })\n  const removeMousemove = useEventListener(document, 'mousemove', dragHandler)\n  useEventListener(document, 'mouseup', () => {\n    removeMousemove()\n  })\n\n  e.preventDefault()\n}\n\nfunction reset() {\n  transform.value = {\n    scale: 1,\n    deg: 0,\n    offsetX: 0,\n    offsetY: 0,\n    enableTransition: false,\n  }\n}\n\nfunction toggleMode() {\n  if (loading.value) return\n\n  const modeNames = keysOf(modes)\n  const modeValues = Object.values(modes)\n  const currentMode = mode.value.name\n  const index = modeValues.findIndex((i) => i.name === currentMode)\n  const nextIndex = (index + 1) % modeNames.length\n  mode.value = modes[modeNames[nextIndex]]\n  reset()\n}\n\nfunction setActiveItem(index: number) {\n  const len = props.urlList.length\n  activeIndex.value = (index + len) % len\n}\n\nfunction prev() {\n  if (isFirst.value && !props.infinite) return\n  setActiveItem(activeIndex.value - 1)\n}\n\nfunction next() {\n  if (isLast.value && !props.infinite) return\n  setActiveItem(activeIndex.value + 1)\n}\n\nfunction handleActions(action: ImageViewerAction, options = {}) {\n  if (loading.value) return\n  const { minScale, maxScale } = props\n  const { zoomRate, rotateDeg, enableTransition } = {\n    zoomRate: props.zoomRate,\n    rotateDeg: 90,\n    enableTransition: true,\n    ...options,\n  }\n  switch (action) {\n    case 'zoomOut':\n      if (transform.value.scale > minScale) {\n        transform.value.scale = Number.parseFloat(\n          (transform.value.scale / zoomRate).toFixed(3)\n        )\n      }\n      break\n    case 'zoomIn':\n      if (transform.value.scale < maxScale) {\n        transform.value.scale = Number.parseFloat(\n          (transform.value.scale * zoomRate).toFixed(3)\n        )\n      }\n      break\n    case 'clockwise':\n      transform.value.deg += rotateDeg\n      emit('rotate', transform.value.deg)\n      break\n    case 'anticlockwise':\n      transform.value.deg -= rotateDeg\n      emit('rotate', transform.value.deg)\n      break\n  }\n  transform.value.enableTransition = enableTransition\n}\n\nwatch(currentImg, () => {\n  nextTick(() => {\n    const $img = imgRefs.value[0]\n    if (!$img?.complete) {\n      loading.value = true\n    }\n  })\n})\n\nwatch(activeIndex, (val) => {\n  reset()\n  emit('switch', val)\n})\n\nonMounted(() => {\n  registerEventListener()\n  // add tabindex then wrapper can be focusable via Javascript\n  // focus wrapper so arrow key can't cause inner scroll behavior underneath\n  wrapper.value?.focus?.()\n})\n\ndefineExpose({\n  /**\n   * @description manually switch image\n   */\n  setActiveItem,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport ImageViewer from './src/image-viewer.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElImageViewer: SFCWithInstall<typeof ImageViewer> =\n  withInstall(ImageViewer)\nexport default ElImageViewer\n\nexport * from './src/image-viewer'\n", "import {\n  buildProps,\n  definePropType,\n  isNumber,\n  mutable,\n} from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const imageProps = buildProps({\n  /**\n   * @description when enabling preview, use this flag to control whether clicking on backdrop can exit preview mode.\n   */\n  hideOnClickModal: Boolean,\n  /**\n   * @description image source, same as native.\n   */\n  src: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description indicate how the image should be resized to fit its container, same as [object-fit](https://developer.mozilla.org/en-US/docs/Web/CSS/object-fit).\n   */\n  fit: {\n    type: String,\n    values: ['', 'contain', 'cover', 'fill', 'none', 'scale-down'],\n    default: '',\n  },\n  /**\n   * @description Indicates how the browser should load the image, same as [native](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/img#attr-loading)\n   */\n  loading: {\n    type: String,\n    values: ['eager', 'lazy'],\n  },\n  /**\n   * @description whether to use lazy load.\n   */\n  lazy: Boolean,\n  /**\n   * @description the container to add scroll listener when using lazy load.\n   */\n  scrollContainer: {\n    type: definePropType<string | HTMLElement | undefined>([String, Object]),\n  },\n  /**\n   * @description allow big image preview.\n   */\n  previewSrcList: {\n    type: definePropType<string[]>(Array),\n    default: () => mutable([] as const),\n  },\n  /**\n   * @description whether to append image-viewer to body. A nested parent element attribute transform should have this attribute set to `true`.\n   */\n  previewTeleported: Boolean,\n  /**\n   * @description set image preview z-index.\n   */\n  zIndex: {\n    type: Number,\n  },\n  /**\n   * @description initial preview image index, less than the length of `url-list`.\n   */\n  initialIndex: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description whether the viewer preview is infinite.\n   */\n  infinite: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether the image-viewer can be closed by pressing ESC.\n   */\n  closeOnPressEscape: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description the zoom rate of the image viewer zoom event\n   */\n  zoomRate: {\n    type: Number,\n    default: 1.2,\n  },\n  /**\n   * @description the min scale of the image viewer zoom event.\n   */\n  minScale: {\n    type: Number,\n    default: 0.2,\n  },\n  /**\n   * @description the max scale of the image viewer zoom event.\n   */\n  maxScale: {\n    type: Number,\n    default: 7,\n  },\n  /**\n   * @description set HTML attribute: crossorigin.\n   */\n  crossorigin: {\n    type: definePropType<'anonymous' | 'use-credentials' | ''>(String),\n  },\n} as const)\nexport type ImageProps = ExtractPropTypes<typeof imageProps>\n\nexport const imageEmits = {\n  load: (evt: Event) => evt instanceof Event,\n  error: (evt: Event) => evt instanceof Event,\n  switch: (val: number) => isNumber(val),\n  close: () => true,\n  show: () => true,\n}\nexport type ImageEmits = typeof imageEmits\n", "<template>\n  <div ref=\"container\" v-bind=\"containerAttrs\" :class=\"[ns.b(), $attrs.class]\">\n    <slot v-if=\"hasLoadError\" name=\"error\">\n      <div :class=\"ns.e('error')\">{{ t('el.image.error') }}</div>\n    </slot>\n    <template v-else>\n      <img\n        v-if=\"imageSrc !== undefined\"\n        v-bind=\"imgAttrs\"\n        :src=\"imageSrc\"\n        :loading=\"loading\"\n        :style=\"imageStyle\"\n        :class=\"imageKls\"\n        :crossorigin=\"crossorigin\"\n        @click=\"clickHandler\"\n        @load=\"handleLoad\"\n        @error=\"handleError\"\n      />\n      <div v-if=\"isLoading\" :class=\"ns.e('wrapper')\">\n        <slot name=\"placeholder\">\n          <div :class=\"ns.e('placeholder')\" />\n        </slot>\n      </div>\n    </template>\n    <template v-if=\"preview\">\n      <image-viewer\n        v-if=\"showViewer\"\n        :z-index=\"zIndex\"\n        :initial-index=\"imageIndex\"\n        :infinite=\"infinite\"\n        :zoom-rate=\"zoomRate\"\n        :min-scale=\"minScale\"\n        :max-scale=\"maxScale\"\n        :url-list=\"previewSrcList\"\n        :crossorigin=\"crossorigin\"\n        :hide-on-click-modal=\"hideOnClickModal\"\n        :teleported=\"previewTeleported\"\n        :close-on-press-escape=\"closeOnPressEscape\"\n        @close=\"closeViewer\"\n        @switch=\"switchViewer\"\n      >\n        <div v-if=\"$slots.viewer\">\n          <slot name=\"viewer\" />\n        </div>\n      </image-viewer>\n    </template>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  nextTick,\n  onMounted,\n  ref,\n  useAttrs as useRawAttrs,\n  watch,\n} from 'vue'\nimport { useEventListener, useThrottleFn } from '@vueuse/core'\nimport { fromPairs } from 'lodash-unified'\nimport { useAttrs, useLocale, useNamespace } from '@element-plus/hooks'\nimport ImageViewer from '@element-plus/components/image-viewer'\nimport {\n  getScrollContainer,\n  isClient,\n  isElement,\n  isInContainer,\n  isString,\n} from '@element-plus/utils'\nimport { imageEmits, imageProps } from './image'\n\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElImage',\n  inheritAttrs: false,\n})\n\nconst props = defineProps(imageProps)\nconst emit = defineEmits(imageEmits)\n\nlet prevOverflow = ''\n\nconst { t } = useLocale()\nconst ns = useNamespace('image')\nconst rawAttrs = useRawAttrs()\n\nconst containerAttrs = computed(() => {\n  return fromPairs(\n    Object.entries(rawAttrs).filter(\n      ([key]) => /^(data-|on[A-Z])/i.test(key) || ['id', 'style'].includes(key)\n    )\n  )\n})\n\nconst imgAttrs = useAttrs({\n  excludeListeners: true,\n  excludeKeys: computed<string[]>(() => {\n    return Object.keys(containerAttrs.value)\n  }),\n})\n\nconst imageSrc = ref<string | undefined>()\nconst hasLoadError = ref(false)\nconst isLoading = ref(true)\nconst showViewer = ref(false)\nconst container = ref<HTMLElement>()\nconst _scrollContainer = ref<HTMLElement | Window>()\n\nconst supportLoading = isClient && 'loading' in HTMLImageElement.prototype\nlet stopScrollListener: (() => void) | undefined\nlet stopWheelListener: (() => void) | undefined\n\nconst imageKls = computed(() => [\n  ns.e('inner'),\n  preview.value && ns.e('preview'),\n  isLoading.value && ns.is('loading'),\n])\n\nconst imageStyle = computed<CSSProperties>(() => {\n  const { fit } = props\n  if (isClient && fit) {\n    return { objectFit: fit }\n  }\n  return {}\n})\n\nconst preview = computed(() => {\n  const { previewSrcList } = props\n  return Array.isArray(previewSrcList) && previewSrcList.length > 0\n})\n\nconst imageIndex = computed(() => {\n  const { previewSrcList, initialIndex } = props\n  let previewIndex = initialIndex\n  if (initialIndex > previewSrcList.length - 1) {\n    previewIndex = 0\n  }\n  return previewIndex\n})\n\nconst isManual = computed(() => {\n  if (props.loading === 'eager') return false\n  return (!supportLoading && props.loading === 'lazy') || props.lazy\n})\n\nconst loadImage = () => {\n  if (!isClient) return\n\n  // reset status\n  isLoading.value = true\n  hasLoadError.value = false\n  imageSrc.value = props.src\n}\n\nfunction handleLoad(event: Event) {\n  isLoading.value = false\n  hasLoadError.value = false\n  emit('load', event)\n}\n\nfunction handleError(event: Event) {\n  isLoading.value = false\n  hasLoadError.value = true\n  emit('error', event)\n}\n\nfunction handleLazyLoad() {\n  if (isInContainer(container.value, _scrollContainer.value)) {\n    loadImage()\n    removeLazyLoadListener()\n  }\n}\n\nconst lazyLoadHandler = useThrottleFn(handleLazyLoad, 200, true)\n\nasync function addLazyLoadListener() {\n  if (!isClient) return\n\n  await nextTick()\n\n  const { scrollContainer } = props\n  if (isElement(scrollContainer)) {\n    _scrollContainer.value = scrollContainer\n  } else if (isString(scrollContainer) && scrollContainer !== '') {\n    _scrollContainer.value =\n      document.querySelector<HTMLElement>(scrollContainer) ?? undefined\n  } else if (container.value) {\n    _scrollContainer.value = getScrollContainer(container.value)\n  }\n\n  if (_scrollContainer.value) {\n    stopScrollListener = useEventListener(\n      _scrollContainer,\n      'scroll',\n      lazyLoadHandler\n    )\n    setTimeout(() => handleLazyLoad(), 100)\n  }\n}\n\nfunction removeLazyLoadListener() {\n  if (!isClient || !_scrollContainer.value || !lazyLoadHandler) return\n\n  stopScrollListener?.()\n  _scrollContainer.value = undefined\n}\n\nfunction wheelHandler(e: WheelEvent) {\n  if (!e.ctrlKey) return\n\n  if (e.deltaY < 0) {\n    e.preventDefault()\n    return false\n  } else if (e.deltaY > 0) {\n    e.preventDefault()\n    return false\n  }\n}\n\nfunction clickHandler() {\n  // don't show viewer when preview is false\n  if (!preview.value) return\n\n  stopWheelListener = useEventListener('wheel', wheelHandler, {\n    passive: false,\n  })\n\n  // prevent body scroll\n  prevOverflow = document.body.style.overflow\n  document.body.style.overflow = 'hidden'\n  showViewer.value = true\n  emit('show')\n}\n\nfunction closeViewer() {\n  stopWheelListener?.()\n  document.body.style.overflow = prevOverflow\n  showViewer.value = false\n  emit('close')\n}\n\nfunction switchViewer(val: number) {\n  emit('switch', val)\n}\n\nwatch(\n  () => props.src,\n  () => {\n    if (isManual.value) {\n      // reset status\n      isLoading.value = true\n      hasLoadError.value = false\n      removeLazyLoadListener()\n      addLazyLoadListener()\n    } else {\n      loadImage()\n    }\n  }\n)\n\nonMounted(() => {\n  if (isManual.value) {\n    addLazyLoadListener()\n  } else {\n    loadImage()\n  }\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Image from './src/image.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElImage: SFCWithInstall<typeof Image> = withInstall(Image)\nexport default ElImage\n\nexport * from './src/image'\n", "import { isNil } from 'lodash-unified'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport { buildProps, isNumber } from '@element-plus/utils'\nimport {\n  CHANGE_EVENT,\n  INPUT_EVENT,\n  UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport type { ExtractPropTypes } from 'vue'\nimport type InputNumber from './input-number.vue'\n\nexport const inputNumberProps = buildProps({\n  /**\n   * @description same as `id` in native input\n   */\n  id: {\n    type: String,\n    default: undefined,\n  },\n  /**\n   * @description incremental step\n   */\n  step: {\n    type: Number,\n    default: 1,\n  },\n  /**\n   * @description whether input value can only be multiple of step\n   */\n  stepStrictly: Boolean,\n  /**\n   * @description the maximum allowed value\n   */\n  max: {\n    type: Number,\n    default: Number.POSITIVE_INFINITY,\n  },\n  /**\n   * @description the minimum allowed value\n   */\n  min: {\n    type: Number,\n    default: Number.NEGATIVE_INFINITY,\n  },\n  /**\n   * @description binding value\n   */\n  modelValue: Number,\n  /**\n   * @description same as `readonly` in native input\n   */\n  readonly: Boolean,\n  /**\n   * @description whether the component is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description size of the component\n   */\n  size: useSizeProp,\n  /**\n   * @description whether to enable the control buttons\n   */\n  controls: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description position of the control buttons\n   */\n  controlsPosition: {\n    type: String,\n    default: '',\n    values: ['', 'right'],\n  },\n  /**\n   * @description value should be set when input box is cleared\n   */\n  valueOnClear: {\n    type: [String, Number, null],\n    validator: (val: 'min' | 'max' | number | null) =>\n      val === null || isNumber(val) || ['min', 'max'].includes(val),\n    default: null,\n  },\n  /**\n   * @description same as `name` in native input\n   */\n  name: String,\n  /**\n   * @description same as `placeholder` in native input\n   */\n  placeholder: String,\n  /**\n   * @description precision of input value\n   */\n  precision: {\n    type: Number,\n    validator: (val: number) =>\n      val >= 0 && val === Number.parseInt(`${val}`, 10),\n  },\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  ...useAriaProps(['ariaLabel']),\n} as const)\nexport type InputNumberProps = ExtractPropTypes<typeof inputNumberProps>\n\nexport const inputNumberEmits = {\n  [CHANGE_EVENT]: (cur: number | undefined, prev: number | undefined) =>\n    prev !== cur,\n  blur: (e: FocusEvent) => e instanceof FocusEvent,\n  focus: (e: FocusEvent) => e instanceof FocusEvent,\n  [INPUT_EVENT]: (val: number | null | undefined) =>\n    isNumber(val) || isNil(val),\n  [UPDATE_MODEL_EVENT]: (val: number | undefined) =>\n    isNumber(val) || isNil(val),\n}\nexport type InputNumberEmits = typeof inputNumberEmits\n\nexport type InputNumberInstance = InstanceType<typeof InputNumber>\n", "<template>\n  <div\n    :class=\"[\n      ns.b(),\n      ns.m(inputNumberSize),\n      ns.is('disabled', inputNumberDisabled),\n      ns.is('without-controls', !controls),\n      ns.is('controls-right', controlsAtRight),\n    ]\"\n    @dragstart.prevent\n  >\n    <span\n      v-if=\"controls\"\n      v-repeat-click=\"decrease\"\n      role=\"button\"\n      :aria-label=\"t('el.inputNumber.decrease')\"\n      :class=\"[ns.e('decrease'), ns.is('disabled', minDisabled)]\"\n      @keydown.enter=\"decrease\"\n    >\n      <slot name=\"decrease-icon\">\n        <el-icon>\n          <arrow-down v-if=\"controlsAtRight\" />\n          <minus v-else />\n        </el-icon>\n      </slot>\n    </span>\n    <span\n      v-if=\"controls\"\n      v-repeat-click=\"increase\"\n      role=\"button\"\n      :aria-label=\"t('el.inputNumber.increase')\"\n      :class=\"[ns.e('increase'), ns.is('disabled', maxDisabled)]\"\n      @keydown.enter=\"increase\"\n    >\n      <slot name=\"increase-icon\">\n        <el-icon>\n          <arrow-up v-if=\"controlsAtRight\" />\n          <plus v-else />\n        </el-icon>\n      </slot>\n    </span>\n    <el-input\n      :id=\"id\"\n      ref=\"input\"\n      type=\"number\"\n      :step=\"step\"\n      :model-value=\"displayValue\"\n      :placeholder=\"placeholder\"\n      :readonly=\"readonly\"\n      :disabled=\"inputNumberDisabled\"\n      :size=\"inputNumberSize\"\n      :max=\"max\"\n      :min=\"min\"\n      :name=\"name\"\n      :aria-label=\"ariaLabel\"\n      :validate-event=\"false\"\n      @keydown.up.prevent=\"increase\"\n      @keydown.down.prevent=\"decrease\"\n      @blur=\"handleBlur\"\n      @focus=\"handleFocus\"\n      @input=\"handleInput\"\n      @change=\"handleInputChange\"\n    >\n      <template v-if=\"$slots.prefix\" #prefix>\n        <slot name=\"prefix\" />\n      </template>\n      <template v-if=\"$slots.suffix\" #suffix>\n        <slot name=\"suffix\" />\n      </template>\n    </el-input>\n  </div>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, onMounted, onUpdated, reactive, ref, watch } from 'vue'\nimport { isNil } from 'lodash-unified'\nimport { ElInput } from '@element-plus/components/input'\nimport { ElIcon } from '@element-plus/components/icon'\nimport {\n  useFormDisabled,\n  useFormItem,\n  useFormSize,\n} from '@element-plus/components/form'\nimport { vRepeatClick } from '@element-plus/directives'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport {\n  debugWarn,\n  isNumber,\n  isString,\n  isUndefined,\n  throwError,\n} from '@element-plus/utils'\nimport { ArrowDown, ArrowUp, Minus, Plus } from '@element-plus/icons-vue'\nimport {\n  CHANGE_EVENT,\n  INPUT_EVENT,\n  UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { inputNumberEmits, inputNumberProps } from './input-number'\n\nimport type { InputInstance } from '@element-plus/components/input'\n\ndefineOptions({\n  name: 'ElInputNumber',\n})\n\nconst props = defineProps(inputNumberProps)\nconst emit = defineEmits(inputNumberEmits)\n\nconst { t } = useLocale()\nconst ns = useNamespace('input-number')\nconst input = ref<InputInstance>()\n\ninterface Data {\n  currentValue: number | null | undefined\n  userInput: null | number | string\n}\nconst data = reactive<Data>({\n  currentValue: props.modelValue,\n  userInput: null,\n})\n\nconst { formItem } = useFormItem()\n\nconst minDisabled = computed(\n  () => isNumber(props.modelValue) && props.modelValue <= props.min\n)\nconst maxDisabled = computed(\n  () => isNumber(props.modelValue) && props.modelValue >= props.max\n)\n\nconst numPrecision = computed(() => {\n  const stepPrecision = getPrecision(props.step)\n  if (!isUndefined(props.precision)) {\n    if (stepPrecision > props.precision) {\n      debugWarn(\n        'InputNumber',\n        'precision should not be less than the decimal places of step'\n      )\n    }\n    return props.precision\n  } else {\n    return Math.max(getPrecision(props.modelValue), stepPrecision)\n  }\n})\nconst controlsAtRight = computed(() => {\n  return props.controls && props.controlsPosition === 'right'\n})\n\nconst inputNumberSize = useFormSize()\nconst inputNumberDisabled = useFormDisabled()\n\nconst displayValue = computed(() => {\n  if (data.userInput !== null) {\n    return data.userInput\n  }\n  let currentValue: number | string | undefined | null = data.currentValue\n  if (isNil(currentValue)) return ''\n  if (isNumber(currentValue)) {\n    if (Number.isNaN(currentValue)) return ''\n    if (!isUndefined(props.precision)) {\n      currentValue = currentValue.toFixed(props.precision)\n    }\n  }\n  return currentValue\n})\nconst toPrecision = (num: number, pre?: number) => {\n  if (isUndefined(pre)) pre = numPrecision.value\n  if (pre === 0) return Math.round(num)\n  let snum = String(num)\n  const pointPos = snum.indexOf('.')\n  if (pointPos === -1) return num\n  const nums = snum.replace('.', '').split('')\n  const datum = nums[pointPos + pre]\n  if (!datum) return num\n  const length = snum.length\n  if (snum.charAt(length - 1) === '5') {\n    snum = `${snum.slice(0, Math.max(0, length - 1))}6`\n  }\n  return Number.parseFloat(Number(snum).toFixed(pre))\n}\nconst getPrecision = (value: number | null | undefined) => {\n  if (isNil(value)) return 0\n  const valueString = value.toString()\n  const dotPosition = valueString.indexOf('.')\n  let precision = 0\n  if (dotPosition !== -1) {\n    precision = valueString.length - dotPosition - 1\n  }\n  return precision\n}\nconst ensurePrecision = (val: number, coefficient: 1 | -1 = 1) => {\n  if (!isNumber(val)) return data.currentValue\n  // Solve the accuracy problem of JS decimal calculation by converting the value to integer.\n  return toPrecision(val + props.step * coefficient)\n}\nconst increase = () => {\n  if (props.readonly || inputNumberDisabled.value || maxDisabled.value) return\n  const value = Number(displayValue.value) || 0\n  const newVal = ensurePrecision(value)\n  setCurrentValue(newVal)\n  emit(INPUT_EVENT, data.currentValue)\n  setCurrentValueToModelValue()\n}\nconst decrease = () => {\n  if (props.readonly || inputNumberDisabled.value || minDisabled.value) return\n  const value = Number(displayValue.value) || 0\n  const newVal = ensurePrecision(value, -1)\n  setCurrentValue(newVal)\n  emit(INPUT_EVENT, data.currentValue)\n  setCurrentValueToModelValue()\n}\nconst verifyValue = (\n  value: number | string | null | undefined,\n  update?: boolean\n): number | null | undefined => {\n  const { max, min, step, precision, stepStrictly, valueOnClear } = props\n  if (max < min) {\n    throwError('InputNumber', 'min should not be greater than max.')\n  }\n  let newVal = Number(value)\n  if (isNil(value) || Number.isNaN(newVal)) {\n    return null\n  }\n  if (value === '') {\n    if (valueOnClear === null) {\n      return null\n    }\n    newVal = isString(valueOnClear) ? { min, max }[valueOnClear] : valueOnClear\n  }\n  if (stepStrictly) {\n    newVal = toPrecision(Math.round(newVal / step) * step, precision)\n    if (newVal !== value) {\n      update && emit(UPDATE_MODEL_EVENT, newVal)\n    }\n  }\n  if (!isUndefined(precision)) {\n    newVal = toPrecision(newVal, precision)\n  }\n  if (newVal > max || newVal < min) {\n    newVal = newVal > max ? max : min\n    update && emit(UPDATE_MODEL_EVENT, newVal)\n  }\n  return newVal\n}\nconst setCurrentValue = (\n  value: number | string | null | undefined,\n  emitChange = true\n) => {\n  const oldVal = data.currentValue\n  const newVal = verifyValue(value)\n  if (!emitChange) {\n    emit(UPDATE_MODEL_EVENT, newVal!)\n    return\n  }\n  if (oldVal === newVal && value) return\n  data.userInput = null\n  emit(UPDATE_MODEL_EVENT, newVal!)\n  if (oldVal !== newVal) {\n    emit(CHANGE_EVENT, newVal!, oldVal!)\n  }\n  if (props.validateEvent) {\n    formItem?.validate?.('change').catch((err) => debugWarn(err))\n  }\n  data.currentValue = newVal\n}\nconst handleInput = (value: string) => {\n  data.userInput = value\n  const newVal = value === '' ? null : Number(value)\n  emit(INPUT_EVENT, newVal)\n  setCurrentValue(newVal, false)\n}\nconst handleInputChange = (value: string) => {\n  const newVal = value !== '' ? Number(value) : ''\n  if ((isNumber(newVal) && !Number.isNaN(newVal)) || value === '') {\n    setCurrentValue(newVal)\n  }\n  setCurrentValueToModelValue()\n  data.userInput = null\n}\n\nconst focus = () => {\n  input.value?.focus?.()\n}\n\nconst blur = () => {\n  input.value?.blur?.()\n}\n\nconst handleFocus = (event: MouseEvent | FocusEvent) => {\n  emit('focus', event)\n}\n\nconst handleBlur = (event: MouseEvent | FocusEvent) => {\n  data.userInput = null\n  emit('blur', event)\n  if (props.validateEvent) {\n    formItem?.validate?.('blur').catch((err) => debugWarn(err))\n  }\n}\n\nconst setCurrentValueToModelValue = () => {\n  if (data.currentValue !== props.modelValue) {\n    data.currentValue = props.modelValue\n  }\n}\nconst handleWheel = (e: WheelEvent) => {\n  if (document.activeElement === e.target) e.preventDefault()\n}\n\nwatch(\n  () => props.modelValue,\n  (value, oldValue) => {\n    const newValue = verifyValue(value, true)\n    if (data.userInput === null && newValue !== oldValue) {\n      data.currentValue = newValue\n    }\n  },\n  { immediate: true }\n)\nonMounted(() => {\n  const { min, max, modelValue } = props\n  const innerInput = input.value?.input as HTMLInputElement\n  innerInput.setAttribute('role', 'spinbutton')\n  if (Number.isFinite(max)) {\n    innerInput.setAttribute('aria-valuemax', String(max))\n  } else {\n    innerInput.removeAttribute('aria-valuemax')\n  }\n  if (Number.isFinite(min)) {\n    innerInput.setAttribute('aria-valuemin', String(min))\n  } else {\n    innerInput.removeAttribute('aria-valuemin')\n  }\n  innerInput.setAttribute(\n    'aria-valuenow',\n    data.currentValue || data.currentValue === 0\n      ? String(data.currentValue)\n      : ''\n  )\n  innerInput.setAttribute('aria-disabled', String(inputNumberDisabled.value))\n  if (!isNumber(modelValue) && modelValue != null) {\n    let val: number | null = Number(modelValue)\n    if (Number.isNaN(val)) {\n      val = null\n    }\n    emit(UPDATE_MODEL_EVENT, val!)\n  }\n  innerInput.addEventListener('wheel', handleWheel, { passive: false })\n})\nonUpdated(() => {\n  const innerInput = input.value?.input\n  innerInput?.setAttribute('aria-valuenow', `${data.currentValue ?? ''}`)\n})\ndefineExpose({\n  /** @description get focus the input component */\n  focus,\n  /** @description remove focus the input component */\n  blur,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport InputNumber from './src/input-number.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElInputNumber: SFCWithInstall<typeof InputNumber> =\n  withInstall(InputNumber)\n\nexport default ElInputNumber\nexport * from './src/input-number'\n", "import { buildProps, iconPropType } from '@element-plus/utils'\nimport type { ExtractPropTypes, PropType } from 'vue'\nimport type Link from './link.vue'\n\nexport const linkProps = buildProps({\n  /**\n   * @description type\n   */\n  type: {\n    type: String,\n    values: ['primary', 'success', 'warning', 'info', 'danger', 'default'],\n    default: 'default',\n  },\n  /**\n   * @description whether the component has underline\n   */\n  underline: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether the component is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description same as native hyperlink's `href`\n   */\n  href: { type: String, default: '' },\n  /**\n   * @description same as native hyperlink's `target`\n   */\n  target: {\n    type: String as PropType<'_blank' | '_parent' | '_self' | '_top' | string>,\n    default: '_self',\n  },\n  /**\n   * @description icon component\n   */\n  icon: {\n    type: iconPropType,\n  },\n} as const)\nexport type LinkProps = ExtractPropTypes<typeof linkProps>\n\nexport const linkEmits = {\n  click: (evt: MouseEvent) => evt instanceof MouseEvent,\n}\nexport type LinkEmits = typeof linkEmits\n\nexport type LinkInstance = InstanceType<typeof Link>\n", "<template>\n  <a\n    :class=\"linkKls\"\n    :href=\"disabled || !href ? undefined : href\"\n    :target=\"disabled || !href ? undefined : target\"\n    @click=\"handleClick\"\n  >\n    <el-icon v-if=\"icon\"><component :is=\"icon\" /></el-icon>\n    <span v-if=\"$slots.default\" :class=\"ns.e('inner')\">\n      <slot />\n    </span>\n\n    <slot v-if=\"$slots.icon\" name=\"icon\" />\n  </a>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { useNamespace } from '@element-plus/hooks'\nimport { linkEmits, linkProps } from './link'\n\ndefineOptions({\n  name: 'ElLink',\n})\nconst props = defineProps(linkProps)\nconst emit = defineEmits(linkEmits)\n\nconst ns = useNamespace('link')\n\nconst linkKls = computed(() => [\n  ns.b(),\n  ns.m(props.type),\n  ns.is('disabled', props.disabled),\n  ns.is('underline', props.underline && !props.disabled),\n])\n\nfunction handleClick(event: MouseEvent) {\n  if (!props.disabled) emit('click', event)\n}\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Link from './src/link.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElLink: SFCWithInstall<typeof Link> = withInstall(Link)\nexport default ElLink\n\nexport * from './src/link'\n", "// @ts-nocheck\nimport { triggerEvent } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport type MenuItem from './menu-item'\n\nclass SubMenu {\n  public subMenuItems: NodeList\n  public subIndex = 0\n  constructor(public parent: MenuItem, public domNode: ParentNode) {\n    this.subIndex = 0\n    this.init()\n  }\n\n  init(): void {\n    this.subMenuItems = this.domNode.querySelectorAll('li')\n    this.addListeners()\n  }\n\n  gotoSubIndex(idx: number): void {\n    if (idx === this.subMenuItems.length) {\n      idx = 0\n    } else if (idx < 0) {\n      idx = this.subMenuItems.length - 1\n    }\n    ;(this.subMenuItems[idx] as HTMLElement).focus()\n    this.subIndex = idx\n  }\n\n  addListeners(): void {\n    const parentNode = this.parent.domNode\n    Array.prototype.forEach.call(this.subMenuItems, (el: Element) => {\n      el.addEventListener('keydown', (event: KeyboardEvent) => {\n        let prevDef = false\n        switch (event.code) {\n          case EVENT_CODE.down: {\n            this.gotoSubIndex(this.subIndex + 1)\n            prevDef = true\n            break\n          }\n          case EVENT_CODE.up: {\n            this.gotoSubIndex(this.subIndex - 1)\n            prevDef = true\n            break\n          }\n          case EVENT_CODE.tab: {\n            triggerEvent(parentNode as HTMLElement, 'mouseleave')\n            break\n          }\n          case EVENT_CODE.enter:\n          case EVENT_CODE.space: {\n            prevDef = true\n            ;(event.currentTarget as HTMLElement).click()\n            break\n          }\n        }\n        if (prevDef) {\n          event.preventDefault()\n          event.stopPropagation()\n        }\n        return false\n      })\n    })\n  }\n}\n\nexport default SubMenu\n", "// @ts-nocheck\nimport { triggerEvent } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport SubMenu from './submenu'\n\nclass MenuItem {\n  public submenu: SubMenu = null\n  constructor(public domNode: HTMLElement, namespace: string) {\n    this.submenu = null\n    this.init(namespace)\n  }\n\n  init(namespace: string): void {\n    this.domNode.setAttribute('tabindex', '0')\n    const menuChild = this.domNode.querySelector(`.${namespace}-menu`)\n    if (menuChild) {\n      this.submenu = new SubMenu(this, menuChild)\n    }\n    this.addListeners()\n  }\n\n  addListeners(): void {\n    this.domNode.addEventListener('keydown', (event: KeyboardEvent) => {\n      let prevDef = false\n      switch (event.code) {\n        case EVENT_CODE.down: {\n          triggerEvent(event.currentTarget as HTMLElement, 'mouseenter')\n          this.submenu && this.submenu.gotoSubIndex(0)\n          prevDef = true\n          break\n        }\n        case EVENT_CODE.up: {\n          triggerEvent(event.currentTarget as HTMLElement, 'mouseenter')\n          this.submenu &&\n            this.submenu.gotoSubIndex(this.submenu.subMenuItems.length - 1)\n          prevDef = true\n          break\n        }\n        case EVENT_CODE.tab: {\n          triggerEvent(event.currentTarget as HTMLElement, 'mouseleave')\n          break\n        }\n        case EVENT_CODE.enter:\n        case EVENT_CODE.space: {\n          prevDef = true\n          ;(event.currentTarget as HTMLElement).click()\n          break\n        }\n      }\n      if (prevDef) {\n        event.preventDefault()\n      }\n    })\n  }\n}\n\nexport default MenuItem\n", "import MenuItem from './menu-item'\n\nimport type { RendererNode } from 'vue'\n\nclass Menu {\n  constructor(public domNode: RendererNode, namespace: string) {\n    this.init(namespace)\n  }\n  init(namespace: string): void {\n    const menuChildren = this.domNode.childNodes\n    Array.from<Node>(menuChildren).forEach((child) => {\n      if (child.nodeType === 1) {\n        new MenuItem(child as HTMLElement, namespace)\n      }\n    })\n  }\n}\n\nexport default Menu\n", "<template>\n  <transition mode=\"out-in\" v-bind=\"listeners\">\n    <slot />\n  </transition>\n</template>\n<script lang=\"ts\">\nimport { defineComponent } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { addClass, hasClass, removeClass } from '@element-plus/utils'\n\nimport type { BaseTransitionProps, TransitionProps } from 'vue'\n\nexport default defineComponent({\n  name: 'ElMenuCollapseTransition',\n  setup() {\n    const ns = useNamespace('menu')\n    const listeners = {\n      onBeforeEnter: (el) => (el.style.opacity = '0.2'),\n      onEnter(el, done) {\n        addClass(el, `${ns.namespace.value}-opacity-transition`)\n        el.style.opacity = '1'\n        done()\n      },\n\n      onAfterEnter(el) {\n        removeClass(el, `${ns.namespace.value}-opacity-transition`)\n        el.style.opacity = ''\n      },\n\n      onBeforeLeave(el) {\n        if (!el.dataset) {\n          ;(el as any).dataset = {}\n        }\n\n        if (hasClass(el, ns.m('collapse'))) {\n          removeClass(el, ns.m('collapse'))\n          el.dataset.oldOverflow = el.style.overflow\n          el.dataset.scrollWidth = el.clientWidth.toString()\n          addClass(el, ns.m('collapse'))\n        } else {\n          addClass(el, ns.m('collapse'))\n          el.dataset.oldOverflow = el.style.overflow\n          el.dataset.scrollWidth = el.clientWidth.toString()\n          removeClass(el, ns.m('collapse'))\n        }\n\n        el.style.width = `${el.scrollWidth}px`\n        el.style.overflow = 'hidden'\n      },\n\n      onLeave(el: HTMLElement) {\n        addClass(el, 'horizontal-collapse-transition')\n        el.style.width = `${el.dataset.scrollWidth}px`\n      },\n    } as BaseTransitionProps<HTMLElement> as TransitionProps\n\n    return {\n      listeners,\n    }\n  },\n})\n</script>\n", "import { computed } from 'vue'\n\nimport type { ComponentInternalInstance, Ref } from 'vue'\n\nexport default function useMenu(\n  instance: ComponentInternalInstance,\n  currentIndex: Ref<string>\n) {\n  const indexPath = computed(() => {\n    let parent = instance.parent!\n    const path = [currentIndex.value]\n    while (parent.type.name !== 'ElMenu') {\n      if (parent.props.index) {\n        path.unshift(parent.props.index as string)\n      }\n      parent = parent.parent!\n    }\n    return path\n  })\n\n  const parentMenu = computed(() => {\n    let parent = instance.parent\n    while (parent && !['ElMenu', 'ElSubMenu'].includes(parent.type.name!)) {\n      parent = parent.parent\n    }\n    return parent!\n  })\n\n  return {\n    parentMenu,\n    indexPath,\n  }\n}\n", "import { computed } from 'vue'\nimport { TinyColor } from '@ctrl/tinycolor'\n\nimport type { MenuProps } from './menu'\n\nexport default function useMenuColor(props: MenuProps) {\n  const menuBarColor = computed(() => {\n    const color = props.backgroundColor\n    if (!color) {\n      return ''\n    } else {\n      return new TinyColor(color).shade(20).toString()\n    }\n  })\n  return menuBarColor\n}\n", "import { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport useMenuColor from './use-menu-color'\n\nimport type { MenuProps } from './menu'\n\nexport const useMenuCssVar = (props: MenuProps, level: number) => {\n  const ns = useNamespace('menu')\n  return computed(() => {\n    return ns.cssVarBlock({\n      'text-color': props.textColor || '',\n      'hover-text-color': props.textColor || '',\n      'bg-color': props.backgroundColor || '',\n      'hover-bg-color': useMenuColor(props).value || '',\n      'active-color': props.activeTextColor || '',\n      level: `${level}`,\n    })\n  })\n}\n", "import {\n  Fragment,\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  h,\n  inject,\n  onBeforeUnmount,\n  onMounted,\n  provide,\n  reactive,\n  ref,\n  vShow,\n  watch,\n  withDirectives,\n} from 'vue'\nimport { useTimeoutFn } from '@vueuse/core'\nimport ElCollapseTransition from '@element-plus/components/collapse-transition'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport {\n  buildProps,\n  iconPropType,\n  isString,\n  throwError,\n} from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { ArrowDown, ArrowRight } from '@element-plus/icons-vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport useMenu from './use-menu'\nimport { useMenuCssVar } from './use-menu-css-var'\n\nimport type { Placement } from '@element-plus/components/popper'\nimport type { ExtractPropTypes, VNodeArrayChildren } from 'vue'\nimport type { MenuProvider, SubMenuProvider } from './types'\n\nexport const subMenuProps = buildProps({\n  /**\n   * @description unique identification\n   */\n  index: {\n    type: String,\n    required: true,\n  },\n  /**\n   * @description timeout before showing a sub-menu(inherit `show-timeout` of the menu by default.)\n   */\n  showTimeout: Number,\n  /**\n   * @description timeout before hiding a sub-menu(inherit `hide-timeout` of the menu by default.)\n   */\n  hideTimeout: Number,\n  /**\n   * @description custom class name for the popup menu\n   */\n  popperClass: String,\n  /**\n   * @description whether the sub-menu is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description whether popup menu is teleported to the body\n   */\n  teleported: {\n    type: Boolean,\n    default: undefined,\n  },\n  /**\n   * @description offset of the popper (overrides the `popper` of menu)\n   */\n  popperOffset: Number,\n  /**\n   * @description Icon when menu are expanded and submenu are closed, `expand-close-icon` and `expand-open-icon` need to be passed together to take effect\n   */\n  expandCloseIcon: {\n    type: iconPropType,\n  },\n  /**\n   * @description Icon when menu are expanded and submenu are opened, `expand-open-icon` and `expand-close-icon` need to be passed together to take effect\n   */\n  expandOpenIcon: {\n    type: iconPropType,\n  },\n  /**\n   * @description Icon when menu are collapsed and submenu are closed, `collapse-close-icon` and `collapse-open-icon` need to be passed together to take effect\n   */\n  collapseCloseIcon: {\n    type: iconPropType,\n  },\n  /**\n   * @description Icon when menu are collapsed and submenu are opened, `collapse-open-icon` and `collapse-close-icon` need to be passed together to take effect\n   */\n  collapseOpenIcon: {\n    type: iconPropType,\n  },\n} as const)\nexport type SubMenuProps = ExtractPropTypes<typeof subMenuProps>\n\nconst COMPONENT_NAME = 'ElSubMenu'\nexport default defineComponent({\n  name: COMPONENT_NAME,\n  props: subMenuProps,\n\n  setup(props, { slots, expose }) {\n    const instance = getCurrentInstance()!\n    const { indexPath, parentMenu } = useMenu(\n      instance,\n      computed(() => props.index)\n    )\n    const nsMenu = useNamespace('menu')\n    const nsSubMenu = useNamespace('sub-menu')\n\n    // inject\n    const rootMenu = inject<MenuProvider>('rootMenu')\n    if (!rootMenu) throwError(COMPONENT_NAME, 'can not inject root menu')\n\n    const subMenu = inject<SubMenuProvider>(`subMenu:${parentMenu.value!.uid}`)\n    if (!subMenu) throwError(COMPONENT_NAME, 'can not inject sub menu')\n\n    const items = ref<MenuProvider['items']>({})\n    const subMenus = ref<MenuProvider['subMenus']>({})\n\n    let timeout: (() => void) | undefined\n    const mouseInChild = ref(false)\n    const verticalTitleRef = ref<HTMLDivElement>()\n    const vPopper = ref<InstanceType<typeof ElTooltip> | null>(null)\n\n    // computed\n    const currentPlacement = computed<Placement>(() =>\n      mode.value === 'horizontal' && isFirstLevel.value\n        ? 'bottom-start'\n        : 'right-start'\n    )\n    const subMenuTitleIcon = computed(() => {\n      return (mode.value === 'horizontal' && isFirstLevel.value) ||\n        (mode.value === 'vertical' && !rootMenu.props.collapse)\n        ? props.expandCloseIcon && props.expandOpenIcon\n          ? opened.value\n            ? props.expandOpenIcon\n            : props.expandCloseIcon\n          : ArrowDown\n        : props.collapseCloseIcon && props.collapseOpenIcon\n        ? opened.value\n          ? props.collapseOpenIcon\n          : props.collapseCloseIcon\n        : ArrowRight\n    })\n    const isFirstLevel = computed(() => {\n      return subMenu.level === 0\n    })\n    const appendToBody = computed(() => {\n      const value = props.teleported\n      return value === undefined ? isFirstLevel.value : value\n    })\n    const menuTransitionName = computed(() =>\n      rootMenu.props.collapse\n        ? `${nsMenu.namespace.value}-zoom-in-left`\n        : `${nsMenu.namespace.value}-zoom-in-top`\n    )\n    const fallbackPlacements = computed<Placement[]>(() =>\n      mode.value === 'horizontal' && isFirstLevel.value\n        ? [\n            'bottom-start',\n            'bottom-end',\n            'top-start',\n            'top-end',\n            'right-start',\n            'left-start',\n          ]\n        : [\n            'right-start',\n            'right',\n            'right-end',\n            'left-start',\n            'bottom-start',\n            'bottom-end',\n            'top-start',\n            'top-end',\n          ]\n    )\n    const opened = computed(() => rootMenu.openedMenus.includes(props.index))\n    const active = computed(() => {\n      let isActive = false\n\n      Object.values(items.value).forEach((item) => {\n        if (item.active) {\n          isActive = true\n        }\n      })\n\n      Object.values(subMenus.value).forEach((subItem) => {\n        if (subItem.active) {\n          isActive = true\n        }\n      })\n\n      return isActive\n    })\n\n    const mode = computed(() => rootMenu.props.mode)\n    const item = reactive({\n      index: props.index,\n      indexPath,\n      active,\n    })\n\n    const ulStyle = useMenuCssVar(rootMenu.props, subMenu.level + 1)\n\n    const subMenuPopperOffset = computed(() => {\n      return props.popperOffset ?? rootMenu.props.popperOffset\n    })\n\n    const subMenuPopperClass = computed(() => {\n      return props.popperClass ?? rootMenu.props.popperClass\n    })\n\n    const subMenuShowTimeout = computed(() => {\n      return props.showTimeout ?? rootMenu.props.showTimeout\n    })\n\n    const subMenuHideTimeout = computed(() => {\n      return props.hideTimeout ?? rootMenu.props.hideTimeout\n    })\n\n    // methods\n    const doDestroy = () =>\n      vPopper.value?.popperRef?.popperInstanceRef?.destroy()\n\n    const handleCollapseToggle = (value: boolean) => {\n      if (!value) {\n        doDestroy()\n      }\n    }\n\n    const handleClick = () => {\n      if (\n        (rootMenu.props.menuTrigger === 'hover' &&\n          rootMenu.props.mode === 'horizontal') ||\n        (rootMenu.props.collapse && rootMenu.props.mode === 'vertical') ||\n        props.disabled\n      )\n        return\n\n      rootMenu.handleSubMenuClick({\n        index: props.index,\n        indexPath: indexPath.value,\n        active: active.value,\n      })\n    }\n\n    const handleMouseenter = (\n      event: MouseEvent | FocusEvent,\n      showTimeout = subMenuShowTimeout.value\n    ) => {\n      if (event.type === 'focus') {\n        return\n      }\n      if (\n        (rootMenu.props.menuTrigger === 'click' &&\n          rootMenu.props.mode === 'horizontal') ||\n        (!rootMenu.props.collapse && rootMenu.props.mode === 'vertical') ||\n        props.disabled\n      ) {\n        subMenu.mouseInChild.value = true\n        return\n      }\n      subMenu.mouseInChild.value = true\n\n      timeout?.()\n      ;({ stop: timeout } = useTimeoutFn(() => {\n        rootMenu.openMenu(props.index, indexPath.value)\n      }, showTimeout))\n\n      if (appendToBody.value) {\n        parentMenu.value.vnode.el?.dispatchEvent(new MouseEvent('mouseenter'))\n      }\n    }\n\n    const handleMouseleave = (deepDispatch = false) => {\n      if (\n        (rootMenu.props.menuTrigger === 'click' &&\n          rootMenu.props.mode === 'horizontal') ||\n        (!rootMenu.props.collapse && rootMenu.props.mode === 'vertical')\n      ) {\n        subMenu.mouseInChild.value = false\n        return\n      }\n      timeout?.()\n      subMenu.mouseInChild.value = false\n      ;({ stop: timeout } = useTimeoutFn(\n        () =>\n          !mouseInChild.value &&\n          rootMenu.closeMenu(props.index, indexPath.value),\n        subMenuHideTimeout.value\n      ))\n\n      if (appendToBody.value && deepDispatch) {\n        subMenu.handleMouseleave?.(true)\n      }\n    }\n\n    watch(\n      () => rootMenu.props.collapse,\n      (value) => handleCollapseToggle(Boolean(value))\n    )\n\n    // provide\n    {\n      const addSubMenu: SubMenuProvider['addSubMenu'] = (item) => {\n        subMenus.value[item.index] = item\n      }\n      const removeSubMenu: SubMenuProvider['removeSubMenu'] = (item) => {\n        delete subMenus.value[item.index]\n      }\n      provide<SubMenuProvider>(`subMenu:${instance.uid}`, {\n        addSubMenu,\n        removeSubMenu,\n        handleMouseleave,\n        mouseInChild,\n        level: subMenu.level + 1,\n      })\n    }\n\n    // expose\n    expose({\n      opened,\n    })\n\n    // lifecycle\n    onMounted(() => {\n      rootMenu.addSubMenu(item)\n      subMenu.addSubMenu(item)\n    })\n\n    onBeforeUnmount(() => {\n      subMenu.removeSubMenu(item)\n      rootMenu.removeSubMenu(item)\n    })\n\n    return () => {\n      const titleTag: VNodeArrayChildren = [\n        slots.title?.(),\n        h(\n          ElIcon,\n          {\n            class: nsSubMenu.e('icon-arrow'),\n            style: {\n              transform: opened.value\n                ? (props.expandCloseIcon && props.expandOpenIcon) ||\n                  (props.collapseCloseIcon &&\n                    props.collapseOpenIcon &&\n                    rootMenu.props.collapse)\n                  ? 'none'\n                  : 'rotateZ(180deg)'\n                : 'none',\n            },\n          },\n          {\n            default: () =>\n              isString(subMenuTitleIcon.value)\n                ? h(instance.appContext.components[subMenuTitleIcon.value])\n                : h(subMenuTitleIcon.value),\n          }\n        ),\n      ]\n\n      // this render function is only used for bypass `Vue`'s compiler caused patching issue.\n      // temporarily mark ElPopper as any due to type inconsistency.\n      const child = rootMenu.isMenuPopup\n        ? h(\n            // TODO: correct popper's type.\n            ElTooltip as any,\n            {\n              ref: vPopper,\n              visible: opened.value,\n              effect: 'light',\n              pure: true,\n              offset: subMenuPopperOffset.value,\n              showArrow: false,\n              persistent: true,\n              popperClass: subMenuPopperClass.value,\n              placement: currentPlacement.value,\n              teleported: appendToBody.value,\n              fallbackPlacements: fallbackPlacements.value,\n              transition: menuTransitionName.value,\n              gpuAcceleration: false,\n            },\n            {\n              content: () =>\n                h(\n                  'div',\n                  {\n                    class: [\n                      nsMenu.m(mode.value),\n                      nsMenu.m('popup-container'),\n                      subMenuPopperClass.value,\n                    ],\n                    onMouseenter: (evt: MouseEvent) =>\n                      handleMouseenter(evt, 100),\n                    onMouseleave: () => handleMouseleave(true),\n                    onFocus: (evt: FocusEvent) => handleMouseenter(evt, 100),\n                  },\n                  [\n                    h(\n                      'ul',\n                      {\n                        class: [\n                          nsMenu.b(),\n                          nsMenu.m('popup'),\n                          nsMenu.m(`popup-${currentPlacement.value}`),\n                        ],\n                        style: ulStyle.value,\n                      },\n                      [slots.default?.()]\n                    ),\n                  ]\n                ),\n              default: () =>\n                h(\n                  'div',\n                  {\n                    class: nsSubMenu.e('title'),\n                    onClick: handleClick,\n                  },\n                  titleTag\n                ),\n            }\n          )\n        : h(Fragment, {}, [\n            h(\n              'div',\n              {\n                class: nsSubMenu.e('title'),\n                ref: verticalTitleRef,\n                onClick: handleClick,\n              },\n              titleTag\n            ),\n            h(\n              ElCollapseTransition,\n              {},\n              {\n                default: () =>\n                  withDirectives(\n                    h(\n                      'ul',\n                      {\n                        role: 'menu',\n                        class: [nsMenu.b(), nsMenu.m('inline')],\n                        style: ulStyle.value,\n                      },\n                      [slots.default?.()]\n                    ),\n                    [[vShow, opened.value]]\n                  ),\n              }\n            ),\n          ])\n\n      return h(\n        'li',\n        {\n          class: [\n            nsSubMenu.b(),\n            nsSubMenu.is('active', active.value),\n            nsSubMenu.is('opened', opened.value),\n            nsSubMenu.is('disabled', props.disabled),\n          ],\n          role: 'menuitem',\n          ariaHaspopup: true,\n          ariaExpanded: opened.value,\n          onMouseenter: handleMouseenter,\n          onMouseleave: () => handleMouseleave(),\n          onFocus: handleMouseenter,\n        },\n        [child]\n      )\n    }\n  },\n})\n", "import {\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  h,\n  nextTick,\n  onMounted,\n  provide,\n  reactive,\n  ref,\n  watch,\n  watchEffect,\n  withDirectives,\n} from 'vue'\n\nimport { useResizeObserver } from '@vueuse/core'\nimport { isNil } from 'lodash-unified'\nimport ElIcon from '@element-plus/components/icon'\nimport { More } from '@element-plus/icons-vue'\nimport {\n  buildProps,\n  definePropType,\n  flattedChildren,\n  iconPropType,\n  isObject,\n  isString,\n  mutable,\n} from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { ClickOutside as vClickoutside } from '@element-plus/directives'\nimport Menubar from './utils/menu-bar'\nimport ElMenuCollapseTransition from './menu-collapse-transition.vue'\nimport ElSubMenu from './sub-menu'\nimport { useMenuCssVar } from './use-menu-css-var'\nimport type { PopperEffect } from '@element-plus/components/popper'\n\nimport type { MenuItemClicked, MenuProvider, SubMenuProvider } from './types'\nimport type { NavigationFailure, Router } from 'vue-router'\nimport type {\n  Component,\n  DirectiveArguments,\n  ExtractPropTypes,\n  VNode,\n  VNodeArrayChildren,\n} from 'vue'\nimport type { UseResizeObserverReturn } from '@vueuse/core'\n\nexport const menuProps = buildProps({\n  /**\n   * @description menu display mode\n   */\n  mode: {\n    type: String,\n    values: ['horizontal', 'vertical'],\n    default: 'vertical',\n  },\n  /**\n   * @description index of active menu on page load\n   */\n  defaultActive: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description array that contains indexes of currently active sub-menus\n   */\n  defaultOpeneds: {\n    type: definePropType<string[]>(Array),\n    default: () => mutable([] as const),\n  },\n  /**\n   * @description whether only one sub-menu can be active\n   */\n  uniqueOpened: Boolean,\n  /**\n   * @description whether `vue-router` mode is activated. If true, index will be used as 'path' to activate the route action. Use with `default-active` to set the active item on load.\n   */\n  router: Boolean,\n  /**\n   * @description how sub-menus are triggered, only works when `mode` is 'horizontal'\n   */\n  menuTrigger: {\n    type: String,\n    values: ['hover', 'click'],\n    default: 'hover',\n  },\n  /**\n   * @description whether the menu is collapsed (available only in vertical mode)\n   */\n  collapse: Boolean,\n  /**\n   * @description background color of Menu (hex format) (deprecated, use `--bg-color` instead)\n   * @deprecated use `--bg-color` instead\n   */\n  backgroundColor: String,\n  /**\n   * @description text color of Menu (hex format) (deprecated, use `--text-color` instead)\n   * @deprecated use `--text-color` instead\n   */\n  textColor: String,\n  /**\n   * @description text color of currently active menu item (hex format) (deprecated, use `--active-color` instead)\n   * @deprecated use `--active-color` instead\n   */\n  activeTextColor: String,\n  /**\n   * @description optional, whether menu is collapsed when clicking outside\n   */\n  closeOnClickOutside: Boolean,\n  /**\n   * @description whether to enable the collapse transition\n   */\n  collapseTransition: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether the menu is ellipsis (available only in horizontal mode)\n   */\n  ellipsis: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description offset of the popper (effective for all submenus)\n   */\n  popperOffset: {\n    type: Number,\n    default: 6,\n  },\n  /**\n   * @description custom ellipsis icon (available only in horizontal mode and ellipsis is true)\n   */\n  ellipsisIcon: {\n    type: iconPropType,\n    default: () => More,\n  },\n  /**\n   * @description Tooltip theme, built-in theme: `dark` / `light` when menu is collapsed\n   */\n  popperEffect: {\n    type: definePropType<PopperEffect | string>(String),\n    default: 'dark',\n  },\n  /**\n   * @description custom class name for all popup menus\n   */\n  popperClass: String,\n  /**\n   * @description control timeout for all menus before showing\n   */\n  showTimeout: {\n    type: Number,\n    default: 300,\n  },\n  /**\n   * @description control timeout for all menus before hiding\n   */\n  hideTimeout: {\n    type: Number,\n    default: 300,\n  },\n} as const)\nexport type MenuProps = ExtractPropTypes<typeof menuProps>\n\nconst checkIndexPath = (indexPath: unknown): indexPath is string[] =>\n  Array.isArray(indexPath) && indexPath.every((path) => isString(path))\n\nexport const menuEmits = {\n  close: (index: string, indexPath: string[]) =>\n    isString(index) && checkIndexPath(indexPath),\n\n  open: (index: string, indexPath: string[]) =>\n    isString(index) && checkIndexPath(indexPath),\n\n  select: (\n    index: string,\n    indexPath: string[],\n    item: MenuItemClicked,\n    routerResult?: Promise<void | NavigationFailure>\n  ) =>\n    isString(index) &&\n    checkIndexPath(indexPath) &&\n    isObject(item) &&\n    (routerResult === undefined || routerResult instanceof Promise),\n}\nexport type MenuEmits = typeof menuEmits\n\nexport default defineComponent({\n  name: 'ElMenu',\n\n  props: menuProps,\n  emits: menuEmits,\n\n  setup(props, { emit, slots, expose }) {\n    const instance = getCurrentInstance()!\n    const router = instance.appContext.config.globalProperties.$router as Router\n    const menu = ref<HTMLUListElement>()\n    const nsMenu = useNamespace('menu')\n    const nsSubMenu = useNamespace('sub-menu')\n\n    // data\n    const sliceIndex = ref(-1)\n\n    const openedMenus = ref<MenuProvider['openedMenus']>(\n      props.defaultOpeneds && !props.collapse\n        ? props.defaultOpeneds.slice(0)\n        : []\n    )\n    const activeIndex = ref<MenuProvider['activeIndex']>(props.defaultActive)\n    const items = ref<MenuProvider['items']>({})\n    const subMenus = ref<MenuProvider['subMenus']>({})\n\n    // computed\n    const isMenuPopup = computed<MenuProvider['isMenuPopup']>(() => {\n      return (\n        props.mode === 'horizontal' ||\n        (props.mode === 'vertical' && props.collapse)\n      )\n    })\n\n    // methods\n    const initMenu = () => {\n      const activeItem = activeIndex.value && items.value[activeIndex.value]\n      if (!activeItem || props.mode === 'horizontal' || props.collapse) return\n\n      const indexPath = activeItem.indexPath\n\n      // 展开该菜单项的路径上所有子菜单\n      // expand all subMenus of the menu item\n      indexPath.forEach((index) => {\n        const subMenu = subMenus.value[index]\n        subMenu && openMenu(index, subMenu.indexPath)\n      })\n    }\n\n    const openMenu: MenuProvider['openMenu'] = (index, indexPath) => {\n      if (openedMenus.value.includes(index)) return\n      // 将不在该菜单路径下的其余菜单收起\n      // collapse all menu that are not under current menu item\n      if (props.uniqueOpened) {\n        openedMenus.value = openedMenus.value.filter((index: string) =>\n          indexPath.includes(index)\n        )\n      }\n      openedMenus.value.push(index)\n      emit('open', index, indexPath)\n    }\n\n    const close = (index: string) => {\n      const i = openedMenus.value.indexOf(index)\n      if (i !== -1) {\n        openedMenus.value.splice(i, 1)\n      }\n    }\n\n    const closeMenu: MenuProvider['closeMenu'] = (index, indexPath) => {\n      close(index)\n      emit('close', index, indexPath)\n    }\n\n    const handleSubMenuClick: MenuProvider['handleSubMenuClick'] = ({\n      index,\n      indexPath,\n    }) => {\n      const isOpened = openedMenus.value.includes(index)\n\n      if (isOpened) {\n        closeMenu(index, indexPath)\n      } else {\n        openMenu(index, indexPath)\n      }\n    }\n\n    const handleMenuItemClick: MenuProvider['handleMenuItemClick'] = (\n      menuItem\n    ) => {\n      if (props.mode === 'horizontal' || props.collapse) {\n        openedMenus.value = []\n      }\n\n      const { index, indexPath } = menuItem\n      if (isNil(index) || isNil(indexPath)) return\n\n      if (props.router && router) {\n        const route = menuItem.route || index\n        const routerResult = router.push(route).then((res) => {\n          if (!res) activeIndex.value = index\n          return res\n        })\n        emit(\n          'select',\n          index,\n          indexPath,\n          { index, indexPath, route },\n          routerResult\n        )\n      } else {\n        activeIndex.value = index\n        emit('select', index, indexPath, { index, indexPath })\n      }\n    }\n\n    const updateActiveIndex = (val: string) => {\n      const itemsInData = items.value\n      const item =\n        itemsInData[val] ||\n        (activeIndex.value && itemsInData[activeIndex.value]) ||\n        itemsInData[props.defaultActive]\n\n      if (item) {\n        activeIndex.value = item.index\n      } else {\n        activeIndex.value = val\n      }\n    }\n\n    const calcMenuItemWidth = (menuItem: HTMLElement) => {\n      const computedStyle = getComputedStyle(menuItem)\n      const marginLeft = Number.parseInt(computedStyle.marginLeft, 10)\n      const marginRight = Number.parseInt(computedStyle.marginRight, 10)\n      return menuItem.offsetWidth + marginLeft + marginRight || 0\n    }\n\n    const calcSliceIndex = () => {\n      if (!menu.value) return -1\n      const items = Array.from(menu.value?.childNodes ?? []).filter(\n        (item) =>\n          // remove comment type node #12634\n          item.nodeName !== '#comment' &&\n          (item.nodeName !== '#text' || item.nodeValue)\n      ) as HTMLElement[]\n      const moreItemWidth = 64\n      const computedMenuStyle = getComputedStyle(menu.value!)\n      const paddingLeft = Number.parseInt(computedMenuStyle.paddingLeft, 10)\n      const paddingRight = Number.parseInt(computedMenuStyle.paddingRight, 10)\n      const menuWidth = menu.value!.clientWidth - paddingLeft - paddingRight\n      let calcWidth = 0\n      let sliceIndex = 0\n      items.forEach((item, index) => {\n        calcWidth += calcMenuItemWidth(item)\n        if (calcWidth <= menuWidth - moreItemWidth) {\n          sliceIndex = index + 1\n        }\n      })\n      return sliceIndex === items.length ? -1 : sliceIndex\n    }\n\n    const getIndexPath = (index: string) => subMenus.value[index].indexPath\n\n    // Common computer monitor FPS is 60Hz, which means 60 redraws per second. Calculation formula: 1000ms/60 ≈ 16.67ms, In order to avoid a certain chance of repeated triggering when `resize`, set wait to 16.67 * 2 = 33.34\n    const debounce = (fn: () => void, wait = 33.34) => {\n      let timmer: ReturnType<typeof setTimeout> | null\n      return () => {\n        timmer && clearTimeout(timmer)\n        timmer = setTimeout(() => {\n          fn()\n        }, wait)\n      }\n    }\n\n    let isFirstTimeRender = true\n    const handleResize = () => {\n      if (sliceIndex.value === calcSliceIndex()) return\n      const callback = () => {\n        sliceIndex.value = -1\n        nextTick(() => {\n          sliceIndex.value = calcSliceIndex()\n        })\n      }\n      // execute callback directly when first time resize to avoid shaking\n      isFirstTimeRender ? callback() : debounce(callback)()\n      isFirstTimeRender = false\n    }\n\n    watch(\n      () => props.defaultActive,\n      (currentActive) => {\n        if (!items.value[currentActive]) {\n          activeIndex.value = ''\n        }\n        updateActiveIndex(currentActive)\n      }\n    )\n\n    watch(\n      () => props.collapse,\n      (value) => {\n        if (value) openedMenus.value = []\n      }\n    )\n\n    watch(items.value, initMenu)\n\n    let resizeStopper: UseResizeObserverReturn['stop']\n    watchEffect(() => {\n      if (props.mode === 'horizontal' && props.ellipsis)\n        resizeStopper = useResizeObserver(menu, handleResize).stop\n      else resizeStopper?.()\n    })\n\n    const mouseInChild = ref(false)\n\n    // provide\n    {\n      const addSubMenu: MenuProvider['addSubMenu'] = (item) => {\n        subMenus.value[item.index] = item\n      }\n\n      const removeSubMenu: MenuProvider['removeSubMenu'] = (item) => {\n        delete subMenus.value[item.index]\n      }\n\n      const addMenuItem: MenuProvider['addMenuItem'] = (item) => {\n        items.value[item.index] = item\n      }\n\n      const removeMenuItem: MenuProvider['removeMenuItem'] = (item) => {\n        delete items.value[item.index]\n      }\n      provide<MenuProvider>(\n        'rootMenu',\n        reactive({\n          props,\n          openedMenus,\n          items,\n          subMenus,\n          activeIndex,\n          isMenuPopup,\n\n          addMenuItem,\n          removeMenuItem,\n          addSubMenu,\n          removeSubMenu,\n          openMenu,\n          closeMenu,\n          handleMenuItemClick,\n          handleSubMenuClick,\n        })\n      )\n      provide<SubMenuProvider>(`subMenu:${instance.uid}`, {\n        addSubMenu,\n        removeSubMenu,\n        mouseInChild,\n        level: 0,\n      })\n    }\n\n    // lifecycle\n    onMounted(() => {\n      if (props.mode === 'horizontal') {\n        new Menubar(instance.vnode.el!, nsMenu.namespace.value)\n      }\n    })\n\n    {\n      const open = (index: string) => {\n        const { indexPath } = subMenus.value[index]\n        indexPath.forEach((i) => openMenu(i, indexPath))\n      }\n\n      expose({\n        open,\n        close,\n        handleResize,\n      })\n    }\n\n    const ulStyle = useMenuCssVar(props, 0)\n\n    return () => {\n      let slot: VNodeArrayChildren = slots.default?.() ?? []\n      const vShowMore: VNode[] = []\n\n      if (props.mode === 'horizontal' && menu.value) {\n        const originalSlot = flattedChildren(slot) as VNodeArrayChildren\n        const slotDefault =\n          sliceIndex.value === -1\n            ? originalSlot\n            : originalSlot.slice(0, sliceIndex.value)\n\n        const slotMore =\n          sliceIndex.value === -1 ? [] : originalSlot.slice(sliceIndex.value)\n\n        if (slotMore?.length && props.ellipsis) {\n          slot = slotDefault\n          vShowMore.push(\n            h(\n              ElSubMenu,\n              {\n                index: 'sub-menu-more',\n                class: nsSubMenu.e('hide-arrow'),\n                popperOffset: props.popperOffset,\n              },\n              {\n                title: () =>\n                  h(\n                    ElIcon,\n                    {\n                      class: nsSubMenu.e('icon-more'),\n                    },\n                    {\n                      default: () => h(props.ellipsisIcon as Component),\n                    }\n                  ),\n                default: () => slotMore,\n              }\n            )\n          )\n        }\n      }\n\n      const directives: DirectiveArguments = props.closeOnClickOutside\n        ? [\n            [\n              vClickoutside,\n              () => {\n                if (!openedMenus.value.length) return\n\n                if (!mouseInChild.value) {\n                  openedMenus.value.forEach((openedMenu) =>\n                    emit('close', openedMenu, getIndexPath(openedMenu))\n                  )\n\n                  openedMenus.value = []\n                }\n              },\n            ],\n          ]\n        : []\n\n      const vMenu = withDirectives(\n        h(\n          'ul',\n          {\n            key: String(props.collapse),\n            role: 'menubar',\n            ref: menu,\n            style: ulStyle.value,\n            class: {\n              [nsMenu.b()]: true,\n              [nsMenu.m(props.mode)]: true,\n              [nsMenu.m('collapse')]: props.collapse,\n            },\n          },\n          [...slot, ...vShowMore]\n        ),\n        directives\n      )\n\n      if (props.collapseTransition && props.mode === 'vertical') {\n        return h(ElMenuCollapseTransition, () => vMenu)\n      }\n\n      return vMenu\n    }\n  },\n})\n", "import { buildProps, definePropType, isString } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { RouteLocationRaw } from 'vue-router'\nimport type { MenuItemRegistered } from './types'\n\nexport const menuItemProps = buildProps({\n  /**\n   * @description unique identification\n   */\n  index: {\n    type: definePropType<string | null>([String, null]),\n    default: null,\n  },\n  /**\n   * @description Vue Router object\n   */\n  route: {\n    type: definePropType<RouteLocationRaw>([String, Object]),\n  },\n  /**\n   * @description whether disabled\n   */\n  disabled: Boolean,\n} as const)\nexport type MenuItemProps = ExtractPropTypes<typeof menuItemProps>\n\nexport const menuItemEmits = {\n  click: (item: MenuItemRegistered) =>\n    isString(item.index) && Array.isArray(item.indexPath),\n}\nexport type MenuItemEmits = typeof menuItemEmits\n", "<template>\n  <li\n    :class=\"[\n      nsMenuItem.b(),\n      nsMenuItem.is('active', active),\n      nsMenuItem.is('disabled', disabled),\n    ]\"\n    role=\"menuitem\"\n    tabindex=\"-1\"\n    @click=\"handleClick\"\n  >\n    <el-tooltip\n      v-if=\"\n        parentMenu.type.name === 'ElMenu' &&\n        rootMenu.props.collapse &&\n        $slots.title\n      \"\n      :effect=\"rootMenu.props.popperEffect\"\n      placement=\"right\"\n      :fallback-placements=\"['left']\"\n      persistent\n    >\n      <template #content>\n        <slot name=\"title\" />\n      </template>\n      <div :class=\"nsMenu.be('tooltip', 'trigger')\">\n        <slot />\n      </div>\n    </el-tooltip>\n    <template v-else>\n      <slot />\n      <slot name=\"title\" />\n    </template>\n  </li>\n</template>\n\n<script lang=\"ts\">\n// @ts-nocheck\nimport {\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  inject,\n  onBeforeUnmount,\n  onMounted,\n  reactive,\n  toRef,\n} from 'vue'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport { throwError } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport useMenu from './use-menu'\nimport { menuItemEmits, menuItemProps } from './menu-item'\n\nimport type { MenuItemRegistered, MenuProvider, SubMenuProvider } from './types'\n\nconst COMPONENT_NAME = 'ElMenuItem'\nexport default defineComponent({\n  name: COMPONENT_NAME,\n  components: {\n    ElTooltip,\n  },\n\n  props: menuItemProps,\n  emits: menuItemEmits,\n\n  setup(props, { emit }) {\n    const instance = getCurrentInstance()!\n    const rootMenu = inject<MenuProvider>('rootMenu')\n    const nsMenu = useNamespace('menu')\n    const nsMenuItem = useNamespace('menu-item')\n    if (!rootMenu) throwError(COMPONENT_NAME, 'can not inject root menu')\n\n    const { parentMenu, indexPath } = useMenu(instance, toRef(props, 'index'))\n\n    const subMenu = inject<SubMenuProvider>(`subMenu:${parentMenu.value.uid}`)\n    if (!subMenu) throwError(COMPONENT_NAME, 'can not inject sub menu')\n\n    const active = computed(() => props.index === rootMenu.activeIndex)\n    const item: MenuItemRegistered = reactive({\n      index: props.index,\n      indexPath,\n      active,\n    })\n\n    const handleClick = () => {\n      if (!props.disabled) {\n        rootMenu.handleMenuItemClick({\n          index: props.index,\n          indexPath: indexPath.value,\n          route: props.route,\n        })\n        emit('click', item)\n      }\n    }\n\n    onMounted(() => {\n      subMenu.addSubMenu(item)\n      rootMenu.addMenuItem(item)\n    })\n\n    onBeforeUnmount(() => {\n      subMenu.removeSubMenu(item)\n      rootMenu.removeMenuItem(item)\n    })\n\n    return {\n      parentMenu,\n      rootMenu,\n      active,\n      nsMenu,\n      nsMenuItem,\n      handleClick,\n    }\n  },\n})\n</script>\n", "import type { ExtractPropTypes } from 'vue'\n\nexport const menuItemGroupProps = {\n  /**\n   * @description group title\n   */\n  title: String,\n} as const\nexport type MenuItemGroupProps = ExtractPropTypes<typeof menuItemGroupProps>\n", "<template>\n  <li :class=\"ns.b()\">\n    <div :class=\"ns.e('title')\">\n      <template v-if=\"!$slots.title\">{{ title }}</template>\n      <slot v-else name=\"title\" />\n    </div>\n    <ul>\n      <slot />\n    </ul>\n  </li>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { menuItemGroupProps } from './menu-item-group'\n\nconst COMPONENT_NAME = 'ElMenuItemGroup'\n\nexport default defineComponent({\n  name: COMPONENT_NAME,\n\n  props: menuItemGroupProps,\n\n  setup() {\n    const ns = useNamespace('menu-item-group')\n\n    return {\n      ns,\n    }\n  },\n})\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\n\nimport Menu from './src/menu'\nimport MenuItem from './src/menu-item.vue'\nimport MenuItemGroup from './src/menu-item-group.vue'\nimport SubMenu from './src/sub-menu'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElMenu: SFCWithInstall<typeof Menu> & {\n  MenuItem: typeof MenuItem\n  MenuItemGroup: typeof MenuItemGroup\n  SubMenu: typeof SubMenu\n} = withInstall(Menu, {\n  MenuItem,\n  MenuItemGroup,\n  SubMenu,\n})\nexport default ElMenu\nexport const ElMenuItem: SFCWithInstall<typeof MenuItem> =\n  withNoopInstall(MenuItem)\nexport const ElMenuItemGroup: SFCWithInstall<typeof MenuItemGroup> =\n  withNoopInstall(MenuItemGroup)\nexport const ElSubMenu: SFCWithInstall<typeof SubMenu> =\n  withNoopInstall(SubMenu)\n\nexport * from './src/menu'\nexport * from './src/menu-item'\nexport * from './src/menu-item-group'\nexport * from './src/sub-menu'\nexport * from './src/types'\nexport * from './src/instance'\n", "import { buildProps, iconPropType } from '@element-plus/utils'\nimport { Back } from '@element-plus/icons-vue'\nimport type { ExtractPropTypes } from 'vue'\nimport type PageHeader from './page-header.vue'\n\nexport const pageHeaderProps = buildProps({\n  /**\n   * @description icon component of page header\n   */\n  icon: {\n    type: iconPropType,\n    default: () => Back,\n  },\n  /**\n   * @description main title of page header\n   */\n  title: String,\n  /**\n   * @description content of page header\n   */\n  content: {\n    type: String,\n    default: '',\n  },\n} as const)\nexport type PageHeaderProps = ExtractPropTypes<typeof pageHeaderProps>\n\nexport const pageHeaderEmits = {\n  back: () => true,\n}\nexport type PageHeaderEmits = typeof pageHeaderEmits\n\nexport type PageHeaderInstance = InstanceType<typeof PageHeader>\n", "<template>\n  <div :class=\"kls\">\n    <div v-if=\"$slots.breadcrumb\" :class=\"ns.e('breadcrumb')\">\n      <slot name=\"breadcrumb\" />\n    </div>\n    <div :class=\"ns.e('header')\">\n      <div :class=\"ns.e('left')\">\n        <div\n          :class=\"ns.e('back')\"\n          role=\"button\"\n          tabindex=\"0\"\n          @click=\"handleClick\"\n        >\n          <div\n            v-if=\"icon || $slots.icon\"\n            :aria-label=\"title || t('el.pageHeader.title')\"\n            :class=\"ns.e('icon')\"\n          >\n            <slot name=\"icon\">\n              <el-icon v-if=\"icon\">\n                <component :is=\"icon\" />\n              </el-icon>\n            </slot>\n          </div>\n          <div :class=\"ns.e('title')\">\n            <slot name=\"title\">{{ title || t('el.pageHeader.title') }}</slot>\n          </div>\n        </div>\n        <el-divider direction=\"vertical\" />\n        <div :class=\"ns.e('content')\">\n          <slot name=\"content\">{{ content }}</slot>\n        </div>\n      </div>\n\n      <div v-if=\"$slots.extra\" :class=\"ns.e('extra')\">\n        <slot name=\"extra\" />\n      </div>\n    </div>\n\n    <div v-if=\"$slots.default\" :class=\"ns.e('main')\">\n      <slot />\n    </div>\n  </div>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, useSlots } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { ElDivider } from '@element-plus/components/divider'\n\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { pageHeaderEmits, pageHeaderProps } from './page-header'\n\ndefineOptions({\n  name: 'ElPageHeader',\n})\n\ndefineProps(pageHeaderProps)\nconst emit = defineEmits(pageHeaderEmits)\nconst slots = useSlots()\n\nconst { t } = useLocale()\nconst ns = useNamespace('page-header')\nconst kls = computed(() => {\n  return [\n    ns.b(),\n    {\n      [ns.m('has-breadcrumb')]: !!slots.breadcrumb,\n      [ns.m('has-extra')]: !!slots.extra,\n      [ns.is('contentful')]: !!slots.default,\n    },\n  ]\n})\n\nfunction handleClick() {\n  emit('back')\n}\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport PageHeader from './src/page-header.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElPageHeader: SFCWithInstall<typeof PageHeader> =\n  withInstall(PageHeader)\nexport default ElPageHeader\n\nexport * from './src/page-header'\n", "import type { ComputedRef, InjectionKey, WritableComputedRef } from 'vue'\n\nexport interface ElPaginationContext {\n  currentPage?: WritableComputedRef<number>\n  pageCount?: ComputedRef<number>\n  disabled?: ComputedRef<boolean>\n  changeEvent?: (val: number) => void\n  handleSizeChange?: (val: number) => void\n}\n\nexport const elPaginationKey: InjectionKey<ElPaginationContext> =\n  Symbol('elPaginationKey')\n", "import { buildProps, iconPropType } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Prev from './prev.vue'\n\nexport const paginationPrevProps = buildProps({\n  disabled: Boolean,\n  currentPage: {\n    type: Number,\n    default: 1,\n  },\n  prevText: {\n    type: String,\n  },\n  prevIcon: {\n    type: iconPropType,\n  },\n} as const)\n\nexport const paginationPrevEmits = {\n  click: (evt: MouseEvent) => evt instanceof MouseEvent,\n}\n\nexport type PaginationPrevProps = ExtractPropTypes<typeof paginationPrevProps>\n\nexport type PrevInstance = InstanceType<typeof Prev>\n", "<template>\n  <button\n    type=\"button\"\n    class=\"btn-prev\"\n    :disabled=\"internalDisabled\"\n    :aria-label=\"prevText || t('el.pagination.prev')\"\n    :aria-disabled=\"internalDisabled\"\n    @click=\"$emit('click', $event)\"\n  >\n    <span v-if=\"prevText\">{{ prevText }}</span>\n    <el-icon v-else>\n      <component :is=\"prevIcon\" />\n    </el-icon>\n  </button>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useLocale } from '@element-plus/hooks'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { paginationPrevEmits, paginationPrevProps } from './prev'\n\ndefineOptions({\n  name: 'ElPaginationPrev',\n})\n\nconst props = defineProps(paginationPrevProps)\ndefineEmits(paginationPrevEmits)\n\nconst { t } = useLocale()\n\nconst internalDisabled = computed(\n  () => props.disabled || props.currentPage <= 1\n)\n</script>\n", "import { buildProps, iconPropType } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Next from './next.vue'\n\nexport const paginationNextProps = buildProps({\n  disabled: Boolean,\n  currentPage: {\n    type: Number,\n    default: 1,\n  },\n  pageCount: {\n    type: Number,\n    default: 50,\n  },\n  nextText: {\n    type: String,\n  },\n  nextIcon: {\n    type: iconPropType,\n  },\n} as const)\n\nexport type PaginationNextProps = ExtractPropTypes<typeof paginationNextProps>\n\nexport type NextInstance = InstanceType<typeof Next>\n", "<template>\n  <button\n    type=\"button\"\n    class=\"btn-next\"\n    :disabled=\"internalDisabled\"\n    :aria-label=\"nextText || t('el.pagination.next')\"\n    :aria-disabled=\"internalDisabled\"\n    @click=\"$emit('click', $event)\"\n  >\n    <span v-if=\"nextText\">{{ nextText }}</span>\n    <el-icon v-else>\n      <component :is=\"nextIcon\" />\n    </el-icon>\n  </button>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useLocale } from '@element-plus/hooks'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { paginationNextProps } from './next'\n\ndefineOptions({\n  name: 'ElPaginationNext',\n})\n\nconst props = defineProps(paginationNextProps)\n\ndefineEmits(['click'])\n\nconst { t } = useLocale()\n\nconst internalDisabled = computed(\n  () =>\n    props.disabled ||\n    props.currentPage === props.pageCount ||\n    props.pageCount === 0\n)\n</script>\n", "import type { ExtractPropTypes, InjectionKey } from 'vue'\nimport type { SelectProps } from './select'\n\ninterface SelectGroupContext {\n  disabled: boolean\n}\n\nexport interface SelectContext {\n  props: ExtractPropTypes<typeof SelectProps>\n  states: any\n  expanded: boolean\n  selectRef: HTMLElement\n  optionsArray: any[]\n  setSelected(): void\n  onOptionCreate(vm: SelectOptionProxy): void\n  onOptionDestroy(\n    key: number | string | Record<string, string>,\n    vm: SelectOptionProxy\n  ): void\n  handleOptionSelect(vm: SelectOptionProxy): void\n}\n\n// For individual build sharing injection key, we had to make `Symbol` to string\nexport const selectGroupKey: InjectionKey<SelectGroupContext> =\n  Symbol('ElSelectGroup')\n\nexport const selectKey: InjectionKey<SelectContext> = Symbol('ElSelect')\n\nexport interface SelectOptionProxy {\n  value: string | number | Record<string, string>\n  label: string | number\n  created: boolean\n  disabled: boolean\n  currentLabel: string\n  itemSelected: boolean\n  isDisabled: boolean\n  select: SelectContext\n  hoverItem: () => void\n  updateOption: (query: string) => void\n  visible: boolean\n  hover: boolean\n  selectOptionClick: () => void\n}\n\nexport type ISelectProps = ExtractPropTypes<typeof SelectProps>\n", "// @ts-nocheck\nimport { computed, getCurrentInstance, inject, toRaw, watch } from 'vue'\nimport { get } from 'lodash-unified'\nimport { ensureArray, escapeStringRegexp, isObject } from '@element-plus/utils'\nimport { selectGroupKey, selectKey } from './token'\n\nexport function useOption(props, states) {\n  // inject\n  const select = inject(selectKey)\n  const selectGroup = inject(selectGroupKey, { disabled: false })\n\n  // computed\n  const itemSelected = computed(() => {\n    return contains(ensureArray(select.props.modelValue), props.value)\n  })\n\n  const limitReached = computed(() => {\n    if (select.props.multiple) {\n      const modelValue = ensureArray(select.props.modelValue ?? [])\n      return (\n        !itemSelected.value &&\n        modelValue.length >= select.props.multipleLimit &&\n        select.props.multipleLimit > 0\n      )\n    } else {\n      return false\n    }\n  })\n\n  const currentLabel = computed(() => {\n    return props.label || (isObject(props.value) ? '' : props.value)\n  })\n\n  const currentValue = computed(() => {\n    return props.value || props.label || ''\n  })\n\n  const isDisabled = computed(() => {\n    return props.disabled || states.groupDisabled || limitReached.value\n  })\n\n  const instance = getCurrentInstance()\n\n  const contains = (arr = [], target) => {\n    if (!isObject(props.value)) {\n      return arr && arr.includes(target)\n    } else {\n      const valueKey = select.props.valueKey\n      return (\n        arr &&\n        arr.some((item) => {\n          return toRaw(get(item, valueKey)) === get(target, valueKey)\n        })\n      )\n    }\n  }\n\n  const hoverItem = () => {\n    if (!props.disabled && !selectGroup.disabled) {\n      select.states.hoveringIndex = select.optionsArray.indexOf(instance.proxy)\n    }\n  }\n\n  const updateOption = (query: string) => {\n    const regexp = new RegExp(escapeStringRegexp(query), 'i')\n    states.visible = regexp.test(currentLabel.value) || props.created\n  }\n\n  watch(\n    () => currentLabel.value,\n    () => {\n      if (!props.created && !select.props.remote) select.setSelected()\n    }\n  )\n\n  watch(\n    () => props.value,\n    (val, oldVal) => {\n      const { remote, valueKey } = select.props\n\n      if (val !== oldVal) {\n        select.onOptionDestroy(oldVal, instance.proxy)\n        select.onOptionCreate(instance.proxy)\n      }\n\n      if (!props.created && !remote) {\n        if (\n          valueKey &&\n          isObject(val) &&\n          isObject(oldVal) &&\n          val[valueKey] === oldVal[valueKey]\n        ) {\n          return\n        }\n        select.setSelected()\n      }\n    }\n  )\n\n  watch(\n    () => selectGroup.disabled,\n    () => {\n      states.groupDisabled = selectGroup.disabled\n    },\n    { immediate: true }\n  )\n\n  return {\n    select,\n    currentLabel,\n    currentValue,\n    itemSelected,\n    isDisabled,\n    hoverItem,\n    updateOption,\n  }\n}\n", "<template>\n  <li\n    v-show=\"visible\"\n    :id=\"id\"\n    :class=\"containerKls\"\n    role=\"option\"\n    :aria-disabled=\"isDisabled || undefined\"\n    :aria-selected=\"itemSelected\"\n    @mouseenter=\"hoverItem\"\n    @click.stop=\"selectOptionClick\"\n  >\n    <slot>\n      <span>{{ currentLabel }}</span>\n    </slot>\n  </li>\n</template>\n\n<script lang=\"ts\">\n// @ts-nocheck\nimport {\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  nextTick,\n  onBeforeUnmount,\n  reactive,\n  toRefs,\n  unref,\n} from 'vue'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport { useOption } from './useOption'\nimport type { SelectOptionProxy } from './token'\n\nexport default defineComponent({\n  name: 'ElOption',\n  componentName: 'ElOption',\n\n  props: {\n    /**\n     * @description value of option\n     */\n    value: {\n      required: true,\n      type: [String, Number, Boolean, Object],\n    },\n    /**\n     * @description label of option, same as `value` if omitted\n     */\n    label: [String, Number],\n    created: Boolean,\n    /**\n     * @description whether option is disabled\n     */\n    disabled: Boolean,\n  },\n\n  setup(props) {\n    const ns = useNamespace('select')\n    const id = useId()\n\n    const containerKls = computed(() => [\n      ns.be('dropdown', 'item'),\n      ns.is('disabled', unref(isDisabled)),\n      ns.is('selected', unref(itemSelected)),\n      ns.is('hovering', unref(hover)),\n    ])\n\n    const states = reactive({\n      index: -1,\n      groupDisabled: false,\n      visible: true,\n      hover: false,\n    })\n\n    const {\n      currentLabel,\n      itemSelected,\n      isDisabled,\n      select,\n      hoverItem,\n      updateOption,\n    } = useOption(props, states)\n\n    const { visible, hover } = toRefs(states)\n\n    const vm = getCurrentInstance().proxy as unknown as SelectOptionProxy\n\n    select.onOptionCreate(vm)\n\n    onBeforeUnmount(() => {\n      const key = vm.value\n      const { selected } = select.states\n      const selectedOptions = select.props.multiple ? selected : [selected]\n      const doesSelected = selectedOptions.some((item) => {\n        return item.value === vm.value\n      })\n      // if option is not selected, remove it from cache\n      nextTick(() => {\n        if (select.states.cachedOptions.get(key) === vm && !doesSelected) {\n          select.states.cachedOptions.delete(key)\n        }\n      })\n      select.onOptionDestroy(key, vm)\n    })\n\n    function selectOptionClick() {\n      if (!isDisabled.value) {\n        select.handleOptionSelect(vm)\n      }\n    }\n\n    return {\n      ns,\n      id,\n      containerKls,\n      currentLabel,\n      itemSelected,\n      isDisabled,\n      select,\n      hoverItem,\n      updateOption,\n      visible,\n      hover,\n      selectOptionClick,\n      states,\n    }\n  },\n})\n</script>\n", "<template>\n  <div\n    :class=\"[ns.b('dropdown'), ns.is('multiple', isMultiple), popperClass]\"\n    :style=\"{ [isFitInputWidth ? 'width' : 'minWidth']: minWidth }\"\n  >\n    <div v-if=\"$slots.header\" :class=\"ns.be('dropdown', 'header')\">\n      <slot name=\"header\" />\n    </div>\n    <slot />\n    <div v-if=\"$slots.footer\" :class=\"ns.be('dropdown', 'footer')\">\n      <slot name=\"footer\" />\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, onMounted, ref } from 'vue'\nimport { useResizeObserver } from '@vueuse/core'\nimport { useNamespace } from '@element-plus/hooks'\nimport { selectKey } from './token'\n\nexport default defineComponent({\n  name: 'ElSelectDropdown',\n\n  componentName: 'ElSelectDropdown',\n\n  setup() {\n    const select = inject(selectKey)!\n    const ns = useNamespace('select')\n\n    // computed\n    const popperClass = computed(() => select.props.popperClass)\n    const isMultiple = computed(() => select.props.multiple)\n    const isFitInputWidth = computed(() => select.props.fitInputWidth)\n    const minWidth = ref('')\n\n    function updateMinWidth() {\n      minWidth.value = `${select.selectRef?.offsetWidth}px`\n    }\n\n    onMounted(() => {\n      // TODO: updatePopper\n      // popper.value.update()\n      updateMinWidth()\n      useResizeObserver(select.selectRef, updateMinWidth)\n    })\n\n    return {\n      ns,\n      minWidth,\n      popperClass,\n      isMultiple,\n      isFitInputWidth,\n    }\n  },\n})\n</script>\n", "// @ts-nocheck\nimport {\n  computed,\n  nextTick,\n  onMounted,\n  reactive,\n  ref,\n  toRaw,\n  watch,\n  watchEffect,\n} from 'vue'\nimport {\n  findLastIndex,\n  get,\n  isEqual,\n  debounce as lodashDebounce,\n} from 'lodash-unified'\nimport { useResizeObserver } from '@vueuse/core'\nimport {\n  ValidateComponentsMap,\n  debugWarn,\n  ensureArray,\n  isArray,\n  isClient,\n  isFunction,\n  isIOS,\n  isNumber,\n  isObject,\n  isUndefined,\n  scrollIntoView,\n  toRawType,\n} from '@element-plus/utils'\nimport {\n  CHANGE_EVENT,\n  EVENT_CODE,\n  UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport {\n  useComposition,\n  useEmptyValues,\n  useFocusController,\n  useId,\n  useLocale,\n  useNamespace,\n} from '@element-plus/hooks'\nimport {\n  useFormItem,\n  useFormItemInputId,\n  useFormSize,\n} from '@element-plus/components/form'\n\nimport type ElTooltip from '@element-plus/components/tooltip'\nimport type { ISelectProps, SelectOptionProxy } from './token'\n\nconst MINIMUM_INPUT_WIDTH = 11\n\nexport const useSelect = (props: ISelectProps, emit) => {\n  const { t } = useLocale()\n  const contentId = useId()\n  const nsSelect = useNamespace('select')\n  const nsInput = useNamespace('input')\n\n  const states = reactive({\n    inputValue: '',\n    options: new Map(),\n    cachedOptions: new Map(),\n    disabledOptions: new Map(),\n    optionValues: [] as any[], // sorted value of options\n    selected: [] as any[],\n    selectionWidth: 0,\n    calculatorWidth: 0,\n    collapseItemWidth: 0,\n    selectedLabel: '',\n    hoveringIndex: -1,\n    previousQuery: null,\n    inputHovering: false,\n    menuVisibleOnFocus: false,\n    isBeforeHide: false,\n  })\n\n  // template refs\n  const selectRef = ref<HTMLElement>(null)\n  const selectionRef = ref<HTMLElement>(null)\n  const tooltipRef = ref<InstanceType<typeof ElTooltip> | null>(null)\n  const tagTooltipRef = ref<InstanceType<typeof ElTooltip> | null>(null)\n  const inputRef = ref<HTMLInputElement | null>(null)\n  const calculatorRef = ref<HTMLElement>(null)\n  const prefixRef = ref<HTMLElement>(null)\n  const suffixRef = ref<HTMLElement>(null)\n  const menuRef = ref<HTMLElement>(null)\n  const tagMenuRef = ref<HTMLElement>(null)\n  const collapseItemRef = ref<HTMLElement>(null)\n  const scrollbarRef = ref<{\n    handleScroll: () => void\n  } | null>(null)\n\n  const {\n    isComposing,\n    handleCompositionStart,\n    handleCompositionUpdate,\n    handleCompositionEnd,\n  } = useComposition({\n    afterComposition: (e) => onInput(e),\n  })\n\n  const { wrapperRef, isFocused } = useFocusController(inputRef, {\n    beforeFocus() {\n      return selectDisabled.value\n    },\n    afterFocus() {\n      if (props.automaticDropdown && !expanded.value) {\n        expanded.value = true\n        states.menuVisibleOnFocus = true\n      }\n    },\n    beforeBlur(event) {\n      return (\n        tooltipRef.value?.isFocusInsideContent(event) ||\n        tagTooltipRef.value?.isFocusInsideContent(event)\n      )\n    },\n    afterBlur() {\n      expanded.value = false\n      states.menuVisibleOnFocus = false\n    },\n  })\n\n  // the controller of the expanded popup\n  const expanded = ref(false)\n  const hoverOption = ref()\n\n  const { form, formItem } = useFormItem()\n  const { inputId } = useFormItemInputId(props, {\n    formItemContext: formItem,\n  })\n  const { valueOnClear, isEmptyValue } = useEmptyValues(props)\n\n  const selectDisabled = computed(() => props.disabled || form?.disabled)\n\n  const hasModelValue = computed(() => {\n    return isArray(props.modelValue)\n      ? props.modelValue.length > 0\n      : !isEmptyValue(props.modelValue)\n  })\n\n  const showClose = computed(() => {\n    return (\n      props.clearable &&\n      !selectDisabled.value &&\n      states.inputHovering &&\n      hasModelValue.value\n    )\n  })\n  const iconComponent = computed(() =>\n    props.remote && props.filterable && !props.remoteShowSuffix\n      ? ''\n      : props.suffixIcon\n  )\n  const iconReverse = computed(() =>\n    nsSelect.is('reverse', iconComponent.value && expanded.value)\n  )\n\n  const validateState = computed(() => formItem?.validateState || '')\n  const validateIcon = computed(\n    () => ValidateComponentsMap[validateState.value]\n  )\n\n  const debounce = computed(() => (props.remote ? 300 : 0))\n\n  const emptyText = computed(() => {\n    if (props.loading) {\n      return props.loadingText || t('el.select.loading')\n    } else {\n      if (props.remote && !states.inputValue && states.options.size === 0)\n        return false\n      if (\n        props.filterable &&\n        states.inputValue &&\n        states.options.size > 0 &&\n        filteredOptionsCount.value === 0\n      ) {\n        return props.noMatchText || t('el.select.noMatch')\n      }\n      if (states.options.size === 0) {\n        return props.noDataText || t('el.select.noData')\n      }\n    }\n    return null\n  })\n\n  const filteredOptionsCount = computed(\n    () => optionsArray.value.filter((option) => option.visible).length\n  )\n\n  const optionsArray = computed(() => {\n    const list = Array.from(states.options.values())\n    const newList = []\n    states.optionValues.forEach((item) => {\n      const index = list.findIndex((i) => i.value === item)\n      if (index > -1) {\n        newList.push(list[index])\n      }\n    })\n    return newList.length >= list.length ? newList : list\n  })\n\n  const cachedOptionsArray = computed(() =>\n    Array.from(states.cachedOptions.values())\n  )\n\n  const showNewOption = computed(() => {\n    const hasExistingOption = optionsArray.value\n      .filter((option) => {\n        return !option.created\n      })\n      .some((option) => {\n        return option.currentLabel === states.inputValue\n      })\n    return (\n      props.filterable &&\n      props.allowCreate &&\n      states.inputValue !== '' &&\n      !hasExistingOption\n    )\n  })\n\n  const updateOptions = () => {\n    if (props.filterable && isFunction(props.filterMethod)) return\n    if (props.filterable && props.remote && isFunction(props.remoteMethod))\n      return\n    optionsArray.value.forEach((option) => {\n      option.updateOption?.(states.inputValue)\n    })\n  }\n\n  const selectSize = useFormSize()\n\n  const collapseTagSize = computed(() =>\n    ['small'].includes(selectSize.value) ? 'small' : 'default'\n  )\n\n  const dropdownMenuVisible = computed({\n    get() {\n      return expanded.value && emptyText.value !== false\n    },\n    set(val: boolean) {\n      expanded.value = val\n    },\n  })\n\n  const shouldShowPlaceholder = computed(() => {\n    if (props.multiple && !isUndefined(props.modelValue)) {\n      return ensureArray(props.modelValue).length === 0 && !states.inputValue\n    }\n    const value = isArray(props.modelValue)\n      ? props.modelValue[0]\n      : props.modelValue\n    return props.filterable || isUndefined(value) ? !states.inputValue : true\n  })\n\n  const currentPlaceholder = computed(() => {\n    const _placeholder = props.placeholder ?? t('el.select.placeholder')\n    return props.multiple || !hasModelValue.value\n      ? _placeholder\n      : states.selectedLabel\n  })\n\n  // iOS Safari does not handle click events when a mouseenter event is registered and a DOM-change happens in a child\n  // We use a Vue custom event binding to only register the event on non-iOS devices\n  // ref.: https://developer.apple.com/library/archive/documentation/AppleApplications/Reference/SafariWebContent/HandlingEvents/HandlingEvents.html\n  // Github Issue: https://github.com/vuejs/vue/issues/9859\n  const mouseEnterEventName = computed(() => (isIOS ? null : 'mouseenter'))\n\n  watch(\n    () => props.modelValue,\n    (val, oldVal) => {\n      if (props.multiple) {\n        if (props.filterable && !props.reserveKeyword) {\n          states.inputValue = ''\n          handleQueryChange('')\n        }\n      }\n      setSelected()\n      if (!isEqual(val, oldVal) && props.validateEvent) {\n        formItem?.validate('change').catch((err) => debugWarn(err))\n      }\n    },\n    {\n      flush: 'post',\n      deep: true,\n    }\n  )\n\n  watch(\n    () => expanded.value,\n    (val) => {\n      if (val) {\n        handleQueryChange(states.inputValue)\n      } else {\n        states.inputValue = ''\n        states.previousQuery = null\n        states.isBeforeHide = true\n      }\n      emit('visible-change', val)\n    }\n  )\n\n  watch(\n    // fix `Array.prototype.push/splice/..` cannot trigger non-deep watcher\n    // https://github.com/vuejs/vue-next/issues/2116\n    () => states.options.entries(),\n    () => {\n      if (!isClient) return\n      // tooltipRef.value?.updatePopper?.()\n      const inputs = selectRef.value?.querySelectorAll('input') || []\n      if (\n        (!props.filterable &&\n          !props.defaultFirstOption &&\n          !isUndefined(props.modelValue)) ||\n        !Array.from(inputs).includes(document.activeElement as HTMLInputElement)\n      ) {\n        setSelected()\n      }\n      if (\n        props.defaultFirstOption &&\n        (props.filterable || props.remote) &&\n        filteredOptionsCount.value\n      ) {\n        checkDefaultFirstOption()\n      }\n    },\n    {\n      flush: 'post',\n    }\n  )\n\n  watch(\n    () => states.hoveringIndex,\n    (val) => {\n      if (isNumber(val) && val > -1) {\n        hoverOption.value = optionsArray.value[val] || {}\n      } else {\n        hoverOption.value = {}\n      }\n      optionsArray.value.forEach((option) => {\n        option.hover = hoverOption.value === option\n      })\n    }\n  )\n\n  watchEffect(() => {\n    // Anything could cause options changed, then update options\n    // If you want to control it by condition, write here\n    if (states.isBeforeHide) return\n    updateOptions()\n  })\n\n  const handleQueryChange = (val: string) => {\n    if (states.previousQuery === val || isComposing.value) {\n      return\n    }\n    states.previousQuery = val\n    if (props.filterable && isFunction(props.filterMethod)) {\n      props.filterMethod(val)\n    } else if (\n      props.filterable &&\n      props.remote &&\n      isFunction(props.remoteMethod)\n    ) {\n      props.remoteMethod(val)\n    }\n    if (\n      props.defaultFirstOption &&\n      (props.filterable || props.remote) &&\n      filteredOptionsCount.value\n    ) {\n      nextTick(checkDefaultFirstOption)\n    } else {\n      nextTick(updateHoveringIndex)\n    }\n  }\n\n  /**\n   * find and highlight first option as default selected\n   * @remark\n   * - if the first option in dropdown list is user-created,\n   *   it would be at the end of the optionsArray\n   *   so find it and set hover.\n   *   (NOTE: there must be only one user-created option in dropdown list with query)\n   * - if there's no user-created option in list, just find the first one as usual\n   *   (NOTE: exclude options that are disabled or in disabled-group)\n   */\n  const checkDefaultFirstOption = () => {\n    const optionsInDropdown = optionsArray.value.filter(\n      (n) => n.visible && !n.disabled && !n.states.groupDisabled\n    )\n    const userCreatedOption = optionsInDropdown.find((n) => n.created)\n    const firstOriginOption = optionsInDropdown[0]\n    states.hoveringIndex = getValueIndex(\n      optionsArray.value,\n      userCreatedOption || firstOriginOption\n    )\n  }\n\n  const setSelected = () => {\n    if (!props.multiple) {\n      const value = isArray(props.modelValue)\n        ? props.modelValue[0]\n        : props.modelValue\n      const option = getOption(value)\n      states.selectedLabel = option.currentLabel\n      states.selected = [option]\n      return\n    } else {\n      states.selectedLabel = ''\n    }\n    const result: any[] = []\n    if (!isUndefined(props.modelValue)) {\n      ensureArray(props.modelValue).forEach((value) => {\n        result.push(getOption(value))\n      })\n    }\n    states.selected = result\n  }\n\n  const getOption = (value) => {\n    let option\n    const isObjectValue = toRawType(value).toLowerCase() === 'object'\n    const isNull = toRawType(value).toLowerCase() === 'null'\n    const isUndefined = toRawType(value).toLowerCase() === 'undefined'\n\n    for (let i = states.cachedOptions.size - 1; i >= 0; i--) {\n      const cachedOption = cachedOptionsArray.value[i]\n      const isEqualValue = isObjectValue\n        ? get(cachedOption.value, props.valueKey) === get(value, props.valueKey)\n        : cachedOption.value === value\n      if (isEqualValue) {\n        option = {\n          value,\n          currentLabel: cachedOption.currentLabel,\n          get isDisabled() {\n            return cachedOption.isDisabled\n          },\n        }\n        break\n      }\n    }\n    if (option) return option\n    const label = isObjectValue\n      ? value.label\n      : !isNull && !isUndefined\n      ? value\n      : ''\n    const newOption = {\n      value,\n      currentLabel: label,\n    }\n    return newOption\n  }\n\n  const updateHoveringIndex = () => {\n    states.hoveringIndex = optionsArray.value.findIndex((item) =>\n      states.selected.some(\n        (selected) => getValueKey(selected) === getValueKey(item)\n      )\n    )\n  }\n\n  const resetSelectionWidth = () => {\n    states.selectionWidth = selectionRef.value.getBoundingClientRect().width\n  }\n\n  const resetCalculatorWidth = () => {\n    states.calculatorWidth = calculatorRef.value.getBoundingClientRect().width\n  }\n\n  const resetCollapseItemWidth = () => {\n    states.collapseItemWidth =\n      collapseItemRef.value.getBoundingClientRect().width\n  }\n\n  const updateTooltip = () => {\n    tooltipRef.value?.updatePopper?.()\n  }\n\n  const updateTagTooltip = () => {\n    tagTooltipRef.value?.updatePopper?.()\n  }\n\n  const onInputChange = () => {\n    if (states.inputValue.length > 0 && !expanded.value) {\n      expanded.value = true\n    }\n    handleQueryChange(states.inputValue)\n  }\n\n  const onInput = (event) => {\n    states.inputValue = event.target.value\n    if (props.remote) {\n      debouncedOnInputChange()\n    } else {\n      return onInputChange()\n    }\n  }\n\n  const debouncedOnInputChange = lodashDebounce(() => {\n    onInputChange()\n  }, debounce.value)\n\n  const emitChange = (val) => {\n    if (!isEqual(props.modelValue, val)) {\n      emit(CHANGE_EVENT, val)\n    }\n  }\n\n  const getLastNotDisabledIndex = (value) =>\n    findLastIndex(value, (it) => !states.disabledOptions.has(it))\n\n  const deletePrevTag = (e) => {\n    if (!props.multiple) return\n    if (e.code === EVENT_CODE.delete) return\n    if (e.target.value.length <= 0) {\n      const value = ensureArray(props.modelValue).slice()\n      const lastNotDisabledIndex = getLastNotDisabledIndex(value)\n      if (lastNotDisabledIndex < 0) return\n      const removeTagValue = value[lastNotDisabledIndex]\n      value.splice(lastNotDisabledIndex, 1)\n      emit(UPDATE_MODEL_EVENT, value)\n      emitChange(value)\n      emit('remove-tag', removeTagValue)\n    }\n  }\n\n  const deleteTag = (event, tag) => {\n    const index = states.selected.indexOf(tag)\n    if (index > -1 && !selectDisabled.value) {\n      const value = ensureArray(props.modelValue).slice()\n      value.splice(index, 1)\n      emit(UPDATE_MODEL_EVENT, value)\n      emitChange(value)\n      emit('remove-tag', tag.value)\n    }\n    event.stopPropagation()\n    focus()\n  }\n\n  const deleteSelected = (event) => {\n    event.stopPropagation()\n    const value: string | any[] = props.multiple ? [] : valueOnClear.value\n    if (props.multiple) {\n      for (const item of states.selected) {\n        if (item.isDisabled) value.push(item.value)\n      }\n    }\n    emit(UPDATE_MODEL_EVENT, value)\n    emitChange(value)\n    states.hoveringIndex = -1\n    expanded.value = false\n    emit('clear')\n    focus()\n  }\n\n  const handleOptionSelect = (option) => {\n    if (props.multiple) {\n      const value = ensureArray(props.modelValue ?? []).slice()\n      const optionIndex = getValueIndex(value, option.value)\n      if (optionIndex > -1) {\n        value.splice(optionIndex, 1)\n      } else if (\n        props.multipleLimit <= 0 ||\n        value.length < props.multipleLimit\n      ) {\n        value.push(option.value)\n      }\n      emit(UPDATE_MODEL_EVENT, value)\n      emitChange(value)\n      if (option.created) {\n        handleQueryChange('')\n      }\n      if (props.filterable && !props.reserveKeyword) {\n        states.inputValue = ''\n      }\n    } else {\n      emit(UPDATE_MODEL_EVENT, option.value)\n      emitChange(option.value)\n      expanded.value = false\n    }\n    focus()\n    if (expanded.value) return\n    nextTick(() => {\n      scrollToOption(option)\n    })\n  }\n\n  const getValueIndex = (arr: any[] = [], value) => {\n    if (!isObject(value)) return arr.indexOf(value)\n\n    const valueKey = props.valueKey\n    let index = -1\n    arr.some((item, i) => {\n      if (toRaw(get(item, valueKey)) === get(value, valueKey)) {\n        index = i\n        return true\n      }\n      return false\n    })\n    return index\n  }\n\n  const scrollToOption = (option) => {\n    const targetOption = isArray(option) ? option[0] : option\n    let target = null\n\n    if (targetOption?.value) {\n      const options = optionsArray.value.filter(\n        (item) => item.value === targetOption.value\n      )\n      if (options.length > 0) {\n        target = options[0].$el\n      }\n    }\n\n    if (tooltipRef.value && target) {\n      const menu = tooltipRef.value?.popperRef?.contentRef?.querySelector?.(\n        `.${nsSelect.be('dropdown', 'wrap')}`\n      )\n      if (menu) {\n        scrollIntoView(menu as HTMLElement, target)\n      }\n    }\n    scrollbarRef.value?.handleScroll()\n  }\n\n  const onOptionCreate = (vm: SelectOptionProxy) => {\n    states.options.set(vm.value, vm)\n    states.cachedOptions.set(vm.value, vm)\n    vm.disabled && states.disabledOptions.set(vm.value, vm)\n  }\n\n  const onOptionDestroy = (key, vm: SelectOptionProxy) => {\n    if (states.options.get(key) === vm) {\n      states.options.delete(key)\n    }\n  }\n\n  const popperRef = computed(() => {\n    return tooltipRef.value?.popperRef?.contentRef\n  })\n\n  const handleMenuEnter = () => {\n    states.isBeforeHide = false\n    nextTick(() => scrollToOption(states.selected))\n  }\n\n  const focus = () => {\n    inputRef.value?.focus()\n  }\n\n  const blur = () => {\n    inputRef.value?.blur()\n  }\n\n  const handleClearClick = (event: Event) => {\n    deleteSelected(event)\n  }\n\n  const handleClickOutside = () => {\n    expanded.value = false\n    isFocused.value && blur()\n  }\n\n  const handleEsc = () => {\n    if (states.inputValue.length > 0) {\n      states.inputValue = ''\n    } else {\n      expanded.value = false\n    }\n  }\n\n  const toggleMenu = () => {\n    if (selectDisabled.value) return\n\n    // We only set the inputHovering state to true on mouseenter event on iOS devices\n    // To keep the state updated we set it here to true\n    if (isIOS) states.inputHovering = true\n\n    if (states.menuVisibleOnFocus) {\n      // controlled by automaticDropdown\n      states.menuVisibleOnFocus = false\n    } else {\n      expanded.value = !expanded.value\n    }\n  }\n\n  const selectOption = () => {\n    if (!expanded.value) {\n      toggleMenu()\n    } else {\n      if (optionsArray.value[states.hoveringIndex]) {\n        handleOptionSelect(optionsArray.value[states.hoveringIndex])\n      }\n    }\n  }\n\n  const getValueKey = (item) => {\n    return isObject(item.value) ? get(item.value, props.valueKey) : item.value\n  }\n\n  const optionsAllDisabled = computed(() =>\n    optionsArray.value\n      .filter((option) => option.visible)\n      .every((option) => option.disabled)\n  )\n\n  const showTagList = computed(() => {\n    if (!props.multiple) {\n      return []\n    }\n    return props.collapseTags\n      ? states.selected.slice(0, props.maxCollapseTags)\n      : states.selected\n  })\n\n  const collapseTagList = computed(() => {\n    if (!props.multiple) {\n      return []\n    }\n    return props.collapseTags\n      ? states.selected.slice(props.maxCollapseTags)\n      : []\n  })\n\n  const navigateOptions = (direction) => {\n    if (!expanded.value) {\n      expanded.value = true\n      return\n    }\n    if (\n      states.options.size === 0 ||\n      states.filteredOptionsCount === 0 ||\n      isComposing.value\n    )\n      return\n\n    if (!optionsAllDisabled.value) {\n      if (direction === 'next') {\n        states.hoveringIndex++\n        if (states.hoveringIndex === states.options.size) {\n          states.hoveringIndex = 0\n        }\n      } else if (direction === 'prev') {\n        states.hoveringIndex--\n        if (states.hoveringIndex < 0) {\n          states.hoveringIndex = states.options.size - 1\n        }\n      }\n      const option = optionsArray.value[states.hoveringIndex]\n      if (\n        option.disabled === true ||\n        option.states.groupDisabled === true ||\n        !option.visible\n      ) {\n        navigateOptions(direction)\n      }\n      nextTick(() => scrollToOption(hoverOption.value))\n    }\n  }\n\n  const getGapWidth = () => {\n    if (!selectionRef.value) return 0\n    const style = window.getComputedStyle(selectionRef.value)\n    return Number.parseFloat(style.gap || '6px')\n  }\n\n  // computed style\n  const tagStyle = computed(() => {\n    const gapWidth = getGapWidth()\n    const maxWidth =\n      collapseItemRef.value && props.maxCollapseTags === 1\n        ? states.selectionWidth - states.collapseItemWidth - gapWidth\n        : states.selectionWidth\n    return { maxWidth: `${maxWidth}px` }\n  })\n\n  const collapseTagStyle = computed(() => {\n    return { maxWidth: `${states.selectionWidth}px` }\n  })\n\n  const inputStyle = computed(() => ({\n    width: `${Math.max(states.calculatorWidth, MINIMUM_INPUT_WIDTH)}px`,\n  }))\n\n  useResizeObserver(selectionRef, resetSelectionWidth)\n  useResizeObserver(calculatorRef, resetCalculatorWidth)\n  useResizeObserver(menuRef, updateTooltip)\n  useResizeObserver(wrapperRef, updateTooltip)\n  useResizeObserver(tagMenuRef, updateTagTooltip)\n  useResizeObserver(collapseItemRef, resetCollapseItemWidth)\n\n  onMounted(() => {\n    setSelected()\n  })\n\n  return {\n    inputId,\n    contentId,\n    nsSelect,\n    nsInput,\n    states,\n    isFocused,\n    expanded,\n    optionsArray,\n    hoverOption,\n    selectSize,\n    filteredOptionsCount,\n    resetCalculatorWidth,\n    updateTooltip,\n    updateTagTooltip,\n    debouncedOnInputChange,\n    onInput,\n    deletePrevTag,\n    deleteTag,\n    deleteSelected,\n    handleOptionSelect,\n    scrollToOption,\n    hasModelValue,\n    shouldShowPlaceholder,\n    currentPlaceholder,\n    mouseEnterEventName,\n    showClose,\n    iconComponent,\n    iconReverse,\n    validateState,\n    validateIcon,\n    showNewOption,\n    updateOptions,\n    collapseTagSize,\n    setSelected,\n    selectDisabled,\n    emptyText,\n    handleCompositionStart,\n    handleCompositionUpdate,\n    handleCompositionEnd,\n    onOptionCreate,\n    onOptionDestroy,\n    handleMenuEnter,\n    focus,\n    blur,\n    handleClearClick,\n    handleClickOutside,\n    handleEsc,\n    toggleMenu,\n    selectOption,\n    getValueKey,\n    navigateOptions,\n    dropdownMenuVisible,\n    showTagList,\n    collapseTagList,\n\n    // computed style\n    tagStyle,\n    collapseTagStyle,\n    inputStyle,\n\n    // DOM ref\n    popperRef,\n    inputRef,\n    tooltipRef,\n    tagTooltipRef,\n    calculatorRef,\n    prefixRef,\n    suffixRef,\n    selectRef,\n    wrapperRef,\n    selectionRef,\n    scrollbarRef,\n    menuRef,\n    tagMenuRef,\n    collapseItemRef,\n  }\n}\n", "import { defineComponent, inject } from 'vue'\nimport { isEqual } from 'lodash-unified'\nimport { isArray, isFunction, isString } from '@element-plus/utils'\nimport { selectKey } from './token'\nimport type { Component, VNode, VNodeNormalizedChildren } from 'vue'\n\nexport default defineComponent({\n  name: 'ElOptions',\n  setup(_, { slots }) {\n    const select = inject(selectKey)\n    let cachedValueList: any[] = []\n\n    return () => {\n      const children = slots.default?.()!\n      const valueList: any[] = []\n\n      function filterOptions(children?: VNodeNormalizedChildren) {\n        if (!isArray(children)) return\n        ;(children as VNode[]).forEach((item) => {\n          const name = ((item?.type || {}) as Component)?.name\n\n          if (name === 'ElOptionGroup') {\n            filterOptions(\n              !isString(item.children) &&\n                !isArray(item.children) &&\n                isFunction(item.children?.default)\n                ? item.children?.default()\n                : item.children\n            )\n          } else if (name === 'ElOption') {\n            valueList.push(item.props?.value)\n          } else if (isArray(item.children)) {\n            filterOptions(item.children)\n          }\n        })\n      }\n\n      if (children.length) {\n        filterOptions(children[0]?.children)\n      }\n\n      if (!isEqual(valueList, cachedValueList)) {\n        cachedValueList = valueList\n        if (select) {\n          select.states.optionValues = valueList\n        }\n      }\n\n      return children\n    }\n  },\n})\n", "import { placements } from '@popperjs/core'\nimport {\n  useAriaProps,\n  useEmptyValuesProps,\n  useSizeProp,\n} from '@element-plus/hooks'\nimport { buildProps, definePropType, iconPropType } from '@element-plus/utils'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport { ArrowDown, CircleClose } from '@element-plus/icons-vue'\nimport { tagProps } from '@element-plus/components/tag'\nimport type {\n  Options,\n  Placement,\n  PopperEffect,\n} from '@element-plus/components/popper'\n\nexport const SelectProps = buildProps({\n  /**\n   * @description the name attribute of select input\n   */\n  name: String,\n  /**\n   * @description native input id\n   */\n  id: String,\n  /**\n   * @description binding value\n   */\n  modelValue: {\n    type: [Array, String, Number, Boolean, Object],\n    default: undefined,\n  },\n  /**\n   * @description the autocomplete attribute of select input\n   */\n  autocomplete: {\n    type: String,\n    default: 'off',\n  },\n  /**\n   * @description for non-filterable Select, this prop decides if the option menu pops up when the input is focused\n   */\n  automaticDropdown: Boolean,\n  /**\n   * @description size of Input\n   */\n  size: useSizeProp,\n  /**\n   * @description tooltip theme, built-in theme: `dark` / `light`\n   */\n  effect: {\n    type: definePropType<PopperEffect | string>(String),\n    default: 'light',\n  },\n  /**\n   * @description whether Select is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description whether select can be cleared\n   */\n  clearable: Boolean,\n  /**\n   * @description whether Select is filterable\n   */\n  filterable: Boolean,\n  /**\n   * @description whether creating new items is allowed. To use this, `filterable` must be true\n   */\n  allowCreate: Boolean,\n  /**\n   * @description whether Select is loading data from server\n   */\n  loading: Boolean,\n  /**\n   * @description custom class name for Select's dropdown\n   */\n  popperClass: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n   */\n  popperOptions: {\n    type: definePropType<Partial<Options>>(Object),\n    default: () => ({} as Partial<Options>),\n  },\n  /**\n   * @description whether options are loaded from server\n   */\n  remote: Boolean,\n  /**\n   * @description displayed text while loading data from server, default is 'Loading'\n   */\n  loadingText: String,\n  /**\n   * @description displayed text when no data matches the filtering query, you can also use slot `empty`, default is 'No matching data'\n   */\n  noMatchText: String,\n  /**\n   * @description displayed text when there is no options, you can also use slot `empty`, default is 'No data'\n   */\n  noDataText: String,\n  /**\n   * @description custom remote search method\n   */\n  remoteMethod: Function,\n  /**\n   * @description custom filter method\n   */\n  filterMethod: Function,\n  /**\n   * @description whether multiple-select is activated\n   */\n  multiple: Boolean,\n  /**\n   * @description maximum number of options user can select when `multiple` is `true`. No limit when set to 0\n   */\n  multipleLimit: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description placeholder, default is 'Select'\n   */\n  placeholder: {\n    type: String,\n  },\n  /**\n   * @description select first matching option on enter key. Use with `filterable` or `remote`\n   */\n  defaultFirstOption: Boolean,\n  /**\n   * @description when `multiple` and `filter` is true, whether to reserve current keyword after selecting an option\n   */\n  reserveKeyword: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description unique identity key name for value, required when value is an object\n   */\n  valueKey: {\n    type: String,\n    default: 'value',\n  },\n  /**\n   * @description whether to collapse tags to a text when multiple selecting\n   */\n  collapseTags: Boolean,\n  /**\n   * @description whether show all selected tags when mouse hover text of collapse-tags. To use this, `collapse-tags` must be true\n   */\n  collapseTagsTooltip: Boolean,\n  /**\n   * @description the max tags number to be shown. To use this, `collapse-tags` must be true\n   */\n  maxCollapseTags: {\n    type: Number,\n    default: 1,\n  },\n  /**\n   * @description whether select dropdown is teleported to the body\n   */\n  teleported: useTooltipContentProps.teleported,\n  /**\n   * @description when select dropdown is inactive and `persistent` is `false`, select dropdown will be destroyed\n   */\n  persistent: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description custom clear icon component\n   */\n  clearIcon: {\n    type: iconPropType,\n    default: CircleClose,\n  },\n  /**\n   * @description whether the width of the dropdown is the same as the input\n   */\n  fitInputWidth: Boolean,\n  /**\n   * @description custom suffix icon component\n   */\n  suffixIcon: {\n    type: iconPropType,\n    default: ArrowDown,\n  },\n  /**\n   * @description tag type\n   */\n  // eslint-disable-next-line vue/require-prop-types\n  tagType: { ...tagProps.type, default: 'info' },\n  /**\n   * @description tag effect\n   */\n  tagEffect: { ...tagProps.effect, default: 'light' },\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description in remote search method show suffix icon\n   */\n  remoteShowSuffix: Boolean,\n  /**\n   * @description position of dropdown\n   */\n  placement: {\n    type: definePropType<Placement>(String),\n    values: placements,\n    default: 'bottom-start',\n  },\n  /**\n   * @description list of possible positions for dropdown\n   */\n  fallbackPlacements: {\n    type: definePropType<Placement[]>(Array),\n    default: ['bottom-start', 'top-start', 'right', 'left'],\n  },\n  /**\n   * @description which element the selection dropdown appends to\n   */\n  appendTo: String,\n  ...useEmptyValuesProps,\n  ...useAriaProps(['ariaLabel']),\n})\n", "<template>\n  <div\n    ref=\"selectRef\"\n    v-click-outside:[popperRef]=\"handleClickOutside\"\n    :class=\"[nsSelect.b(), nsSelect.m(selectSize)]\"\n    @[mouseEnterEventName]=\"states.inputHovering = true\"\n    @mouseleave=\"states.inputHovering = false\"\n  >\n    <el-tooltip\n      ref=\"tooltipRef\"\n      :visible=\"dropdownMenuVisible\"\n      :placement=\"placement\"\n      :teleported=\"teleported\"\n      :popper-class=\"[nsSelect.e('popper'), popperClass]\"\n      :popper-options=\"popperOptions\"\n      :fallback-placements=\"fallbackPlacements\"\n      :effect=\"effect\"\n      pure\n      trigger=\"click\"\n      :transition=\"`${nsSelect.namespace.value}-zoom-in-top`\"\n      :stop-popper-mouse-event=\"false\"\n      :gpu-acceleration=\"false\"\n      :persistent=\"persistent\"\n      :append-to=\"appendTo\"\n      @before-show=\"handleMenuEnter\"\n      @hide=\"states.isBeforeHide = false\"\n    >\n      <template #default>\n        <div\n          ref=\"wrapperRef\"\n          :class=\"[\n            nsSelect.e('wrapper'),\n            nsSelect.is('focused', isFocused),\n            nsSelect.is('hovering', states.inputHovering),\n            nsSelect.is('filterable', filterable),\n            nsSelect.is('disabled', selectDisabled),\n          ]\"\n          @click.prevent=\"toggleMenu\"\n        >\n          <div\n            v-if=\"$slots.prefix\"\n            ref=\"prefixRef\"\n            :class=\"nsSelect.e('prefix')\"\n          >\n            <slot name=\"prefix\" />\n          </div>\n          <div\n            ref=\"selectionRef\"\n            :class=\"[\n              nsSelect.e('selection'),\n              nsSelect.is(\n                'near',\n                multiple && !$slots.prefix && !!states.selected.length\n              ),\n            ]\"\n          >\n            <slot v-if=\"multiple\" name=\"tag\">\n              <div\n                v-for=\"item in showTagList\"\n                :key=\"getValueKey(item)\"\n                :class=\"nsSelect.e('selected-item')\"\n              >\n                <el-tag\n                  :closable=\"!selectDisabled && !item.isDisabled\"\n                  :size=\"collapseTagSize\"\n                  :type=\"tagType\"\n                  :effect=\"tagEffect\"\n                  disable-transitions\n                  :style=\"tagStyle\"\n                  @close=\"deleteTag($event, item)\"\n                >\n                  <span :class=\"nsSelect.e('tags-text')\">\n                    <slot\n                      name=\"label\"\n                      :label=\"item.currentLabel\"\n                      :value=\"item.value\"\n                    >\n                      {{ item.currentLabel }}\n                    </slot>\n                  </span>\n                </el-tag>\n              </div>\n\n              <el-tooltip\n                v-if=\"collapseTags && states.selected.length > maxCollapseTags\"\n                ref=\"tagTooltipRef\"\n                :disabled=\"dropdownMenuVisible || !collapseTagsTooltip\"\n                :fallback-placements=\"['bottom', 'top', 'right', 'left']\"\n                :effect=\"effect\"\n                placement=\"bottom\"\n                :teleported=\"teleported\"\n              >\n                <template #default>\n                  <div\n                    ref=\"collapseItemRef\"\n                    :class=\"nsSelect.e('selected-item')\"\n                  >\n                    <el-tag\n                      :closable=\"false\"\n                      :size=\"collapseTagSize\"\n                      :type=\"tagType\"\n                      :effect=\"tagEffect\"\n                      disable-transitions\n                      :style=\"collapseTagStyle\"\n                    >\n                      <span :class=\"nsSelect.e('tags-text')\">\n                        + {{ states.selected.length - maxCollapseTags }}\n                      </span>\n                    </el-tag>\n                  </div>\n                </template>\n                <template #content>\n                  <div ref=\"tagMenuRef\" :class=\"nsSelect.e('selection')\">\n                    <div\n                      v-for=\"item in collapseTagList\"\n                      :key=\"getValueKey(item)\"\n                      :class=\"nsSelect.e('selected-item')\"\n                    >\n                      <el-tag\n                        class=\"in-tooltip\"\n                        :closable=\"!selectDisabled && !item.isDisabled\"\n                        :size=\"collapseTagSize\"\n                        :type=\"tagType\"\n                        :effect=\"tagEffect\"\n                        disable-transitions\n                        @close=\"deleteTag($event, item)\"\n                      >\n                        <span :class=\"nsSelect.e('tags-text')\">\n                          <slot\n                            name=\"label\"\n                            :label=\"item.currentLabel\"\n                            :value=\"item.value\"\n                          >\n                            {{ item.currentLabel }}\n                          </slot>\n                        </span>\n                      </el-tag>\n                    </div>\n                  </div>\n                </template>\n              </el-tooltip>\n            </slot>\n            <div\n              v-if=\"!selectDisabled\"\n              :class=\"[\n                nsSelect.e('selected-item'),\n                nsSelect.e('input-wrapper'),\n                nsSelect.is('hidden', !filterable),\n              ]\"\n            >\n              <input\n                :id=\"inputId\"\n                ref=\"inputRef\"\n                v-model=\"states.inputValue\"\n                type=\"text\"\n                :name=\"name\"\n                :class=\"[nsSelect.e('input'), nsSelect.is(selectSize)]\"\n                :disabled=\"selectDisabled\"\n                :autocomplete=\"autocomplete\"\n                :style=\"inputStyle\"\n                role=\"combobox\"\n                :readonly=\"!filterable\"\n                spellcheck=\"false\"\n                :aria-activedescendant=\"hoverOption?.id || ''\"\n                :aria-controls=\"contentId\"\n                :aria-expanded=\"dropdownMenuVisible\"\n                :aria-label=\"ariaLabel\"\n                aria-autocomplete=\"none\"\n                aria-haspopup=\"listbox\"\n                @keydown.down.stop.prevent=\"navigateOptions('next')\"\n                @keydown.up.stop.prevent=\"navigateOptions('prev')\"\n                @keydown.esc.stop.prevent=\"handleEsc\"\n                @keydown.enter.stop.prevent=\"selectOption\"\n                @keydown.delete.stop=\"deletePrevTag\"\n                @compositionstart=\"handleCompositionStart\"\n                @compositionupdate=\"handleCompositionUpdate\"\n                @compositionend=\"handleCompositionEnd\"\n                @input=\"onInput\"\n                @click.stop=\"toggleMenu\"\n              />\n              <span\n                v-if=\"filterable\"\n                ref=\"calculatorRef\"\n                aria-hidden=\"true\"\n                :class=\"nsSelect.e('input-calculator')\"\n                v-text=\"states.inputValue\"\n              />\n            </div>\n            <div\n              v-if=\"shouldShowPlaceholder\"\n              :class=\"[\n                nsSelect.e('selected-item'),\n                nsSelect.e('placeholder'),\n                nsSelect.is(\n                  'transparent',\n                  !hasModelValue || (expanded && !states.inputValue)\n                ),\n              ]\"\n            >\n              <slot\n                v-if=\"hasModelValue\"\n                name=\"label\"\n                :label=\"currentPlaceholder\"\n                :value=\"modelValue\"\n              >\n                <span>{{ currentPlaceholder }}</span>\n              </slot>\n              <span v-else>{{ currentPlaceholder }}</span>\n            </div>\n          </div>\n          <div ref=\"suffixRef\" :class=\"nsSelect.e('suffix')\">\n            <el-icon\n              v-if=\"iconComponent && !showClose\"\n              :class=\"[nsSelect.e('caret'), nsSelect.e('icon'), iconReverse]\"\n            >\n              <component :is=\"iconComponent\" />\n            </el-icon>\n            <el-icon\n              v-if=\"showClose && clearIcon\"\n              :class=\"[\n                nsSelect.e('caret'),\n                nsSelect.e('icon'),\n                nsSelect.e('clear'),\n              ]\"\n              @click=\"handleClearClick\"\n            >\n              <component :is=\"clearIcon\" />\n            </el-icon>\n            <el-icon\n              v-if=\"validateState && validateIcon\"\n              :class=\"[nsInput.e('icon'), nsInput.e('validateIcon')]\"\n            >\n              <component :is=\"validateIcon\" />\n            </el-icon>\n          </div>\n        </div>\n      </template>\n      <template #content>\n        <el-select-menu ref=\"menuRef\">\n          <div\n            v-if=\"$slots.header\"\n            :class=\"nsSelect.be('dropdown', 'header')\"\n            @click.stop\n          >\n            <slot name=\"header\" />\n          </div>\n          <el-scrollbar\n            v-show=\"states.options.size > 0 && !loading\"\n            :id=\"contentId\"\n            ref=\"scrollbarRef\"\n            tag=\"ul\"\n            :wrap-class=\"nsSelect.be('dropdown', 'wrap')\"\n            :view-class=\"nsSelect.be('dropdown', 'list')\"\n            :class=\"[nsSelect.is('empty', filteredOptionsCount === 0)]\"\n            role=\"listbox\"\n            :aria-label=\"ariaLabel\"\n            aria-orientation=\"vertical\"\n          >\n            <el-option\n              v-if=\"showNewOption\"\n              :value=\"states.inputValue\"\n              :created=\"true\"\n            />\n            <el-options>\n              <slot />\n            </el-options>\n          </el-scrollbar>\n          <div\n            v-if=\"$slots.loading && loading\"\n            :class=\"nsSelect.be('dropdown', 'loading')\"\n          >\n            <slot name=\"loading\" />\n          </div>\n          <div\n            v-else-if=\"loading || filteredOptionsCount === 0\"\n            :class=\"nsSelect.be('dropdown', 'empty')\"\n          >\n            <slot name=\"empty\">\n              <span>{{ emptyText }}</span>\n            </slot>\n          </div>\n          <div\n            v-if=\"$slots.footer\"\n            :class=\"nsSelect.be('dropdown', 'footer')\"\n            @click.stop\n          >\n            <slot name=\"footer\" />\n          </div>\n        </el-select-menu>\n      </template>\n    </el-tooltip>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, provide, reactive, toRefs } from 'vue'\nimport { ClickOutside } from '@element-plus/directives'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport ElTag from '@element-plus/components/tag'\nimport ElIcon from '@element-plus/components/icon'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { isArray } from '@element-plus/utils'\nimport ElOption from './option.vue'\nimport ElSelectMenu from './select-dropdown.vue'\nimport { useSelect } from './useSelect'\nimport { selectKey } from './token'\nimport ElOptions from './options'\n\nimport { SelectProps } from './select'\nimport type { SelectContext } from './token'\n\nconst COMPONENT_NAME = 'ElSelect'\nexport default defineComponent({\n  name: COMPONENT_NAME,\n  componentName: COMPONENT_NAME,\n  components: {\n    ElSelectMenu,\n    ElOption,\n    ElOptions,\n    ElTag,\n    ElScrollbar,\n    ElTooltip,\n    ElIcon,\n  },\n  directives: { ClickOutside },\n  props: SelectProps,\n  emits: [\n    UPDATE_MODEL_EVENT,\n    CHANGE_EVENT,\n    'remove-tag',\n    'clear',\n    'visible-change',\n    'focus',\n    'blur',\n  ],\n\n  setup(props, { emit }) {\n    const modelValue = computed(() => {\n      const { modelValue: rawModelValue, multiple } = props\n      const fallback = multiple ? [] : undefined\n      // When it is array, we check if this is multi-select.\n      // Based on the result we get\n      if (isArray(rawModelValue)) {\n        return multiple ? rawModelValue : fallback\n      }\n\n      return multiple ? fallback : rawModelValue\n    })\n\n    const _props = reactive({\n      ...toRefs(props),\n      modelValue,\n    })\n\n    const API = useSelect(_props, emit)\n\n    provide(\n      selectKey,\n      reactive({\n        props: _props,\n        states: API.states,\n        optionsArray: API.optionsArray,\n        handleOptionSelect: API.handleOptionSelect,\n        onOptionCreate: API.onOptionCreate,\n        onOptionDestroy: API.onOptionDestroy,\n        selectRef: API.selectRef,\n        setSelected: API.setSelected,\n      }) as unknown as SelectContext\n    )\n\n    return {\n      ...API,\n      modelValue,\n    }\n  },\n})\n</script>\n", "<template>\n  <ul v-show=\"visible\" ref=\"groupRef\" :class=\"ns.be('group', 'wrap')\">\n    <li :class=\"ns.be('group', 'title')\">{{ label }}</li>\n    <li>\n      <ul :class=\"ns.b('group')\">\n        <slot />\n      </ul>\n    </li>\n  </ul>\n</template>\n\n<script lang=\"ts\">\n// @ts-nocheck\nimport {\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  onMounted,\n  provide,\n  reactive,\n  ref,\n  toRefs,\n} from 'vue'\nimport { useMutationObserver } from '@vueuse/core'\nimport { ensureArray } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { selectGroupKey } from './token'\n\nexport default defineComponent({\n  name: 'ElOptionGroup',\n  componentName: 'ElOptionGroup',\n\n  props: {\n    /**\n     * @description name of the group\n     */\n    label: String,\n    /**\n     * @description whether to disable all options in this group\n     */\n    disabled: Boolean,\n  },\n  setup(props) {\n    const ns = useNamespace('select')\n    const groupRef = ref(null)\n    const instance = getCurrentInstance()\n    const children = ref([])\n\n    provide(\n      selectGroupKey,\n      reactive({\n        ...toRefs(props),\n      })\n    )\n\n    const visible = computed(() =>\n      children.value.some((option) => option.visible === true)\n    )\n\n    const isOption = (node) =>\n      node.type?.name === 'ElOption' && !!node.component?.proxy\n\n    // get all instances of options\n    const flattedChildren = (node) => {\n      const Nodes = ensureArray(node)\n      const children = []\n\n      Nodes.forEach((child) => {\n        if (isOption(child)) {\n          children.push(child.component.proxy)\n        } else if (child.children?.length) {\n          children.push(...flattedChildren(child.children))\n        } else if (child.component?.subTree) {\n          children.push(...flattedChildren(child.component.subTree))\n        }\n      })\n\n      return children\n    }\n\n    const updateChildren = () => {\n      children.value = flattedChildren(instance.subTree)\n    }\n\n    onMounted(() => {\n      updateChildren()\n    })\n\n    useMutationObserver(groupRef, updateChildren, {\n      attributes: true,\n      subtree: true,\n      childList: true,\n    })\n\n    return {\n      groupRef,\n      visible,\n      ns,\n    }\n  },\n})\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\n\nimport Select from './src/select.vue'\nimport Option from './src/option.vue'\nimport OptionGroup from './src/option-group.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElSelect: SFCWithInstall<typeof Select> & {\n  Option: typeof Option\n  OptionGroup: typeof OptionGroup\n} = withInstall(Select, {\n  Option,\n  OptionGroup,\n})\nexport default ElSelect\nexport const ElOption: SFCWithInstall<typeof Option> = withNoopInstall(Option)\nexport const ElOptionGroup: SFCWithInstall<typeof OptionGroup> =\n  withNoopInstall(OptionGroup)\n\nexport * from './src/token'\n", "import { inject } from 'vue'\nimport { elPaginationKey } from './constants'\n\nexport const usePagination = () => inject(elPaginationKey, {})\n", "import { buildProps, definePropType, mutable } from '@element-plus/utils'\nimport { componentSizes } from '@element-plus/constants'\nimport type { ExtractPropTypes } from 'vue'\nimport type Sizes from './sizes.vue'\n\nexport const paginationSizesProps = buildProps({\n  pageSize: {\n    type: Number,\n    required: true,\n  },\n  pageSizes: {\n    type: definePropType<number[]>(Array),\n    default: () => mutable([10, 20, 30, 40, 50, 100] as const),\n  },\n  popperClass: {\n    type: String,\n  },\n  disabled: Boolean,\n  teleported: Boolean,\n  size: {\n    type: String,\n    values: componentSizes,\n  },\n  appendSizeTo: String,\n} as const)\n\nexport type PaginationSizesProps = ExtractPropTypes<typeof paginationSizesProps>\n\nexport type SizesInstance = InstanceType<typeof Sizes>\n", "<template>\n  <span :class=\"ns.e('sizes')\">\n    <el-select\n      :model-value=\"innerPageSize\"\n      :disabled=\"disabled\"\n      :popper-class=\"popperClass\"\n      :size=\"size\"\n      :teleported=\"teleported\"\n      :validate-event=\"false\"\n      :append-to=\"appendSizeTo\"\n      @change=\"handleChange\"\n    >\n      <el-option\n        v-for=\"item in innerPageSizes\"\n        :key=\"item\"\n        :value=\"item\"\n        :label=\"item + t('el.pagination.pagesize')\"\n      />\n    </el-select>\n  </span>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, ref, watch } from 'vue'\nimport { isEqual } from 'lodash-unified'\nimport { ElOption, ElSelect } from '@element-plus/components/select'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { usePagination } from '../usePagination'\nimport { paginationSizesProps } from './sizes'\n\ndefineOptions({\n  name: 'ElPaginationSizes',\n})\n\nconst props = defineProps(paginationSizesProps)\nconst emit = defineEmits(['page-size-change'])\nconst { t } = useLocale()\nconst ns = useNamespace('pagination')\nconst pagination = usePagination()\nconst innerPageSize = ref<number>(props.pageSize!)\n\nwatch(\n  () => props.pageSizes,\n  (newVal, oldVal) => {\n    if (isEqual(newVal, oldVal)) return\n    if (Array.isArray(newVal)) {\n      const pageSize = newVal.includes(props.pageSize!)\n        ? props.pageSize\n        : props.pageSizes[0]\n      emit('page-size-change', pageSize)\n    }\n  }\n)\n\nwatch(\n  () => props.pageSize,\n  (newVal) => {\n    innerPageSize.value = newVal!\n  }\n)\n\nconst innerPageSizes = computed(() => props.pageSizes)\nfunction handleChange(val: number) {\n  if (val !== innerPageSize.value) {\n    innerPageSize.value = val\n    pagination.handleSizeChange?.(Number(val))\n  }\n}\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport { componentSizes } from '@element-plus/constants'\nimport type { ExtractPropTypes } from 'vue'\nimport type Jumper from './jumper.vue'\n\nexport const paginationJumperProps = buildProps({\n  size: {\n    type: String,\n    values: componentSizes,\n  },\n} as const)\n\nexport type PaginationJumperProps = ExtractPropTypes<\n  typeof paginationJumperProps\n>\n\nexport type PaginationJumperInstance = InstanceType<typeof Jumper>\n", "<template>\n  <span :class=\"ns.e('jump')\" :disabled=\"disabled\">\n    <span :class=\"[ns.e('goto')]\">{{ t('el.pagination.goto') }}</span>\n    <el-input\n      :size=\"size\"\n      :class=\"[ns.e('editor'), ns.is('in-pagination')]\"\n      :min=\"1\"\n      :max=\"pageCount\"\n      :disabled=\"disabled\"\n      :model-value=\"innerValue\"\n      :validate-event=\"false\"\n      :aria-label=\"t('el.pagination.page')\"\n      type=\"number\"\n      @update:model-value=\"handleInput\"\n      @change=\"handleChange\"\n    />\n    <span :class=\"[ns.e('classifier')]\">{{\n      t('el.pagination.pageClassifier')\n    }}</span>\n  </span>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, ref } from 'vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport ElInput from '@element-plus/components/input'\nimport { usePagination } from '../usePagination'\nimport { paginationJumperProps } from './jumper'\n\ndefineOptions({\n  name: 'ElPaginationJumper',\n})\n\ndefineProps(paginationJumperProps)\nconst { t } = useLocale()\nconst ns = useNamespace('pagination')\nconst { pageCount, disabled, currentPage, changeEvent } = usePagination()\nconst userInput = ref<number | string>()\nconst innerValue = computed(() => userInput.value ?? currentPage?.value)\n\nfunction handleInput(val: number | string) {\n  userInput.value = val ? +val : ''\n}\n\nfunction handleChange(val: number | string) {\n  val = Math.trunc(+val)\n  changeEvent?.(val)\n  userInput.value = undefined\n}\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport type Total from './total.vue'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const paginationTotalProps = buildProps({\n  total: {\n    type: Number,\n    default: 1000,\n  },\n} as const)\n\nexport type PaginationTotalProps = ExtractPropTypes<typeof paginationTotalProps>\n\nexport type TotalInstance = InstanceType<typeof Total>\n", "<template>\n  <span :class=\"ns.e('total')\" :disabled=\"disabled\">\n    {{\n      t('el.pagination.total', {\n        total,\n      })\n    }}\n  </span>\n</template>\n\n<script lang=\"ts\" setup>\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { usePagination } from '../usePagination'\nimport { paginationTotalProps } from './total'\n\nconst { t } = useLocale()\nconst ns = useNamespace('pagination')\nconst { disabled } = usePagination()\n\ndefineOptions({\n  name: 'ElPaginationTotal',\n})\n\ndefineProps(paginationTotalProps)\n</script>\n", "import { buildProps } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type Pager from './pager.vue'\n\nexport const paginationPagerProps = buildProps({\n  currentPage: {\n    type: Number,\n    default: 1,\n  },\n  pageCount: {\n    type: Number,\n    required: true,\n  },\n  pagerCount: {\n    type: Number,\n    default: 7,\n  },\n  disabled: Boolean,\n} as const)\n\nexport type PaginationPagerProps = ExtractPropTypes<typeof paginationPagerProps>\n\nexport type PagerInstance = InstanceType<typeof Pager>\n", "<template>\n  <ul :class=\"nsPager.b()\" @click=\"onPagerClick\" @keyup.enter=\"onEnter\">\n    <li\n      v-if=\"pageCount > 0\"\n      :class=\"[\n        nsPager.is('active', currentPage === 1),\n        nsPager.is('disabled', disabled),\n      ]\"\n      class=\"number\"\n      :aria-current=\"currentPage === 1\"\n      :aria-label=\"t('el.pagination.currentPage', { pager: 1 })\"\n      :tabindex=\"tabindex\"\n    >\n      1\n    </li>\n    <li\n      v-if=\"showPrevMore\"\n      :class=\"prevMoreKls\"\n      :tabindex=\"tabindex\"\n      :aria-label=\"t('el.pagination.prevPages', { pager: pagerCount - 2 })\"\n      @mouseenter=\"onMouseEnter(true)\"\n      @mouseleave=\"quickPrevHover = false\"\n      @focus=\"onFocus(true)\"\n      @blur=\"quickPrevFocus = false\"\n    >\n      <d-arrow-left v-if=\"(quickPrevHover || quickPrevFocus) && !disabled\" />\n      <more-filled v-else />\n    </li>\n    <li\n      v-for=\"pager in pagers\"\n      :key=\"pager\"\n      :class=\"[\n        nsPager.is('active', currentPage === pager),\n        nsPager.is('disabled', disabled),\n      ]\"\n      class=\"number\"\n      :aria-current=\"currentPage === pager\"\n      :aria-label=\"t('el.pagination.currentPage', { pager })\"\n      :tabindex=\"tabindex\"\n    >\n      {{ pager }}\n    </li>\n    <li\n      v-if=\"showNextMore\"\n      :class=\"nextMoreKls\"\n      :tabindex=\"tabindex\"\n      :aria-label=\"t('el.pagination.nextPages', { pager: pagerCount - 2 })\"\n      @mouseenter=\"onMouseEnter()\"\n      @mouseleave=\"quickNextHover = false\"\n      @focus=\"onFocus()\"\n      @blur=\"quickNextFocus = false\"\n    >\n      <d-arrow-right v-if=\"(quickNextHover || quickNextFocus) && !disabled\" />\n      <more-filled v-else />\n    </li>\n    <li\n      v-if=\"pageCount > 1\"\n      :class=\"[\n        nsPager.is('active', currentPage === pageCount),\n        nsPager.is('disabled', disabled),\n      ]\"\n      class=\"number\"\n      :aria-current=\"currentPage === pageCount\"\n      :aria-label=\"t('el.pagination.currentPage', { pager: pageCount })\"\n      :tabindex=\"tabindex\"\n    >\n      {{ pageCount }}\n    </li>\n  </ul>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, ref, watchEffect } from 'vue'\nimport { DArrowLeft, DArrowRight, MoreFilled } from '@element-plus/icons-vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { paginationPagerProps } from './pager'\ndefineOptions({\n  name: 'ElPaginationPager',\n})\nconst props = defineProps(paginationPagerProps)\nconst emit = defineEmits(['change'])\nconst nsPager = useNamespace('pager')\nconst nsIcon = useNamespace('icon')\nconst { t } = useLocale()\n\nconst showPrevMore = ref(false)\nconst showNextMore = ref(false)\nconst quickPrevHover = ref(false)\nconst quickNextHover = ref(false)\nconst quickPrevFocus = ref(false)\nconst quickNextFocus = ref(false)\nconst pagers = computed(() => {\n  const pagerCount = props.pagerCount\n  const halfPagerCount = (pagerCount - 1) / 2\n  const currentPage = Number(props.currentPage)\n  const pageCount = Number(props.pageCount)\n  let showPrevMore = false\n  let showNextMore = false\n  if (pageCount > pagerCount) {\n    if (currentPage > pagerCount - halfPagerCount) {\n      showPrevMore = true\n    }\n    if (currentPage < pageCount - halfPagerCount) {\n      showNextMore = true\n    }\n  }\n  const array: number[] = []\n  if (showPrevMore && !showNextMore) {\n    const startPage = pageCount - (pagerCount - 2)\n    for (let i = startPage; i < pageCount; i++) {\n      array.push(i)\n    }\n  } else if (!showPrevMore && showNextMore) {\n    for (let i = 2; i < pagerCount; i++) {\n      array.push(i)\n    }\n  } else if (showPrevMore && showNextMore) {\n    const offset = Math.floor(pagerCount / 2) - 1\n    for (let i = currentPage - offset; i <= currentPage + offset; i++) {\n      array.push(i)\n    }\n  } else {\n    for (let i = 2; i < pageCount; i++) {\n      array.push(i)\n    }\n  }\n  return array\n})\n\nconst prevMoreKls = computed(() => [\n  'more',\n  'btn-quickprev',\n  nsIcon.b(),\n  nsPager.is('disabled', props.disabled),\n])\nconst nextMoreKls = computed(() => [\n  'more',\n  'btn-quicknext',\n  nsIcon.b(),\n  nsPager.is('disabled', props.disabled),\n])\n\nconst tabindex = computed(() => (props.disabled ? -1 : 0))\nwatchEffect(() => {\n  const halfPagerCount = (props.pagerCount - 1) / 2\n  showPrevMore.value = false\n  showNextMore.value = false\n  if (props.pageCount! > props.pagerCount) {\n    if (props.currentPage > props.pagerCount - halfPagerCount) {\n      showPrevMore.value = true\n    }\n    if (props.currentPage < props.pageCount! - halfPagerCount) {\n      showNextMore.value = true\n    }\n  }\n})\nfunction onMouseEnter(forward = false) {\n  if (props.disabled) return\n  if (forward) {\n    quickPrevHover.value = true\n  } else {\n    quickNextHover.value = true\n  }\n}\nfunction onFocus(forward = false) {\n  if (forward) {\n    quickPrevFocus.value = true\n  } else {\n    quickNextFocus.value = true\n  }\n}\nfunction onEnter(e: UIEvent) {\n  const target = e.target as HTMLElement\n  if (\n    target.tagName.toLowerCase() === 'li' &&\n    Array.from(target.classList).includes('number')\n  ) {\n    const newPage = Number(target.textContent)\n    if (newPage !== props.currentPage) {\n      emit('change', newPage)\n    }\n  } else if (\n    target.tagName.toLowerCase() === 'li' &&\n    Array.from(target.classList).includes('more')\n  ) {\n    onPagerClick(e)\n  }\n}\nfunction onPagerClick(event: UIEvent) {\n  const target = event.target as HTMLElement\n  if (target.tagName.toLowerCase() === 'ul' || props.disabled) {\n    return\n  }\n  let newPage = Number(target.textContent)\n  const pageCount = props.pageCount!\n  const currentPage = props.currentPage\n  const pagerCountOffset = props.pagerCount - 2\n  if (target.className.includes('more')) {\n    if (target.className.includes('quickprev')) {\n      newPage = currentPage - pagerCountOffset\n    } else if (target.className.includes('quicknext')) {\n      newPage = currentPage + pagerCountOffset\n    }\n  }\n  if (!Number.isNaN(+newPage)) {\n    if (newPage < 1) {\n      newPage = 1\n    }\n    if (newPage > pageCount) {\n      newPage = pageCount\n    }\n  }\n  if (newPage !== currentPage) {\n    emit('change', newPage)\n  }\n}\n</script>\n", "import {\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  h,\n  provide,\n  ref,\n  watch,\n} from 'vue'\nimport { ArrowLeft, ArrowRight } from '@element-plus/icons-vue'\nimport {\n  buildProps,\n  debugWarn,\n  definePropType,\n  iconPropType,\n  isNumber,\n  mutable,\n} from '@element-plus/utils'\nimport {\n  useDeprecated,\n  useGlobalSize,\n  useLocale,\n  useNamespace,\n  useSizeProp,\n} from '@element-plus/hooks'\nimport { elPaginationKey } from './constants'\n\nimport Prev from './components/prev.vue'\nimport Next from './components/next.vue'\nimport Sizes from './components/sizes.vue'\nimport Jumper from './components/jumper.vue'\nimport Total from './components/total.vue'\nimport Pager from './components/pager.vue'\nimport type { ExtractPropTypes, VNode } from 'vue'\n/**\n * It it user's responsibility to guarantee that the value of props.total... is number\n * (same as pageSize, defaultPageSize, currentPage, defaultCurrentPage, pageCount)\n * Otherwise we can reasonable infer that the corresponding field is absent\n */\nconst isAbsent = (v: unknown): v is undefined => typeof v !== 'number'\n\ntype LayoutKey =\n  | 'prev'\n  | 'pager'\n  | 'next'\n  | 'jumper'\n  | '->'\n  | 'total'\n  | 'sizes'\n  | 'slot'\n\nexport const paginationProps = buildProps({\n  /**\n   * @description options of item count per page\n   */\n  pageSize: Number,\n  /**\n   * @description default initial value of page size, not setting is the same as setting 10\n   */\n  defaultPageSize: Number,\n  /**\n   * @description total item count\n   */\n  total: Number,\n  /**\n   * @description total page count. Set either `total` or `page-count` and pages will be displayed; if you need `page-sizes`, `total` is required\n   */\n  pageCount: Number,\n  /**\n   * @description number of pagers. Pagination collapses when the total page count exceeds this value\n   */\n  pagerCount: {\n    type: Number,\n    validator: (value: unknown) => {\n      return (\n        isNumber(value) &&\n        Math.trunc(value) === value &&\n        value > 4 &&\n        value < 22 &&\n        value % 2 === 1\n      )\n    },\n    default: 7,\n  },\n  /**\n   * @description current page number\n   */\n  currentPage: Number,\n  /**\n   * @description default initial value of current-page, not setting is the same as setting 1\n   */\n  defaultCurrentPage: Number,\n  /**\n   * @description layout of Pagination, elements separated with a comma\n   */\n  layout: {\n    type: String,\n    default: (\n      ['prev', 'pager', 'next', 'jumper', '->', 'total'] as LayoutKey[]\n    ).join(', '),\n  },\n  /**\n   * @description item count of each page\n   */\n  pageSizes: {\n    type: definePropType<number[]>(Array),\n    default: () => mutable([10, 20, 30, 40, 50, 100] as const),\n  },\n  /**\n   * @description custom class name for the page size Select's dropdown\n   */\n  popperClass: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description text for the prev button\n   */\n  prevText: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description icon for the prev button, higher priority of `prev-text`\n   */\n  prevIcon: {\n    type: iconPropType,\n    default: () => ArrowLeft,\n  },\n  /**\n   * @description text for the next button\n   */\n  nextText: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description icon for the next button, higher priority of `next-text`\n   */\n  nextIcon: {\n    type: iconPropType,\n    default: () => ArrowRight,\n  },\n  /**\n   * @description whether Pagination size is teleported to body\n   */\n  teleported: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether to use small pagination\n   */\n  small: Boolean,\n  /**\n   * @description set page size\n   */\n  size: useSizeProp,\n  /**\n   * @description whether the buttons have a background color\n   */\n  background: Boolean,\n  /**\n   * @description whether Pagination is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description whether to hide when there's only one page\n   */\n  hideOnSinglePage: Boolean,\n  /**\n   * @description which element the size dropdown appends to.\n   */\n  appendSizeTo: String,\n} as const)\nexport type PaginationProps = ExtractPropTypes<typeof paginationProps>\n\nexport const paginationEmits = {\n  'update:current-page': (val: number) => isNumber(val),\n  'update:page-size': (val: number) => isNumber(val),\n  'size-change': (val: number) => isNumber(val),\n  change: (currentPage: number, pageSize: number) =>\n    isNumber(currentPage) && isNumber(pageSize),\n  'current-change': (val: number) => isNumber(val),\n  'prev-click': (val: number) => isNumber(val),\n  'next-click': (val: number) => isNumber(val),\n}\nexport type PaginationEmits = typeof paginationEmits\n\nconst componentName = 'ElPagination'\nexport default defineComponent({\n  name: componentName,\n\n  props: paginationProps,\n  emits: paginationEmits,\n\n  setup(props, { emit, slots }) {\n    const { t } = useLocale()\n    const ns = useNamespace('pagination')\n    const vnodeProps = getCurrentInstance()!.vnode.props || {}\n    const _globalSize = useGlobalSize()\n    const _size = computed(() =>\n      props.small ? 'small' : props.size ?? _globalSize.value\n    )\n    useDeprecated(\n      {\n        from: 'small',\n        replacement: 'size',\n        version: '3.0.0',\n        scope: 'el-pagination',\n        ref: 'https://element-plus.org/zh-CN/component/pagination.html',\n      },\n      computed(() => !!props.small)\n    )\n    // we can find @xxx=\"xxx\" props on `vnodeProps` to check if user bind corresponding events\n    const hasCurrentPageListener =\n      'onUpdate:currentPage' in vnodeProps ||\n      'onUpdate:current-page' in vnodeProps ||\n      'onCurrentChange' in vnodeProps\n    const hasPageSizeListener =\n      'onUpdate:pageSize' in vnodeProps ||\n      'onUpdate:page-size' in vnodeProps ||\n      'onSizeChange' in vnodeProps\n    const assertValidUsage = computed(() => {\n      // Users have to set either one, otherwise count of pages cannot be determined\n      if (isAbsent(props.total) && isAbsent(props.pageCount)) return false\n      // <el-pagination ...otherProps :current-page=\"xxx\" /> without corresponding listener is forbidden now\n      // Users have to use two way binding of `currentPage`\n      // If users just want to provide a default value, `defaultCurrentPage` is here for you\n      if (!isAbsent(props.currentPage) && !hasCurrentPageListener) return false\n      // When you want to change sizes, things get more complex, detailed below\n      // Basically the most important value we need is page count\n      // either directly from props.pageCount\n      // or calculated from props.total\n      // we will take props.pageCount precedence over props.total\n      if (props.layout.includes('sizes')) {\n        if (!isAbsent(props.pageCount)) {\n          // if props.pageCount is assign by user, then user have to watch pageSize change\n          // and recalculate pageCount\n          if (!hasPageSizeListener) return false\n        } else if (!isAbsent(props.total)) {\n          // Otherwise, we will see if user have props.pageSize defined\n          // If so, meaning user want to have pageSize controlled himself/herself from component\n          // Thus page size listener is required\n          // users are account for page size change\n          if (!isAbsent(props.pageSize)) {\n            if (!hasPageSizeListener) {\n              return false\n            }\n          } else {\n            // (else block just for explaination)\n            // else page size is controlled by el-pagination internally\n          }\n        }\n      }\n      return true\n    })\n\n    const innerPageSize = ref(\n      isAbsent(props.defaultPageSize) ? 10 : props.defaultPageSize\n    )\n    const innerCurrentPage = ref(\n      isAbsent(props.defaultCurrentPage) ? 1 : props.defaultCurrentPage\n    )\n\n    const pageSizeBridge = computed({\n      get() {\n        return isAbsent(props.pageSize) ? innerPageSize.value : props.pageSize\n      },\n      set(v: number) {\n        if (isAbsent(props.pageSize)) {\n          innerPageSize.value = v\n        }\n        if (hasPageSizeListener) {\n          emit('update:page-size', v)\n          emit('size-change', v)\n        }\n      },\n    })\n\n    const pageCountBridge = computed<number>(() => {\n      let pageCount = 0\n      if (!isAbsent(props.pageCount)) {\n        pageCount = props.pageCount\n      } else if (!isAbsent(props.total)) {\n        pageCount = Math.max(1, Math.ceil(props.total / pageSizeBridge.value))\n      }\n      return pageCount\n    })\n\n    const currentPageBridge = computed<number>({\n      get() {\n        return isAbsent(props.currentPage)\n          ? innerCurrentPage.value\n          : props.currentPage\n      },\n      set(v) {\n        let newCurrentPage = v\n        if (v < 1) {\n          newCurrentPage = 1\n        } else if (v > pageCountBridge.value) {\n          newCurrentPage = pageCountBridge.value\n        }\n        if (isAbsent(props.currentPage)) {\n          innerCurrentPage.value = newCurrentPage\n        }\n        if (hasCurrentPageListener) {\n          emit('update:current-page', newCurrentPage)\n          emit('current-change', newCurrentPage)\n        }\n      },\n    })\n\n    watch(pageCountBridge, (val) => {\n      if (currentPageBridge.value > val) currentPageBridge.value = val\n    })\n\n    watch(\n      [currentPageBridge, pageSizeBridge],\n      (value) => {\n        emit('change', ...value)\n      },\n      { flush: 'post' }\n    )\n\n    function handleCurrentChange(val: number) {\n      currentPageBridge.value = val\n    }\n\n    function handleSizeChange(val: number) {\n      pageSizeBridge.value = val\n      const newPageCount = pageCountBridge.value\n      if (currentPageBridge.value > newPageCount) {\n        currentPageBridge.value = newPageCount\n      }\n    }\n\n    function prev() {\n      if (props.disabled) return\n      currentPageBridge.value -= 1\n      emit('prev-click', currentPageBridge.value)\n    }\n\n    function next() {\n      if (props.disabled) return\n      currentPageBridge.value += 1\n      emit('next-click', currentPageBridge.value)\n    }\n\n    function addClass(element: any, cls: string) {\n      if (element) {\n        if (!element.props) {\n          element.props = {}\n        }\n        element.props.class = [element.props.class, cls].join(' ')\n      }\n    }\n\n    provide(elPaginationKey, {\n      pageCount: pageCountBridge,\n      disabled: computed(() => props.disabled),\n      currentPage: currentPageBridge,\n      changeEvent: handleCurrentChange,\n      handleSizeChange,\n    })\n\n    return () => {\n      if (!assertValidUsage.value) {\n        debugWarn(componentName, t('el.pagination.deprecationWarning'))\n        return null\n      }\n      if (!props.layout) return null\n      if (props.hideOnSinglePage && pageCountBridge.value <= 1) return null\n      const rootChildren: Array<VNode | VNode[] | null> = []\n      const rightWrapperChildren: Array<VNode | VNode[] | null> = []\n      const rightWrapperRoot = h(\n        'div',\n        { class: ns.e('rightwrapper') },\n        rightWrapperChildren\n      )\n      const TEMPLATE_MAP: Record<\n        Exclude<LayoutKey, '->'>,\n        VNode | VNode[] | null\n      > = {\n        prev: h(Prev, {\n          disabled: props.disabled,\n          currentPage: currentPageBridge.value,\n          prevText: props.prevText,\n          prevIcon: props.prevIcon,\n          onClick: prev,\n        }),\n        jumper: h(Jumper, {\n          size: _size.value,\n        }),\n        pager: h(Pager, {\n          currentPage: currentPageBridge.value,\n          pageCount: pageCountBridge.value,\n          pagerCount: props.pagerCount,\n          onChange: handleCurrentChange,\n          disabled: props.disabled,\n        }),\n        next: h(Next, {\n          disabled: props.disabled,\n          currentPage: currentPageBridge.value,\n          pageCount: pageCountBridge.value,\n          nextText: props.nextText,\n          nextIcon: props.nextIcon,\n          onClick: next,\n        }),\n        sizes: h(Sizes, {\n          pageSize: pageSizeBridge.value,\n          pageSizes: props.pageSizes,\n          popperClass: props.popperClass,\n          disabled: props.disabled,\n          teleported: props.teleported,\n          size: _size.value,\n          appendSizeTo: props.appendSizeTo,\n        }),\n        slot: slots?.default?.() ?? null,\n        total: h(Total, { total: isAbsent(props.total) ? 0 : props.total }),\n      }\n\n      const components = props.layout\n        .split(',')\n        .map((item: string) => item.trim()) as LayoutKey[]\n\n      let haveRightWrapper = false\n\n      components.forEach((c) => {\n        if (c === '->') {\n          haveRightWrapper = true\n          return\n        }\n        if (!haveRightWrapper) {\n          rootChildren.push(TEMPLATE_MAP[c])\n        } else {\n          rightWrapperChildren.push(TEMPLATE_MAP[c])\n        }\n      })\n\n      addClass(rootChildren[0], ns.is('first'))\n      addClass(rootChildren[rootChildren.length - 1], ns.is('last'))\n\n      if (haveRightWrapper && rightWrapperChildren.length > 0) {\n        addClass(rightWrapperChildren[0], ns.is('first'))\n        addClass(\n          rightWrapperChildren[rightWrapperChildren.length - 1],\n          ns.is('last')\n        )\n        rootChildren.push(rightWrapperRoot)\n      }\n      return h(\n        'div',\n        {\n          class: [\n            ns.b(),\n            ns.is('background', props.background),\n            ns.m(_size.value),\n          ],\n        },\n        rootChildren\n      )\n    }\n  },\n})\n", "import { withInstall } from '@element-plus/utils'\n\nimport Pagination from './src/pagination'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElPagination: SFCWithInstall<typeof Pagination> =\n  withInstall(Pagination)\nexport default ElPagination\n\nexport * from './src/pagination'\nexport * from './src/constants'\n", "import { buttonTypes } from '@element-plus/components/button'\nimport { QuestionFilled } from '@element-plus/icons-vue'\nimport { buildProps, iconPropType } from '@element-plus/utils'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport type { ExtractPropTypes } from 'vue'\nimport type Popconfirm from './popconfirm.vue'\n\nexport const popconfirmProps = buildProps({\n  /**\n   * @description Title\n   */\n  title: String,\n  /**\n   * @description Confirm button text\n   */\n  confirmButtonText: String,\n  /**\n   * @description Cancel button text\n   */\n  cancelButtonText: String,\n  /**\n   * @description Confirm button type\n   */\n  confirmButtonType: {\n    type: String,\n    values: buttonTypes,\n    default: 'primary',\n  },\n  /**\n   * @description Cancel button type\n   */\n  cancelButtonType: {\n    type: String,\n    values: buttonTypes,\n    default: 'text',\n  },\n  /**\n   * @description Icon Component\n   */\n  icon: {\n    type: iconPropType,\n    default: () => QuestionFilled,\n  },\n  /**\n   * @description Icon color\n   */\n  iconColor: {\n    type: String,\n    default: '#f90',\n  },\n  /**\n   * @description is hide Icon\n   */\n  hideIcon: {\n    type: Boolean,\n    default: false,\n  },\n  /**\n   * @description delay of disappear, in millisecond\n   */\n  hideAfter: {\n    type: Number,\n    default: 200,\n  },\n  /**\n   * @description whether popconfirm is teleported to the body\n   */\n  teleported: useTooltipContentProps.teleported,\n  /**\n   * @description when popconfirm inactive and `persistent` is `false` , popconfirm will be destroyed\n   */\n  persistent: useTooltipContentProps.persistent,\n  /**\n   * @description popconfirm width, min width 150px\n   */\n  width: {\n    type: [String, Number],\n    default: 150,\n  },\n} as const)\n\nexport const popconfirmEmits = {\n  /**\n   * @description triggers when click confirm button\n   */\n  confirm: (e: MouseEvent) => e instanceof MouseEvent,\n  /**\n   * @description triggers when click cancel button\n   */\n  cancel: (e: MouseEvent) => e instanceof MouseEvent,\n}\n\nexport type PopconfirmEmits = typeof popconfirmEmits\n\nexport type PopconfirmProps = ExtractPropTypes<typeof popconfirmProps>\n\nexport type PopconfirmInstance = InstanceType<typeof Popconfirm>\n", "<template>\n  <el-tooltip\n    ref=\"tooltipRef\"\n    trigger=\"click\"\n    effect=\"light\"\n    v-bind=\"$attrs\"\n    :popper-class=\"`${ns.namespace.value}-popover`\"\n    :popper-style=\"style\"\n    :teleported=\"teleported\"\n    :fallback-placements=\"['bottom', 'top', 'right', 'left']\"\n    :hide-after=\"hideAfter\"\n    :persistent=\"persistent\"\n  >\n    <template #content>\n      <div :class=\"ns.b()\">\n        <div :class=\"ns.e('main')\">\n          <el-icon\n            v-if=\"!hideIcon && icon\"\n            :class=\"ns.e('icon')\"\n            :style=\"{ color: iconColor }\"\n          >\n            <component :is=\"icon\" />\n          </el-icon>\n          {{ title }}\n        </div>\n        <div :class=\"ns.e('action')\">\n          <slot name=\"actions\" :confirm=\"confirm\" :cancel=\"cancel\">\n            <el-button\n              size=\"small\"\n              :type=\"cancelButtonType === 'text' ? '' : cancelButtonType\"\n              :text=\"cancelButtonType === 'text'\"\n              @click=\"cancel\"\n            >\n              {{ finalCancelButtonText }}\n            </el-button>\n            <el-button\n              size=\"small\"\n              :type=\"confirmButtonType === 'text' ? '' : confirmButtonType\"\n              :text=\"confirmButtonType === 'text'\"\n              @click=\"confirm\"\n            >\n              {{ finalConfirmButtonText }}\n            </el-button>\n          </slot>\n        </div>\n      </div>\n    </template>\n    <template v-if=\"$slots.reference\">\n      <slot name=\"reference\" />\n    </template>\n  </el-tooltip>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, ref } from 'vue'\nimport ElButton from '@element-plus/components/button'\nimport ElIcon from '@element-plus/components/icon'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { addUnit } from '@element-plus/utils'\nimport { popconfirmEmits, popconfirmProps } from './popconfirm'\n\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\n\ndefineOptions({\n  name: 'ElPopconfirm',\n})\n\nconst props = defineProps(popconfirmProps)\nconst emit = defineEmits(popconfirmEmits)\n\nconst { t } = useLocale()\nconst ns = useNamespace('popconfirm')\nconst tooltipRef = ref<TooltipInstance>()\n\nconst hidePopper = () => {\n  tooltipRef.value?.onClose?.()\n}\n\nconst style = computed(() => {\n  return {\n    width: addUnit(props.width),\n  }\n})\n\nconst confirm = (e: MouseEvent) => {\n  emit('confirm', e)\n  hidePopper()\n}\nconst cancel = (e: MouseEvent) => {\n  emit('cancel', e)\n  hidePopper()\n}\n\nconst finalConfirmButtonText = computed(\n  () => props.confirmButtonText || t('el.popconfirm.confirmButtonText')\n)\nconst finalCancelButtonText = computed(\n  () => props.cancelButtonText || t('el.popconfirm.cancelButtonText')\n)\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Popconfirm from './src/popconfirm.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElPopconfirm: SFCWithInstall<typeof Popconfirm> =\n  withInstall(Popconfirm)\nexport default ElPopconfirm\n\nexport * from './src/popconfirm'\n", "import { buildProps, isBoolean } from '@element-plus/utils'\nimport {\n  useTooltipContentProps,\n  useTooltipTriggerProps,\n} from '@element-plus/components/tooltip'\nimport { dropdownProps } from '@element-plus/components/dropdown'\nimport type { ExtractPropTypes, PropType } from 'vue'\nimport type Popover from './popover.vue'\n\nexport const popoverProps = buildProps({\n  /**\n   * @description how the popover is triggered\n   */\n  trigger: useTooltipTriggerProps.trigger,\n  /**\n   * @description popover placement\n   */\n  placement: dropdownProps.placement,\n  /**\n   * @description whether Popover is disabled\n   */\n  disabled: useTooltipTriggerProps.disabled,\n  /**\n   * @description whether popover is visible\n   */\n  visible: useTooltipContentProps.visible,\n  /**\n   * @description popover transition animation\n   */\n  transition: useTooltipContentProps.transition,\n  /**\n   * @description parameters for [popper.js](https://popper.js.org/docs/v2/)\n   */\n  popperOptions: dropdownProps.popperOptions,\n  /**\n   * @description [tabindex](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex) of Popover\n   */\n  tabindex: dropdownProps.tabindex,\n  /**\n   * @description popover content, can be replaced with a default `slot`\n   */\n  content: useTooltipContentProps.content,\n  /**\n   * @description custom style for popover\n   */\n  popperStyle: useTooltipContentProps.popperStyle,\n  /**\n   * @description custom class name for popover\n   */\n  popperClass: useTooltipContentProps.popperClass,\n  enterable: {\n    ...useTooltipContentProps.enterable,\n    default: true,\n  },\n  /**\n   * @description Tooltip theme, built-in theme: `dark` / `light`\n   */\n  effect: {\n    ...useTooltipContentProps.effect,\n    default: 'light',\n  },\n  /**\n   * @description whether popover dropdown is teleported to the body\n   */\n  teleported: useTooltipContentProps.teleported,\n  /**\n   * @description popover title\n   */\n  title: String,\n  /**\n   * @description popover width\n   */\n  width: {\n    type: [String, Number],\n    default: 150,\n  },\n  /**\n   * @description popover offset\n   */\n  offset: {\n    type: Number,\n    default: undefined,\n  },\n  /**\n   * @description delay of appearance, in millisecond\n   */\n  showAfter: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description delay of disappear, in millisecond\n   */\n  hideAfter: {\n    type: Number,\n    default: 200,\n  },\n  /**\n   * @description timeout in milliseconds to hide tooltip\n   */\n  autoClose: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description whether a tooltip arrow is displayed or not. For more info, please refer to [ElPopper](https://github.com/element-plus/element-plus/tree/dev/packages/components/popper)\n   */\n  showArrow: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description when popover inactive and `persistent` is `false` , popover will be destroyed\n   */\n  persistent: {\n    type: Boolean,\n    default: true,\n  },\n  'onUpdate:visible': {\n    type: Function as PropType<(visible: boolean) => void>,\n  },\n} as const)\nexport type PopoverProps = ExtractPropTypes<typeof popoverProps>\n\nexport const popoverEmits = {\n  'update:visible': (value: boolean) => isBoolean(value),\n  'before-enter': () => true,\n  'before-leave': () => true,\n  'after-enter': () => true,\n  'after-leave': () => true,\n}\nexport type PopoverEmits = typeof popoverEmits\n\nexport type PopoverInstance = InstanceType<typeof Popover>\n", "<template>\n  <el-tooltip\n    ref=\"tooltipRef\"\n    v-bind=\"$attrs\"\n    :trigger=\"trigger\"\n    :placement=\"placement\"\n    :disabled=\"disabled\"\n    :visible=\"visible\"\n    :transition=\"transition\"\n    :popper-options=\"popperOptions\"\n    :tabindex=\"tabindex\"\n    :content=\"content\"\n    :offset=\"offset\"\n    :show-after=\"showAfter\"\n    :hide-after=\"hideAfter\"\n    :auto-close=\"autoClose\"\n    :show-arrow=\"showArrow\"\n    :aria-label=\"title\"\n    :effect=\"effect\"\n    :enterable=\"enterable\"\n    :popper-class=\"kls\"\n    :popper-style=\"style\"\n    :teleported=\"teleported\"\n    :persistent=\"persistent\"\n    :gpu-acceleration=\"gpuAcceleration\"\n    @update:visible=\"onUpdateVisible\"\n    @before-show=\"beforeEnter\"\n    @before-hide=\"beforeLeave\"\n    @show=\"afterEnter\"\n    @hide=\"afterLeave\"\n  >\n    <template v-if=\"$slots.reference\">\n      <slot name=\"reference\" />\n    </template>\n\n    <template #content>\n      <div v-if=\"title\" :class=\"ns.e('title')\" role=\"title\">\n        {{ title }}\n      </div>\n      <slot>\n        {{ content }}\n      </slot>\n    </template>\n  </el-tooltip>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, ref, unref } from 'vue'\nimport { ElTooltip } from '@element-plus/components/tooltip'\nimport { addUnit } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { popoverEmits, popoverProps } from './popover'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\n\ndefineOptions({\n  name: 'ElPopover',\n})\n\nconst props = defineProps(popoverProps)\nconst emit = defineEmits(popoverEmits)\n\nconst updateEventKeyRaw = `onUpdate:visible` as const\n\nconst onUpdateVisible = computed(() => {\n  return props[updateEventKeyRaw]\n})\n\nconst ns = useNamespace('popover')\nconst tooltipRef = ref<TooltipInstance>()\nconst popperRef = computed(() => {\n  return unref(tooltipRef)?.popperRef\n})\n\nconst style = computed(() => {\n  return [\n    {\n      width: addUnit(props.width),\n    },\n    props.popperStyle!,\n  ]\n})\n\nconst kls = computed(() => {\n  return [ns.b(), props.popperClass!, { [ns.m('plain')]: !!props.content }]\n})\n\nconst gpuAcceleration = computed(() => {\n  return props.transition === `${ns.namespace.value}-fade-in-linear`\n})\n\nconst hide = () => {\n  tooltipRef.value?.hide()\n}\n\nconst beforeEnter = () => {\n  emit('before-enter')\n}\nconst beforeLeave = () => {\n  emit('before-leave')\n}\n\nconst afterEnter = () => {\n  emit('after-enter')\n}\n\nconst afterLeave = () => {\n  emit('update:visible', false)\n  emit('after-leave')\n}\n\ndefineExpose({\n  /** @description popper ref */\n  popperRef,\n  /** @description hide popover */\n  hide,\n})\n</script>\n", "import type { DirectiveBinding, ObjectDirective } from 'vue'\nimport type { PopoverInstance } from './popover'\n\nconst attachEvents = (el: HTMLElement, binding: DirectiveBinding) => {\n  const popperComponent: PopoverInstance = binding.arg || binding.value\n  const popover = popperComponent?.popperRef\n  if (popover) {\n    popover.triggerRef = el\n  }\n}\n\nexport default {\n  mounted(el, binding) {\n    attachEvents(el, binding)\n  },\n  updated(el, binding) {\n    attachEvents(el, binding)\n  },\n} as ObjectDirective\n\nexport const VPopover = 'popover'\n", "import { withInstall, withInstallDirective } from '@element-plus/utils'\n\nimport Popover from './src/popover.vue'\nimport PopoverDirective, { VPopover } from './src/directive'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElPopoverDirective: SFCWithInstall<typeof PopoverDirective> =\n  withInstallDirective(PopoverDirective, VPopover)\n\nexport const ElPopover: SFCWithInstall<typeof Popover> & {\n  directive: typeof ElPopoverDirective\n} = withInstall(Popover, {\n  directive: ElPopoverDirective,\n})\nexport default ElPopover\n\nexport * from './src/popover'\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport type { ExtractPropTypes, SVGAttributes } from 'vue'\nimport type Progress from './progress.vue'\n\nexport type ProgressColor = { color: string; percentage: number }\nexport type ProgressFn = (percentage: number) => string\n\nexport const progressProps = buildProps({\n  /**\n   * @description type of progress bar\n   */\n  type: {\n    type: String,\n    default: 'line',\n    values: ['line', 'circle', 'dashboard'],\n  },\n  /**\n   * @description percentage, required\n   */\n  percentage: {\n    type: Number,\n    default: 0,\n    validator: (val: number): boolean => val >= 0 && val <= 100,\n  },\n  /**\n   * @description the current status of progress bar\n   */\n  status: {\n    type: String,\n    default: '',\n    values: ['', 'success', 'exception', 'warning'],\n  },\n  /**\n   * @description set indeterminate progress\n   */\n  indeterminate: Boolean,\n  /**\n   * @description control the animation duration of indeterminate progress or striped flow progress\n   */\n  duration: {\n    type: Number,\n    default: 3,\n  },\n  /**\n   * @description the width of progress bar\n   */\n  strokeWidth: {\n    type: Number,\n    default: 6,\n  },\n  /**\n   * @description butt/circle/dashboard type shape at the end path\n   */\n  strokeLinecap: {\n    type: definePropType<NonNullable<SVGAttributes['stroke-linecap']>>(String),\n    default: 'round',\n  },\n  /**\n   * @description whether to place the percentage inside progress bar, only works when `type` is 'line'\n   */\n  textInside: Boolean,\n  /**\n   * @description the canvas width of circle progress bar\n   */\n  width: {\n    type: Number,\n    default: 126,\n  },\n  /**\n   * @description whether to show percentage\n   */\n  showText: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description background color of progress bar. Overrides `status` prop\n   */\n  color: {\n    type: definePropType<string | ProgressColor[] | ProgressFn>([\n      String,\n      Array,\n      Function,\n    ]),\n    default: '',\n  },\n  /**\n   * @description stripe over the progress bar's color\n   */\n  striped: Boolean,\n  /**\n   * @description get the stripes to flow\n   */\n  stripedFlow: Boolean,\n  /**\n   * @description custom text format\n   */\n  format: {\n    type: definePropType<ProgressFn>(Function),\n    default: (percentage: number): string => `${percentage}%`,\n  },\n} as const)\n\nexport type ProgressProps = ExtractPropTypes<typeof progressProps>\nexport type ProgressInstance = InstanceType<typeof Progress>\n", "<template>\n  <div\n    :class=\"[\n      ns.b(),\n      ns.m(type),\n      ns.is(status),\n      {\n        [ns.m('without-text')]: !showText,\n        [ns.m('text-inside')]: textInside,\n      },\n    ]\"\n    role=\"progressbar\"\n    :aria-valuenow=\"percentage\"\n    aria-valuemin=\"0\"\n    aria-valuemax=\"100\"\n  >\n    <div v-if=\"type === 'line'\" :class=\"ns.b('bar')\">\n      <div\n        :class=\"ns.be('bar', 'outer')\"\n        :style=\"{ height: `${strokeWidth}px` }\"\n      >\n        <div\n          :class=\"[\n            ns.be('bar', 'inner'),\n            { [ns.bem('bar', 'inner', 'indeterminate')]: indeterminate },\n            { [ns.bem('bar', 'inner', 'striped')]: striped },\n            { [ns.bem('bar', 'inner', 'striped-flow')]: stripedFlow },\n          ]\"\n          :style=\"barStyle\"\n        >\n          <div\n            v-if=\"(showText || $slots.default) && textInside\"\n            :class=\"ns.be('bar', 'innerText')\"\n          >\n            <slot :percentage=\"percentage\">\n              <span>{{ content }}</span>\n            </slot>\n          </div>\n        </div>\n      </div>\n    </div>\n    <div\n      v-else\n      :class=\"ns.b('circle')\"\n      :style=\"{ height: `${width}px`, width: `${width}px` }\"\n    >\n      <svg viewBox=\"0 0 100 100\">\n        <path\n          :class=\"ns.be('circle', 'track')\"\n          :d=\"trackPath\"\n          :stroke=\"`var(${ns.cssVarName('fill-color-light')}, #e5e9f2)`\"\n          :stroke-linecap=\"strokeLinecap\"\n          :stroke-width=\"relativeStrokeWidth\"\n          fill=\"none\"\n          :style=\"trailPathStyle\"\n        />\n        <path\n          :class=\"ns.be('circle', 'path')\"\n          :d=\"trackPath\"\n          :stroke=\"stroke\"\n          fill=\"none\"\n          :opacity=\"percentage ? 1 : 0\"\n          :stroke-linecap=\"strokeLinecap\"\n          :stroke-width=\"relativeStrokeWidth\"\n          :style=\"circlePathStyle\"\n        />\n      </svg>\n    </div>\n    <div\n      v-if=\"(showText || $slots.default) && !textInside\"\n      :class=\"ns.e('text')\"\n      :style=\"{ fontSize: `${progressTextSize}px` }\"\n    >\n      <slot :percentage=\"percentage\">\n        <span v-if=\"!status\">{{ content }}</span>\n        <el-icon v-else>\n          <component :is=\"statusIcon\" />\n        </el-icon>\n      </slot>\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport {\n  Check,\n  CircleCheck,\n  CircleClose,\n  Close,\n  WarningFilled,\n} from '@element-plus/icons-vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { isFunction, isString } from '@element-plus/utils'\nimport { progressProps } from './progress'\nimport type { CSSProperties } from 'vue'\nimport type { ProgressColor } from './progress'\n\ndefineOptions({\n  name: 'ElProgress',\n})\n\nconst STATUS_COLOR_MAP: Record<string, string> = {\n  success: '#13ce66',\n  exception: '#ff4949',\n  warning: '#e6a23c',\n  default: '#20a0ff',\n}\n\nconst props = defineProps(progressProps)\n\nconst ns = useNamespace('progress')\n\nconst barStyle = computed<CSSProperties>(() => {\n  const barStyle: CSSProperties = {\n    width: `${props.percentage}%`,\n    animationDuration: `${props.duration}s`,\n  }\n  const color = getCurrentColor(props.percentage)\n  if (color.includes('gradient')) {\n    barStyle.background = color\n  } else {\n    barStyle.backgroundColor = color\n  }\n  return barStyle\n})\n\nconst relativeStrokeWidth = computed(() =>\n  ((props.strokeWidth / props.width) * 100).toFixed(1)\n)\n\nconst radius = computed(() => {\n  if (['circle', 'dashboard'].includes(props.type)) {\n    return Number.parseInt(\n      `${50 - Number.parseFloat(relativeStrokeWidth.value) / 2}`,\n      10\n    )\n  }\n  return 0\n})\n\nconst trackPath = computed(() => {\n  const r = radius.value\n  const isDashboard = props.type === 'dashboard'\n  return `\n          M 50 50\n          m 0 ${isDashboard ? '' : '-'}${r}\n          a ${r} ${r} 0 1 1 0 ${isDashboard ? '-' : ''}${r * 2}\n          a ${r} ${r} 0 1 1 0 ${isDashboard ? '' : '-'}${r * 2}\n          `\n})\n\nconst perimeter = computed(() => 2 * Math.PI * radius.value)\n\nconst rate = computed(() => (props.type === 'dashboard' ? 0.75 : 1))\n\nconst strokeDashoffset = computed(() => {\n  const offset = (-1 * perimeter.value * (1 - rate.value)) / 2\n  return `${offset}px`\n})\n\nconst trailPathStyle = computed<CSSProperties>(() => ({\n  strokeDasharray: `${perimeter.value * rate.value}px, ${perimeter.value}px`,\n  strokeDashoffset: strokeDashoffset.value,\n}))\n\nconst circlePathStyle = computed<CSSProperties>(() => ({\n  strokeDasharray: `${\n    perimeter.value * rate.value * (props.percentage / 100)\n  }px, ${perimeter.value}px`,\n  strokeDashoffset: strokeDashoffset.value,\n  transition:\n    'stroke-dasharray 0.6s ease 0s, stroke 0.6s ease, opacity ease 0.6s',\n}))\n\nconst stroke = computed(() => {\n  let ret: string\n  if (props.color) {\n    ret = getCurrentColor(props.percentage)\n  } else {\n    ret = STATUS_COLOR_MAP[props.status] || STATUS_COLOR_MAP.default\n  }\n  return ret\n})\n\nconst statusIcon = computed(() => {\n  if (props.status === 'warning') {\n    return WarningFilled\n  }\n  if (props.type === 'line') {\n    return props.status === 'success' ? CircleCheck : CircleClose\n  } else {\n    return props.status === 'success' ? Check : Close\n  }\n})\n\nconst progressTextSize = computed(() => {\n  return props.type === 'line'\n    ? 12 + props.strokeWidth * 0.4\n    : props.width * 0.111111 + 2\n})\n\nconst content = computed(() => props.format(props.percentage))\n\nfunction getColors(color: ProgressColor[]) {\n  const span = 100 / color.length\n  const seriesColors = color.map((seriesColor, index) => {\n    if (isString(seriesColor)) {\n      return {\n        color: seriesColor,\n        percentage: (index + 1) * span,\n      }\n    }\n    return seriesColor\n  })\n  return seriesColors.sort((a, b) => a.percentage - b.percentage)\n}\n\nconst getCurrentColor = (percentage: number) => {\n  const { color } = props\n  if (isFunction(color)) {\n    return color(percentage)\n  } else if (isString(color)) {\n    return color\n  } else {\n    const colors = getColors(color)\n    for (const color of colors) {\n      if (color.percentage > percentage) return color.color\n    }\n    return colors[colors.length - 1]?.color\n  }\n}\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Progress from './src/progress.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElProgress: SFCWithInstall<typeof Progress> = withInstall(Progress)\nexport default ElProgress\n\nexport * from './src/progress'\n", "import { Star, StarFilled } from '@element-plus/icons-vue'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport {\n  buildProps,\n  definePropType,\n  iconPropType,\n  isNumber,\n  mutable,\n} from '@element-plus/utils'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport type { Component, ExtractPropTypes } from 'vue'\nimport type Rate from './rate.vue'\n\nexport const rateProps = buildProps({\n  /**\n   * @description binding value\n   */\n  modelValue: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description native `id` attribute\n   */\n  id: {\n    type: String,\n    default: undefined,\n  },\n  /**\n   * @description threshold value between low and medium level. The value itself will be included in low level\n   */\n  lowThreshold: {\n    type: Number,\n    default: 2,\n  },\n  /**\n   * @description threshold value between medium and high level. The value itself will be included in high level\n   */\n  highThreshold: {\n    type: Number,\n    default: 4,\n  },\n  /**\n   * @description max rating score\n   */\n  max: {\n    type: Number,\n    default: 5,\n  },\n  /**\n   * @description colors for icons. If array, it should have 3 elements, each of which corresponds with a score level, else if object, the key should be threshold value between two levels, and the value should be corresponding color\n   */\n  colors: {\n    type: definePropType<string[] | Record<number, string>>([Array, Object]),\n    default: () => mutable(['', '', ''] as const),\n  },\n  /**\n   * @description color of unselected icons\n   */\n  voidColor: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description color of unselected read-only icons\n   */\n  disabledVoidColor: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description icon components. If array, it should have 3 elements, each of which corresponds with a score level, else if object, the key should be threshold value between two levels, and the value should be corresponding icon component\n   */\n  icons: {\n    type: definePropType<\n      Array<string | Component> | Record<number, string | Component>\n    >([Array, Object]),\n    default: () =>\n      [StarFilled, StarFilled, StarFilled] as [Component, Component, Component],\n  },\n  /**\n   * @description component of unselected icons\n   */\n  voidIcon: {\n    type: iconPropType,\n    default: () => Star as Component,\n  },\n  /**\n   * @description component of unselected read-only icons\n   */\n  disabledVoidIcon: {\n    type: iconPropType,\n    default: () => StarFilled as Component,\n  },\n  /**\n   * @description whether Rate is read-only\n   */\n  disabled: Boolean,\n  /**\n   * @description whether picking half start is allowed\n   */\n  allowHalf: Boolean,\n  /**\n   * @description whether to display texts\n   */\n  showText: Boolean,\n  /**\n   * @description whether to display current score. show-score and show-text cannot be true at the same time\n   */\n  showScore: Boolean,\n  /**\n   * @description color of texts\n   */\n  textColor: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description text array\n   */\n  texts: {\n    type: definePropType<string[]>(Array),\n    default: () =>\n      mutable([\n        'Extremely bad',\n        'Disappointed',\n        'Fair',\n        'Satisfied',\n        'Surprise',\n      ] as const),\n  },\n  /**\n   * @description score template\n   */\n  scoreTemplate: {\n    type: String,\n    default: '{value}',\n  },\n  /**\n   * @description size of Rate\n   */\n  size: useSizeProp,\n  /**\n   * @description whether value can be reset to `0`\n   */\n  clearable: Boolean,\n  ...useAriaProps(['ariaLabel']),\n} as const)\n\nexport type RateProps = ExtractPropTypes<typeof rateProps>\n\nexport const rateEmits = {\n  [CHANGE_EVENT]: (value: number) => isNumber(value),\n  [UPDATE_MODEL_EVENT]: (value: number) => isNumber(value),\n}\nexport type RateEmits = typeof rateEmits\n\nexport type RateInstance = InstanceType<typeof Rate>\n", "<template>\n  <div\n    :id=\"inputId\"\n    :class=\"[rateClasses, ns.is('disabled', rateDisabled)]\"\n    role=\"slider\"\n    :aria-label=\"!isLabeledByFormItem ? ariaLabel || 'rating' : undefined\"\n    :aria-labelledby=\"\n      isLabeledByFormItem ? formItemContext?.labelId : undefined\n    \"\n    :aria-valuenow=\"currentValue\"\n    :aria-valuetext=\"text || undefined\"\n    aria-valuemin=\"0\"\n    :aria-valuemax=\"max\"\n    tabindex=\"0\"\n    :style=\"rateStyles\"\n    @keydown=\"handleKey\"\n  >\n    <span\n      v-for=\"(item, key) in max\"\n      :key=\"key\"\n      :class=\"ns.e('item')\"\n      @mousemove=\"setCurrentValue(item, $event)\"\n      @mouseleave=\"resetCurrentValue\"\n      @click=\"selectValue(item)\"\n    >\n      <el-icon\n        :class=\"[\n          ns.e('icon'),\n          { hover: hoverIndex === item },\n          ns.is('active', item <= currentValue),\n        ]\"\n      >\n        <template v-if=\"!showDecimalIcon(item)\">\n          <component :is=\"activeComponent\" v-show=\"item <= currentValue\" />\n          <component :is=\"voidComponent\" v-show=\"!(item <= currentValue)\" />\n        </template>\n        <template v-if=\"showDecimalIcon(item)\">\n          <component :is=\"voidComponent\" :class=\"[ns.em('decimal', 'box')]\" />\n          <el-icon\n            :style=\"decimalStyle\"\n            :class=\"[ns.e('icon'), ns.e('decimal')]\"\n          >\n            <component :is=\"decimalIconComponent\" />\n          </el-icon>\n        </template>\n      </el-icon>\n    </span>\n    <span\n      v-if=\"showText || showScore\"\n      :class=\"ns.e('text')\"\n      :style=\"{ color: textColor }\"\n    >\n      {{ text }}\n    </span>\n  </div>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, inject, markRaw, ref, watch } from 'vue'\nimport { EVENT_CODE, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { hasClass, isArray, isObject, isString } from '@element-plus/utils'\nimport {\n  formContextKey,\n  formItemContextKey,\n  useFormItemInputId,\n  useFormSize,\n} from '@element-plus/components/form'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { useNamespace } from '@element-plus/hooks'\nimport { rateEmits, rateProps } from './rate'\nimport type { CSSProperties, Component } from 'vue'\n\nfunction getValueFromMap<T>(\n  value: number,\n  map: Record<string, T | { excluded?: boolean; value: T }>\n) {\n  const isExcludedObject = (\n    val: unknown\n  ): val is { excluded?: boolean } & Record<any, unknown> => isObject(val)\n\n  const matchedKeys = Object.keys(map)\n    .map((key) => +key)\n    .filter((key) => {\n      const val = map[key]\n      const excluded = isExcludedObject(val) ? val.excluded : false\n      return excluded ? value < key : value <= key\n    })\n    .sort((a, b) => a - b)\n  const matchedValue = map[matchedKeys[0]]\n  return (isExcludedObject(matchedValue) && matchedValue.value) || matchedValue\n}\n\ndefineOptions({\n  name: 'ElRate',\n})\n\nconst props = defineProps(rateProps)\nconst emit = defineEmits(rateEmits)\n\nconst formContext = inject(formContextKey, undefined)\nconst formItemContext = inject(formItemContextKey, undefined)\nconst rateSize = useFormSize()\nconst ns = useNamespace('rate')\nconst { inputId, isLabeledByFormItem } = useFormItemInputId(props, {\n  formItemContext,\n})\n\nconst currentValue = ref(props.modelValue)\nconst hoverIndex = ref(-1)\nconst pointerAtLeftHalf = ref(true)\n\nconst rateClasses = computed(() => [ns.b(), ns.m(rateSize.value)])\nconst rateDisabled = computed(() => props.disabled || formContext?.disabled)\nconst rateStyles = computed(() => {\n  return ns.cssVarBlock({\n    'void-color': props.voidColor,\n    'disabled-void-color': props.disabledVoidColor,\n    'fill-color': activeColor.value,\n  }) as CSSProperties\n})\n\nconst text = computed(() => {\n  let result = ''\n  if (props.showScore) {\n    result = props.scoreTemplate.replace(\n      /\\{\\s*value\\s*\\}/,\n      rateDisabled.value ? `${props.modelValue}` : `${currentValue.value}`\n    )\n  } else if (props.showText) {\n    result = props.texts[Math.ceil(currentValue.value) - 1]\n  }\n  return result\n})\nconst valueDecimal = computed(\n  () => props.modelValue * 100 - Math.floor(props.modelValue) * 100\n)\nconst colorMap = computed(() =>\n  isArray(props.colors)\n    ? {\n        [props.lowThreshold]: props.colors[0],\n        [props.highThreshold]: { value: props.colors[1], excluded: true },\n        [props.max]: props.colors[2],\n      }\n    : props.colors\n)\nconst activeColor = computed(() => {\n  const color = getValueFromMap(currentValue.value, colorMap.value)\n  // {value: '', excluded: true} returned\n  return isObject(color) ? '' : color\n})\nconst decimalStyle = computed(() => {\n  let width = ''\n  if (rateDisabled.value) {\n    width = `${valueDecimal.value}%`\n  } else if (props.allowHalf) {\n    width = '50%'\n  }\n  return {\n    color: activeColor.value,\n    width,\n  }\n})\nconst componentMap = computed(() => {\n  let icons = isArray(props.icons) ? [...props.icons] : { ...props.icons }\n  icons = markRaw(icons) as\n    | Array<string | Component>\n    | Record<number, string | Component>\n  return isArray(icons)\n    ? {\n        [props.lowThreshold]: icons[0],\n        [props.highThreshold]: {\n          value: icons[1],\n          excluded: true,\n        },\n        [props.max]: icons[2],\n      }\n    : icons\n})\nconst decimalIconComponent = computed(() =>\n  getValueFromMap(props.modelValue, componentMap.value)\n)\nconst voidComponent = computed(() =>\n  rateDisabled.value\n    ? isString(props.disabledVoidIcon)\n      ? props.disabledVoidIcon\n      : (markRaw(props.disabledVoidIcon) as Component)\n    : isString(props.voidIcon)\n    ? props.voidIcon\n    : (markRaw(props.voidIcon) as Component)\n)\nconst activeComponent = computed(() =>\n  getValueFromMap(currentValue.value, componentMap.value)\n)\n\nfunction showDecimalIcon(item: number) {\n  const showWhenDisabled =\n    rateDisabled.value &&\n    valueDecimal.value > 0 &&\n    item - 1 < props.modelValue &&\n    item > props.modelValue\n  const showWhenAllowHalf =\n    props.allowHalf &&\n    pointerAtLeftHalf.value &&\n    item - 0.5 <= currentValue.value &&\n    item > currentValue.value\n  return showWhenDisabled || showWhenAllowHalf\n}\n\nfunction emitValue(value: number) {\n  // if allow clear, and selected value is same as modelValue, reset value to 0\n  if (props.clearable && value === props.modelValue) {\n    value = 0\n  }\n\n  emit(UPDATE_MODEL_EVENT, value)\n  if (props.modelValue !== value) {\n    emit('change', value)\n  }\n}\n\nfunction selectValue(value: number) {\n  if (rateDisabled.value) {\n    return\n  }\n  if (props.allowHalf && pointerAtLeftHalf.value) {\n    emitValue(currentValue.value)\n  } else {\n    emitValue(value)\n  }\n}\n\nfunction handleKey(e: KeyboardEvent) {\n  if (rateDisabled.value) {\n    return\n  }\n  let _currentValue = currentValue.value\n  const code = e.code\n  if (code === EVENT_CODE.up || code === EVENT_CODE.right) {\n    if (props.allowHalf) {\n      _currentValue += 0.5\n    } else {\n      _currentValue += 1\n    }\n    e.stopPropagation()\n    e.preventDefault()\n  } else if (code === EVENT_CODE.left || code === EVENT_CODE.down) {\n    if (props.allowHalf) {\n      _currentValue -= 0.5\n    } else {\n      _currentValue -= 1\n    }\n    e.stopPropagation()\n    e.preventDefault()\n  }\n  _currentValue = _currentValue < 0 ? 0 : _currentValue\n  _currentValue = _currentValue > props.max ? props.max : _currentValue\n  emit(UPDATE_MODEL_EVENT, _currentValue)\n  emit('change', _currentValue)\n  return _currentValue\n}\n\nfunction setCurrentValue(value: number, event?: MouseEvent) {\n  if (rateDisabled.value) {\n    return\n  }\n  if (props.allowHalf && event) {\n    // TODO: use cache via computed https://github.com/element-plus/element-plus/pull/5456#discussion_r786472092\n    let target = event.target as HTMLElement\n    if (hasClass(target, ns.e('item'))) {\n      target = target.querySelector(`.${ns.e('icon')}`)!\n    }\n    if (target.clientWidth === 0 || hasClass(target, ns.e('decimal'))) {\n      target = target.parentNode as HTMLElement\n    }\n    pointerAtLeftHalf.value = event.offsetX * 2 <= target.clientWidth\n    currentValue.value = pointerAtLeftHalf.value ? value - 0.5 : value\n  } else {\n    currentValue.value = value\n  }\n  hoverIndex.value = value\n}\n\nfunction resetCurrentValue() {\n  if (rateDisabled.value) {\n    return\n  }\n  if (props.allowHalf) {\n    pointerAtLeftHalf.value = props.modelValue !== Math.floor(props.modelValue)\n  }\n  currentValue.value = props.modelValue\n  hoverIndex.value = -1\n}\n\nwatch(\n  () => props.modelValue,\n  (val) => {\n    currentValue.value = val\n    pointerAtLeftHalf.value = props.modelValue !== Math.floor(props.modelValue)\n  }\n)\n\nif (!props.modelValue) {\n  emit(UPDATE_MODEL_EVENT, 0)\n}\n\ndefineExpose({\n  /** @description set current value */\n  setCurrentValue,\n  /** @description reset current value */\n  resetCurrentValue,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Rate from './src/rate.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElRate: SFCWithInstall<typeof Rate> = withInstall(Rate)\nexport default ElRate\n\nexport * from './src/rate'\n", "import { buildProps } from '@element-plus/utils'\nimport {\n  CircleCheckFilled,\n  CircleCloseFilled,\n  InfoFilled,\n  WarningFilled,\n} from '@element-plus/icons-vue'\nimport type { Component, ExtractPropTypes } from 'vue'\nimport type Result from './result.vue'\n\nexport const IconMap = {\n  success: 'icon-success',\n  warning: 'icon-warning',\n  error: 'icon-error',\n  info: 'icon-info',\n} as const\n\nexport const IconComponentMap: Record<\n  typeof IconMap[keyof typeof IconMap],\n  Component\n> = {\n  [IconMap.success]: CircleCheckFilled,\n  [IconMap.warning]: WarningFilled,\n  [IconMap.error]: CircleCloseFilled,\n  [IconMap.info]: InfoFilled,\n}\n\nexport const resultProps = buildProps({\n  /**\n   * @description title of result\n   */\n  title: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description sub title of result\n   */\n  subTitle: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description icon type of result\n   */\n  icon: {\n    type: String,\n    values: ['success', 'warning', 'info', 'error'],\n    default: 'info',\n  },\n} as const)\n\nexport type ResultProps = ExtractPropTypes<typeof resultProps>\n\nexport type ResultInstance = InstanceType<typeof Result>\n", "<template>\n  <div :class=\"ns.b()\">\n    <div :class=\"ns.e('icon')\">\n      <slot name=\"icon\">\n        <component\n          :is=\"resultIcon.component\"\n          v-if=\"resultIcon.component\"\n          :class=\"resultIcon.class\"\n        />\n      </slot>\n    </div>\n    <div v-if=\"title || $slots.title\" :class=\"ns.e('title')\">\n      <slot name=\"title\">\n        <p>{{ title }}</p>\n      </slot>\n    </div>\n    <div v-if=\"subTitle || $slots['sub-title']\" :class=\"ns.e('subtitle')\">\n      <slot name=\"sub-title\">\n        <p>{{ subTitle }}</p>\n      </slot>\n    </div>\n    <div v-if=\"$slots.extra\" :class=\"ns.e('extra')\">\n      <slot name=\"extra\" />\n    </div>\n  </div>\n</template>\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { IconComponentMap, IconMap, resultProps } from './result'\n\ndefineOptions({\n  name: 'ElResult',\n})\n\nconst props = defineProps(resultProps)\n\nconst ns = useNamespace('result')\n\nconst resultIcon = computed(() => {\n  const icon = props.icon\n  const iconClass = icon && IconMap[icon] ? IconMap[icon] : 'icon-info'\n  const iconComponent =\n    IconComponentMap[iconClass] || IconComponentMap['icon-info']\n\n  return {\n    class: iconClass,\n    component: iconComponent,\n  }\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Result from './src/result.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElResult: SFCWithInstall<typeof Result> = withInstall(Result)\n\nexport default ElResult\n\nexport * from './src/result'\n", "var safeIsNaN = Number.isNaN ||\n    function ponyfill(value) {\n        return typeof value === 'number' && value !== value;\n    };\nfunction isEqual(first, second) {\n    if (first === second) {\n        return true;\n    }\n    if (safeIsNaN(first) && safeIsNaN(second)) {\n        return true;\n    }\n    return false;\n}\nfunction areInputsEqual(newInputs, lastInputs) {\n    if (newInputs.length !== lastInputs.length) {\n        return false;\n    }\n    for (var i = 0; i < newInputs.length; i++) {\n        if (!isEqual(newInputs[i], lastInputs[i])) {\n            return false;\n        }\n    }\n    return true;\n}\n\nfunction memoizeOne(resultFn, isEqual) {\n    if (isEqual === void 0) { isEqual = areInputsEqual; }\n    var cache = null;\n    function memoized() {\n        var newArgs = [];\n        for (var _i = 0; _i < arguments.length; _i++) {\n            newArgs[_i] = arguments[_i];\n        }\n        if (cache && cache.lastThis === this && isEqual(newArgs, cache.lastArgs)) {\n            return cache.lastResult;\n        }\n        var lastResult = resultFn.apply(this, newArgs);\n        cache = {\n            lastResult: lastResult,\n            lastArgs: newArgs,\n            lastThis: this,\n        };\n        return lastResult;\n    }\n    memoized.clear = function clear() {\n        cache = null;\n    };\n    return memoized;\n}\n\nexport { memoizeOne as default };\n", "import { computed, getCurrentInstance } from 'vue'\nimport { memoize } from 'lodash-unified'\nimport memoOne from 'memoize-one'\n\nimport type { VirtualizedProps } from '../props'\n\nexport const useCache = <T>() => {\n  const vm = getCurrentInstance()!\n\n  const props = vm.proxy!.$props as VirtualizedProps\n\n  return computed(() => {\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    const _getItemStyleCache = (_: any, __: any, ___: any) =>\n      ({} as Record<string, T>)\n    return props.perfMode\n      ? memoize(_getItemStyleCache)\n      : memoOne(_getItemStyleCache)\n  })\n}\n", "export const DEFAULT_DYNAMIC_LIST_ITEM_SIZE = 50\n\nexport const ITEM_RENDER_EVT = 'itemRendered'\nexport const SCROLL_EVT = 'scroll'\n\nexport const FORWARD = 'forward'\nexport const BACKWARD = 'backward'\n\nexport const AUTO_ALIGNMENT = 'auto'\nexport const SMART_ALIGNMENT = 'smart'\nexport const START_ALIGNMENT = 'start'\nexport const CENTERED_ALIGNMENT = 'center'\nexport const END_ALIGNMENT = 'end'\n\nexport const HORIZONTAL = 'horizontal'\nexport const VERTICAL = 'vertical'\n\nexport const LTR = 'ltr'\nexport const RTL = 'rtl'\n\nexport const RTL_OFFSET_NAG = 'negative'\nexport const RTL_OFFSET_POS_ASC = 'positive-ascending'\nexport const RTL_OFFSET_POS_DESC = 'positive-descending'\n\nexport const PageKey = {\n  [HORIZONTAL]: 'pageX',\n  [VERTICAL]: 'pageY',\n}\n\nexport const ScrollbarSizeKey = {\n  [HORIZONTAL]: 'height',\n  [VERTICAL]: 'width',\n}\n\nexport const ScrollbarDirKey = {\n  [HORIZONTAL]: 'left',\n  [VERTICAL]: 'top',\n}\n\nexport const SCROLLBAR_MIN_SIZE = 20\n", "import { cAF, isFirefox, rAF } from '@element-plus/utils'\nimport { HORIZONTAL, VERTICAL } from '../defaults'\n\nimport type { ComputedRef } from 'vue'\nimport type { LayoutDirection } from '../types'\n\nconst LayoutKeys = {\n  [HORIZONTAL]: 'deltaX',\n  [VERTICAL]: 'deltaY',\n} as const\n\ninterface ListWheelState {\n  atStartEdge: ComputedRef<boolean> // exclusive to reachEnd\n  atEndEdge: ComputedRef<boolean>\n  layout: ComputedRef<LayoutDirection>\n}\n\ntype ListWheelHandler = (offset: number) => void\n\nconst useWheel = (\n  { atEndEdge, atStartEdge, layout }: ListWheelState,\n  onWheelDelta: ListWheelHandler\n) => {\n  let frameHandle: number\n  let offset = 0\n\n  // let scrollLock = false\n  // let lockHandle = null\n\n  // const lockScroll = () => {\n  //   clearTimeout(lockHandle)\n  //   scrollLock = true\n  //   lockHandle = setTimeout(() => scrollLock = false, 50)\n  // }\n\n  const hasReachedEdge = (offset: number) => {\n    const edgeReached =\n      (offset < 0 && atStartEdge.value) || (offset > 0 && atEndEdge.value)\n\n    return edgeReached\n  }\n\n  const onWheel = (e: WheelEvent) => {\n    cAF(frameHandle)\n\n    const newOffset = e[LayoutKeys[layout.value]]\n\n    if (hasReachedEdge(offset) && hasReachedEdge(offset + newOffset)) return\n\n    offset += newOffset\n\n    if (!isFirefox()) {\n      e.preventDefault()\n    }\n\n    frameHandle = rAF(() => {\n      onWheelDelta(offset)\n      offset = 0\n    })\n  }\n\n  return {\n    hasReachedEdge,\n    onWheel,\n  }\n}\n\nexport default useWheel\n", "import {\n  buildProp,\n  buildProps,\n  definePropType,\n  mutable,\n} from '@element-plus/utils'\nimport { VERTICAL } from './defaults'\n\nimport type { ExtractPropTypes, StyleValue } from 'vue'\nimport type { GridItemKeyGetter, ItemSize } from './types'\n\nconst itemSize = buildProp({\n  type: definePropType<number | ItemSize>([Number, Function]),\n  required: true,\n} as const)\n\nconst estimatedItemSize = buildProp({\n  type: Number,\n} as const)\n\nconst cache = buildProp({\n  type: Number,\n  default: 2,\n} as const)\n\nconst direction = buildProp({\n  type: String,\n  values: ['ltr', 'rtl'],\n  default: 'ltr',\n} as const)\n\nconst initScrollOffset = buildProp({\n  type: Number,\n  default: 0,\n} as const)\n\nconst total = buildProp({\n  type: Number,\n  required: true,\n} as const)\n\nconst layout = buildProp({\n  type: String,\n  values: ['horizontal', 'vertical'],\n  default: VERTICAL,\n} as const)\n\nexport const virtualizedProps = buildProps({\n  className: {\n    type: String,\n    default: '',\n  },\n\n  containerElement: {\n    type: definePropType<string | Element>([String, Object]),\n    default: 'div',\n  },\n\n  data: {\n    type: definePropType<any[]>(Array),\n    default: () => mutable([] as const),\n  },\n\n  /**\n   * @description controls the horizontal direction.\n   */\n  direction,\n\n  height: {\n    type: [String, Number],\n    required: true,\n  },\n\n  innerElement: {\n    type: [String, Object],\n    default: 'div',\n  },\n\n  style: {\n    type: definePropType<StyleValue>([Object, String, Array]),\n  },\n\n  useIsScrolling: {\n    type: Boolean,\n    default: false,\n  },\n\n  width: {\n    type: [Number, String],\n    required: false,\n  },\n\n  perfMode: {\n    type: Boolean,\n    default: true,\n  },\n  scrollbarAlwaysOn: {\n    type: Boolean,\n    default: false,\n  },\n} as const)\n\nexport const virtualizedListProps = buildProps({\n  /**\n   * @description describes how many items should be pre rendered to the head\n   * and the tail of the window\n   */\n  cache,\n\n  estimatedItemSize,\n\n  /**\n   * @description controls the list's orientation\n   */\n  layout,\n\n  initScrollOffset,\n\n  /**\n   * @description describes the total number of the list.\n   */\n  total,\n\n  itemSize,\n  ...virtualizedProps,\n} as const)\n\nconst scrollbarSize = {\n  type: Number,\n  default: 6,\n} as const\n\nconst startGap = { type: Number, default: 0 } as const\nconst endGap = { type: Number, default: 2 } as const\n\nexport const virtualizedGridProps = buildProps({\n  columnCache: cache,\n  columnWidth: itemSize,\n  estimatedColumnWidth: estimatedItemSize,\n  estimatedRowHeight: estimatedItemSize,\n  initScrollLeft: initScrollOffset,\n  initScrollTop: initScrollOffset,\n  itemKey: {\n    type: definePropType<GridItemKeyGetter>(Function),\n    default: ({\n      columnIndex,\n      rowIndex,\n    }: {\n      columnIndex: number\n      rowIndex: number\n    }) => `${rowIndex}:${columnIndex}`,\n  },\n  rowCache: cache,\n  rowHeight: itemSize,\n  totalColumn: total,\n  totalRow: total,\n  hScrollbarSize: scrollbarSize,\n  vScrollbarSize: scrollbarSize,\n  scrollbarStartGap: startGap,\n  scrollbarEndGap: endGap,\n  role: String,\n  ...virtualizedProps,\n} as const)\n\nexport const virtualizedScrollbarProps = buildProps({\n  alwaysOn: Boolean,\n  class: String,\n  layout,\n  total,\n  ratio: {\n    type: Number,\n    required: true,\n  },\n  clientSize: {\n    type: Number,\n    required: true,\n  },\n  scrollFrom: {\n    type: Number,\n    required: true,\n  },\n  scrollbarSize,\n  startGap,\n  endGap,\n\n  visible: Boolean,\n} as const)\n\nexport type VirtualizedProps = ExtractPropTypes<typeof virtualizedProps>\nexport type VirtualizedListProps = ExtractPropTypes<typeof virtualizedListProps>\nexport type VirtualizedGridProps = ExtractPropTypes<typeof virtualizedGridProps>\n\nexport type VirtualizedScrollbarProps = ExtractPropTypes<\n  typeof virtualizedScrollbarProps\n>\n", "// @ts-nocheck\nimport {\n  BACKWARD,\n  FORWARD,\n  HORIZONTAL,\n  LTR,\n  PageKey,\n  RTL,\n  RTL_OFFSET_NAG,\n  RTL_OFFSET_POS_ASC,\n  RTL_OFFSET_POS_DESC,\n} from './defaults'\n\nimport type { CSSProperties } from 'vue'\nimport type { Direction, LayoutDirection, RTLOffsetType } from './types'\n\nexport const getScrollDir = (prev: number, cur: number) =>\n  prev < cur ? FORWARD : BACKWARD\n\nexport const isHorizontal = (dir: string) =>\n  dir === LTR || dir === RTL || dir === HORIZONTAL\n\nexport const isRTL = (dir: Direction) => dir === RTL\n\nlet cachedRTLResult: RTLOffsetType | null = null\n\nexport function getRTLOffsetType(recalculate = false): RTLOffsetType {\n  if (cachedRTLResult === null || recalculate) {\n    const outerDiv = document.createElement('div')\n    const outerStyle = outerDiv.style\n    outerStyle.width = '50px'\n    outerStyle.height = '50px'\n    outerStyle.overflow = 'scroll'\n    outerStyle.direction = 'rtl'\n\n    const innerDiv = document.createElement('div')\n    const innerStyle = innerDiv.style\n    innerStyle.width = '100px'\n    innerStyle.height = '100px'\n\n    outerDiv.appendChild(innerDiv)\n\n    document.body.appendChild(outerDiv)\n\n    if (outerDiv.scrollLeft > 0) {\n      cachedRTLResult = RTL_OFFSET_POS_DESC\n    } else {\n      outerDiv.scrollLeft = 1\n      if (outerDiv.scrollLeft === 0) {\n        cachedRTLResult = RTL_OFFSET_NAG\n      } else {\n        cachedRTLResult = RTL_OFFSET_POS_ASC\n      }\n    }\n\n    document.body.removeChild(outerDiv)\n\n    return cachedRTLResult\n  }\n\n  return cachedRTLResult\n}\n\nexport const getRelativePos = (\n  e: TouchEvent | MouseEvent,\n  layout: LayoutDirection\n) => {\n  return 'touches' in e ? e.touches[0][PageKey[layout]] : e[PageKey[layout]]\n}\n\ntype RenderThumbStyleParams = {\n  bar: {\n    size: 'height' | 'width'\n    axis: 'X' | 'Y'\n  }\n  size: string\n  move: number\n}\n\nexport function renderThumbStyle(\n  { move, size, bar }: RenderThumbStyleParams,\n  layout: string\n) {\n  const style: CSSProperties = {}\n  const translate = `translate${bar.axis}(${move}px)`\n\n  style[bar.size] = size\n  style.transform = translate\n  style.msTransform = translate\n  // polyfill\n  ;(style as any).webkitTransform = translate\n\n  if (layout === 'horizontal') {\n    style.height = '100%'\n  } else {\n    style.width = '100%'\n  }\n\n  return style\n}\n", "// @ts-nocheck\nimport {\n  computed,\n  defineComponent,\n  h,\n  onBeforeUnmount,\n  reactive,\n  ref,\n  unref,\n  watch,\n  withModifiers,\n} from 'vue'\nimport { BAR_MAP } from '@element-plus/components/scrollbar'\nimport { cAF, rAF } from '@element-plus/utils'\n\nimport { useNamespace } from '@element-plus/hooks'\nimport { HORIZONTAL, SCROLLBAR_MIN_SIZE, ScrollbarDirKey } from '../defaults'\nimport { virtualizedScrollbarProps } from '../props'\nimport { renderThumbStyle } from '../utils'\n\nimport type { CSSProperties } from 'vue'\n\nconst ScrollBar = defineComponent({\n  name: 'ElVirtualScrollBar',\n  props: virtualizedScrollbarProps,\n  emits: ['scroll', 'start-move', 'stop-move'],\n  setup(props, { emit }) {\n    const GAP = computed(() => props.startGap + props.endGap) // top 2 + bottom 2 | left 2 + right 2\n\n    const nsVirtualScrollbar = useNamespace('virtual-scrollbar')\n    const nsScrollbar = useNamespace('scrollbar')\n    // DOM refs\n    const trackRef = ref<HTMLElement>()\n    const thumbRef = ref<HTMLElement>()\n\n    // local variables\n    let frameHandle: null | number = null\n    let onselectstartStore: null | typeof document.onselectstart = null\n\n    // data\n    const state = reactive({\n      isDragging: false,\n      traveled: 0,\n    })\n\n    const bar = computed(() => BAR_MAP[props.layout])\n\n    const trackSize = computed(() => props.clientSize! - unref(GAP))\n\n    const trackStyle = computed<CSSProperties>(() => ({\n      position: 'absolute',\n      width: `${\n        HORIZONTAL === props.layout ? trackSize.value : props.scrollbarSize\n      }px`,\n      height: `${\n        HORIZONTAL === props.layout ? props.scrollbarSize : trackSize.value\n      }px`,\n      [ScrollbarDirKey[props.layout]]: '2px',\n      right: '2px',\n      bottom: '2px',\n      borderRadius: '4px',\n    }))\n\n    const thumbSize = computed(() => {\n      const ratio = props.ratio!\n      const clientSize = props.clientSize!\n      if (ratio >= 100) {\n        return Number.POSITIVE_INFINITY\n      }\n\n      if (ratio >= 50) {\n        return (ratio * clientSize) / 100\n      }\n\n      const SCROLLBAR_MAX_SIZE = clientSize / 3\n      return Math.floor(\n        Math.min(\n          Math.max(ratio * clientSize, SCROLLBAR_MIN_SIZE),\n          SCROLLBAR_MAX_SIZE\n        )\n      )\n    })\n\n    // const sizeRange = computed(() => props.size - thumbSize.value)\n\n    const thumbStyle = computed<CSSProperties>(() => {\n      if (!Number.isFinite(thumbSize.value)) {\n        return {\n          display: 'none',\n        }\n      }\n\n      const thumb = `${thumbSize.value}px`\n\n      const style: CSSProperties = renderThumbStyle(\n        {\n          bar: bar.value,\n          size: thumb,\n          move: state.traveled,\n        },\n        props.layout\n      )\n\n      return style\n    })\n\n    const totalSteps = computed(() =>\n      Math.floor(props.clientSize! - thumbSize.value - unref(GAP))\n    )\n\n    const attachEvents = () => {\n      window.addEventListener('mousemove', onMouseMove)\n      window.addEventListener('mouseup', onMouseUp)\n\n      const thumbEl = unref(thumbRef)\n\n      if (!thumbEl) return\n\n      onselectstartStore = document.onselectstart\n      document.onselectstart = () => false\n\n      thumbEl.addEventListener('touchmove', onMouseMove, { passive: true })\n      thumbEl.addEventListener('touchend', onMouseUp)\n    }\n\n    const detachEvents = () => {\n      window.removeEventListener('mousemove', onMouseMove)\n      window.removeEventListener('mouseup', onMouseUp)\n\n      document.onselectstart = onselectstartStore\n      onselectstartStore = null\n\n      const thumbEl = unref(thumbRef)\n      if (!thumbEl) return\n\n      thumbEl.removeEventListener('touchmove', onMouseMove)\n      thumbEl.removeEventListener('touchend', onMouseUp)\n    }\n\n    const onThumbMouseDown = (e: Event) => {\n      e.stopImmediatePropagation()\n      if (\n        (e as KeyboardEvent).ctrlKey ||\n        [1, 2].includes((e as MouseEvent).button)\n      ) {\n        return\n      }\n\n      state.isDragging = true\n      state[bar.value.axis] =\n        e.currentTarget![bar.value.offset] -\n        (e[bar.value.client] -\n          (e.currentTarget as HTMLElement).getBoundingClientRect()[\n            bar.value.direction\n          ])\n\n      emit('start-move')\n      attachEvents()\n    }\n\n    const onMouseUp = () => {\n      state.isDragging = false\n      state[bar.value.axis] = 0\n      emit('stop-move')\n      detachEvents()\n    }\n\n    const onMouseMove = (e: Event) => {\n      const { isDragging } = state\n      if (!isDragging) return\n      if (!thumbRef.value || !trackRef.value) return\n\n      const prevPage = state[bar.value.axis]\n      if (!prevPage) return\n\n      cAF(frameHandle!)\n      // using the current track's offset top/left - the current pointer's clientY/clientX\n      // to get the relative position of the pointer to the track.\n      const offset =\n        (trackRef.value.getBoundingClientRect()[bar.value.direction] -\n          e[bar.value.client]) *\n        -1\n\n      // find where the thumb was clicked on.\n      const thumbClickPosition = thumbRef.value[bar.value.offset] - prevPage\n      /**\n       *  +--------------+                                   +--------------+\n       *  |              -  <--------- thumb.offsetTop       |              |\n       *  |             |+|             <--+                 |              |\n       *  |              -                 |                 |              |\n       *  |   Content    |                 |                 |              |\n       *  |              |                 |                 |              |\n       *  |              |                 |                 |              |\n       *  |              |                 |                 |              -\n       *  |              |                 +-->              |             |+|\n       *  |              |                                   |              -\n       *  +--------------+                                   +--------------+\n       */\n\n      // using the current position - prev position to\n\n      const distance = offset - thumbClickPosition\n      // get how many steps in total.\n      // gap of 2 on top, 2 on bottom, in total 4.\n      // using totalSteps ÷ totalSize getting each step's size * distance to get the new\n      // scroll offset to scrollTo\n      frameHandle = rAF(() => {\n        state.traveled = Math.max(\n          props.startGap,\n          Math.min(\n            distance,\n            totalSteps.value // 2 is the top value\n          )\n        )\n        emit('scroll', distance, totalSteps.value)\n      })\n    }\n\n    const clickTrackHandler = (e: MouseEvent) => {\n      const offset = Math.abs(\n        (e.target as HTMLElement).getBoundingClientRect()[bar.value.direction] -\n          e[bar.value.client]\n      )\n      const thumbHalf = thumbRef.value![bar.value.offset] / 2\n      const distance = offset - thumbHalf\n\n      state.traveled = Math.max(0, Math.min(distance, totalSteps.value))\n      emit('scroll', distance, totalSteps.value)\n    }\n\n    watch(\n      () => props.scrollFrom,\n      (v) => {\n        if (state.isDragging) return\n        /**\n         *  this is simply mapping the current scrollbar offset\n         *\n         *  formula 1:\n         *    v = scrollOffset / (estimatedTotalSize - clientSize)\n         *    traveled = v * (clientSize - thumbSize - GAP) --> v * totalSteps\n         *\n         *  formula 2:\n         *    traveled = (v * clientSize) / (clientSize / totalSteps) --> (v * clientSize) * (totalSteps / clientSize) --> v * totalSteps\n         */\n        state.traveled = Math.ceil(v! * totalSteps.value)\n      }\n    )\n\n    onBeforeUnmount(() => {\n      detachEvents()\n    })\n\n    return () => {\n      return h(\n        'div',\n        {\n          role: 'presentation',\n          ref: trackRef,\n          class: [\n            nsVirtualScrollbar.b(),\n            props.class,\n            (props.alwaysOn || state.isDragging) && 'always-on',\n          ],\n          style: trackStyle.value,\n          onMousedown: withModifiers(clickTrackHandler, ['stop', 'prevent']),\n          onTouchstartPrevent: onThumbMouseDown,\n        },\n        h(\n          'div',\n          {\n            ref: thumbRef,\n            class: nsScrollbar.e('thumb'),\n            style: thumbStyle.value,\n            onMousedown: onThumbMouseDown,\n          },\n          []\n        )\n      )\n    }\n  },\n})\n\nexport default ScrollBar\n", "import {\n  Fragment,\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  h,\n  nextTick,\n  onActivated,\n  onMounted,\n  onUpdated,\n  ref,\n  resolveDynamicComponent,\n  unref,\n} from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport { hasOwn, isClient, isNumber, isString } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useCache } from '../hooks/use-cache'\nimport useWheel from '../hooks/use-wheel'\nimport Scrollbar from '../components/scrollbar'\nimport { getRTLOffsetType, getScrollDir, isHorizontal } from '../utils'\nimport { virtualizedListProps } from '../props'\nimport {\n  AUTO_ALIGNMENT,\n  BACKWARD,\n  FORWARD,\n  HORIZONTAL,\n  ITEM_RENDER_EVT,\n  RTL,\n  RTL_OFFSET_NAG,\n  RTL_OFFSET_POS_ASC,\n  RTL_OFFSET_POS_DESC,\n  SCROLL_EVT,\n} from '../defaults'\n\nimport type { CSSProperties, Slot, VNode, VNodeChild } from 'vue'\nimport type { Alignment, ListConstructorProps } from '../types'\nimport type { VirtualizedListProps } from '../props'\n\nconst createList = ({\n  name,\n  getOffset,\n  getItemSize,\n  getItemOffset,\n  getEstimatedTotalSize,\n  getStartIndexForOffset,\n  getStopIndexForStartIndex,\n  initCache,\n  clearCache,\n  validateProps,\n}: ListConstructorProps<VirtualizedListProps>) => {\n  return defineComponent({\n    name: name ?? 'ElVirtualList',\n    props: virtualizedListProps,\n    emits: [ITEM_RENDER_EVT, SCROLL_EVT],\n    setup(props, { emit, expose }) {\n      validateProps(props)\n      const instance = getCurrentInstance()!\n\n      const ns = useNamespace('vl')\n\n      const dynamicSizeCache = ref(initCache(props, instance))\n\n      const getItemStyleCache = useCache<CSSProperties>()\n      // refs\n      // here windowRef and innerRef can be type of HTMLElement\n      // or user defined component type, depends on the type passed\n      // by user\n      const windowRef = ref<HTMLElement>()\n      const innerRef = ref<HTMLElement>()\n      const scrollbarRef = ref()\n      const states = ref({\n        isScrolling: false,\n        scrollDir: 'forward',\n        scrollOffset: isNumber(props.initScrollOffset)\n          ? props.initScrollOffset\n          : 0,\n        updateRequested: false,\n        isScrollbarDragging: false,\n        scrollbarAlwaysOn: props.scrollbarAlwaysOn,\n      })\n\n      // computed\n      const itemsToRender = computed(() => {\n        const { total, cache } = props\n        const { isScrolling, scrollDir, scrollOffset } = unref(states)\n\n        if (total === 0) {\n          return [0, 0, 0, 0]\n        }\n\n        const startIndex = getStartIndexForOffset(\n          props,\n          scrollOffset,\n          unref(dynamicSizeCache)\n        )\n        const stopIndex = getStopIndexForStartIndex(\n          props,\n          startIndex,\n          scrollOffset,\n          unref(dynamicSizeCache)\n        )\n\n        const cacheBackward =\n          !isScrolling || scrollDir === BACKWARD ? Math.max(1, cache) : 1\n        const cacheForward =\n          !isScrolling || scrollDir === FORWARD ? Math.max(1, cache) : 1\n\n        return [\n          Math.max(0, startIndex - cacheBackward),\n          Math.max(0, Math.min(total! - 1, stopIndex + cacheForward)),\n          startIndex,\n          stopIndex,\n        ]\n      })\n\n      const estimatedTotalSize = computed(() =>\n        getEstimatedTotalSize(props, unref(dynamicSizeCache))\n      )\n\n      const _isHorizontal = computed(() => isHorizontal(props.layout))\n\n      const windowStyle = computed(() => [\n        {\n          position: 'relative',\n          [`overflow-${_isHorizontal.value ? 'x' : 'y'}`]: 'scroll',\n          WebkitOverflowScrolling: 'touch',\n          willChange: 'transform',\n        },\n        {\n          direction: props.direction,\n          height: isNumber(props.height) ? `${props.height}px` : props.height,\n          width: isNumber(props.width) ? `${props.width}px` : props.width,\n        },\n        props.style,\n      ])\n\n      const innerStyle = computed(() => {\n        const size = unref(estimatedTotalSize)\n        const horizontal = unref(_isHorizontal)\n        return {\n          height: horizontal ? '100%' : `${size}px`,\n          pointerEvents: unref(states).isScrolling ? 'none' : undefined,\n          width: horizontal ? `${size}px` : '100%',\n        }\n      })\n\n      const clientSize = computed(() =>\n        _isHorizontal.value ? props.width : props.height\n      )\n\n      // methods\n      const { onWheel } = useWheel(\n        {\n          atStartEdge: computed(() => states.value.scrollOffset <= 0),\n          atEndEdge: computed(\n            () => states.value.scrollOffset >= estimatedTotalSize.value\n          ),\n          layout: computed(() => props.layout),\n        },\n        (offset) => {\n          ;(\n            scrollbarRef.value as any as {\n              onMouseUp: () => void\n            }\n          ).onMouseUp?.()\n          scrollTo(\n            Math.min(\n              states.value.scrollOffset + offset,\n              estimatedTotalSize.value - (clientSize.value as number)\n            )\n          )\n        }\n      )\n\n      useEventListener(windowRef, 'wheel', onWheel, {\n        passive: false,\n      })\n\n      const emitEvents = () => {\n        const { total } = props\n\n        if (total! > 0) {\n          const [cacheStart, cacheEnd, visibleStart, visibleEnd] =\n            unref(itemsToRender)\n          emit(ITEM_RENDER_EVT, cacheStart, cacheEnd, visibleStart, visibleEnd)\n        }\n\n        const { scrollDir, scrollOffset, updateRequested } = unref(states)\n        emit(SCROLL_EVT, scrollDir, scrollOffset, updateRequested)\n      }\n\n      const scrollVertically = (e: Event) => {\n        const { clientHeight, scrollHeight, scrollTop } =\n          e.currentTarget as HTMLElement\n        const _states = unref(states)\n        if (_states.scrollOffset === scrollTop) {\n          return\n        }\n\n        const scrollOffset = Math.max(\n          0,\n          Math.min(scrollTop, scrollHeight - clientHeight)\n        )\n\n        states.value = {\n          ..._states,\n          isScrolling: true,\n          scrollDir: getScrollDir(_states.scrollOffset, scrollOffset),\n          scrollOffset,\n          updateRequested: false,\n        }\n\n        nextTick(resetIsScrolling)\n      }\n\n      const scrollHorizontally = (e: Event) => {\n        const { clientWidth, scrollLeft, scrollWidth } =\n          e.currentTarget as HTMLElement\n        const _states = unref(states)\n\n        if (_states.scrollOffset === scrollLeft) {\n          return\n        }\n\n        const { direction } = props\n\n        let scrollOffset = scrollLeft\n\n        if (direction === RTL) {\n          // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n          // This is not the case for all browsers though (e.g. Chrome reports values as positive, measured relative to the left).\n          // It's also easier for this component if we convert offsets to the same format as they would be in for ltr.\n          // So the simplest solution is to determine which browser behavior we're dealing with, and convert based on it.\n          switch (getRTLOffsetType()) {\n            case RTL_OFFSET_NAG: {\n              scrollOffset = -scrollLeft\n              break\n            }\n            case RTL_OFFSET_POS_DESC: {\n              scrollOffset = scrollWidth - clientWidth - scrollLeft\n              break\n            }\n          }\n        }\n\n        scrollOffset = Math.max(\n          0,\n          Math.min(scrollOffset, scrollWidth - clientWidth)\n        )\n\n        states.value = {\n          ..._states,\n          isScrolling: true,\n          scrollDir: getScrollDir(_states.scrollOffset, scrollOffset),\n          scrollOffset,\n          updateRequested: false,\n        }\n\n        nextTick(resetIsScrolling)\n      }\n\n      const onScroll = (e: Event) => {\n        unref(_isHorizontal) ? scrollHorizontally(e) : scrollVertically(e)\n        emitEvents()\n      }\n\n      const onScrollbarScroll = (distanceToGo: number, totalSteps: number) => {\n        const offset =\n          ((estimatedTotalSize.value - (clientSize.value as number)) /\n            totalSteps) *\n          distanceToGo\n        scrollTo(\n          Math.min(\n            estimatedTotalSize.value - (clientSize.value as number),\n            offset\n          )\n        )\n      }\n\n      const scrollTo = (offset: number) => {\n        offset = Math.max(offset, 0)\n\n        if (offset === unref(states).scrollOffset) {\n          return\n        }\n\n        states.value = {\n          ...unref(states),\n          scrollOffset: offset,\n          scrollDir: getScrollDir(unref(states).scrollOffset, offset),\n          updateRequested: true,\n        }\n\n        nextTick(resetIsScrolling)\n      }\n\n      const scrollToItem = (\n        idx: number,\n        alignment: Alignment = AUTO_ALIGNMENT\n      ) => {\n        const { scrollOffset } = unref(states)\n\n        idx = Math.max(0, Math.min(idx, props.total! - 1))\n        scrollTo(\n          getOffset(\n            props,\n            idx,\n            alignment,\n            scrollOffset,\n            unref(dynamicSizeCache)\n          )\n        )\n      }\n\n      const getItemStyle = (idx: number) => {\n        const { direction, itemSize, layout } = props\n\n        const itemStyleCache = getItemStyleCache.value(\n          clearCache && itemSize,\n          clearCache && layout,\n          clearCache && direction\n        )\n\n        let style: CSSProperties\n        if (hasOwn(itemStyleCache, String(idx))) {\n          style = itemStyleCache[idx]\n        } else {\n          const offset = getItemOffset(props, idx, unref(dynamicSizeCache))\n          const size = getItemSize(props, idx, unref(dynamicSizeCache))\n          const horizontal = unref(_isHorizontal)\n\n          const isRtl = direction === RTL\n          const offsetHorizontal = horizontal ? offset : 0\n          itemStyleCache[idx] = style = {\n            position: 'absolute',\n            left: isRtl ? undefined : `${offsetHorizontal}px`,\n            right: isRtl ? `${offsetHorizontal}px` : undefined,\n            top: !horizontal ? `${offset}px` : 0,\n            height: !horizontal ? `${size}px` : '100%',\n            width: horizontal ? `${size}px` : '100%',\n          }\n        }\n\n        return style\n      }\n\n      // TODO:\n      // perf optimization here, reset isScrolling with debounce.\n\n      const resetIsScrolling = () => {\n        // timer = null\n\n        states.value.isScrolling = false\n        nextTick(() => {\n          getItemStyleCache.value(-1, null, null)\n        })\n      }\n\n      const resetScrollTop = () => {\n        const window = windowRef.value\n        if (window) {\n          window.scrollTop = 0\n        }\n      }\n\n      // life cycles\n      onMounted(() => {\n        if (!isClient) return\n        const { initScrollOffset } = props\n        const windowElement = unref(windowRef)\n        if (isNumber(initScrollOffset) && windowElement) {\n          if (unref(_isHorizontal)) {\n            windowElement.scrollLeft = initScrollOffset\n          } else {\n            windowElement.scrollTop = initScrollOffset\n          }\n        }\n\n        emitEvents()\n      })\n\n      onUpdated(() => {\n        const { direction, layout } = props\n        const { scrollOffset, updateRequested } = unref(states)\n        const windowElement = unref(windowRef)\n\n        if (updateRequested && windowElement) {\n          if (layout === HORIZONTAL) {\n            if (direction === RTL) {\n              // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n              // This is not the case for all browsers though (e.g. Chrome reports values as positive, measured relative to the left).\n              // So we need to determine which browser behavior we're dealing with, and mimic it.\n              switch (getRTLOffsetType()) {\n                case RTL_OFFSET_NAG: {\n                  windowElement.scrollLeft = -scrollOffset\n                  break\n                }\n                case RTL_OFFSET_POS_ASC: {\n                  windowElement.scrollLeft = scrollOffset\n                  break\n                }\n                default: {\n                  const { clientWidth, scrollWidth } = windowElement\n                  windowElement.scrollLeft =\n                    scrollWidth - clientWidth - scrollOffset\n                  break\n                }\n              }\n            } else {\n              windowElement.scrollLeft = scrollOffset\n            }\n          } else {\n            windowElement.scrollTop = scrollOffset\n          }\n        }\n      })\n\n      onActivated(() => {\n        unref(windowRef)!.scrollTop = unref(states).scrollOffset\n      })\n\n      const api = {\n        ns,\n        clientSize,\n        estimatedTotalSize,\n        windowStyle,\n        windowRef,\n        innerRef,\n        innerStyle,\n        itemsToRender,\n        scrollbarRef,\n        states,\n        getItemStyle,\n        onScroll,\n        onScrollbarScroll,\n        onWheel,\n        scrollTo,\n        scrollToItem,\n        resetScrollTop,\n      }\n\n      expose({\n        windowRef,\n        innerRef,\n        getItemStyleCache,\n        scrollTo,\n        scrollToItem,\n        resetScrollTop,\n        states,\n      })\n\n      return api\n    },\n\n    render(ctx: any) {\n      const {\n        $slots,\n        className,\n        clientSize,\n        containerElement,\n        data,\n        getItemStyle,\n        innerElement,\n        itemsToRender,\n        innerStyle,\n        layout,\n        total,\n        onScroll,\n        onScrollbarScroll,\n        states,\n        useIsScrolling,\n        windowStyle,\n        ns,\n      } = ctx\n\n      const [start, end] = itemsToRender\n\n      const Container = resolveDynamicComponent(containerElement)\n      const Inner = resolveDynamicComponent(innerElement)\n\n      const children = [] as VNodeChild[]\n\n      if (total > 0) {\n        for (let i = start; i <= end; i++) {\n          children.push(\n            h(\n              Fragment,\n              { key: i },\n              ($slots.default as Slot)?.({\n                data,\n                index: i,\n                isScrolling: useIsScrolling ? states.isScrolling : undefined,\n                style: getItemStyle(i),\n              })\n            )\n          )\n        }\n      }\n\n      const InnerNode = [\n        h(\n          Inner as VNode,\n          {\n            style: innerStyle,\n            ref: 'innerRef',\n          },\n          !isString(Inner)\n            ? {\n                default: () => children,\n              }\n            : children\n        ),\n      ]\n\n      const scrollbar = h(Scrollbar, {\n        ref: 'scrollbarRef',\n        clientSize,\n        layout,\n        onScroll: onScrollbarScroll,\n        ratio: (clientSize * 100) / this.estimatedTotalSize,\n        scrollFrom:\n          states.scrollOffset / (this.estimatedTotalSize - clientSize),\n        total,\n      })\n\n      const listContainer = h(\n        Container as VNode,\n        {\n          class: [ns.e('window'), className],\n          style: windowStyle,\n          onScroll,\n          ref: 'windowRef',\n          key: 0,\n        },\n        !isString(Container) ? { default: () => [InnerNode] } : [InnerNode]\n      )\n\n      return h(\n        'div',\n        {\n          key: 0,\n          class: [ns.e('wrapper'), states.scrollbarAlwaysOn ? 'always-on' : ''],\n        },\n        [listContainer, scrollbar]\n      )\n    },\n  })\n}\n\nexport default createList\n", "import { isString, throwError } from '@element-plus/utils'\nimport buildList from '../builders/build-list'\nimport { isHorizontal } from '../utils'\nimport {\n  AUTO_ALIGNMENT,\n  CENTERED_ALIGNMENT,\n  END_ALIGNMENT,\n  SMART_ALIGNMENT,\n  START_ALIGNMENT,\n} from '../defaults'\n\nimport type { VirtualizedListProps } from '../props'\n\ntype Props = VirtualizedListProps\n\nconst FixedSizeList = buildList({\n  name: 'ElFixedSizeList',\n  getItemOffset: ({ itemSize }, index) => index * (itemSize as number),\n\n  getItemSize: ({ itemSize }) => itemSize as number,\n\n  getEstimatedTotalSize: ({ total, itemSize }) => (itemSize as number) * total,\n\n  getOffset: (\n    { height, total, itemSize, layout, width },\n    index,\n    alignment,\n    scrollOffset\n  ) => {\n    const size = (isHorizontal(layout) ? width : height) as number\n    if (process.env.NODE_ENV !== 'production' && isString(size)) {\n      throwError(\n        '[ElVirtualList]',\n        `\n        You should set\n          width/height\n        to number when your layout is\n          horizontal/vertical\n      `\n      )\n    }\n    const lastItemOffset = Math.max(0, total * (itemSize as number) - size)\n    const maxOffset = Math.min(lastItemOffset, index * (itemSize as number))\n    const minOffset = Math.max(0, (index + 1) * (itemSize as number) - size)\n\n    if (alignment === SMART_ALIGNMENT) {\n      if (\n        scrollOffset >= minOffset - size &&\n        scrollOffset <= maxOffset + size\n      ) {\n        alignment = AUTO_ALIGNMENT\n      } else {\n        alignment = CENTERED_ALIGNMENT\n      }\n    }\n\n    switch (alignment) {\n      case START_ALIGNMENT: {\n        return maxOffset\n      }\n      case END_ALIGNMENT: {\n        return minOffset\n      }\n      case CENTERED_ALIGNMENT: {\n        // \"Centered\" offset is usually the average of the min and max.\n        // But near the edges of the list, this doesn't hold true.\n        const middleOffset = Math.round(minOffset + (maxOffset - minOffset) / 2)\n        if (middleOffset < Math.ceil(size / 2)) {\n          return 0 // near the beginning\n        } else if (middleOffset > lastItemOffset + Math.floor(size / 2)) {\n          return lastItemOffset // near the end\n        } else {\n          return middleOffset\n        }\n      }\n      case AUTO_ALIGNMENT:\n      default: {\n        if (scrollOffset >= minOffset && scrollOffset <= maxOffset) {\n          return scrollOffset\n        } else if (scrollOffset < minOffset) {\n          return minOffset\n        } else {\n          return maxOffset\n        }\n      }\n    }\n  },\n\n  getStartIndexForOffset: ({ total, itemSize }, offset) =>\n    Math.max(0, Math.min(total - 1, Math.floor(offset / (itemSize as number)))),\n\n  getStopIndexForStartIndex: (\n    { height, total, itemSize, layout, width }: Props,\n    startIndex: number,\n    scrollOffset: number\n  ) => {\n    const offset = startIndex * (itemSize as number)\n    const size = isHorizontal(layout) ? width : height\n    const numVisibleItems = Math.ceil(\n      ((size as number) + scrollOffset - offset) / (itemSize as number)\n    )\n    return Math.max(\n      0,\n      Math.min(\n        total - 1,\n        // because startIndex is inclusive, so in order to prevent array outbound indexing\n        // we need to - 1 to prevent outbound behavior\n        startIndex + numVisibleItems - 1\n      )\n    )\n  },\n\n  /**\n   * Fixed size list does not need this cache\n   * Using any to bypass it, TODO: Using type inference to fix this.\n   */\n  initCache() {\n    return undefined as any\n  },\n\n  clearCache: true,\n\n  validateProps() {\n    //\n  },\n})\n\nexport type FixedSizeListInstance = InstanceType<typeof FixedSizeList>\nexport default FixedSizeList\n", "import { throwError } from '@element-plus/utils'\n\nimport createList from '../builders/build-list'\n\nimport { isHorizontal } from '../utils'\nimport {\n  AUTO_ALIGNMENT,\n  CENTERED_ALIGNMENT,\n  DEFAULT_DYNAMIC_LIST_ITEM_SIZE,\n  END_ALIGNMENT,\n  SMART_ALIGNMENT,\n  START_ALIGNMENT,\n} from '../defaults'\nimport type { VirtualizedListProps } from '../props'\n\nimport type { ItemSize, ListCache, ListItem } from '../types'\n\ntype Props = VirtualizedListProps\n\nconst SCOPE = 'ElDynamicSizeList'\nconst getItemFromCache = (\n  props: Props,\n  index: number,\n  listCache: ListCache\n): ListItem => {\n  const { itemSize } = props\n  const { items, lastVisitedIndex } = listCache\n\n  if (index > lastVisitedIndex) {\n    let offset = 0\n    if (lastVisitedIndex >= 0) {\n      const item = items[lastVisitedIndex]\n      offset = item.offset + item.size\n    }\n\n    for (let i = lastVisitedIndex + 1; i <= index; i++) {\n      const size = (itemSize as ItemSize)(i)\n\n      items[i] = {\n        offset,\n        size,\n      }\n\n      offset += size\n    }\n\n    listCache.lastVisitedIndex = index\n  }\n\n  return items[index]\n}\n\nconst findItem = (props: Props, listCache: ListCache, offset: number) => {\n  const { items, lastVisitedIndex } = listCache\n\n  const lastVisitedOffset =\n    lastVisitedIndex > 0 ? items[lastVisitedIndex].offset : 0\n\n  if (lastVisitedOffset >= offset) {\n    return bs(props, listCache, 0, lastVisitedIndex, offset)\n  }\n  return es(props, listCache, Math.max(0, lastVisitedIndex), offset)\n}\n\n// bs stands for binary search which has approximately time complexity of O(Log n)\n// space complexity of O(1)\n// in this case we use it for search the offset of each item, since\n// the cached items' offset is monotonically increasing\nconst bs = (\n  props: Props,\n  listCache: ListCache,\n  low: number,\n  high: number,\n  offset: number\n) => {\n  while (low <= high) {\n    const mid = low + Math.floor((high - low) / 2)\n    const currentOffset = getItemFromCache(props, mid, listCache).offset\n\n    if (currentOffset === offset) {\n      return mid\n    } else if (currentOffset < offset) {\n      low = mid + 1\n    } else if (currentOffset > offset) {\n      high = mid - 1\n    }\n  }\n\n  return Math.max(0, low - 1)\n}\n\n// es stands for exponential search which has time complexity of O(Log n) and\n// space complexity of O(1) in the case of finding the boundary element.\n// the exponential indicator in this case is 2.\n// for more detail about exponential search click this link\n// https://www.freecodecamp.org/news/search-algorithms-exponential-search-explained/\n\nconst es = (\n  props: Props,\n  listCache: ListCache,\n  index: number,\n  offset: number\n) => {\n  const { total } = props\n  let exponent = 1\n\n  while (\n    index < total &&\n    getItemFromCache(props, index, listCache).offset < offset\n  ) {\n    index += exponent\n    exponent *= 2\n  }\n\n  return bs(\n    props,\n    listCache,\n    Math.floor(index / 2),\n    Math.min(index, total - 1),\n    offset\n  )\n}\n\nconst getEstimatedTotalSize = (\n  { total }: Props,\n  { items, estimatedItemSize, lastVisitedIndex }: ListCache\n) => {\n  let totalSizeOfMeasuredItems = 0\n\n  if (lastVisitedIndex >= total) {\n    lastVisitedIndex = total - 1\n  }\n\n  if (lastVisitedIndex >= 0) {\n    const item = items[lastVisitedIndex]\n    totalSizeOfMeasuredItems = item.offset + item.size\n  }\n\n  const numUnmeasuredItems = total - lastVisitedIndex - 1\n  const totalSizeOfUnmeasuredItems = numUnmeasuredItems * estimatedItemSize\n  return totalSizeOfMeasuredItems + totalSizeOfUnmeasuredItems\n}\n\nconst DynamicSizeList = createList({\n  name: 'ElDynamicSizeList',\n  getItemOffset: (props, index, listCache) =>\n    getItemFromCache(props, index, listCache).offset,\n\n  getItemSize: (_, index, { items }) => items[index].size,\n\n  getEstimatedTotalSize,\n\n  getOffset: (props, index, alignment, scrollOffset, listCache) => {\n    const { height, layout, width } = props\n\n    const size = (isHorizontal(layout) ? width : height) as number\n    const item = getItemFromCache(props, index, listCache)\n\n    const estimatedTotalSize = getEstimatedTotalSize(props, listCache)\n\n    const maxOffset = Math.max(\n      0,\n      Math.min(estimatedTotalSize - size, item.offset)\n    )\n    const minOffset = Math.max(0, item.offset - size + item.size)\n\n    if (alignment === SMART_ALIGNMENT) {\n      if (\n        scrollOffset >= minOffset - size &&\n        scrollOffset <= maxOffset + size\n      ) {\n        alignment = AUTO_ALIGNMENT\n      } else {\n        alignment = CENTERED_ALIGNMENT\n      }\n    }\n\n    switch (alignment) {\n      case START_ALIGNMENT: {\n        return maxOffset\n      }\n      case END_ALIGNMENT: {\n        return minOffset\n      }\n      case CENTERED_ALIGNMENT: {\n        return Math.round(minOffset + (maxOffset - minOffset) / 2)\n      }\n      case AUTO_ALIGNMENT:\n      default: {\n        if (scrollOffset >= minOffset && scrollOffset <= maxOffset) {\n          return scrollOffset\n        } else if (scrollOffset < minOffset) {\n          return minOffset\n        } else {\n          return maxOffset\n        }\n      }\n    }\n  },\n\n  getStartIndexForOffset: (props, offset, listCache) =>\n    findItem(props, listCache, offset),\n\n  getStopIndexForStartIndex: (props, startIndex, scrollOffset, listCache) => {\n    const { height, total, layout, width } = props\n\n    const size = (isHorizontal(layout) ? width : height) as number\n    const item = getItemFromCache(props, startIndex, listCache)\n    const maxOffset = scrollOffset + size\n\n    let offset = item.offset + item.size\n    let stopIndex = startIndex\n\n    while (stopIndex < total - 1 && offset < maxOffset) {\n      stopIndex++\n      offset += getItemFromCache(props, stopIndex, listCache).size\n    }\n\n    return stopIndex\n  },\n\n  initCache({ estimatedItemSize = DEFAULT_DYNAMIC_LIST_ITEM_SIZE }, instance) {\n    const cache = {\n      items: {},\n      estimatedItemSize,\n      lastVisitedIndex: -1,\n    } as ListCache\n\n    cache.clearCacheAfterIndex = (index: number, forceUpdate = true) => {\n      cache.lastVisitedIndex = Math.min(cache.lastVisitedIndex, index - 1)\n      instance.exposed?.getItemStyleCache(-1)\n\n      if (forceUpdate) {\n        instance.proxy?.$forceUpdate()\n      }\n    }\n\n    return cache\n  },\n\n  clearCache: false,\n\n  validateProps: ({ itemSize }) => {\n    if (process.env.NODE_ENV !== 'production') {\n      if (typeof itemSize !== 'function') {\n        throwError(\n          SCOPE,\n          `\n          itemSize is required as function, but the given value was ${typeof itemSize}\n        `\n        )\n      }\n    }\n  },\n})\n\nexport type DynamicSizeListInstance = InstanceType<typeof DynamicSizeList>\nexport default DynamicSizeList\n", "import { cAF, rAF } from '@element-plus/utils'\n\nimport type { ComputedRef } from 'vue'\n\ninterface GridWheelState {\n  atXStartEdge: ComputedRef<boolean>\n  atXEndEdge: ComputedRef<boolean>\n  atYStartEdge: ComputedRef<boolean>\n  atYEndEdge: ComputedRef<boolean>\n}\n\ntype GridWheelHandler = (x: number, y: number) => void\n\nexport const useGridWheel = (\n  { atXEndEdge, atXStartEdge, atYEndEdge, atYStartEdge }: GridWheelState,\n  onWheelDelta: GridWheelHandler\n) => {\n  let frameHandle: number | null = null\n  let xOffset = 0\n  let yOffset = 0\n\n  const hasReachedEdge = (x: number, y: number) => {\n    const xEdgeReached =\n      (x <= 0 && atXStartEdge.value) || (x >= 0 && atXEndEdge.value)\n    const yEdgeReached =\n      (y <= 0 && atYStartEdge.value) || (y >= 0 && atYEndEdge.value)\n    return xEdgeReached && yEdgeReached\n  }\n\n  const onWheel = (e: WheelEvent) => {\n    cAF(frameHandle!)\n\n    let x = e.deltaX\n    let y = e.deltaY\n    // Simulate native behavior when using touch pad/track pad for wheeling.\n    if (Math.abs(x) > Math.abs(y)) {\n      y = 0\n    } else {\n      x = 0\n    }\n\n    // Special case for windows machine with shift key + wheel scrolling\n    if (e.shiftKey && y !== 0) {\n      x = y\n      y = 0\n    }\n\n    if (\n      hasReachedEdge(xOffset, yOffset) &&\n      hasReachedEdge(xOffset + x, yOffset + y)\n    )\n      return\n\n    xOffset += x\n    yOffset += y\n\n    e.preventDefault()\n\n    frameHandle = rAF(() => {\n      onWheelDelta(xOffset, yOffset)\n      xOffset = 0\n      yOffset = 0\n    })\n  }\n\n  return {\n    hasReachedEdge,\n    onWheel,\n  }\n}\n", "// @ts-nocheck\nimport {\n  Fragment,\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  h,\n  nextTick,\n  onMounted,\n  ref,\n  resolveDynamicComponent,\n  unref,\n} from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport {\n  getScrollBarWidth,\n  hasOwn,\n  isClient,\n  isNumber,\n  isString,\n} from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport Scrollbar from '../components/scrollbar'\nimport { useGridWheel } from '../hooks/use-grid-wheel'\nimport { useCache } from '../hooks/use-cache'\nimport { virtualizedGridProps } from '../props'\nimport { getRTLOffsetType, getScrollDir, isRTL } from '../utils'\nimport {\n  AUTO_ALIGNMENT,\n  BACKWARD,\n  FORWARD,\n  ITEM_RENDER_EVT,\n  RTL,\n  RTL_OFFSET_NAG,\n  RTL_OFFSET_POS_ASC,\n  RTL_OFFSET_POS_DESC,\n  SCROLL_EVT,\n} from '../defaults'\nimport type {\n  CSSProperties,\n  Ref,\n  StyleValue,\n  UnwrapRef,\n  VNode,\n  VNodeChild,\n} from 'vue'\nimport type {\n  Alignment,\n  GridConstructorProps,\n  GridScrollOptions,\n  ScrollbarExpose,\n} from '../types'\nimport type { VirtualizedGridProps } from '../props'\n\nconst createGrid = ({\n  name,\n  clearCache,\n  getColumnPosition,\n  getColumnStartIndexForOffset,\n  getColumnStopIndexForStartIndex,\n  getEstimatedTotalHeight,\n  getEstimatedTotalWidth,\n  getColumnOffset,\n  getRowOffset,\n  getRowPosition,\n  getRowStartIndexForOffset,\n  getRowStopIndexForStartIndex,\n\n  initCache,\n  injectToInstance,\n  validateProps,\n}: GridConstructorProps<VirtualizedGridProps>) => {\n  return defineComponent({\n    name: name ?? 'ElVirtualList',\n    props: virtualizedGridProps,\n    emits: [ITEM_RENDER_EVT, SCROLL_EVT],\n    setup(props, { emit, expose, slots }) {\n      const ns = useNamespace('vl')\n\n      validateProps(props)\n      const instance = getCurrentInstance()!\n      const cache = ref(initCache(props, instance))\n      injectToInstance?.(instance, cache)\n      // refs\n      // here windowRef and innerRef can be type of HTMLElement\n      // or user defined component type, depends on the type passed\n      // by user\n      const windowRef = ref<HTMLElement>()\n      const hScrollbar = ref<ScrollbarExpose>()\n      const vScrollbar = ref<ScrollbarExpose>()\n      // innerRef is the actual container element which contains all the elements\n      const innerRef = ref(null)\n      const states = ref({\n        isScrolling: false,\n        scrollLeft: isNumber(props.initScrollLeft) ? props.initScrollLeft : 0,\n        scrollTop: isNumber(props.initScrollTop) ? props.initScrollTop : 0,\n        updateRequested: false,\n        xAxisScrollDir: FORWARD,\n        yAxisScrollDir: FORWARD,\n      })\n\n      const getItemStyleCache = useCache()\n\n      // computed\n      const parsedHeight = computed(() =>\n        Number.parseInt(`${props.height}`, 10)\n      )\n      const parsedWidth = computed(() => Number.parseInt(`${props.width}`, 10))\n      const columnsToRender = computed(() => {\n        const { totalColumn, totalRow, columnCache } = props\n        const { isScrolling, xAxisScrollDir, scrollLeft } = unref(states)\n\n        if (totalColumn === 0 || totalRow === 0) {\n          return [0, 0, 0, 0]\n        }\n\n        const startIndex = getColumnStartIndexForOffset(\n          props,\n          scrollLeft,\n          unref(cache)\n        )\n        const stopIndex = getColumnStopIndexForStartIndex(\n          props,\n          startIndex,\n          scrollLeft,\n          unref(cache)\n        )\n\n        const cacheBackward =\n          !isScrolling || xAxisScrollDir === BACKWARD\n            ? Math.max(1, columnCache)\n            : 1\n        const cacheForward =\n          !isScrolling || xAxisScrollDir === FORWARD\n            ? Math.max(1, columnCache)\n            : 1\n\n        return [\n          Math.max(0, startIndex - cacheBackward),\n          Math.max(0, Math.min(totalColumn! - 1, stopIndex + cacheForward)),\n          startIndex,\n          stopIndex,\n        ]\n      })\n\n      const rowsToRender = computed(() => {\n        const { totalColumn, totalRow, rowCache } = props\n        const { isScrolling, yAxisScrollDir, scrollTop } = unref(states)\n\n        if (totalColumn === 0 || totalRow === 0) {\n          return [0, 0, 0, 0]\n        }\n\n        const startIndex = getRowStartIndexForOffset(\n          props,\n          scrollTop,\n          unref(cache)\n        )\n        const stopIndex = getRowStopIndexForStartIndex(\n          props,\n          startIndex,\n          scrollTop,\n          unref(cache)\n        )\n\n        const cacheBackward =\n          !isScrolling || yAxisScrollDir === BACKWARD\n            ? Math.max(1, rowCache)\n            : 1\n        const cacheForward =\n          !isScrolling || yAxisScrollDir === FORWARD ? Math.max(1, rowCache) : 1\n\n        return [\n          Math.max(0, startIndex - cacheBackward),\n          Math.max(0, Math.min(totalRow! - 1, stopIndex + cacheForward)),\n          startIndex,\n          stopIndex,\n        ]\n      })\n\n      const estimatedTotalHeight = computed(() =>\n        getEstimatedTotalHeight(props, unref(cache))\n      )\n      const estimatedTotalWidth = computed(() =>\n        getEstimatedTotalWidth(props, unref(cache))\n      )\n\n      const windowStyle = computed<StyleValue>(() => [\n        {\n          position: 'relative',\n          overflow: 'hidden',\n          WebkitOverflowScrolling: 'touch',\n          willChange: 'transform',\n        },\n        {\n          direction: props.direction,\n          height: isNumber(props.height) ? `${props.height}px` : props.height,\n          width: isNumber(props.width) ? `${props.width}px` : props.width,\n        },\n        props.style ?? {},\n      ])\n\n      const innerStyle = computed(() => {\n        const width = `${unref(estimatedTotalWidth)}px`\n        const height = `${unref(estimatedTotalHeight)}px`\n\n        return {\n          height,\n          pointerEvents: unref(states).isScrolling ? 'none' : undefined,\n          width,\n        }\n      })\n\n      // methods\n      const emitEvents = () => {\n        const { totalColumn, totalRow } = props\n\n        if (totalColumn! > 0 && totalRow! > 0) {\n          const [\n            columnCacheStart,\n            columnCacheEnd,\n            columnVisibleStart,\n            columnVisibleEnd,\n          ] = unref(columnsToRender)\n          const [rowCacheStart, rowCacheEnd, rowVisibleStart, rowVisibleEnd] =\n            unref(rowsToRender)\n          // emit the render item event with\n          // [xAxisInvisibleStart, xAxisInvisibleEnd, xAxisVisibleStart, xAxisVisibleEnd]\n          // [yAxisInvisibleStart, yAxisInvisibleEnd, yAxisVisibleStart, yAxisVisibleEnd]\n          emit(ITEM_RENDER_EVT, {\n            columnCacheStart,\n            columnCacheEnd,\n            rowCacheStart,\n            rowCacheEnd,\n            columnVisibleStart,\n            columnVisibleEnd,\n            rowVisibleStart,\n            rowVisibleEnd,\n          })\n        }\n\n        const {\n          scrollLeft,\n          scrollTop,\n          updateRequested,\n          xAxisScrollDir,\n          yAxisScrollDir,\n        } = unref(states)\n        emit(SCROLL_EVT, {\n          xAxisScrollDir,\n          scrollLeft,\n          yAxisScrollDir,\n          scrollTop,\n          updateRequested,\n        })\n      }\n\n      const onScroll = (e: Event) => {\n        const {\n          clientHeight,\n          clientWidth,\n          scrollHeight,\n          scrollLeft,\n          scrollTop,\n          scrollWidth,\n        } = e.currentTarget as HTMLElement\n\n        const _states = unref(states)\n\n        if (\n          _states.scrollTop === scrollTop &&\n          _states.scrollLeft === scrollLeft\n        ) {\n          return\n        }\n\n        let _scrollLeft = scrollLeft\n\n        if (isRTL(props.direction)) {\n          switch (getRTLOffsetType()) {\n            case RTL_OFFSET_NAG:\n              _scrollLeft = -scrollLeft\n              break\n            case RTL_OFFSET_POS_DESC:\n              _scrollLeft = scrollWidth - clientWidth - scrollLeft\n              break\n          }\n        }\n\n        states.value = {\n          ..._states,\n          isScrolling: true,\n          scrollLeft: _scrollLeft,\n          scrollTop: Math.max(\n            0,\n            Math.min(scrollTop, scrollHeight - clientHeight)\n          ),\n          updateRequested: true,\n          xAxisScrollDir: getScrollDir(_states.scrollLeft, _scrollLeft),\n          yAxisScrollDir: getScrollDir(_states.scrollTop, scrollTop),\n        }\n\n        nextTick(() => resetIsScrolling())\n\n        onUpdated()\n        emitEvents()\n      }\n\n      const onVerticalScroll = (distance: number, totalSteps: number) => {\n        const height = unref(parsedHeight)\n        const offset =\n          ((estimatedTotalHeight.value - height) / totalSteps) * distance\n        scrollTo({\n          scrollTop: Math.min(estimatedTotalHeight.value - height, offset),\n        })\n      }\n\n      const onHorizontalScroll = (distance: number, totalSteps: number) => {\n        const width = unref(parsedWidth)\n        const offset =\n          ((estimatedTotalWidth.value - width) / totalSteps) * distance\n        scrollTo({\n          scrollLeft: Math.min(estimatedTotalWidth.value - width, offset),\n        })\n      }\n\n      const { onWheel } = useGridWheel(\n        {\n          atXStartEdge: computed(() => states.value.scrollLeft <= 0),\n          atXEndEdge: computed(\n            () =>\n              states.value.scrollLeft >=\n              estimatedTotalWidth.value - unref(parsedWidth)\n          ),\n          atYStartEdge: computed(() => states.value.scrollTop <= 0),\n          atYEndEdge: computed(\n            () =>\n              states.value.scrollTop >=\n              estimatedTotalHeight.value - unref(parsedHeight)\n          ),\n        },\n        (x: number, y: number) => {\n          hScrollbar.value?.onMouseUp?.()\n          vScrollbar.value?.onMouseUp?.()\n          const width = unref(parsedWidth)\n          const height = unref(parsedHeight)\n          scrollTo({\n            scrollLeft: Math.min(\n              states.value.scrollLeft + x,\n              estimatedTotalWidth.value - width\n            ),\n            scrollTop: Math.min(\n              states.value.scrollTop + y,\n              estimatedTotalHeight.value - height\n            ),\n          })\n        }\n      )\n\n      useEventListener(windowRef, 'wheel', onWheel, {\n        passive: false,\n      })\n\n      const scrollTo = ({\n        scrollLeft = states.value.scrollLeft,\n        scrollTop = states.value.scrollTop,\n      }: GridScrollOptions) => {\n        scrollLeft = Math.max(scrollLeft, 0)\n        scrollTop = Math.max(scrollTop, 0)\n        const _states = unref(states)\n        if (\n          scrollTop === _states.scrollTop &&\n          scrollLeft === _states.scrollLeft\n        ) {\n          return\n        }\n\n        states.value = {\n          ..._states,\n          xAxisScrollDir: getScrollDir(_states.scrollLeft, scrollLeft),\n          yAxisScrollDir: getScrollDir(_states.scrollTop, scrollTop),\n          scrollLeft,\n          scrollTop,\n          updateRequested: true,\n        }\n\n        nextTick(() => resetIsScrolling())\n\n        onUpdated()\n        emitEvents()\n      }\n\n      const scrollToItem = (\n        rowIndex = 0,\n        columnIdx = 0,\n        alignment: Alignment = AUTO_ALIGNMENT\n      ) => {\n        const _states = unref(states)\n        columnIdx = Math.max(0, Math.min(columnIdx, props.totalColumn! - 1))\n        rowIndex = Math.max(0, Math.min(rowIndex, props.totalRow! - 1))\n        const scrollBarWidth = getScrollBarWidth(ns.namespace.value)\n\n        const _cache = unref(cache)\n        const estimatedHeight = getEstimatedTotalHeight(props, _cache)\n        const estimatedWidth = getEstimatedTotalWidth(props, _cache)\n\n        scrollTo({\n          scrollLeft: getColumnOffset(\n            props,\n            columnIdx,\n            alignment,\n            _states.scrollLeft,\n            _cache,\n            estimatedWidth > props.width! ? scrollBarWidth : 0\n          ),\n          scrollTop: getRowOffset(\n            props,\n            rowIndex,\n            alignment,\n            _states.scrollTop,\n            _cache,\n            estimatedHeight > props.height! ? scrollBarWidth : 0\n          ),\n        })\n      }\n\n      const getItemStyle = (\n        rowIndex: number,\n        columnIndex: number\n      ): CSSProperties => {\n        const { columnWidth, direction, rowHeight } = props\n        const itemStyleCache = getItemStyleCache.value(\n          clearCache && columnWidth,\n          clearCache && rowHeight,\n          clearCache && direction\n        )\n        // since there was no need to introduce an nested array into cache object\n        // we use row,column to construct the key for indexing the map.\n        const key = `${rowIndex},${columnIndex}`\n\n        if (hasOwn(itemStyleCache, key)) {\n          return itemStyleCache[key]\n        } else {\n          const [, left] = getColumnPosition(props, columnIndex, unref(cache))\n          const _cache = unref(cache)\n\n          const rtl = isRTL(direction)\n          const [height, top] = getRowPosition(props, rowIndex, _cache)\n          const [width] = getColumnPosition(props, columnIndex, _cache)\n\n          itemStyleCache[key] = {\n            position: 'absolute',\n            left: rtl ? undefined : `${left}px`,\n            right: rtl ? `${left}px` : undefined,\n            top: `${top}px`,\n            height: `${height}px`,\n            width: `${width}px`,\n          }\n\n          return itemStyleCache[key]\n        }\n      }\n\n      // TODO: debounce setting is scrolling.\n\n      const resetIsScrolling = () => {\n        // timer = null\n\n        states.value.isScrolling = false\n        nextTick(() => {\n          getItemStyleCache.value(-1, null, null)\n        })\n      }\n\n      // life cycles\n      onMounted(() => {\n        // for SSR\n        if (!isClient) return\n        const { initScrollLeft, initScrollTop } = props\n        const windowElement = unref(windowRef)\n        if (windowElement) {\n          if (isNumber(initScrollLeft)) {\n            windowElement.scrollLeft = initScrollLeft\n          }\n          if (isNumber(initScrollTop)) {\n            windowElement.scrollTop = initScrollTop\n          }\n        }\n        emitEvents()\n      })\n\n      const onUpdated = () => {\n        const { direction } = props\n        const { scrollLeft, scrollTop, updateRequested } = unref(states)\n\n        const windowElement = unref(windowRef)\n        if (updateRequested && windowElement) {\n          if (direction === RTL) {\n            switch (getRTLOffsetType()) {\n              case RTL_OFFSET_NAG: {\n                windowElement.scrollLeft = -scrollLeft\n                break\n              }\n              case RTL_OFFSET_POS_ASC: {\n                windowElement.scrollLeft = scrollLeft\n                break\n              }\n              default: {\n                const { clientWidth, scrollWidth } = windowElement\n                windowElement.scrollLeft =\n                  scrollWidth - clientWidth - scrollLeft\n                break\n              }\n            }\n          } else {\n            windowElement.scrollLeft = Math.max(0, scrollLeft)\n          }\n\n          windowElement.scrollTop = Math.max(0, scrollTop)\n        }\n      }\n\n      const { resetAfterColumnIndex, resetAfterRowIndex, resetAfter } =\n        instance.proxy as any\n\n      expose({\n        windowRef,\n        innerRef,\n        getItemStyleCache,\n        scrollTo,\n        scrollToItem,\n        states,\n        resetAfterColumnIndex,\n        resetAfterRowIndex,\n        resetAfter,\n      })\n\n      // rendering part\n\n      const renderScrollbars = () => {\n        const {\n          scrollbarAlwaysOn,\n          scrollbarStartGap,\n          scrollbarEndGap,\n          totalColumn,\n          totalRow,\n        } = props\n\n        const width = unref(parsedWidth)\n        const height = unref(parsedHeight)\n        const estimatedWidth = unref(estimatedTotalWidth)\n        const estimatedHeight = unref(estimatedTotalHeight)\n        const { scrollLeft, scrollTop } = unref(states)\n        const horizontalScrollbar = h(Scrollbar, {\n          ref: hScrollbar,\n          alwaysOn: scrollbarAlwaysOn,\n          startGap: scrollbarStartGap,\n          endGap: scrollbarEndGap,\n          class: ns.e('horizontal'),\n          clientSize: width,\n          layout: 'horizontal',\n          onScroll: onHorizontalScroll,\n          ratio: (width * 100) / estimatedWidth,\n          scrollFrom: scrollLeft / (estimatedWidth - width),\n          total: totalRow,\n          visible: true,\n        })\n\n        const verticalScrollbar = h(Scrollbar, {\n          ref: vScrollbar,\n          alwaysOn: scrollbarAlwaysOn,\n          startGap: scrollbarStartGap,\n          endGap: scrollbarEndGap,\n          class: ns.e('vertical'),\n          clientSize: height,\n          layout: 'vertical',\n          onScroll: onVerticalScroll,\n          ratio: (height * 100) / estimatedHeight,\n          scrollFrom: scrollTop / (estimatedHeight - height),\n\n          total: totalColumn,\n          visible: true,\n        })\n\n        return {\n          horizontalScrollbar,\n          verticalScrollbar,\n        }\n      }\n\n      const renderItems = () => {\n        const [columnStart, columnEnd] = unref(columnsToRender)\n        const [rowStart, rowEnd] = unref(rowsToRender)\n        const { data, totalColumn, totalRow, useIsScrolling, itemKey } = props\n        const children: VNodeChild[] = []\n        if (totalRow > 0 && totalColumn > 0) {\n          for (let row = rowStart; row <= rowEnd; row++) {\n            for (let column = columnStart; column <= columnEnd; column++) {\n              const key = itemKey({ columnIndex: column, data, rowIndex: row })\n              children.push(\n                h(\n                  Fragment,\n                  { key },\n                  slots.default?.({\n                    columnIndex: column,\n                    data,\n                    isScrolling: useIsScrolling\n                      ? unref(states).isScrolling\n                      : undefined,\n                    style: getItemStyle(row, column),\n                    rowIndex: row,\n                  })\n                )\n              )\n            }\n          }\n        }\n        return children\n      }\n\n      const renderInner = () => {\n        const Inner = resolveDynamicComponent(props.innerElement) as VNode\n        const children = renderItems()\n        return [\n          h(\n            Inner,\n            {\n              style: unref(innerStyle),\n              ref: innerRef,\n            },\n            !isString(Inner)\n              ? {\n                  default: () => children,\n                }\n              : children\n          ),\n        ]\n      }\n\n      const renderWindow = () => {\n        const Container = resolveDynamicComponent(\n          props.containerElement\n        ) as VNode\n        const { horizontalScrollbar, verticalScrollbar } = renderScrollbars()\n        const Inner = renderInner()\n\n        return h(\n          'div',\n          {\n            key: 0,\n            class: ns.e('wrapper'),\n            role: props.role,\n          },\n          [\n            h(\n              Container,\n              {\n                class: props.className,\n                style: unref(windowStyle),\n                onScroll,\n                ref: windowRef,\n              },\n              !isString(Container) ? { default: () => Inner } : Inner\n            ),\n            horizontalScrollbar,\n            verticalScrollbar,\n          ]\n        )\n      }\n\n      return renderWindow\n    },\n  })\n}\n\nexport default createGrid\n\ntype Dir = typeof FORWARD | typeof BACKWARD\n\nexport type GridInstance = InstanceType<ReturnType<typeof createGrid>> &\n  UnwrapRef<{\n    windowRef: Ref<HTMLElement>\n    innerRef: Ref<HTMLElement>\n    getItemStyleCache: ReturnType<typeof useCache>\n    scrollTo: (scrollOptions: GridScrollOptions) => void\n    scrollToItem: (\n      rowIndex: number,\n      columnIndex: number,\n      alignment: Alignment\n    ) => void\n    states: Ref<{\n      isScrolling: boolean\n      scrollLeft: number\n      scrollTop: number\n      updateRequested: boolean\n      xAxisScrollDir: Dir\n      yAxisScrollDir: Dir\n    }>\n  }>\n", "import { isNumber, throwError } from '@element-plus/utils'\nimport createGrid from '../builders/build-grid'\n\nimport {\n  AUTO_ALIGNMENT,\n  CENTERED_ALIGNMENT,\n  END_ALIGNMENT,\n  SMART_ALIGNMENT,\n  START_ALIGNMENT,\n} from '../defaults'\n\nconst SCOPE = 'ElFixedSizeGrid'\n\nconst FixedSizeGrid = createGrid({\n  name: 'ElFixedSizeGrid',\n  getColumnPosition: ({ columnWidth }, index) => [\n    columnWidth as number,\n    index * (columnWidth as number),\n  ],\n\n  getRowPosition: ({ rowHeight }, index) => [\n    rowHeight as number,\n    index * (rowHeight as number),\n  ],\n\n  getEstimatedTotalHeight: ({ totalRow, rowHeight }) =>\n    (rowHeight as number) * totalRow,\n\n  getEstimatedTotalWidth: ({ totalColumn, columnWidth }) =>\n    (columnWidth as number) * totalColumn,\n\n  getColumnOffset: (\n    { totalColumn, columnWidth, width },\n    columnIndex,\n    alignment,\n    scrollLeft,\n    _,\n    scrollBarWidth\n  ) => {\n    width = Number(width)\n    const lastColumnOffset = Math.max(\n      0,\n      totalColumn * (columnWidth as number) - width\n    )\n    const maxOffset = Math.min(\n      lastColumnOffset,\n      columnIndex * (columnWidth as number)\n    )\n    const minOffset = Math.max(\n      0,\n      columnIndex * (columnWidth as number) -\n        width +\n        scrollBarWidth +\n        (columnWidth as number)\n    )\n\n    if (alignment === 'smart') {\n      if (scrollLeft >= minOffset - width && scrollLeft <= maxOffset + width) {\n        alignment = AUTO_ALIGNMENT\n      } else {\n        alignment = CENTERED_ALIGNMENT\n      }\n    }\n\n    switch (alignment) {\n      case START_ALIGNMENT:\n        return maxOffset\n      case END_ALIGNMENT:\n        return minOffset\n      case CENTERED_ALIGNMENT: {\n        const middleOffset = Math.round(minOffset + (maxOffset - minOffset) / 2)\n        if (middleOffset < Math.ceil(width / 2)) {\n          return 0\n        } else if (middleOffset > lastColumnOffset + Math.floor(width / 2)) {\n          return lastColumnOffset\n        } else {\n          return middleOffset\n        }\n      }\n      case AUTO_ALIGNMENT:\n      default:\n        if (scrollLeft >= minOffset && scrollLeft <= maxOffset) {\n          return scrollLeft\n        } else if (minOffset > maxOffset) {\n          return minOffset\n        } else if (scrollLeft < minOffset) {\n          return minOffset\n        } else {\n          return maxOffset\n        }\n    }\n  },\n\n  getRowOffset: (\n    { rowHeight, height, totalRow },\n    rowIndex,\n    align,\n    scrollTop,\n    _,\n    scrollBarWidth\n  ): number => {\n    height = Number(height)\n    const lastRowOffset = Math.max(0, totalRow * (rowHeight as number) - height)\n    const maxOffset = Math.min(lastRowOffset, rowIndex * (rowHeight as number))\n    const minOffset = Math.max(\n      0,\n      rowIndex * (rowHeight as number) -\n        height +\n        scrollBarWidth +\n        (rowHeight as number)\n    )\n\n    if (align === SMART_ALIGNMENT) {\n      if (scrollTop >= minOffset - height && scrollTop <= maxOffset + height) {\n        align = AUTO_ALIGNMENT\n      } else {\n        align = CENTERED_ALIGNMENT\n      }\n    }\n\n    switch (align) {\n      case START_ALIGNMENT:\n        return maxOffset\n      case END_ALIGNMENT:\n        return minOffset\n      case CENTERED_ALIGNMENT: {\n        const middleOffset = Math.round(minOffset + (maxOffset - minOffset) / 2)\n        if (middleOffset < Math.ceil(height / 2)) {\n          return 0\n        } else if (middleOffset > lastRowOffset + Math.floor(height / 2)) {\n          return lastRowOffset\n        } else {\n          return middleOffset\n        }\n      }\n      case AUTO_ALIGNMENT:\n      default:\n        if (scrollTop >= minOffset && scrollTop <= maxOffset) {\n          return scrollTop\n        } else if (minOffset > maxOffset) {\n          return minOffset\n        } else if (scrollTop < minOffset) {\n          return minOffset\n        } else {\n          return maxOffset\n        }\n    }\n  },\n\n  getColumnStartIndexForOffset: ({ columnWidth, totalColumn }, scrollLeft) =>\n    Math.max(\n      0,\n      Math.min(\n        totalColumn - 1,\n        Math.floor(scrollLeft / (columnWidth as number))\n      )\n    ),\n\n  getColumnStopIndexForStartIndex: (\n    { columnWidth, totalColumn, width },\n    startIndex: number,\n    scrollLeft: number\n  ): number => {\n    const left = startIndex * (columnWidth as number)\n    const visibleColumnsCount = Math.ceil(\n      ((width as number) + scrollLeft - left) / (columnWidth as number)\n    )\n    return Math.max(\n      0,\n      Math.min(totalColumn - 1, startIndex + visibleColumnsCount - 1)\n    )\n  },\n\n  getRowStartIndexForOffset: (\n    { rowHeight, totalRow },\n    scrollTop: number\n  ): number =>\n    Math.max(\n      0,\n      Math.min(totalRow - 1, Math.floor(scrollTop / (rowHeight as number)))\n    ),\n\n  getRowStopIndexForStartIndex: (\n    { rowHeight, totalRow, height },\n    startIndex: number,\n    scrollTop: number\n  ): number => {\n    const top = startIndex * (rowHeight as number)\n    const numVisibleRows = Math.ceil(\n      ((height as number) + scrollTop - top) / (rowHeight as number)\n    )\n    return Math.max(\n      0,\n      Math.min(\n        totalRow - 1,\n        startIndex + numVisibleRows - 1 // -1 is because stop index is inclusive\n      )\n    )\n  },\n  /**\n   * Fixed size grid does not need this cache\n   * Using any to bypass it, TODO: Using type inference to fix this.\n   */\n  initCache: () => undefined as any,\n\n  clearCache: true,\n\n  validateProps: ({ columnWidth, rowHeight }) => {\n    if (process.env.NODE_ENV !== 'production') {\n      if (!isNumber(columnWidth)) {\n        throwError(\n          SCOPE,\n          `\n          \"columnWidth\" must be passed as number,\n            instead ${typeof columnWidth} was given.\n        `\n        )\n      }\n\n      if (!isNumber(rowHeight)) {\n        throwError(\n          SCOPE,\n          `\n          \"columnWidth\" must be passed as number,\n            instead ${typeof rowHeight} was given.\n        `\n        )\n      }\n    }\n  },\n})\n\nexport default FixedSizeGrid\n", "// @ts-nocheck\nimport {\n  isFunction,\n  isNumber,\n  isUndefined,\n  throwError,\n} from '@element-plus/utils'\nimport createGrid from '../builders/build-grid'\n\nimport {\n  AUTO_ALIGNMENT,\n  CENTERED_ALIGNMENT,\n  DEFAULT_DYNAMIC_LIST_ITEM_SIZE,\n  END_ALIGNMENT,\n  SMART_ALIGNMENT,\n  START_ALIGNMENT,\n} from '../defaults'\nimport type { GridInstance } from '../builders/build-grid'\nimport type { VirtualizedGridProps } from '../props'\n\nimport type { Alignment, GridCache, ItemSize, ListItem } from '../types'\n\nconst { max, min, floor } = Math\nconst SCOPE = 'ElDynamicSizeGrid'\n\ntype Props = VirtualizedGridProps\ntype CacheItemType = 'column' | 'row'\ntype Indices = {\n  columnIndex?: number\n  rowIndex?: number\n}\n\n// generates props access key via type\nconst ACCESS_SIZER_KEY_MAP = {\n  column: 'columnWidth',\n  row: 'rowHeight',\n}\n\n// generates cache access key via type\nconst ACCESS_LAST_VISITED_KEY_MAP = {\n  column: 'lastVisitedColumnIndex',\n  row: 'lastVisitedRowIndex',\n}\n\nconst getItemFromCache = (\n  props: Props,\n  index: number,\n  gridCache: GridCache,\n  type: CacheItemType\n) => {\n  const [cachedItems, sizer, lastVisited] = [\n    gridCache[type],\n    props[ACCESS_SIZER_KEY_MAP[type]],\n    gridCache[ACCESS_LAST_VISITED_KEY_MAP[type]],\n  ] as [Record<string, ListItem>, ItemSize, number]\n\n  if (index > lastVisited) {\n    let offset = 0\n    if (lastVisited >= 0) {\n      const item = cachedItems[lastVisited]\n      offset = item.offset + item.size\n    }\n\n    for (let i = lastVisited + 1; i <= index; i++) {\n      // console.log(i, sizer(i))\n      const size = sizer(i)\n\n      cachedItems[i] = {\n        offset,\n        size,\n      }\n\n      offset += size\n    }\n\n    gridCache[ACCESS_LAST_VISITED_KEY_MAP[type]] = index\n  }\n\n  return cachedItems[index]\n}\n\nconst bs = (\n  props: Props,\n  gridCache: GridCache,\n  low: number,\n  high: number,\n  offset: number,\n  type: CacheItemType\n) => {\n  while (low <= high) {\n    const mid = low + floor((high - low) / 2)\n    const currentOffset = getItemFromCache(props, mid, gridCache, type).offset\n\n    if (currentOffset === offset) {\n      return mid\n    } else if (currentOffset < offset) {\n      low = mid + 1\n    } else {\n      high = mid - 1\n    }\n  }\n\n  return max(0, low - 1)\n}\n\nconst es = (\n  props: Props,\n  gridCache: GridCache,\n  idx: number,\n  offset: number,\n  type: CacheItemType\n) => {\n  const total = type === 'column' ? props.totalColumn : props.totalRow\n  let exponent = 1\n\n  while (\n    idx < total &&\n    getItemFromCache(props, idx, gridCache, type).offset < offset\n  ) {\n    idx += exponent\n    exponent *= 2\n  }\n\n  return bs(props, gridCache, floor(idx / 2), min(idx, total - 1), offset, type)\n}\n\nconst findItem = (\n  props: Props,\n  gridCache: GridCache,\n  offset: number,\n  type: CacheItemType\n) => {\n  const [cache, lastVisitedIndex] = [\n    gridCache[type],\n    gridCache[ACCESS_LAST_VISITED_KEY_MAP[type]],\n  ] as [Record<string, ListItem>, number]\n\n  const lastVisitedItemOffset =\n    lastVisitedIndex > 0 ? cache[lastVisitedIndex].offset : 0\n\n  if (lastVisitedItemOffset >= offset) {\n    return bs(props, gridCache, 0, lastVisitedIndex, offset, type)\n  }\n\n  return es(props, gridCache, max(0, lastVisitedIndex), offset, type)\n}\n\nconst getEstimatedTotalHeight = (\n  { totalRow }: Props,\n  { estimatedRowHeight, lastVisitedRowIndex, row }: GridCache\n) => {\n  let sizeOfVisitedRows = 0\n\n  if (lastVisitedRowIndex >= totalRow) {\n    lastVisitedRowIndex = totalRow - 1\n  }\n\n  if (lastVisitedRowIndex >= 0) {\n    const item = row[lastVisitedRowIndex]\n    sizeOfVisitedRows = item.offset + item.size\n  }\n\n  const unvisitedItems = totalRow - lastVisitedRowIndex - 1\n  const sizeOfUnvisitedItems = unvisitedItems * estimatedRowHeight\n\n  return sizeOfVisitedRows + sizeOfUnvisitedItems\n}\nconst getEstimatedTotalWidth = (\n  { totalColumn }: Props,\n  { column, estimatedColumnWidth, lastVisitedColumnIndex }: GridCache\n) => {\n  let sizeOfVisitedColumns = 0\n\n  if (lastVisitedColumnIndex > totalColumn) {\n    lastVisitedColumnIndex = totalColumn - 1\n  }\n\n  if (lastVisitedColumnIndex >= 0) {\n    const item = column[lastVisitedColumnIndex]\n    sizeOfVisitedColumns = item.offset + item.size\n  }\n\n  const unvisitedItems = totalColumn - lastVisitedColumnIndex - 1\n  const sizeOfUnvisitedItems = unvisitedItems * estimatedColumnWidth\n\n  return sizeOfVisitedColumns + sizeOfUnvisitedItems\n}\n\nconst ACCESS_ESTIMATED_SIZE_KEY_MAP = {\n  column: getEstimatedTotalWidth,\n  row: getEstimatedTotalHeight,\n}\n\nconst getOffset = (\n  props: Props,\n  index: number,\n  alignment: Alignment,\n  scrollOffset: number,\n  cache: GridCache,\n  type: CacheItemType,\n  scrollBarWidth: number\n) => {\n  const [size, estimatedSizeAssociates] = [\n    type === 'row' ? props.height : props.width,\n    ACCESS_ESTIMATED_SIZE_KEY_MAP[type],\n  ] as [number, (props: Props, cache: GridCache) => number]\n  const item = getItemFromCache(props, index, cache, type)\n\n  const estimatedSize = estimatedSizeAssociates(props, cache)\n\n  const maxOffset = max(0, min(estimatedSize - size, item.offset))\n  const minOffset = max(0, item.offset - size + scrollBarWidth + item.size)\n\n  if (alignment === SMART_ALIGNMENT) {\n    if (scrollOffset >= minOffset - size && scrollOffset <= maxOffset + size) {\n      alignment = AUTO_ALIGNMENT\n    } else {\n      alignment = CENTERED_ALIGNMENT\n    }\n  }\n\n  switch (alignment) {\n    case START_ALIGNMENT: {\n      return maxOffset\n    }\n    case END_ALIGNMENT: {\n      return minOffset\n    }\n    case CENTERED_ALIGNMENT: {\n      return Math.round(minOffset + (maxOffset - minOffset) / 2)\n    }\n    case AUTO_ALIGNMENT:\n    default: {\n      if (scrollOffset >= minOffset && scrollOffset <= maxOffset) {\n        return scrollOffset\n      } else if (minOffset > maxOffset) {\n        return minOffset\n      } else if (scrollOffset < minOffset) {\n        return minOffset\n      } else {\n        return maxOffset\n      }\n    }\n  }\n}\n\nconst DynamicSizeGrid = createGrid({\n  name: 'ElDynamicSizeGrid',\n  getColumnPosition: (props, idx, cache) => {\n    const item = getItemFromCache(props, idx, cache, 'column')\n    return [item.size, item.offset]\n  },\n\n  getRowPosition: (props, idx, cache) => {\n    const item = getItemFromCache(props, idx, cache, 'row')\n    return [item.size, item.offset]\n  },\n\n  getColumnOffset: (\n    props,\n    columnIndex,\n    alignment,\n    scrollLeft,\n    cache,\n    scrollBarWidth\n  ) =>\n    getOffset(\n      props,\n      columnIndex,\n      alignment,\n      scrollLeft,\n      cache,\n      'column',\n      scrollBarWidth\n    ),\n\n  getRowOffset: (\n    props,\n    rowIndex,\n    alignment,\n    scrollTop,\n    cache,\n    scrollBarWidth: number\n  ) =>\n    getOffset(\n      props,\n      rowIndex,\n      alignment,\n      scrollTop,\n      cache,\n      'row',\n      scrollBarWidth\n    ),\n\n  getColumnStartIndexForOffset: (props, scrollLeft, cache) =>\n    findItem(props, cache, scrollLeft, 'column'),\n\n  getColumnStopIndexForStartIndex: (props, startIndex, scrollLeft, cache) => {\n    const item = getItemFromCache(props, startIndex, cache, 'column')\n\n    const maxOffset = scrollLeft + (props.width as number)\n\n    let offset = item.offset + item.size\n    let stopIndex = startIndex\n    while (stopIndex < props.totalColumn - 1 && offset < maxOffset) {\n      stopIndex++\n      offset += getItemFromCache(props, startIndex, cache, 'column').size\n    }\n    return stopIndex\n  },\n\n  getEstimatedTotalHeight,\n  getEstimatedTotalWidth,\n\n  getRowStartIndexForOffset: (props, scrollTop, cache) =>\n    findItem(props, cache, scrollTop, 'row'),\n\n  getRowStopIndexForStartIndex: (props, startIndex, scrollTop, cache) => {\n    const { totalRow, height } = props\n    const item = getItemFromCache(props, startIndex, cache, 'row')\n    const maxOffset = scrollTop + (height as number)\n\n    let offset = item.size + item.offset\n    let stopIndex = startIndex\n\n    while (stopIndex < totalRow - 1 && offset < maxOffset) {\n      stopIndex++\n      offset += getItemFromCache(props, stopIndex, cache, 'row').size\n    }\n\n    return stopIndex\n  },\n  injectToInstance: (instance, cache) => {\n    const resetAfter = (\n      { columnIndex, rowIndex }: Indices,\n      forceUpdate?: boolean\n    ) => {\n      forceUpdate = isUndefined(forceUpdate) ? true : forceUpdate\n\n      if (isNumber(columnIndex)) {\n        cache.value.lastVisitedColumnIndex = Math.min(\n          cache.value.lastVisitedColumnIndex,\n          columnIndex - 1\n        )\n      }\n\n      if (isNumber(rowIndex)) {\n        // console.log(rowIndex)\n        cache.value.lastVisitedRowIndex = Math.min(\n          cache.value.lastVisitedRowIndex,\n          rowIndex - 1\n        )\n      }\n\n      instance.exposed?.getItemStyleCache.value(-1, null, null)\n\n      if (forceUpdate) instance.proxy?.$forceUpdate()\n    }\n\n    const resetAfterColumnIndex = (\n      columnIndex: number,\n      forceUpdate: boolean\n    ) => {\n      resetAfter(\n        {\n          columnIndex,\n        },\n        forceUpdate\n      )\n    }\n\n    const resetAfterRowIndex = (rowIndex: number, forceUpdate: boolean) => {\n      resetAfter(\n        {\n          rowIndex,\n        },\n        forceUpdate\n      )\n    }\n\n    Object.assign(instance.proxy, {\n      resetAfterColumnIndex,\n      resetAfterRowIndex,\n      resetAfter,\n    })\n  },\n  initCache: ({\n    estimatedColumnWidth = DEFAULT_DYNAMIC_LIST_ITEM_SIZE,\n    estimatedRowHeight = DEFAULT_DYNAMIC_LIST_ITEM_SIZE,\n  }) => {\n    const cache = {\n      column: {},\n      estimatedColumnWidth,\n      estimatedRowHeight,\n      lastVisitedColumnIndex: -1,\n      lastVisitedRowIndex: -1,\n      row: {},\n    } as GridCache\n\n    // TODO: expose methods.\n    return cache\n  },\n\n  clearCache: false,\n\n  validateProps: ({ columnWidth, rowHeight }) => {\n    if (process.env.NODE_ENV !== 'production') {\n      if (!isFunction(columnWidth)) {\n        throwError(\n          SCOPE,\n          `\n          \"columnWidth\" must be passed as function,\n            instead ${typeof columnWidth} was given.\n        `\n        )\n      }\n\n      if (!isFunction(rowHeight)) {\n        throwError(\n          SCOPE,\n          `\n          \"rowHeight\" must be passed as function,\n            instead ${typeof rowHeight} was given.\n        `\n        )\n      }\n    }\n  },\n})\n\nexport default DynamicSizeGrid\n\nexport type ResetAfterIndex = (idx: number, forceUpdate: boolean) => void\nexport type ResetAfterIndices = (indices: Indices, forceUpdate: boolean) => void\n\nexport type DynamicSizeGridInstance = GridInstance & {\n  resetAfterColumnIndex: ResetAfterIndex\n  resetAfterRowIndex: ResetAfterIndex\n  resetAfter: ResetAfterIndices\n}\n", "<template>\n  <div\n    :class=\"ns.be('group', 'title')\"\n    :style=\"{ ...style, lineHeight: `${height}px` }\"\n  >\n    {{ item.label }}\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport type { CSSProperties, PropType } from 'vue'\n\nexport default defineComponent({\n  props: {\n    item: {\n      type: Object,\n      required: true,\n    },\n    style: {\n      type: Object as PropType<CSSProperties>,\n    },\n    height: Number,\n  },\n  setup() {\n    const ns = useNamespace('select')\n    return {\n      ns,\n    }\n  },\n})\n</script>\n", "import type { IOptionV2Props } from './token'\nimport type { OptionEmitFn } from './defaults'\n\nexport function useOption(\n  props: IOptionV2Props,\n  { emit }: { emit: OptionEmitFn }\n) {\n  return {\n    hoverItem: () => {\n      if (!props.disabled) {\n        emit('hover', props.index)\n      }\n    },\n    selectOptionClick: () => {\n      if (!props.disabled) {\n        emit('select', props.item, props.index)\n      }\n    },\n  }\n}\n", "import { computed } from 'vue'\nimport { get } from 'lodash-unified'\n\nimport type { ISelectV2Props } from './token'\nimport type { Option } from './select.types'\n\nexport interface Props {\n  label?: string\n  value?: string\n  disabled?: string\n  options?: string\n}\n\nexport const defaultProps: Required<Props> = {\n  label: 'label',\n  value: 'value',\n  disabled: 'disabled',\n  options: 'options',\n}\n\nexport function useProps(props: Pick<ISelectV2Props, 'props'>) {\n  const aliasProps = computed(() => ({ ...defaultProps, ...props.props }))\n\n  const getLabel = (option: Option) => get(option, aliasProps.value.label)\n  const getValue = (option: Option) => get(option, aliasProps.value.value)\n  const getDisabled = (option: Option) => get(option, aliasProps.value.disabled)\n  const getOptions = (option: Option) => get(option, aliasProps.value.options)\n\n  return {\n    aliasProps,\n    getLabel,\n    getValue,\n    getDisabled,\n    getOptions,\n  }\n}\n", "import { placements } from '@popperjs/core'\nimport {\n  useAriaProps,\n  useEmptyValuesProps,\n  useSizeProp,\n} from '@element-plus/hooks'\nimport {\n  buildProps,\n  definePropType,\n  iconPropType,\n  isNumber,\n} from '@element-plus/utils'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { useTooltipContentProps } from '@element-plus/components/tooltip'\nimport { CircleClose } from '@element-plus/icons-vue'\nimport { tagProps } from '../../tag'\nimport { defaultProps } from './useProps'\n\nimport type { Option, OptionType } from './select.types'\nimport type { Props } from './useProps'\nimport type { EmitFn } from '@element-plus/utils/vue/typescript'\nimport type { ExtractPropTypes } from 'vue'\nimport type {\n  Options,\n  Placement,\n  PopperEffect,\n} from '@element-plus/components/popper'\n\nexport const SelectProps = buildProps({\n  /**\n   * @description whether creating new items is allowed. To use this, `filterable` must be true\n   */\n  allowCreate: Boolean,\n  /**\n   * @description autocomplete of select input\n   */\n  autocomplete: {\n    type: definePropType<'none' | 'both' | 'list' | 'inline'>(String),\n    default: 'none',\n  },\n  /**\n   * @description for non-filterable Select, this prop decides if the option menu pops up when the input is focused\n   */\n  automaticDropdown: Boolean,\n  /**\n   * @description whether select can be cleared\n   */\n  clearable: Boolean,\n  /**\n   * @description custom clear icon\n   */\n  clearIcon: {\n    type: iconPropType,\n    default: CircleClose,\n  },\n  /**\n   * @description tooltip theme, built-in theme: `dark` / `light`\n   */\n  effect: {\n    type: definePropType<PopperEffect | string>(String),\n    default: 'light',\n  },\n  /**\n   * @description whether to collapse tags to a text when multiple selecting\n   */\n  collapseTags: Boolean,\n  /**\n   * @description whether show all selected tags when mouse hover text of collapse-tags. To use this, `collapse-tags` must be true\n   */\n  collapseTagsTooltip: Boolean,\n  /**\n   * @description The max tags number to be shown. To use this, `collapse-tags` must be true\n   */\n  maxCollapseTags: {\n    type: Number,\n    default: 1,\n  },\n  /**\n   * @description\n   */\n  defaultFirstOption: Boolean,\n  /**\n   * @description is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description\n   */\n  estimatedOptionHeight: {\n    type: Number,\n    default: undefined,\n  },\n  /**\n   * @description is filterable\n   */\n  filterable: Boolean,\n  /**\n   * @description\n   */\n  filterMethod: Function,\n  /**\n   * @description The height of the dropdown panel, 34px for each item\n   */\n  height: {\n    type: Number,\n    default: 274, // same as select dropdown menu\n  },\n  /**\n   * @description The height of the dropdown item\n   */\n  itemHeight: {\n    type: Number,\n    default: 34,\n  },\n  /**\n   * @description\n   */\n  id: String,\n  /**\n   * @description whether Select is loading data from server\n   */\n  loading: Boolean,\n  /**\n   * @description displayed text while loading data from server, default is 'Loading'\n   */\n  loadingText: String,\n  /**\n   * @description biding value\n   */\n  modelValue: {\n    type: definePropType<\n      any[] | string | number | boolean | Record<string, any> | any\n    >([Array, String, Number, Boolean, Object]),\n  },\n  /**\n   * @description is multiple\n   */\n  multiple: Boolean,\n  /**\n   * @description maximum number of options user can select when multiple is true. No limit when set to 0\n   */\n  multipleLimit: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description the name attribute of select input\n   */\n  name: String,\n  /**\n   * @description displayed text when there is no options, you can also use slot empty, the default is 'No Data'\n   */\n  noDataText: String,\n  /**\n   * @description displayed text when no data matches the filtering query, you can also use slot `empty`, default is 'No matching data'\n   */\n  noMatchText: String,\n  /**\n   * @description function that gets called when the input value changes. Its parameter is the current input value. To use this, `filterable` must be true\n   */\n  remoteMethod: Function,\n  /**\n   * @description whether reserve the keyword after select filtered option.\n   */\n  reserveKeyword: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description data of the options, the key of `value` and `label` can be customize by `props`\n   */\n  options: {\n    type: definePropType<OptionType[]>(Array),\n    required: true,\n  },\n  /**\n   * @description placeholder, the default is 'Please select'\n   */\n  placeholder: {\n    type: String,\n  },\n  /**\n   * @description whether select dropdown is teleported to the body\n   */\n  teleported: useTooltipContentProps.teleported,\n  /**\n   * @description when select dropdown is inactive and `persistent` is `false`, select dropdown will be destroyed\n   */\n  persistent: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description custom class name for Select's dropdown\n   */\n  popperClass: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n   */\n  popperOptions: {\n    type: definePropType<Partial<Options>>(Object),\n    default: () => ({} as Partial<Options>),\n  },\n  /**\n   * @description whether search data from server\n   */\n  remote: Boolean,\n  /**\n   * @description size of component\n   */\n  size: useSizeProp,\n  /**\n   * @description configuration options, see the following table\n   */\n  props: {\n    type: definePropType<Props>(Object),\n    default: () => defaultProps,\n  },\n  /**\n   * @description unique identity key name for value, required when value is an object\n   */\n  valueKey: {\n    type: String,\n    default: 'value',\n  },\n  /**\n   * @description Controls whether the scrollbar is always displayed\n   */\n  scrollbarAlwaysOn: Boolean,\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description position of dropdown\n   */\n  placement: {\n    type: definePropType<Placement>(String),\n    values: placements,\n    default: 'bottom-start',\n  },\n  /**\n   * @description list of possible positions for dropdown\n   */\n  fallbackPlacements: {\n    type: definePropType<Placement[]>(Array),\n    default: ['bottom-start', 'top-start', 'right', 'left'],\n  },\n  /**\n   * @description tag type\n   */\n  tagType: { ...tagProps.type, default: 'info' },\n  /**\n   * @description tag effect\n   */\n  tagEffect: { ...tagProps.effect, default: 'light' },\n  ...useEmptyValuesProps,\n  ...useAriaProps(['ariaLabel']),\n} as const)\n\nexport const OptionProps = buildProps({\n  data: Array,\n  disabled: Boolean,\n  hovering: Boolean,\n  item: {\n    type: definePropType<Option>(Object),\n    required: true,\n  },\n  index: Number,\n  style: Object,\n  selected: Boolean,\n  created: Boolean,\n} as const)\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nexport const selectEmits = {\n  [UPDATE_MODEL_EVENT]: (val: ISelectV2Props['modelValue']) => true,\n  [CHANGE_EVENT]: (val: ISelectV2Props['modelValue']) => true,\n  'remove-tag': (val: unknown) => true,\n  'visible-change': (visible: boolean) => true,\n  focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n  blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n  clear: () => true,\n}\nexport const optionEmits = {\n  hover: (index?: number) => isNumber(index),\n  select: (val: Option, index?: number) => true,\n}\n/* eslint-enable @typescript-eslint/no-unused-vars */\n\nexport type ISelectV2Props = ExtractPropTypes<typeof SelectProps>\nexport type IOptionV2Props = ExtractPropTypes<typeof OptionProps>\nexport type SelectEmitFn = EmitFn<typeof selectEmits>\nexport type OptionEmitFn = EmitFn<typeof optionEmits>\n", "import type { IOptionV2Props, ISelectV2Props } from './defaults'\nimport type { InjectionKey, Ref } from 'vue'\nimport type { Option } from './select.types'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\n\nexport interface SelectV2Context {\n  props: ISelectV2Props\n  expanded: Ref<boolean>\n  tooltipRef: Ref<TooltipInstance | undefined>\n  onSelect: (option: Option) => void\n  onHover: (idx?: number) => void\n  onKeyboardNavigate: (direction: 'forward' | 'backward') => void\n  onKeyboardSelect: () => void\n}\n\nexport const selectV2InjectionKey: InjectionKey<SelectV2Context> = Symbol(\n  'ElSelectV2Injection'\n)\nexport type { ISelectV2Props, IOptionV2Props }\n", "<template>\n  <li\n    :aria-selected=\"selected\"\n    :style=\"style\"\n    :class=\"[\n      ns.be('dropdown', 'item'),\n      ns.is('selected', selected),\n      ns.is('disabled', disabled),\n      ns.is('created', created),\n      ns.is('hovering', hovering),\n    ]\"\n    @mouseenter=\"hoverItem\"\n    @click.stop=\"selectOptionClick\"\n  >\n    <slot :item=\"item\" :index=\"index\" :disabled=\"disabled\">\n      <span>{{ getLabel(item) }}</span>\n    </slot>\n  </li>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, inject } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useOption } from './useOption'\nimport { useProps } from './useProps'\nimport { OptionProps, optionEmits } from './defaults'\nimport { selectV2InjectionKey } from './token'\n\nexport default defineComponent({\n  props: OptionProps,\n  emits: optionEmits,\n  setup(props, { emit }) {\n    const select = inject(selectV2InjectionKey)!\n    const ns = useNamespace('select')\n    const { hoverItem, selectOptionClick } = useOption(props, { emit })\n    const { getLabel } = useProps(select.props)\n\n    return {\n      ns,\n      hoverItem,\n      selectOptionClick,\n      getLabel,\n    }\n  },\n})\n</script>\n", "import {\n  computed,\n  defineComponent,\n  inject,\n  ref,\n  toRaw,\n  unref,\n  watch,\n} from 'vue'\nimport { get } from 'lodash-unified'\nimport { isObject, isUndefined } from '@element-plus/utils'\nimport {\n  DynamicSizeList,\n  FixedSizeList,\n} from '@element-plus/components/virtual-list'\nimport { useNamespace } from '@element-plus/hooks'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport GroupItem from './group-item.vue'\nimport OptionItem from './option-item.vue'\nimport { useProps } from './useProps'\n\nimport { selectV2InjectionKey } from './token'\n\nimport type {\n  DynamicSizeListInstance,\n  FixedSizeListInstance,\n  ItemProps,\n} from '@element-plus/components/virtual-list'\nimport type { Option, OptionItemProps } from './select.types'\nimport type {\n  ComponentPublicInstance,\n  ComputedRef,\n  ExtractPropTypes,\n  Ref,\n} from 'vue'\n\nconst props = {\n  loading: Boolean,\n  data: {\n    type: Array,\n    required: true as const,\n  },\n  hoveringIndex: Number,\n  width: Number,\n}\ninterface SelectDropdownExposed {\n  listRef: Ref<FixedSizeListInstance | DynamicSizeListInstance | undefined>\n  isSized: ComputedRef<boolean>\n  isItemDisabled: (modelValue: any[] | any, selected: boolean) => boolean\n  isItemHovering: (target: number) => boolean\n  isItemSelected: (modelValue: any[] | any, target: Option) => boolean\n  scrollToItem: (index: number) => void\n  resetScrollTop: () => void\n}\nexport type SelectDropdownInstance = ComponentPublicInstance<\n  ExtractPropTypes<typeof props>,\n  SelectDropdownExposed\n>\nexport default defineComponent({\n  name: 'ElSelectDropdown',\n  props,\n  setup(props, { slots, expose }) {\n    const select = inject(selectV2InjectionKey)!\n    const ns = useNamespace('select')\n    const { getLabel, getValue, getDisabled } = useProps(select.props)\n\n    const cachedHeights = ref<Array<number>>([])\n\n    const listRef = ref<FixedSizeListInstance | DynamicSizeListInstance>()\n\n    const size = computed(() => props.data.length)\n    watch(\n      () => size.value,\n      () => {\n        select.tooltipRef.value!.updatePopper?.()\n      }\n    )\n\n    const isSized = computed(() =>\n      isUndefined(select.props.estimatedOptionHeight)\n    )\n    const listProps = computed(() => {\n      if (isSized.value) {\n        return {\n          itemSize: select.props.itemHeight,\n        }\n      }\n\n      return {\n        estimatedSize: select.props.estimatedOptionHeight,\n        itemSize: (idx: number) => cachedHeights.value[idx],\n      }\n    })\n\n    const contains = (arr: Array<any> = [], target: any) => {\n      const {\n        props: { valueKey },\n      } = select\n\n      if (!isObject(target)) {\n        return arr.includes(target)\n      }\n\n      return (\n        arr &&\n        arr.some((item) => {\n          return toRaw(get(item, valueKey)) === get(target, valueKey)\n        })\n      )\n    }\n    const isEqual = (selected: unknown, target: unknown) => {\n      if (!isObject(target)) {\n        return selected === target\n      } else {\n        const { valueKey } = select.props\n        return get(selected, valueKey) === get(target, valueKey)\n      }\n    }\n\n    const isItemSelected: SelectDropdownExposed['isItemSelected'] = (\n      modelValue,\n      target\n    ) => {\n      if (select.props.multiple) {\n        return contains(modelValue, getValue(target))\n      }\n      return isEqual(modelValue, getValue(target))\n    }\n\n    const isItemDisabled: SelectDropdownExposed['isItemDisabled'] = (\n      modelValue,\n      selected\n    ) => {\n      const { disabled, multiple, multipleLimit } = select.props\n      return (\n        disabled ||\n        (!selected &&\n          (multiple\n            ? multipleLimit > 0 && modelValue.length >= multipleLimit\n            : false))\n      )\n    }\n\n    const isItemHovering: SelectDropdownExposed['isItemHovering'] = (target) =>\n      props.hoveringIndex === target\n\n    const scrollToItem: SelectDropdownExposed['scrollToItem'] = (index) => {\n      const list = listRef.value\n      if (list) {\n        list.scrollToItem(index)\n      }\n    }\n\n    const resetScrollTop: SelectDropdownExposed['resetScrollTop'] = () => {\n      const list = listRef.value\n      if (list) {\n        list.resetScrollTop()\n      }\n    }\n    const exposed: SelectDropdownExposed = {\n      listRef,\n      isSized,\n\n      isItemDisabled,\n      isItemHovering,\n      isItemSelected,\n      scrollToItem,\n      resetScrollTop,\n    }\n    expose(exposed)\n\n    const Item = (itemProps: ItemProps<any>) => {\n      const { index, data, style } = itemProps\n      const sized = unref(isSized)\n      const { itemSize, estimatedSize } = unref(listProps)\n      const { modelValue } = select.props\n      const { onSelect, onHover } = select\n      const item = data[index]\n      if (item.type === 'Group') {\n        return (\n          <GroupItem\n            item={item}\n            style={style}\n            height={sized ? (itemSize as number) : estimatedSize}\n          />\n        )\n      }\n\n      const isSelected = isItemSelected(modelValue, item)\n      const isDisabled = isItemDisabled(modelValue, isSelected)\n      const isHovering = isItemHovering(index)\n      return (\n        <OptionItem\n          {...itemProps}\n          selected={isSelected}\n          disabled={getDisabled(item) || isDisabled}\n          created={!!item.created}\n          hovering={isHovering}\n          item={item}\n          onSelect={onSelect}\n          onHover={onHover}\n        >\n          {{\n            default: (props: OptionItemProps) =>\n              slots.default?.(props) || <span>{getLabel(item)}</span>,\n          }}\n        </OptionItem>\n      )\n    }\n\n    // computed\n    const { onKeyboardNavigate, onKeyboardSelect } = select\n\n    const onForward = () => {\n      onKeyboardNavigate('forward')\n    }\n\n    const onBackward = () => {\n      onKeyboardNavigate('backward')\n    }\n\n    const onEscOrTab = () => {\n      // The following line actually doesn't work. Fixing it may introduce a small breaking change for some users, so just comment it out for now.\n      // select.expanded = false\n    }\n\n    const onKeydown = (e: KeyboardEvent) => {\n      const { code } = e\n      const { tab, esc, down, up, enter } = EVENT_CODE\n      if (code !== tab) {\n        e.preventDefault()\n        e.stopPropagation()\n      }\n\n      switch (code) {\n        case tab:\n        case esc: {\n          onEscOrTab()\n          break\n        }\n        case down: {\n          onForward()\n          break\n        }\n        case up: {\n          onBackward()\n          break\n        }\n        case enter: {\n          onKeyboardSelect()\n          break\n        }\n      }\n    }\n\n    return () => {\n      const { data, width } = props\n      const { height, multiple, scrollbarAlwaysOn } = select.props\n\n      const List = unref(isSized) ? FixedSizeList : DynamicSizeList\n\n      return (\n        <div\n          class={[ns.b('dropdown'), ns.is('multiple', multiple)]}\n          style={{\n            width: `${width}px`,\n          }}\n        >\n          {slots.header?.()}\n          {slots.loading?.() || slots.empty?.() || (\n            <List\n              ref={listRef}\n              {...unref(listProps)}\n              className={ns.be('dropdown', 'list')}\n              scrollbarAlwaysOn={scrollbarAlwaysOn}\n              data={data}\n              height={height}\n              width={width}\n              total={data.length}\n              // @ts-ignore - dts problem\n              onKeydown={onKeydown}\n            >\n              {{\n                default: (props: ItemProps<any>) => <Item {...props} />,\n              }}\n            </List>\n          )}\n          {slots.footer?.()}\n        </div>\n      )\n    }\n  },\n})\n", "import { computed, ref } from 'vue'\nimport { useProps } from './useProps'\nimport type { ISelectV2Props } from './token'\nimport type { Option, SelectStates } from './select.types'\n\nexport function useAllowCreate(props: ISelectV2Props, states: SelectStates) {\n  const { aliasProps, getLabel, getValue } = useProps(props)\n\n  const createOptionCount = ref(0)\n  const cachedSelectedOption = ref<Option>()\n\n  const enableAllowCreateMode = computed(() => {\n    return props.allowCreate && props.filterable\n  })\n\n  function hasExistingOption(query: string) {\n    const hasOption = (option: Option) => getLabel(option) === query\n    return (\n      (props.options && props.options.some(hasOption)) ||\n      states.createdOptions.some(hasOption)\n    )\n  }\n\n  function selectNewOption(option: Option) {\n    if (!enableAllowCreateMode.value) {\n      return\n    }\n    if (props.multiple && option.created) {\n      createOptionCount.value++\n    } else {\n      cachedSelectedOption.value = option\n    }\n  }\n\n  function createNewOption(query: string) {\n    if (enableAllowCreateMode.value) {\n      if (query && query.length > 0) {\n        if (hasExistingOption(query)) {\n          return\n        }\n        const newOption = {\n          [aliasProps.value.value]: query,\n          [aliasProps.value.label]: query,\n          created: true,\n          [aliasProps.value.disabled]: false,\n        }\n        if (states.createdOptions.length >= createOptionCount.value) {\n          states.createdOptions[createOptionCount.value] = newOption\n        } else {\n          states.createdOptions.push(newOption)\n        }\n      } else {\n        if (props.multiple) {\n          states.createdOptions.length = createOptionCount.value\n        } else {\n          const selectedOption = cachedSelectedOption.value\n          states.createdOptions.length = 0\n          if (selectedOption && selectedOption.created) {\n            states.createdOptions.push(selectedOption)\n          }\n        }\n      }\n    }\n  }\n\n  function removeNewOption(option: Option) {\n    if (\n      !enableAllowCreateMode.value ||\n      !option ||\n      !option.created ||\n      (option.created &&\n        props.reserveKeyword &&\n        states.inputValue === getLabel(option))\n    ) {\n      return\n    }\n    const idx = states.createdOptions.findIndex(\n      (it) => getValue(it) === getValue(option)\n    )\n    if (~idx) {\n      states.createdOptions.splice(idx, 1)\n      createOptionCount.value--\n    }\n  }\n\n  function clearAllNewOption() {\n    if (enableAllowCreateMode.value) {\n      states.createdOptions.length = 0\n      createOptionCount.value = 0\n    }\n  }\n\n  return {\n    createNewOption,\n    removeNewOption,\n    selectNewOption,\n    clearAllNewOption,\n  }\n}\n", "import {\n  computed,\n  nextTick,\n  onMounted,\n  reactive,\n  ref,\n  watch,\n  watchEffect,\n} from 'vue'\nimport {\n  findLastIndex,\n  get,\n  isEqual,\n  debounce as lodashDebounce,\n} from 'lodash-unified'\nimport { useResizeObserver } from '@vueuse/core'\nimport {\n  ValidateComponentsMap,\n  debugWarn,\n  escapeStringRegexp,\n  isArray,\n  isFunction,\n  isObject,\n} from '@element-plus/utils'\nimport {\n  useComposition,\n  useEmptyValues,\n  useFocusController,\n  useLocale,\n  useNamespace,\n} from '@element-plus/hooks'\nimport {\n  CHANGE_EVENT,\n  EVENT_CODE,\n  UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport {\n  useFormItem,\n  useFormItemInputId,\n  useFormSize,\n} from '@element-plus/components/form'\n\nimport { ArrowDown } from '@element-plus/icons-vue'\nimport { useAllowCreate } from './useAllowCreate'\nimport { useProps } from './useProps'\n\nimport type { Option, OptionType, SelectStates } from './select.types'\nimport type { ISelectV2Props } from './token'\nimport type { SelectEmitFn } from './defaults'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { SelectDropdownInstance } from './select-dropdown'\n\nconst MINIMUM_INPUT_WIDTH = 11\n\nconst useSelect = (props: ISelectV2Props, emit: SelectEmitFn) => {\n  // inject\n  const { t } = useLocale()\n  const nsSelect = useNamespace('select')\n  const nsInput = useNamespace('input')\n  const { form: elForm, formItem: elFormItem } = useFormItem()\n  const { inputId } = useFormItemInputId(props, {\n    formItemContext: elFormItem,\n  })\n  const { aliasProps, getLabel, getValue, getDisabled, getOptions } =\n    useProps(props)\n  const { valueOnClear, isEmptyValue } = useEmptyValues(props)\n\n  const states: SelectStates = reactive({\n    inputValue: '',\n    cachedOptions: [],\n    createdOptions: [],\n    hoveringIndex: -1,\n    inputHovering: false,\n    selectionWidth: 0,\n    calculatorWidth: 0,\n    collapseItemWidth: 0,\n    previousQuery: null,\n    previousValue: undefined,\n    selectedLabel: '',\n    menuVisibleOnFocus: false,\n    isBeforeHide: false,\n  })\n\n  // data refs\n  const popperSize = ref(-1)\n\n  // DOM & Component refs\n  const selectRef = ref<HTMLElement>()\n  const selectionRef = ref<HTMLElement>()\n  const tooltipRef = ref<TooltipInstance>()\n  const tagTooltipRef = ref<TooltipInstance>()\n  const inputRef = ref<HTMLElement>()\n  const calculatorRef = ref<HTMLElement>()\n  const prefixRef = ref<HTMLElement>()\n  const suffixRef = ref<HTMLElement>()\n  const menuRef = ref<SelectDropdownInstance>()\n  const tagMenuRef = ref<HTMLElement>()\n  const collapseItemRef = ref<HTMLElement>()\n\n  const {\n    isComposing,\n    handleCompositionStart,\n    handleCompositionEnd,\n    handleCompositionUpdate,\n  } = useComposition({\n    afterComposition: (e) => onInput(e),\n  })\n\n  const { wrapperRef, isFocused } = useFocusController(inputRef, {\n    beforeFocus() {\n      return selectDisabled.value\n    },\n    afterFocus() {\n      if (props.automaticDropdown && !expanded.value) {\n        expanded.value = true\n        states.menuVisibleOnFocus = true\n      }\n    },\n    beforeBlur(event) {\n      return (\n        tooltipRef.value?.isFocusInsideContent(event) ||\n        tagTooltipRef.value?.isFocusInsideContent(event)\n      )\n    },\n    afterBlur() {\n      expanded.value = false\n      states.menuVisibleOnFocus = false\n    },\n  })\n\n  const allOptions = ref<OptionType[]>([])\n  const filteredOptions = ref<OptionType[]>([])\n  // the controller of the expanded popup\n  const expanded = ref(false)\n\n  const selectDisabled = computed(() => props.disabled || elForm?.disabled)\n\n  const popupHeight = computed(() => {\n    const totalHeight = filteredOptions.value.length * props.itemHeight\n    return totalHeight > props.height ? props.height : totalHeight\n  })\n\n  const hasModelValue = computed(() => {\n    return props.multiple\n      ? isArray(props.modelValue) && props.modelValue.length > 0\n      : !isEmptyValue(props.modelValue)\n  })\n\n  const showClearBtn = computed(() => {\n    return (\n      props.clearable &&\n      !selectDisabled.value &&\n      states.inputHovering &&\n      hasModelValue.value\n    )\n  })\n\n  const iconComponent = computed(() =>\n    props.remote && props.filterable ? '' : ArrowDown\n  )\n\n  const iconReverse = computed(\n    () => iconComponent.value && nsSelect.is('reverse', expanded.value)\n  )\n\n  const validateState = computed(() => elFormItem?.validateState || '')\n  const validateIcon = computed(() => {\n    // When we use indexed access to get the type of an undeclared property,\n    // the unsafe type `any` will be inferred, which TypeScript throws an error to emphasize it.\n    // To avoid TypeScript complaining about it, we use truthiness narrowing to narrow the type of validateState.\n    if (!validateState.value) return\n    return ValidateComponentsMap[validateState.value]\n  })\n\n  const debounce = computed(() => (props.remote ? 300 : 0))\n\n  // filteredOptions includes flatten the data into one dimensional array.\n  const emptyText = computed(() => {\n    if (props.loading) {\n      return props.loadingText || t('el.select.loading')\n    } else {\n      if (props.remote && !states.inputValue && allOptions.value.length === 0)\n        return false\n      if (\n        props.filterable &&\n        states.inputValue &&\n        allOptions.value.length > 0 &&\n        filteredOptions.value.length === 0\n      ) {\n        return props.noMatchText || t('el.select.noMatch')\n      }\n      if (allOptions.value.length === 0) {\n        return props.noDataText || t('el.select.noData')\n      }\n    }\n    return null\n  })\n\n  const filterOptions = (query: string) => {\n    const isValidOption = (o: Option): boolean => {\n      if (props.filterable && isFunction(props.filterMethod)) return true\n      if (props.filterable && props.remote && isFunction(props.remoteMethod))\n        return true\n      // when query was given, we should test on the label see whether the label contains the given query\n      const regexp = new RegExp(escapeStringRegexp(query), 'i')\n      return query ? regexp.test(getLabel(o) || '') : true\n    }\n    if (props.loading) {\n      return []\n    }\n\n    return [...states.createdOptions, ...props.options].reduce((all, item) => {\n      const options = getOptions(item)\n\n      if (isArray(options)) {\n        const filtered = options.filter(isValidOption)\n\n        if (filtered.length > 0) {\n          all.push(\n            {\n              label: getLabel(item),\n              type: 'Group',\n            },\n            ...filtered\n          )\n        }\n      } else if (props.remote || isValidOption(item)) {\n        all.push(item)\n      }\n\n      return all\n    }, []) as OptionType[]\n  }\n\n  const updateOptions = () => {\n    allOptions.value = filterOptions('')\n    filteredOptions.value = filterOptions(states.inputValue)\n  }\n\n  const allOptionsValueMap = computed(() => {\n    const valueMap = new Map()\n\n    allOptions.value.forEach((option, index) => {\n      valueMap.set(getValueKey(getValue(option)), { option, index })\n    })\n    return valueMap\n  })\n\n  const filteredOptionsValueMap = computed(() => {\n    const valueMap = new Map()\n\n    filteredOptions.value.forEach((option, index) => {\n      valueMap.set(getValueKey(getValue(option)), { option, index })\n    })\n    return valueMap\n  })\n\n  const optionsAllDisabled = computed(() =>\n    filteredOptions.value.every((option) => getDisabled(option))\n  )\n\n  const selectSize = useFormSize()\n\n  const collapseTagSize = computed(() =>\n    'small' === selectSize.value ? 'small' : 'default'\n  )\n\n  const calculatePopperSize = () => {\n    popperSize.value = selectRef.value?.offsetWidth || 200\n  }\n\n  const getGapWidth = () => {\n    if (!selectionRef.value) return 0\n    const style = window.getComputedStyle(selectionRef.value)\n    return Number.parseFloat(style.gap || '6px')\n  }\n\n  // computed style\n  const tagStyle = computed(() => {\n    const gapWidth = getGapWidth()\n    const maxWidth =\n      collapseItemRef.value && props.maxCollapseTags === 1\n        ? states.selectionWidth - states.collapseItemWidth - gapWidth\n        : states.selectionWidth\n    return { maxWidth: `${maxWidth}px` }\n  })\n\n  const collapseTagStyle = computed(() => {\n    return { maxWidth: `${states.selectionWidth}px` }\n  })\n\n  const inputStyle = computed(() => ({\n    width: `${Math.max(states.calculatorWidth, MINIMUM_INPUT_WIDTH)}px`,\n  }))\n\n  const shouldShowPlaceholder = computed(() => {\n    if (isArray(props.modelValue)) {\n      return props.modelValue.length === 0 && !states.inputValue\n    }\n\n    // when it's not multiple mode, we only determine this flag based on filterable and expanded\n    // when filterable flag is true, which means we have input box on the screen\n    return props.filterable ? !states.inputValue : true\n  })\n\n  const currentPlaceholder = computed(() => {\n    const _placeholder = props.placeholder ?? t('el.select.placeholder')\n    return props.multiple || !hasModelValue.value\n      ? _placeholder\n      : states.selectedLabel\n  })\n\n  // this obtains the actual popper DOM element.\n  const popperRef = computed(() => tooltipRef.value?.popperRef?.contentRef)\n\n  // the index with current value in options\n  const indexRef = computed<number>(() => {\n    if (props.multiple) {\n      const len = (props.modelValue as []).length\n      if (\n        (props.modelValue as Array<any>).length > 0 &&\n        filteredOptionsValueMap.value.has(props.modelValue[len - 1])\n      ) {\n        const { index } = filteredOptionsValueMap.value.get(\n          props.modelValue[len - 1]\n        )\n        return index\n      }\n    } else {\n      if (\n        props.modelValue &&\n        filteredOptionsValueMap.value.has(props.modelValue)\n      ) {\n        const { index } = filteredOptionsValueMap.value.get(props.modelValue)\n        return index\n      }\n    }\n    return -1\n  })\n\n  const dropdownMenuVisible = computed({\n    get() {\n      return expanded.value && emptyText.value !== false\n    },\n    set(val: boolean) {\n      expanded.value = val\n    },\n  })\n\n  const showTagList = computed(() => {\n    if (!props.multiple) {\n      return []\n    }\n    return props.collapseTags\n      ? states.cachedOptions.slice(0, props.maxCollapseTags)\n      : states.cachedOptions\n  })\n\n  const collapseTagList = computed(() => {\n    if (!props.multiple) {\n      return []\n    }\n    return props.collapseTags\n      ? states.cachedOptions.slice(props.maxCollapseTags)\n      : []\n  })\n\n  // hooks\n  const {\n    createNewOption,\n    removeNewOption,\n    selectNewOption,\n    clearAllNewOption,\n  } = useAllowCreate(props, states)\n\n  // methods\n  const toggleMenu = () => {\n    if (selectDisabled.value) return\n\n    if (states.menuVisibleOnFocus) {\n      // controlled by automaticDropdown\n      states.menuVisibleOnFocus = false\n    } else {\n      expanded.value = !expanded.value\n    }\n  }\n\n  const onInputChange = () => {\n    if (states.inputValue.length > 0 && !expanded.value) {\n      expanded.value = true\n    }\n    createNewOption(states.inputValue)\n    handleQueryChange(states.inputValue)\n  }\n\n  const debouncedOnInputChange = lodashDebounce(onInputChange, debounce.value)\n\n  const handleQueryChange = (val: string) => {\n    if (states.previousQuery === val || isComposing.value) {\n      return\n    }\n    states.previousQuery = val\n    if (props.filterable && isFunction(props.filterMethod)) {\n      props.filterMethod(val)\n    } else if (\n      props.filterable &&\n      props.remote &&\n      isFunction(props.remoteMethod)\n    ) {\n      props.remoteMethod(val)\n    }\n    if (\n      props.defaultFirstOption &&\n      (props.filterable || props.remote) &&\n      filteredOptions.value.length\n    ) {\n      nextTick(checkDefaultFirstOption)\n    } else {\n      nextTick(updateHoveringIndex)\n    }\n  }\n\n  /**\n   * find and highlight first option as default selected\n   * @remark\n   * - if the first option in dropdown list is user-created,\n   *   it would be at the end of the optionsArray\n   *   so find it and set hover.\n   *   (NOTE: there must be only one user-created option in dropdown list with query)\n   * - if there's no user-created option in list, just find the first one as usual\n   *   (NOTE: exclude options that are disabled or in disabled-group)\n   */\n  const checkDefaultFirstOption = () => {\n    const optionsInDropdown = filteredOptions.value.filter(\n      (n) => !n.disabled && n.type !== 'Group'\n    )\n    const userCreatedOption = optionsInDropdown.find((n) => n.created)\n    const firstOriginOption = optionsInDropdown[0]\n    states.hoveringIndex = getValueIndex(\n      filteredOptions.value,\n      userCreatedOption || firstOriginOption\n    )\n  }\n\n  const emitChange = (val: any | any[]) => {\n    if (!isEqual(props.modelValue, val)) {\n      emit(CHANGE_EVENT, val)\n    }\n  }\n\n  const update = (val: any) => {\n    emit(UPDATE_MODEL_EVENT, val)\n    emitChange(val)\n    states.previousValue = props.multiple ? String(val) : val\n  }\n\n  const getValueIndex = (arr: unknown[] = [], value: unknown) => {\n    if (!isObject(value)) {\n      return arr.indexOf(value)\n    }\n    const valueKey = props.valueKey\n    let index = -1\n    arr.some((item, i) => {\n      if (get(item, valueKey) === get(value, valueKey)) {\n        index = i\n        return true\n      }\n      return false\n    })\n    return index\n  }\n\n  const getValueKey = (item: unknown) => {\n    return isObject(item) ? get(item, props.valueKey) : item\n  }\n\n  const handleResize = () => {\n    calculatePopperSize()\n  }\n\n  const resetSelectionWidth = () => {\n    states.selectionWidth = selectionRef.value!.getBoundingClientRect().width\n  }\n\n  const resetCalculatorWidth = () => {\n    states.calculatorWidth = calculatorRef.value!.getBoundingClientRect().width\n  }\n\n  const resetCollapseItemWidth = () => {\n    states.collapseItemWidth =\n      collapseItemRef.value!.getBoundingClientRect().width\n  }\n\n  const updateTooltip = () => {\n    tooltipRef.value?.updatePopper?.()\n  }\n\n  const updateTagTooltip = () => {\n    tagTooltipRef.value?.updatePopper?.()\n  }\n\n  const onSelect = (option: Option) => {\n    if (props.multiple) {\n      let selectedOptions = (props.modelValue as any[]).slice()\n\n      const index = getValueIndex(selectedOptions, getValue(option))\n      if (index > -1) {\n        selectedOptions = [\n          ...selectedOptions.slice(0, index),\n          ...selectedOptions.slice(index + 1),\n        ]\n        states.cachedOptions.splice(index, 1)\n        removeNewOption(option)\n      } else if (\n        props.multipleLimit <= 0 ||\n        selectedOptions.length < props.multipleLimit\n      ) {\n        selectedOptions = [...selectedOptions, getValue(option)]\n        states.cachedOptions.push(option)\n        selectNewOption(option)\n      }\n      update(selectedOptions)\n      if (option.created) {\n        handleQueryChange('')\n      }\n      if (props.filterable && !props.reserveKeyword) {\n        states.inputValue = ''\n      }\n    } else {\n      states.selectedLabel = getLabel(option)\n      update(getValue(option))\n      expanded.value = false\n      selectNewOption(option)\n      if (!option.created) {\n        clearAllNewOption()\n      }\n    }\n    focus()\n  }\n\n  const deleteTag = (event: MouseEvent, option: Option) => {\n    let selectedOptions = (props.modelValue as any[]).slice()\n\n    const index = getValueIndex(selectedOptions, getValue(option))\n\n    if (index > -1 && !selectDisabled.value) {\n      selectedOptions = [\n        ...(props.modelValue as Array<unknown>).slice(0, index),\n        ...(props.modelValue as Array<unknown>).slice(index + 1),\n      ]\n      states.cachedOptions.splice(index, 1)\n      update(selectedOptions)\n      emit('remove-tag', getValue(option))\n      removeNewOption(option)\n    }\n    event.stopPropagation()\n    focus()\n  }\n\n  const focus = () => {\n    inputRef.value?.focus()\n  }\n\n  const blur = () => {\n    inputRef.value?.blur()\n  }\n\n  // keyboard handlers\n  const handleEsc = () => {\n    if (states.inputValue.length > 0) {\n      states.inputValue = ''\n    } else {\n      expanded.value = false\n    }\n  }\n\n  const getLastNotDisabledIndex = (value: unknown[]) =>\n    findLastIndex(\n      value,\n      (it) =>\n        !states.cachedOptions.some(\n          (option) => getValue(option) === it && getDisabled(option)\n        )\n    )\n\n  const handleDel = (e: KeyboardEvent) => {\n    if (!props.multiple) return\n    if (e.code === EVENT_CODE.delete) return\n    if (states.inputValue.length === 0) {\n      e.preventDefault()\n      const selected = (props.modelValue as Array<any>).slice()\n      const lastNotDisabledIndex = getLastNotDisabledIndex(selected)\n      if (lastNotDisabledIndex < 0) return\n      const removeTagValue = selected[lastNotDisabledIndex]\n      selected.splice(lastNotDisabledIndex, 1)\n      const option = states.cachedOptions[lastNotDisabledIndex]\n      states.cachedOptions.splice(lastNotDisabledIndex, 1)\n      removeNewOption(option)\n      update(selected)\n      emit('remove-tag', removeTagValue)\n    }\n  }\n\n  const handleClear = () => {\n    let emptyValue: string | any[]\n    if (isArray(props.modelValue)) {\n      emptyValue = []\n    } else {\n      emptyValue = valueOnClear.value\n    }\n\n    if (props.multiple) {\n      states.cachedOptions = []\n    } else {\n      states.selectedLabel = ''\n    }\n    expanded.value = false\n    update(emptyValue)\n    emit('clear')\n    clearAllNewOption()\n    focus()\n  }\n\n  const onKeyboardNavigate = (\n    direction: 'forward' | 'backward',\n    hoveringIndex: number | undefined = undefined\n  ): void => {\n    const options = filteredOptions.value\n    if (\n      !['forward', 'backward'].includes(direction) ||\n      selectDisabled.value ||\n      options.length <= 0 ||\n      optionsAllDisabled.value ||\n      isComposing.value\n    ) {\n      return\n    }\n    if (!expanded.value) {\n      return toggleMenu()\n    }\n    if (hoveringIndex === undefined) {\n      hoveringIndex = states.hoveringIndex\n    }\n    let newIndex = -1\n    if (direction === 'forward') {\n      newIndex = hoveringIndex + 1\n      if (newIndex >= options.length) {\n        // return to the first option\n        newIndex = 0\n      }\n    } else if (direction === 'backward') {\n      newIndex = hoveringIndex - 1\n      if (newIndex < 0 || newIndex >= options.length) {\n        // navigate to the last one\n        newIndex = options.length - 1\n      }\n    }\n    const option = options[newIndex]\n    if (getDisabled(option) || option.type === 'Group') {\n      // prevent dispatching multiple nextTick callbacks.\n      return onKeyboardNavigate(direction, newIndex)\n    } else {\n      states.hoveringIndex = newIndex\n      scrollToItem(newIndex)\n    }\n  }\n\n  const onKeyboardSelect = () => {\n    if (!expanded.value) {\n      return toggleMenu()\n    } else if (\n      ~states.hoveringIndex &&\n      filteredOptions.value[states.hoveringIndex]\n    ) {\n      onSelect(filteredOptions.value[states.hoveringIndex])\n    }\n  }\n\n  const onHoverOption = (idx?: number) => {\n    states.hoveringIndex = idx ?? -1\n  }\n\n  const updateHoveringIndex = () => {\n    if (!props.multiple) {\n      states.hoveringIndex = filteredOptions.value.findIndex((item) => {\n        return getValueKey(item) === getValueKey(props.modelValue)\n      })\n    } else {\n      states.hoveringIndex = filteredOptions.value.findIndex((item) =>\n        props.modelValue.some(\n          (modelValue: unknown) => getValueKey(modelValue) === getValueKey(item)\n        )\n      )\n    }\n  }\n\n  const onInput = (event: Event) => {\n    states.inputValue = (event.target as HTMLInputElement).value\n    if (props.remote) {\n      debouncedOnInputChange()\n    } else {\n      return onInputChange()\n    }\n  }\n\n  const handleClickOutside = () => {\n    expanded.value = false\n    isFocused.value && blur()\n  }\n\n  const handleMenuEnter = () => {\n    states.isBeforeHide = false\n    return nextTick(() => {\n      if (~indexRef.value) {\n        scrollToItem(states.hoveringIndex)\n      }\n    })\n  }\n\n  const scrollToItem = (index: number) => {\n    menuRef.value!.scrollToItem(index)\n  }\n\n  const getOption = (value: unknown, cachedOptions?: Option[]) => {\n    // match the option with the given value, if not found, create a new option\n    const selectValue = getValueKey(value)\n\n    if (allOptionsValueMap.value.has(selectValue)) {\n      const { option } = allOptionsValueMap.value.get(selectValue)\n\n      return option\n    }\n    if (cachedOptions && cachedOptions.length) {\n      const option = cachedOptions.find(\n        (option) => getValueKey(getValue(option)) === selectValue\n      )\n      if (option) {\n        return option\n      }\n    }\n\n    return {\n      [aliasProps.value.value]: value,\n      [aliasProps.value.label]: value,\n    }\n  }\n\n  const initStates = () => {\n    if (props.multiple) {\n      if ((props.modelValue as Array<any>).length > 0) {\n        const cachedOptions = states.cachedOptions.slice()\n        states.cachedOptions.length = 0\n        states.previousValue = props.modelValue.toString()\n\n        for (const value of props.modelValue) {\n          const option = getOption(value, cachedOptions)\n          states.cachedOptions.push(option)\n        }\n      } else {\n        states.cachedOptions = []\n        states.previousValue = undefined\n      }\n    } else {\n      if (hasModelValue.value) {\n        states.previousValue = props.modelValue\n        const options = filteredOptions.value\n        const selectedItemIndex = options.findIndex(\n          (option) =>\n            getValueKey(getValue(option)) === getValueKey(props.modelValue)\n        )\n        if (~selectedItemIndex) {\n          states.selectedLabel = getLabel(options[selectedItemIndex])\n        } else {\n          states.selectedLabel = getValueKey(props.modelValue)\n        }\n      } else {\n        states.selectedLabel = ''\n        states.previousValue = undefined\n      }\n    }\n    clearAllNewOption()\n    calculatePopperSize()\n  }\n\n  // in order to track these individually, we need to turn them into refs instead of watching the entire\n  // reactive object which could cause perf penalty when unnecessary field gets changed the watch method will\n  // be invoked.\n\n  watch(expanded, (val) => {\n    if (val) {\n      handleQueryChange('')\n    } else {\n      states.inputValue = ''\n      states.previousQuery = null\n      states.isBeforeHide = true\n      createNewOption('')\n    }\n    emit('visible-change', val)\n  })\n\n  watch(\n    () => props.modelValue,\n    (val, oldVal) => {\n      if (\n        !val ||\n        (props.multiple && val.toString() !== states.previousValue) ||\n        (!props.multiple &&\n          getValueKey(val) !== getValueKey(states.previousValue))\n      ) {\n        initStates()\n      }\n      if (!isEqual(val, oldVal) && props.validateEvent) {\n        elFormItem?.validate?.('change').catch((err) => debugWarn(err))\n      }\n    },\n    {\n      deep: true,\n    }\n  )\n\n  watch(\n    () => props.options,\n    () => {\n      const input = inputRef.value\n      // filter or remote-search scenarios are not initialized\n      if (!input || (input && document.activeElement !== input)) {\n        initStates()\n      }\n    },\n    {\n      deep: true,\n      flush: 'post',\n    }\n  )\n\n  // fix the problem that scrollTop is not reset in filterable mode\n  watch(\n    () => filteredOptions.value,\n    () => {\n      return menuRef.value && nextTick(menuRef.value.resetScrollTop)\n    }\n  )\n\n  watchEffect(() => {\n    // Anything could cause options changed, then update options\n    // If you want to control it by condition, write here\n    if (states.isBeforeHide) return\n    updateOptions()\n  })\n\n  watchEffect(() => {\n    const { valueKey, options } = props\n    const duplicateValue = new Map()\n    for (const item of options) {\n      const optionValue = getValue(item)\n      let v = optionValue\n      if (isObject(v)) {\n        v = get(optionValue, valueKey)\n      }\n      if (duplicateValue.get(v)) {\n        debugWarn(\n          'ElSelectV2',\n          `The option values you provided seem to be duplicated, which may cause some problems, please check.`\n        )\n        break\n      } else {\n        duplicateValue.set(v, true)\n      }\n    }\n  })\n\n  onMounted(() => {\n    initStates()\n  })\n  useResizeObserver(selectRef, handleResize)\n  useResizeObserver(selectionRef, resetSelectionWidth)\n  useResizeObserver(calculatorRef, resetCalculatorWidth)\n  useResizeObserver(menuRef, updateTooltip)\n  useResizeObserver(wrapperRef, updateTooltip)\n  useResizeObserver(tagMenuRef, updateTagTooltip)\n  useResizeObserver(collapseItemRef, resetCollapseItemWidth)\n\n  return {\n    // data exports\n    inputId,\n    collapseTagSize,\n    currentPlaceholder,\n    expanded,\n    emptyText,\n    popupHeight,\n    debounce,\n    allOptions,\n    filteredOptions,\n    iconComponent,\n    iconReverse,\n    tagStyle,\n    collapseTagStyle,\n    inputStyle,\n    popperSize,\n    dropdownMenuVisible,\n    hasModelValue,\n    shouldShowPlaceholder,\n    selectDisabled,\n    selectSize,\n    showClearBtn,\n    states,\n    isFocused,\n    nsSelect,\n    nsInput,\n\n    // refs items exports\n    calculatorRef,\n    inputRef,\n    menuRef,\n    tagMenuRef,\n    tooltipRef,\n    tagTooltipRef,\n    selectRef,\n    wrapperRef,\n    selectionRef,\n    prefixRef,\n    suffixRef,\n    collapseItemRef,\n\n    popperRef,\n\n    validateState,\n    validateIcon,\n    showTagList,\n    collapseTagList,\n\n    // methods exports\n    debouncedOnInputChange,\n    deleteTag,\n    getLabel,\n    getValue,\n    getDisabled,\n    getValueKey,\n    handleClear,\n    handleClickOutside,\n    handleDel,\n    handleEsc,\n    focus,\n    blur,\n    handleMenuEnter,\n    handleResize,\n    resetSelectionWidth,\n    resetCalculatorWidth,\n    updateTooltip,\n    updateTagTooltip,\n    updateOptions,\n    toggleMenu,\n    scrollTo: scrollToItem,\n    onInput,\n    onKeyboardNavigate,\n    onKeyboardSelect,\n    onSelect,\n    onHover: onHoverOption,\n    handleCompositionStart,\n    handleCompositionEnd,\n    handleCompositionUpdate,\n  }\n}\n\nexport default useSelect\n", "<template>\n  <div\n    ref=\"selectRef\"\n    v-click-outside:[popperRef]=\"handleClickOutside\"\n    :class=\"[nsSelect.b(), nsSelect.m(selectSize)]\"\n    @mouseenter=\"states.inputHovering = true\"\n    @mouseleave=\"states.inputHovering = false\"\n  >\n    <el-tooltip\n      ref=\"tooltipRef\"\n      :visible=\"dropdownMenuVisible\"\n      :teleported=\"teleported\"\n      :popper-class=\"[nsSelect.e('popper'), popperClass]\"\n      :gpu-acceleration=\"false\"\n      :stop-popper-mouse-event=\"false\"\n      :popper-options=\"popperOptions\"\n      :fallback-placements=\"fallbackPlacements\"\n      :effect=\"effect\"\n      :placement=\"placement\"\n      pure\n      :transition=\"`${nsSelect.namespace.value}-zoom-in-top`\"\n      trigger=\"click\"\n      :persistent=\"persistent\"\n      @before-show=\"handleMenuEnter\"\n      @hide=\"states.isBeforeHide = false\"\n    >\n      <template #default>\n        <div\n          ref=\"wrapperRef\"\n          :class=\"[\n            nsSelect.e('wrapper'),\n            nsSelect.is('focused', isFocused),\n            nsSelect.is('hovering', states.inputHovering),\n            nsSelect.is('filterable', filterable),\n            nsSelect.is('disabled', selectDisabled),\n          ]\"\n          @click.prevent=\"toggleMenu\"\n        >\n          <div\n            v-if=\"$slots.prefix\"\n            ref=\"prefixRef\"\n            :class=\"nsSelect.e('prefix')\"\n          >\n            <slot name=\"prefix\" />\n          </div>\n          <div\n            ref=\"selectionRef\"\n            :class=\"[\n              nsSelect.e('selection'),\n              nsSelect.is(\n                'near',\n                multiple && !$slots.prefix && !!modelValue.length\n              ),\n            ]\"\n          >\n            <slot v-if=\"multiple\" name=\"tag\">\n              <div\n                v-for=\"item in showTagList\"\n                :key=\"getValueKey(getValue(item))\"\n                :class=\"nsSelect.e('selected-item')\"\n              >\n                <el-tag\n                  :closable=\"!selectDisabled && !getDisabled(item)\"\n                  :size=\"collapseTagSize\"\n                  :type=\"tagType\"\n                  :effect=\"tagEffect\"\n                  disable-transitions\n                  :style=\"tagStyle\"\n                  @close=\"deleteTag($event, item)\"\n                >\n                  <span :class=\"nsSelect.e('tags-text')\">\n                    <slot\n                      name=\"label\"\n                      :label=\"getLabel(item)\"\n                      :value=\"getValue(item)\"\n                    >\n                      {{ getLabel(item) }}\n                    </slot>\n                  </span>\n                </el-tag>\n              </div>\n\n              <el-tooltip\n                v-if=\"collapseTags && modelValue.length > maxCollapseTags\"\n                ref=\"tagTooltipRef\"\n                :disabled=\"dropdownMenuVisible || !collapseTagsTooltip\"\n                :fallback-placements=\"['bottom', 'top', 'right', 'left']\"\n                :effect=\"effect\"\n                placement=\"bottom\"\n                :teleported=\"teleported\"\n              >\n                <template #default>\n                  <div\n                    ref=\"collapseItemRef\"\n                    :class=\"nsSelect.e('selected-item')\"\n                  >\n                    <el-tag\n                      :closable=\"false\"\n                      :size=\"collapseTagSize\"\n                      :type=\"tagType\"\n                      :effect=\"tagEffect\"\n                      :style=\"collapseTagStyle\"\n                      disable-transitions\n                    >\n                      <span :class=\"nsSelect.e('tags-text')\">\n                        + {{ modelValue.length - maxCollapseTags }}\n                      </span>\n                    </el-tag>\n                  </div>\n                </template>\n                <template #content>\n                  <div ref=\"tagMenuRef\" :class=\"nsSelect.e('selection')\">\n                    <div\n                      v-for=\"selected in collapseTagList\"\n                      :key=\"getValueKey(getValue(selected))\"\n                      :class=\"nsSelect.e('selected-item')\"\n                    >\n                      <el-tag\n                        class=\"in-tooltip\"\n                        :closable=\"!selectDisabled && !getDisabled(selected)\"\n                        :size=\"collapseTagSize\"\n                        :type=\"tagType\"\n                        :effect=\"tagEffect\"\n                        disable-transitions\n                        @close=\"deleteTag($event, selected)\"\n                      >\n                        <span :class=\"nsSelect.e('tags-text')\">\n                          <slot\n                            name=\"label\"\n                            :label=\"getLabel(selected)\"\n                            :value=\"getValue(selected)\"\n                          >\n                            {{ getLabel(selected) }}\n                          </slot>\n                        </span>\n                      </el-tag>\n                    </div>\n                  </div>\n                </template>\n              </el-tooltip>\n            </slot>\n            <div\n              v-if=\"!selectDisabled\"\n              :class=\"[\n                nsSelect.e('selected-item'),\n                nsSelect.e('input-wrapper'),\n                nsSelect.is('hidden', !filterable),\n              ]\"\n            >\n              <input\n                :id=\"inputId\"\n                ref=\"inputRef\"\n                v-model=\"states.inputValue\"\n                :style=\"inputStyle\"\n                :autocomplete=\"autocomplete\"\n                aria-autocomplete=\"list\"\n                aria-haspopup=\"listbox\"\n                autocapitalize=\"off\"\n                :aria-expanded=\"expanded\"\n                :aria-label=\"ariaLabel\"\n                :class=\"[nsSelect.e('input'), nsSelect.is(selectSize)]\"\n                :disabled=\"selectDisabled\"\n                role=\"combobox\"\n                :readonly=\"!filterable\"\n                spellcheck=\"false\"\n                type=\"text\"\n                :name=\"name\"\n                @input=\"onInput\"\n                @compositionstart=\"handleCompositionStart\"\n                @compositionupdate=\"handleCompositionUpdate\"\n                @compositionend=\"handleCompositionEnd\"\n                @keydown.up.stop.prevent=\"onKeyboardNavigate('backward')\"\n                @keydown.down.stop.prevent=\"onKeyboardNavigate('forward')\"\n                @keydown.enter.stop.prevent=\"onKeyboardSelect\"\n                @keydown.esc.stop.prevent=\"handleEsc\"\n                @keydown.delete.stop=\"handleDel\"\n                @click.stop=\"toggleMenu\"\n              />\n              <span\n                v-if=\"filterable\"\n                ref=\"calculatorRef\"\n                aria-hidden=\"true\"\n                :class=\"nsSelect.e('input-calculator')\"\n                v-text=\"states.inputValue\"\n              />\n            </div>\n            <div\n              v-if=\"shouldShowPlaceholder\"\n              :class=\"[\n                nsSelect.e('selected-item'),\n                nsSelect.e('placeholder'),\n                nsSelect.is(\n                  'transparent',\n                  !hasModelValue || (expanded && !states.inputValue)\n                ),\n              ]\"\n            >\n              <slot\n                v-if=\"hasModelValue\"\n                name=\"label\"\n                :label=\"currentPlaceholder\"\n                :value=\"modelValue\"\n              >\n                <span>{{ currentPlaceholder }}</span>\n              </slot>\n              <span v-else>{{ currentPlaceholder }}</span>\n            </div>\n          </div>\n          <div ref=\"suffixRef\" :class=\"nsSelect.e('suffix')\">\n            <el-icon\n              v-if=\"iconComponent\"\n              v-show=\"!showClearBtn\"\n              :class=\"[nsSelect.e('caret'), nsInput.e('icon'), iconReverse]\"\n            >\n              <component :is=\"iconComponent\" />\n            </el-icon>\n            <el-icon\n              v-if=\"showClearBtn && clearIcon\"\n              :class=\"[\n                nsSelect.e('caret'),\n                nsInput.e('icon'),\n                nsSelect.e('clear'),\n              ]\"\n              @click.prevent.stop=\"handleClear\"\n            >\n              <component :is=\"clearIcon\" />\n            </el-icon>\n            <el-icon\n              v-if=\"validateState && validateIcon\"\n              :class=\"[nsInput.e('icon'), nsInput.e('validateIcon')]\"\n            >\n              <component :is=\"validateIcon\" />\n            </el-icon>\n          </div>\n        </div>\n      </template>\n      <template #content>\n        <el-select-menu\n          ref=\"menuRef\"\n          :data=\"filteredOptions\"\n          :width=\"popperSize\"\n          :hovering-index=\"states.hoveringIndex\"\n          :scrollbar-always-on=\"scrollbarAlwaysOn\"\n        >\n          <template v-if=\"$slots.header\" #header>\n            <div :class=\"nsSelect.be('dropdown', 'header')\">\n              <slot name=\"header\" />\n            </div>\n          </template>\n          <template #default=\"scope\">\n            <slot v-bind=\"scope\" />\n          </template>\n          <template v-if=\"$slots.loading && loading\" #loading>\n            <div :class=\"nsSelect.be('dropdown', 'loading')\">\n              <slot name=\"loading\" />\n            </div>\n          </template>\n          <template v-else-if=\"loading || filteredOptions.length === 0\" #empty>\n            <div :class=\"nsSelect.be('dropdown', 'empty')\">\n              <slot name=\"empty\">\n                <span>{{ emptyText }}</span>\n              </slot>\n            </div>\n          </template>\n          <template v-if=\"$slots.footer\" #footer>\n            <div :class=\"nsSelect.be('dropdown', 'footer')\">\n              <slot name=\"footer\" />\n            </div>\n          </template>\n        </el-select-menu>\n      </template>\n    </el-tooltip>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, provide, reactive, toRefs } from 'vue'\nimport { isArray } from '@element-plus/utils'\nimport { ClickOutside } from '@element-plus/directives'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElTag from '@element-plus/components/tag'\nimport ElIcon from '@element-plus/components/icon'\nimport ElSelectMenu from './select-dropdown'\nimport useSelect from './useSelect'\nimport { SelectProps, selectEmits } from './defaults'\nimport { selectV2InjectionKey } from './token'\n\nexport default defineComponent({\n  name: 'ElSelectV2',\n  components: {\n    ElSelectMenu,\n    ElTag,\n    ElTooltip,\n    ElIcon,\n  },\n  directives: { ClickOutside },\n  props: SelectProps,\n  emits: selectEmits,\n  setup(props, { emit }) {\n    const modelValue = computed(() => {\n      const { modelValue: rawModelValue, multiple } = props\n      const fallback = multiple ? [] : undefined\n      // When it is array, we check if this is multi-select.\n      // Based on the result we get\n      if (isArray(rawModelValue)) {\n        return multiple ? rawModelValue : fallback\n      }\n      return multiple ? fallback : rawModelValue\n    })\n\n    const API = useSelect(\n      reactive({\n        ...toRefs(props),\n        modelValue,\n      }),\n      emit\n    )\n    provide(selectV2InjectionKey, {\n      props: reactive({\n        ...toRefs(props),\n        height: API.popupHeight,\n        modelValue,\n      }),\n      expanded: API.expanded,\n      tooltipRef: API.tooltipRef,\n      onSelect: API.onSelect,\n      onHover: API.onHover,\n      onKeyboardNavigate: API.onKeyboardNavigate,\n      onKeyboardSelect: API.onKeyboardSelect,\n    })\n\n    return {\n      ...API,\n      modelValue,\n    }\n  },\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Select from './src/select.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElSelectV2: SFCWithInstall<typeof Select> = withInstall(Select)\nexport default ElSelectV2\n\nexport * from './src/token'\n", "import { buildProps } from '@element-plus/utils'\nimport type Skeleton from './skeleton.vue'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const skeletonProps = buildProps({\n  /**\n   * @description whether showing the animation\n   */\n  animated: {\n    type: Boolean,\n    default: false,\n  },\n  /**\n   * @description how many fake items to render to the DOM\n   */\n  count: {\n    type: Number,\n    default: 1,\n  },\n  /**\n   * @description whether showing the real DOM\n   */\n  rows: {\n    type: Number,\n    default: 3,\n  },\n  /**\n   * @description numbers of the row, only useful when no template slot were given\n   */\n  loading: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description rendering delay in milliseconds\n   */\n  throttle: {\n    type: Number,\n  },\n} as const)\nexport type SkeletonProps = ExtractPropTypes<typeof skeletonProps>\n\nexport type SkeletonInstance = InstanceType<typeof Skeleton>\n", "import { buildProps } from '@element-plus/utils'\nimport type SkeletonItem from './skeleton-item.vue'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const skeletonItemProps = buildProps({\n  /**\n   * @description the current rendering skeleton type\n   */\n  variant: {\n    type: String,\n    values: [\n      'circle',\n      'rect',\n      'h1',\n      'h3',\n      'text',\n      'caption',\n      'p',\n      'image',\n      'button',\n    ],\n    default: 'text',\n  },\n} as const)\nexport type SkeletonItemProps = ExtractPropTypes<typeof skeletonItemProps>\n\nexport type SkeletonItemInstance = InstanceType<typeof SkeletonItem>\n", "<template>\n  <div :class=\"[ns.e('item'), ns.e(variant)]\">\n    <picture-filled v-if=\"variant === 'image'\" />\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { useNamespace } from '@element-plus/hooks'\nimport { PictureFilled } from '@element-plus/icons-vue'\nimport { skeletonItemProps } from './skeleton-item'\n\ndefineOptions({\n  name: 'ElSkeletonItem',\n})\ndefineProps(skeletonItemProps)\nconst ns = useNamespace('skeleton')\n</script>\n", "<template>\n  <template v-if=\"uiLoading\">\n    <div :class=\"[ns.b(), ns.is('animated', animated)]\" v-bind=\"$attrs\">\n      <template v-for=\"i in count\" :key=\"i\">\n        <slot v-if=\"loading\" :key=\"i\" name=\"template\">\n          <el-skeleton-item :class=\"ns.is('first')\" variant=\"p\" />\n          <el-skeleton-item\n            v-for=\"item in rows\"\n            :key=\"item\"\n            :class=\"[\n              ns.e('paragraph'),\n              ns.is('last', item === rows && rows > 1),\n            ]\"\n            variant=\"p\"\n          />\n        </slot>\n      </template>\n    </div>\n  </template>\n  <template v-else>\n    <slot v-bind=\"$attrs\" />\n  </template>\n</template>\n\n<script lang=\"ts\" setup>\nimport { toRef } from 'vue'\nimport { useNamespace, useThrottleRender } from '@element-plus/hooks'\nimport { skeletonProps } from './skeleton'\nimport ElSkeletonItem from './skeleton-item.vue'\n\ndefineOptions({\n  name: 'ElSkeleton',\n})\nconst props = defineProps(skeletonProps)\n\nconst ns = useNamespace('skeleton')\nconst uiLoading = useThrottleRender(toRef(props, 'loading'), props.throttle)\n\ndefineExpose({\n  /** @description loading state */\n  uiLoading,\n})\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\n\nimport Skeleton from './src/skeleton.vue'\nimport SkeletonItem from './src/skeleton-item.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElSkeleton: SFCWithInstall<typeof Skeleton> & {\n  SkeletonItem: typeof SkeletonItem\n} = withInstall(Skeleton, {\n  SkeletonItem,\n})\nexport const ElSkeletonItem: SFCWithInstall<typeof SkeletonItem> =\n  withNoopInstall(SkeletonItem)\nexport default ElSkeleton\n\nexport * from './src/skeleton'\nexport * from './src/skeleton-item'\n", "import type { ComputedRef, InjectionKey, Ref, ToRefs } from 'vue'\nimport type { SliderProps } from './slider'\n\nexport interface SliderContext extends ToRefs<SliderProps> {\n  precision: ComputedRef<number>\n  sliderSize: Ref<number>\n  emitChange: () => void\n  resetSize: () => void\n  updateDragging: (val: boolean) => void\n}\n\nexport const sliderContextKey: InjectionKey<SliderContext> =\n  Symbol('sliderContextKey')\n", "import { placements } from '@popperjs/core'\nimport {\n  buildProps,\n  definePropType,\n  isArray,\n  isNumber,\n} from '@element-plus/utils'\nimport {\n  CHANGE_EVENT,\n  INPUT_EVENT,\n  UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport type { Arrayable } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type { SliderMarkerProps } from './marker'\nimport type Slider from './slider.vue'\n\ntype SliderMarks = Record<number, string | SliderMarkerProps['mark']>\n\nexport interface SliderInitData {\n  firstValue: number\n  secondValue: number\n  oldValue?: Arrayable<number>\n  dragging: boolean\n  sliderSize: number\n}\n\nexport const sliderProps = buildProps({\n  /**\n   * @description binding value\n   */\n  modelValue: {\n    type: definePropType<Arrayable<number>>([Number, Array]),\n    default: 0,\n  },\n  id: {\n    type: String,\n    default: undefined,\n  },\n  /**\n   * @description minimum value\n   */\n  min: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description maximum value\n   */\n  max: {\n    type: Number,\n    default: 100,\n  },\n  /**\n   * @description step size\n   */\n  step: {\n    type: Number,\n    default: 1,\n  },\n  /**\n   * @description whether to display an input box, works when `range` is false\n   */\n  showInput: Boolean,\n  /**\n   * @description whether to display control buttons when `show-input` is true\n   */\n  showInputControls: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description size of the slider wrapper, will not work in vertical mode\n   */\n  size: useSizeProp,\n  /**\n   * @description size of the input box, when set `size`, the default is the value of `size`\n   */\n  inputSize: useSizeProp,\n  /**\n   * @description whether to display breakpoints\n   */\n  showStops: Boolean,\n  /**\n   * @description whether to display tooltip value\n   */\n  showTooltip: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description format to display tooltip value\n   */\n  formatTooltip: {\n    type: definePropType<(val: number) => number | string>(Function),\n    default: undefined,\n  },\n  /**\n   * @description whether Slider is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description whether to select a range\n   */\n  range: Boolean,\n  /**\n   * @description vertical mode\n   */\n  vertical: Boolean,\n  /**\n   * @description slider height, required in vertical mode\n   */\n  height: String,\n  /**\n   * @description debounce delay when typing, in milliseconds, works when `show-input` is true\n   */\n  debounce: {\n    type: Number,\n    default: 300,\n  },\n  /**\n   * @description when `range` is true, screen reader label for the start of the range\n   */\n  rangeStartLabel: {\n    type: String,\n    default: undefined,\n  },\n  /**\n   * @description when `range` is true, screen reader label for the end of the range\n   */\n  rangeEndLabel: {\n    type: String,\n    default: undefined,\n  },\n  /**\n   * @description format to display the `aria-valuenow` attribute for screen readers\n   */\n  formatValueText: {\n    type: definePropType<(val: number) => string>(Function),\n    default: undefined,\n  },\n  /**\n   * @description custom class name for the tooltip\n   */\n  tooltipClass: {\n    type: String,\n    default: undefined,\n  },\n  /**\n   * @description position of Tooltip\n   */\n  placement: {\n    type: String,\n    values: placements,\n    default: 'top',\n  },\n  /**\n   * @description marks, type of key must be `number` and must in closed interval `[min, max]`, each mark can custom style\n   */\n  marks: {\n    type: definePropType<SliderMarks>(Object),\n  },\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  ...useAriaProps(['ariaLabel']),\n} as const)\nexport type SliderProps = ExtractPropTypes<typeof sliderProps>\n\nconst isValidValue = (value: Arrayable<number>) =>\n  isNumber(value) || (isArray(value) && value.every(isNumber))\nexport const sliderEmits = {\n  [UPDATE_MODEL_EVENT]: isValidValue,\n  [INPUT_EVENT]: isValidValue,\n  [CHANGE_EVENT]: isValidValue,\n}\nexport type SliderEmits = typeof sliderEmits\n\nexport type SliderInstance = InstanceType<typeof Slider>\n", "import { nextTick, onMounted, ref } from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport type { SliderInitData, SliderProps } from '../slider'\n\nexport const useLifecycle = (\n  props: SliderProps,\n  initData: SliderInitData,\n  resetSize: () => void\n) => {\n  const sliderWrapper = ref<HTMLElement>()\n\n  onMounted(async () => {\n    if (props.range) {\n      if (Array.isArray(props.modelValue)) {\n        initData.firstValue = Math.max(props.min, props.modelValue[0])\n        initData.secondValue = Math.min(props.max, props.modelValue[1])\n      } else {\n        initData.firstValue = props.min\n        initData.secondValue = props.max\n      }\n      initData.oldValue = [initData.firstValue, initData.secondValue]\n    } else {\n      if (\n        typeof props.modelValue !== 'number' ||\n        Number.isNaN(props.modelValue)\n      ) {\n        initData.firstValue = props.min\n      } else {\n        initData.firstValue = Math.min(\n          props.max,\n          Math.max(props.min, props.modelValue)\n        )\n      }\n      initData.oldValue = initData.firstValue\n    }\n\n    useEventListener(window, 'resize', resetSize)\n\n    await nextTick()\n    resetSize()\n  })\n\n  return {\n    sliderWrapper,\n  }\n}\n", "import { computed } from 'vue'\nimport type { SliderProps } from '../slider'\nimport type { SliderMarkerProps } from '../marker'\n\nexport interface Mark extends SliderMarkerProps {\n  point: number\n  position: number\n}\n\nexport const useMarks = (props: SliderProps) => {\n  return computed(() => {\n    if (!props.marks) {\n      return []\n    }\n\n    const marksKeys = Object.keys(props.marks)\n    return marksKeys\n      .map(Number.parseFloat)\n      .sort((a, b) => a - b)\n      .filter((point) => point <= props.max && point >= props.min)\n      .map(\n        (point): Mark => ({\n          point,\n          position: ((point - props.min) * 100) / (props.max - props.min),\n          mark: props.marks![point],\n        })\n      )\n  })\n}\n", "import { computed, nextTick, ref, shallowRef } from 'vue'\nimport {\n  CHANGE_EVENT,\n  INPUT_EVENT,\n  UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { useFormItem } from '@element-plus/components/form'\nimport type { CSSProperties, Ref, SetupContext } from 'vue'\nimport type { Arrayable } from '@element-plus/utils'\nimport type { SliderEmits, SliderInitData, SliderProps } from '../slider'\nimport type { ButtonRefs, SliderButtonInstance } from '../button'\n\nexport const useSlide = (\n  props: SliderProps,\n  initData: SliderInitData,\n  emit: SetupContext<SliderEmits>['emit']\n) => {\n  const { form: elForm, formItem: elFormItem } = useFormItem()\n\n  const slider = shallowRef<HTMLElement>()\n\n  const firstButton = ref<SliderButtonInstance>()\n\n  const secondButton = ref<SliderButtonInstance>()\n\n  const buttonRefs: ButtonRefs = {\n    firstButton,\n    secondButton,\n  }\n\n  const sliderDisabled = computed(() => {\n    return props.disabled || elForm?.disabled || false\n  })\n\n  const minValue = computed(() => {\n    return Math.min(initData.firstValue, initData.secondValue)\n  })\n\n  const maxValue = computed(() => {\n    return Math.max(initData.firstValue, initData.secondValue)\n  })\n\n  const barSize = computed(() => {\n    return props.range\n      ? `${\n          (100 * (maxValue.value - minValue.value)) / (props.max - props.min)\n        }%`\n      : `${\n          (100 * (initData.firstValue - props.min)) / (props.max - props.min)\n        }%`\n  })\n\n  const barStart = computed(() => {\n    return props.range\n      ? `${(100 * (minValue.value - props.min)) / (props.max - props.min)}%`\n      : '0%'\n  })\n\n  const runwayStyle = computed<CSSProperties>(() => {\n    return props.vertical ? { height: props.height } : {}\n  })\n\n  const barStyle = computed<CSSProperties>(() => {\n    return props.vertical\n      ? {\n          height: barSize.value,\n          bottom: barStart.value,\n        }\n      : {\n          width: barSize.value,\n          left: barStart.value,\n        }\n  })\n\n  const resetSize = () => {\n    if (slider.value) {\n      initData.sliderSize =\n        slider.value[`client${props.vertical ? 'Height' : 'Width'}`]\n    }\n  }\n\n  const getButtonRefByPercent = (\n    percent: number\n  ): Ref<SliderButtonInstance | undefined> => {\n    const targetValue = props.min + (percent * (props.max - props.min)) / 100\n    if (!props.range) {\n      return firstButton\n    }\n    let buttonRefName: 'firstButton' | 'secondButton'\n    if (\n      Math.abs(minValue.value - targetValue) <\n      Math.abs(maxValue.value - targetValue)\n    ) {\n      buttonRefName =\n        initData.firstValue < initData.secondValue\n          ? 'firstButton'\n          : 'secondButton'\n    } else {\n      buttonRefName =\n        initData.firstValue > initData.secondValue\n          ? 'firstButton'\n          : 'secondButton'\n    }\n    return buttonRefs[buttonRefName]\n  }\n\n  const setPosition = (\n    percent: number\n  ): Ref<SliderButtonInstance | undefined> => {\n    const buttonRef = getButtonRefByPercent(percent)\n    buttonRef.value!.setPosition(percent)\n    return buttonRef\n  }\n\n  const setFirstValue = (firstValue: number | undefined) => {\n    initData.firstValue = firstValue ?? props.min\n    _emit(\n      props.range ? [minValue.value, maxValue.value] : firstValue ?? props.min\n    )\n  }\n\n  const setSecondValue = (secondValue: number) => {\n    initData.secondValue = secondValue\n\n    if (props.range) {\n      _emit([minValue.value, maxValue.value])\n    }\n  }\n\n  const _emit = (val: Arrayable<number>) => {\n    emit(UPDATE_MODEL_EVENT, val)\n    emit(INPUT_EVENT, val)\n  }\n\n  const emitChange = async () => {\n    await nextTick()\n    emit(\n      CHANGE_EVENT,\n      props.range ? [minValue.value, maxValue.value] : props.modelValue\n    )\n  }\n\n  const handleSliderPointerEvent = (\n    event: MouseEvent | TouchEvent\n  ): Ref<SliderButtonInstance | undefined> | undefined => {\n    if (sliderDisabled.value || initData.dragging) return\n    resetSize()\n    let newPercent = 0\n    if (props.vertical) {\n      const clientY =\n        (event as TouchEvent).touches?.item(0)?.clientY ??\n        (event as MouseEvent).clientY\n      const sliderOffsetBottom = slider.value!.getBoundingClientRect().bottom\n      newPercent = ((sliderOffsetBottom - clientY) / initData.sliderSize) * 100\n    } else {\n      const clientX =\n        (event as TouchEvent).touches?.item(0)?.clientX ??\n        (event as MouseEvent).clientX\n      const sliderOffsetLeft = slider.value!.getBoundingClientRect().left\n      newPercent = ((clientX - sliderOffsetLeft) / initData.sliderSize) * 100\n    }\n    if (newPercent < 0 || newPercent > 100) return\n    return setPosition(newPercent)\n  }\n\n  const onSliderWrapperPrevent = (event: TouchEvent) => {\n    if (\n      buttonRefs['firstButton'].value?.dragging ||\n      buttonRefs['secondButton'].value?.dragging\n    ) {\n      event.preventDefault()\n    }\n  }\n\n  const onSliderDown = async (event: MouseEvent | TouchEvent) => {\n    const buttonRef = handleSliderPointerEvent(event)\n    if (buttonRef) {\n      await nextTick()\n      buttonRef.value!.onButtonDown(event)\n    }\n  }\n\n  const onSliderClick = (event: MouseEvent | TouchEvent) => {\n    const buttonRef = handleSliderPointerEvent(event)\n    if (buttonRef) {\n      emitChange()\n    }\n  }\n\n  const onSliderMarkerDown = (position: number) => {\n    if (sliderDisabled.value || initData.dragging) return\n    setPosition(position)\n  }\n\n  return {\n    elFormItem,\n    slider,\n    firstButton,\n    secondButton,\n    sliderDisabled,\n    minValue,\n    maxValue,\n    runwayStyle,\n    barStyle,\n    resetSize,\n    setPosition,\n    emitChange,\n    onSliderWrapperPrevent,\n    onSliderClick,\n    onSliderDown,\n    onSliderMarkerDown,\n    setFirstValue,\n    setSecondValue,\n  }\n}\n", "import { computed, inject, nextTick, ref, watch } from 'vue'\nimport { debounce } from 'lodash-unified'\nimport { useEventListener } from '@vueuse/core'\nimport { EVENT_CODE, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { sliderContextKey } from '../constants'\n\nimport type { CSSProperties, ComputedRef, Ref, SetupContext } from 'vue'\nimport type { SliderProps } from '../slider'\nimport type {\n  SliderButtonEmits,\n  SliderButtonInitData,\n  SliderButtonProps,\n} from '../button'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\n\nconst { left, down, right, up, home, end, pageUp, pageDown } = EVENT_CODE\n\nconst useTooltip = (\n  props: SliderButtonProps,\n  formatTooltip: Ref<SliderProps['formatTooltip']>,\n  showTooltip: Ref<SliderProps['showTooltip']>\n) => {\n  const tooltip = ref<TooltipInstance>()\n\n  const tooltipVisible = ref(false)\n\n  const enableFormat = computed(() => {\n    return formatTooltip.value instanceof Function\n  })\n\n  const formatValue = computed(() => {\n    return (\n      (enableFormat.value && formatTooltip.value!(props.modelValue)) ||\n      props.modelValue\n    )\n  })\n\n  const displayTooltip = debounce(() => {\n    showTooltip.value && (tooltipVisible.value = true)\n  }, 50)\n\n  const hideTooltip = debounce(() => {\n    showTooltip.value && (tooltipVisible.value = false)\n  }, 50)\n\n  return {\n    tooltip,\n    tooltipVisible,\n    formatValue,\n    displayTooltip,\n    hideTooltip,\n  }\n}\n\nexport const useSliderButton = (\n  props: SliderButtonProps,\n  initData: SliderButtonInitData,\n  emit: SetupContext<SliderButtonEmits>['emit']\n) => {\n  const {\n    disabled,\n    min,\n    max,\n    step,\n    showTooltip,\n    precision,\n    sliderSize,\n    formatTooltip,\n    emitChange,\n    resetSize,\n    updateDragging,\n  } = inject(sliderContextKey)!\n\n  const { tooltip, tooltipVisible, formatValue, displayTooltip, hideTooltip } =\n    useTooltip(props, formatTooltip!, showTooltip)\n\n  const button = ref<HTMLDivElement>()\n\n  const currentPosition = computed(() => {\n    return `${\n      ((props.modelValue - min.value) / (max.value - min.value)) * 100\n    }%`\n  })\n\n  const wrapperStyle: ComputedRef<CSSProperties> = computed(() => {\n    return props.vertical\n      ? { bottom: currentPosition.value }\n      : { left: currentPosition.value }\n  })\n\n  const handleMouseEnter = () => {\n    initData.hovering = true\n    displayTooltip()\n  }\n\n  const handleMouseLeave = () => {\n    initData.hovering = false\n    if (!initData.dragging) {\n      hideTooltip()\n    }\n  }\n\n  const onButtonDown = (event: MouseEvent | TouchEvent) => {\n    if (disabled.value) return\n    event.preventDefault()\n    onDragStart(event)\n    window.addEventListener('mousemove', onDragging)\n    window.addEventListener('touchmove', onDragging)\n    window.addEventListener('mouseup', onDragEnd)\n    window.addEventListener('touchend', onDragEnd)\n    window.addEventListener('contextmenu', onDragEnd)\n    button.value!.focus()\n  }\n\n  const incrementPosition = (amount: number) => {\n    if (disabled.value) return\n    initData.newPosition =\n      Number.parseFloat(currentPosition.value) +\n      (amount / (max.value - min.value)) * 100\n    setPosition(initData.newPosition)\n    emitChange()\n  }\n\n  const onLeftKeyDown = () => {\n    incrementPosition(-step.value)\n  }\n\n  const onRightKeyDown = () => {\n    incrementPosition(step.value)\n  }\n\n  const onPageDownKeyDown = () => {\n    incrementPosition(-step.value * 4)\n  }\n\n  const onPageUpKeyDown = () => {\n    incrementPosition(step.value * 4)\n  }\n\n  const onHomeKeyDown = () => {\n    if (disabled.value) return\n    setPosition(0)\n    emitChange()\n  }\n\n  const onEndKeyDown = () => {\n    if (disabled.value) return\n    setPosition(100)\n    emitChange()\n  }\n\n  const onKeyDown = (event: KeyboardEvent) => {\n    let isPreventDefault = true\n    if ([left, down].includes(event.key)) {\n      onLeftKeyDown()\n    } else if ([right, up].includes(event.key)) {\n      onRightKeyDown()\n    } else if (event.key === home) {\n      onHomeKeyDown()\n    } else if (event.key === end) {\n      onEndKeyDown()\n    } else if (event.key === pageDown) {\n      onPageDownKeyDown()\n    } else if (event.key === pageUp) {\n      onPageUpKeyDown()\n    } else {\n      isPreventDefault = false\n    }\n    isPreventDefault && event.preventDefault()\n  }\n\n  const getClientXY = (event: MouseEvent | TouchEvent) => {\n    let clientX: number\n    let clientY: number\n    if (event.type.startsWith('touch')) {\n      clientY = (event as TouchEvent).touches[0].clientY\n      clientX = (event as TouchEvent).touches[0].clientX\n    } else {\n      clientY = (event as MouseEvent).clientY\n      clientX = (event as MouseEvent).clientX\n    }\n    return {\n      clientX,\n      clientY,\n    }\n  }\n\n  const onDragStart = (event: MouseEvent | TouchEvent) => {\n    initData.dragging = true\n    initData.isClick = true\n    const { clientX, clientY } = getClientXY(event)\n    if (props.vertical) {\n      initData.startY = clientY\n    } else {\n      initData.startX = clientX\n    }\n    initData.startPosition = Number.parseFloat(currentPosition.value)\n    initData.newPosition = initData.startPosition\n  }\n\n  const onDragging = (event: MouseEvent | TouchEvent) => {\n    if (initData.dragging) {\n      initData.isClick = false\n      displayTooltip()\n      resetSize()\n      let diff: number\n      const { clientX, clientY } = getClientXY(event)\n      if (props.vertical) {\n        initData.currentY = clientY\n        diff = ((initData.startY - initData.currentY) / sliderSize.value) * 100\n      } else {\n        initData.currentX = clientX\n        diff = ((initData.currentX - initData.startX) / sliderSize.value) * 100\n      }\n      initData.newPosition = initData.startPosition + diff\n      setPosition(initData.newPosition)\n    }\n  }\n\n  const onDragEnd = () => {\n    if (initData.dragging) {\n      /*\n       * 防止在 mouseup 后立即触发 click,导致滑块有几率产生一小段位移\n       * 不使用 preventDefault 是因为 mouseup 和 click 没有注册在同一个 DOM 上\n       */\n      setTimeout(() => {\n        initData.dragging = false\n        if (!initData.hovering) {\n          hideTooltip()\n        }\n        if (!initData.isClick) {\n          setPosition(initData.newPosition)\n        }\n        emitChange()\n      }, 0)\n      window.removeEventListener('mousemove', onDragging)\n      window.removeEventListener('touchmove', onDragging)\n      window.removeEventListener('mouseup', onDragEnd)\n      window.removeEventListener('touchend', onDragEnd)\n      window.removeEventListener('contextmenu', onDragEnd)\n    }\n  }\n\n  const setPosition = async (newPosition: number) => {\n    if (newPosition === null || Number.isNaN(+newPosition)) return\n    if (newPosition < 0) {\n      newPosition = 0\n    } else if (newPosition > 100) {\n      newPosition = 100\n    }\n    const lengthPerStep = 100 / ((max.value - min.value) / step.value)\n    const steps = Math.round(newPosition / lengthPerStep)\n    let value =\n      steps * lengthPerStep * (max.value - min.value) * 0.01 + min.value\n    value = Number.parseFloat(value.toFixed(precision.value))\n\n    if (value !== props.modelValue) {\n      emit(UPDATE_MODEL_EVENT, value)\n    }\n\n    if (!initData.dragging && props.modelValue !== initData.oldValue) {\n      initData.oldValue = props.modelValue\n    }\n\n    await nextTick()\n    initData.dragging && displayTooltip()\n    tooltip.value!.updatePopper()\n  }\n\n  watch(\n    () => initData.dragging,\n    (val) => {\n      updateDragging(val)\n    }\n  )\n\n  useEventListener(button, 'touchstart', onButtonDown, { passive: false })\n\n  return {\n    disabled,\n    button,\n    tooltip,\n    tooltipVisible,\n    showTooltip,\n    wrapperStyle,\n    formatValue,\n    handleMouseEnter,\n    handleMouseLeave,\n    onButtonDown,\n    onKeyDown,\n    setPosition,\n  }\n}\n", "import { computed } from 'vue'\nimport { debugWarn } from '@element-plus/utils'\nimport type { CSSProperties, ComputedRef } from 'vue'\nimport type { SliderInitData, SliderProps } from '../slider'\n\ntype Stops = {\n  stops: ComputedRef<number[]>\n  getStopStyle: (position: number) => CSSProperties\n}\n\nexport const useStops = (\n  props: SliderProps,\n  initData: SliderInitData,\n  minValue: ComputedRef<number>,\n  maxValue: ComputedRef<number>\n): Stops => {\n  const stops = computed(() => {\n    if (!props.showStops || props.min > props.max) return []\n    if (props.step === 0) {\n      debugWarn('ElSlider', 'step should not be 0.')\n      return []\n    }\n\n    const stopCount = (props.max - props.min) / props.step\n    const stepWidth = (100 * props.step) / (props.max - props.min)\n    const result = Array.from<number>({ length: stopCount - 1 }).map(\n      (_, index) => (index + 1) * stepWidth\n    )\n\n    if (props.range) {\n      return result.filter((step) => {\n        return (\n          step <\n            (100 * (minValue.value - props.min)) / (props.max - props.min) ||\n          step > (100 * (maxValue.value - props.min)) / (props.max - props.min)\n        )\n      })\n    } else {\n      return result.filter(\n        (step) =>\n          step >\n          (100 * (initData.firstValue - props.min)) / (props.max - props.min)\n      )\n    }\n  })\n\n  const getStopStyle = (position: number): CSSProperties => {\n    return props.vertical\n      ? { bottom: `${position}%` }\n      : { left: `${position}%` }\n  }\n\n  return {\n    stops,\n    getStopStyle,\n  }\n}\n", "import { watch } from 'vue'\nimport { INPUT_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { debugWarn, throwError } from '@element-plus/utils'\nimport type { ComputedRef, SetupContext } from 'vue'\nimport type { Arrayable } from '@element-plus/utils'\nimport type { FormItemContext } from '@element-plus/components/form'\nimport type { SliderEmits, SliderInitData, SliderProps } from '../slider'\n\nexport const useWatch = (\n  props: SliderProps,\n  initData: SliderInitData,\n  minValue: ComputedRef<number>,\n  maxValue: ComputedRef<number>,\n  emit: SetupContext<SliderEmits>['emit'],\n  elFormItem: FormItemContext\n) => {\n  const _emit = (val: Arrayable<number>) => {\n    emit(UPDATE_MODEL_EVENT, val)\n    emit(INPUT_EVENT, val)\n  }\n\n  const valueChanged = () => {\n    if (props.range) {\n      return ![minValue.value, maxValue.value].every(\n        (item, index) => item === (initData.oldValue as number[])[index]\n      )\n    } else {\n      return props.modelValue !== initData.oldValue\n    }\n  }\n\n  const setValues = () => {\n    if (props.min > props.max) {\n      throwError('Slider', 'min should not be greater than max.')\n    }\n    const val = props.modelValue\n    if (props.range && Array.isArray(val)) {\n      if (val[1] < props.min) {\n        _emit([props.min, props.min])\n      } else if (val[0] > props.max) {\n        _emit([props.max, props.max])\n      } else if (val[0] < props.min) {\n        _emit([props.min, val[1]])\n      } else if (val[1] > props.max) {\n        _emit([val[0], props.max])\n      } else {\n        initData.firstValue = val[0]\n        initData.secondValue = val[1]\n        if (valueChanged()) {\n          if (props.validateEvent) {\n            elFormItem?.validate?.('change').catch((err) => debugWarn(err))\n          }\n          initData.oldValue = val.slice()\n        }\n      }\n    } else if (!props.range && typeof val === 'number' && !Number.isNaN(val)) {\n      if (val < props.min) {\n        _emit(props.min)\n      } else if (val > props.max) {\n        _emit(props.max)\n      } else {\n        initData.firstValue = val\n        if (valueChanged()) {\n          if (props.validateEvent) {\n            elFormItem?.validate?.('change').catch((err) => debugWarn(err))\n          }\n          initData.oldValue = val\n        }\n      }\n    }\n  }\n\n  setValues()\n\n  watch(\n    () => initData.dragging,\n    (val) => {\n      if (!val) {\n        setValues()\n      }\n    }\n  )\n\n  watch(\n    () => props.modelValue,\n    (val, oldVal) => {\n      if (\n        initData.dragging ||\n        (Array.isArray(val) &&\n          Array.isArray(oldVal) &&\n          val.every((item, index) => item === oldVal[index]) &&\n          initData.firstValue === val[0] &&\n          initData.secondValue === val[1])\n      ) {\n        return\n      }\n      setValues()\n    },\n    {\n      deep: true,\n    }\n  )\n\n  watch(\n    () => [props.min, props.max],\n    () => {\n      setValues()\n    }\n  )\n}\n", "import { placements } from '@popperjs/core'\nimport { buildProps, isNumber } from '@element-plus/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport type { ComponentPublicInstance, ExtractPropTypes, Ref } from 'vue'\nimport type Button from './button.vue'\n\nexport const sliderButtonProps = buildProps({\n  modelValue: {\n    type: Number,\n    default: 0,\n  },\n  vertical: Boolean,\n  tooltipClass: String,\n  placement: {\n    type: String,\n    values: placements,\n    default: 'top',\n  },\n} as const)\nexport type SliderButtonProps = ExtractPropTypes<typeof sliderButtonProps>\n\nexport const sliderButtonEmits = {\n  [UPDATE_MODEL_EVENT]: (value: number) => isNumber(value),\n}\nexport type SliderButtonEmits = typeof sliderButtonEmits\n\nexport type SliderButtonInstance = ComponentPublicInstance<typeof Button>\n\nexport type ButtonRefs = Record<\n  'firstButton' | 'secondButton',\n  Ref<SliderButtonInstance | undefined>\n>\n\nexport interface SliderButtonInitData {\n  hovering: boolean\n  dragging: boolean\n  isClick: boolean\n  startX: number\n  currentX: number\n  startY: number\n  currentY: number\n  startPosition: number\n  newPosition: number\n  oldValue: number\n}\n", "<template>\n  <div\n    ref=\"button\"\n    :class=\"[ns.e('button-wrapper'), { hover: hovering, dragging }]\"\n    :style=\"wrapperStyle\"\n    :tabindex=\"disabled ? -1 : 0\"\n    @mouseenter=\"handleMouseEnter\"\n    @mouseleave=\"handleMouseLeave\"\n    @mousedown=\"onButtonDown\"\n    @focus=\"handleMouseEnter\"\n    @blur=\"handleMouseLeave\"\n    @keydown=\"onKeyDown\"\n  >\n    <el-tooltip\n      ref=\"tooltip\"\n      :visible=\"tooltipVisible\"\n      :placement=\"placement\"\n      :fallback-placements=\"['top', 'bottom', 'right', 'left']\"\n      :stop-popper-mouse-event=\"false\"\n      :popper-class=\"tooltipClass\"\n      :disabled=\"!showTooltip\"\n      persistent\n    >\n      <template #content>\n        <span>{{ formatValue }}</span>\n      </template>\n      <div :class=\"[ns.e('button'), { hover: hovering, dragging }]\" />\n    </el-tooltip>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { reactive, toRefs } from 'vue'\nimport { ElTooltip } from '@element-plus/components/tooltip'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useSliderButton } from './composables'\nimport { sliderButtonEmits, sliderButtonProps } from './button'\nimport type { SliderButtonInitData } from './button'\n\ndefineOptions({\n  name: 'ElSliderButton',\n})\n\nconst props = defineProps(sliderButtonProps)\nconst emit = defineEmits(sliderButtonEmits)\n\nconst ns = useNamespace('slider')\n\nconst initData = reactive<SliderButtonInitData>({\n  hovering: false,\n  dragging: false,\n  isClick: false,\n  startX: 0,\n  currentX: 0,\n  startY: 0,\n  currentY: 0,\n  startPosition: 0,\n  newPosition: 0,\n  oldValue: props.modelValue,\n})\n\nconst {\n  disabled,\n  button,\n  tooltip,\n  showTooltip,\n  tooltipVisible,\n  wrapperStyle,\n  formatValue,\n  handleMouseEnter,\n  handleMouseLeave,\n  onButtonDown,\n  onKeyDown,\n  setPosition,\n} = useSliderButton(props, initData, emit)\n\nconst { hovering, dragging } = toRefs(initData)\n\ndefineExpose({\n  onButtonDown,\n  onKeyDown,\n  setPosition,\n  hovering,\n  dragging,\n})\n</script>\n", "import { computed, defineComponent, h } from 'vue'\nimport { buildProps, definePropType, isString } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport type { CSSProperties, ExtractPropTypes } from 'vue'\n\nexport const sliderMarkerProps = buildProps({\n  mark: {\n    type: definePropType<\n      | string\n      | {\n          style: CSSProperties\n          label: any\n        }\n    >([String, Object]),\n    default: undefined,\n  },\n} as const)\nexport type SliderMarkerProps = ExtractPropTypes<typeof sliderMarkerProps>\n\nexport default defineComponent({\n  name: 'ElSliderMarker',\n  props: sliderMarkerProps,\n  setup(props) {\n    const ns = useNamespace('slider')\n    const label = computed(() => {\n      return isString(props.mark) ? props.mark : props.mark!.label\n    })\n    const style = computed(() =>\n      isString(props.mark) ? undefined : props.mark!.style\n    )\n\n    return () =>\n      h(\n        'div',\n        {\n          class: ns.e('marks-text'),\n          style: style.value,\n        },\n        label.value\n      )\n  },\n})\n", "<template>\n  <div\n    :id=\"range ? inputId : undefined\"\n    ref=\"sliderWrapper\"\n    :class=\"sliderKls\"\n    :role=\"range ? 'group' : undefined\"\n    :aria-label=\"range && !isLabeledByFormItem ? groupLabel : undefined\"\n    :aria-labelledby=\"\n      range && isLabeledByFormItem ? elFormItem?.labelId : undefined\n    \"\n  >\n    <div\n      ref=\"slider\"\n      :class=\"[\n        ns.e('runway'),\n        { 'show-input': showInput && !range },\n        ns.is('disabled', sliderDisabled),\n      ]\"\n      :style=\"runwayStyle\"\n      @mousedown=\"onSliderDown\"\n      @touchstart.passive=\"onSliderDown\"\n    >\n      <div :class=\"ns.e('bar')\" :style=\"barStyle\" />\n      <slider-button\n        :id=\"!range ? inputId : undefined\"\n        ref=\"firstButton\"\n        :model-value=\"firstValue\"\n        :vertical=\"vertical\"\n        :tooltip-class=\"tooltipClass\"\n        :placement=\"placement\"\n        role=\"slider\"\n        :aria-label=\"\n          range || !isLabeledByFormItem ? firstButtonLabel : undefined\n        \"\n        :aria-labelledby=\"\n          !range && isLabeledByFormItem ? elFormItem?.labelId : undefined\n        \"\n        :aria-valuemin=\"min\"\n        :aria-valuemax=\"range ? secondValue : max\"\n        :aria-valuenow=\"firstValue\"\n        :aria-valuetext=\"firstValueText\"\n        :aria-orientation=\"vertical ? 'vertical' : 'horizontal'\"\n        :aria-disabled=\"sliderDisabled\"\n        @update:model-value=\"setFirstValue\"\n      />\n      <slider-button\n        v-if=\"range\"\n        ref=\"secondButton\"\n        :model-value=\"secondValue\"\n        :vertical=\"vertical\"\n        :tooltip-class=\"tooltipClass\"\n        :placement=\"placement\"\n        role=\"slider\"\n        :aria-label=\"secondButtonLabel\"\n        :aria-valuemin=\"firstValue\"\n        :aria-valuemax=\"max\"\n        :aria-valuenow=\"secondValue\"\n        :aria-valuetext=\"secondValueText\"\n        :aria-orientation=\"vertical ? 'vertical' : 'horizontal'\"\n        :aria-disabled=\"sliderDisabled\"\n        @update:model-value=\"setSecondValue\"\n      />\n      <div v-if=\"showStops\">\n        <div\n          v-for=\"(item, key) in stops\"\n          :key=\"key\"\n          :class=\"ns.e('stop')\"\n          :style=\"getStopStyle(item)\"\n        />\n      </div>\n      <template v-if=\"markList.length > 0\">\n        <div>\n          <div\n            v-for=\"(item, key) in markList\"\n            :key=\"key\"\n            :style=\"getStopStyle(item.position)\"\n            :class=\"[ns.e('stop'), ns.e('marks-stop')]\"\n          />\n        </div>\n        <div :class=\"ns.e('marks')\">\n          <slider-marker\n            v-for=\"(item, key) in markList\"\n            :key=\"key\"\n            :mark=\"item.mark\"\n            :style=\"getStopStyle(item.position)\"\n            @mousedown.stop=\"onSliderMarkerDown(item.position)\"\n          />\n        </div>\n      </template>\n    </div>\n    <el-input-number\n      v-if=\"showInput && !range\"\n      ref=\"input\"\n      :model-value=\"firstValue\"\n      :class=\"ns.e('input')\"\n      :step=\"step\"\n      :disabled=\"sliderDisabled\"\n      :controls=\"showInputControls\"\n      :min=\"min\"\n      :max=\"max\"\n      :precision=\"precision\"\n      :debounce=\"debounce\"\n      :size=\"sliderInputSize\"\n      @update:model-value=\"setFirstValue\"\n      @change=\"emitChange\"\n    />\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, provide, reactive, toRefs } from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport ElInputNumber from '@element-plus/components/input-number'\nimport { useFormItemInputId, useFormSize } from '@element-plus/components/form'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { sliderContextKey } from './constants'\nimport { sliderEmits, sliderProps } from './slider'\nimport SliderButton from './button.vue'\nimport SliderMarker from './marker'\nimport {\n  useLifecycle,\n  useMarks,\n  useSlide,\n  useStops,\n  useWatch,\n} from './composables'\nimport type { SliderInitData } from './slider'\n\ndefineOptions({\n  name: 'ElSlider',\n})\n\nconst props = defineProps(sliderProps)\nconst emit = defineEmits(sliderEmits)\n\nconst ns = useNamespace('slider')\nconst { t } = useLocale()\n\nconst initData = reactive<SliderInitData>({\n  firstValue: 0,\n  secondValue: 0,\n  oldValue: 0,\n  dragging: false,\n  sliderSize: 1,\n})\n\nconst {\n  elFormItem,\n  slider,\n  firstButton,\n  secondButton,\n  sliderDisabled,\n  minValue,\n  maxValue,\n  runwayStyle,\n  barStyle,\n  resetSize,\n  emitChange,\n  onSliderWrapperPrevent,\n  onSliderClick,\n  onSliderDown,\n  onSliderMarkerDown,\n  setFirstValue,\n  setSecondValue,\n} = useSlide(props, initData, emit)\n\nconst { stops, getStopStyle } = useStops(props, initData, minValue, maxValue)\n\nconst { inputId, isLabeledByFormItem } = useFormItemInputId(props, {\n  formItemContext: elFormItem,\n})\n\nconst sliderWrapperSize = useFormSize()\nconst sliderInputSize = computed(\n  () => props.inputSize || sliderWrapperSize.value\n)\n\nconst groupLabel = computed<string>(() => {\n  return (\n    props.ariaLabel ||\n    t('el.slider.defaultLabel', {\n      min: props.min,\n      max: props.max,\n    })\n  )\n})\n\nconst firstButtonLabel = computed<string>(() => {\n  if (props.range) {\n    return props.rangeStartLabel || t('el.slider.defaultRangeStartLabel')\n  } else {\n    return groupLabel.value\n  }\n})\n\nconst firstValueText = computed<string>(() => {\n  return props.formatValueText\n    ? props.formatValueText(firstValue.value)\n    : `${firstValue.value}`\n})\n\nconst secondButtonLabel = computed<string>(() => {\n  return props.rangeEndLabel || t('el.slider.defaultRangeEndLabel')\n})\n\nconst secondValueText = computed<string>(() => {\n  return props.formatValueText\n    ? props.formatValueText(secondValue.value)\n    : `${secondValue.value}`\n})\n\nconst sliderKls = computed(() => [\n  ns.b(),\n  ns.m(sliderWrapperSize.value),\n  ns.is('vertical', props.vertical),\n  { [ns.m('with-input')]: props.showInput },\n])\n\nconst markList = useMarks(props)\n\nuseWatch(props, initData, minValue, maxValue, emit, elFormItem!)\n\nconst precision = computed(() => {\n  const precisions = [props.min, props.max, props.step].map((item) => {\n    const decimal = `${item}`.split('.')[1]\n    return decimal ? decimal.length : 0\n  })\n  return Math.max.apply(null, precisions)\n})\n\nconst { sliderWrapper } = useLifecycle(props, initData, resetSize)\n\nconst { firstValue, secondValue, sliderSize } = toRefs(initData)\n\nconst updateDragging = (val: boolean) => {\n  initData.dragging = val\n}\n\nuseEventListener(sliderWrapper, 'touchstart', onSliderWrapperPrevent, {\n  passive: false,\n})\nuseEventListener(sliderWrapper, 'touchmove', onSliderWrapperPrevent, {\n  passive: false,\n})\n\nprovide(sliderContextKey, {\n  ...toRefs(props),\n  sliderSize,\n  disabled: sliderDisabled,\n  precision,\n  emitChange,\n  resetSize,\n  updateDragging,\n})\n\ndefineExpose({\n  onSliderClick,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Slider from './src/slider.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElSlider: SFCWithInstall<typeof Slider> = withInstall(Slider)\nexport default ElSlider\n\nexport * from './src/slider'\nexport * from './src/constants'\n", "import { computed, defineComponent, h, renderSlot } from 'vue'\nimport { buildProps } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const spaceItemProps = buildProps({\n  prefixCls: {\n    type: String,\n  },\n} as const)\nexport type SpaceItemProps = ExtractPropTypes<typeof spaceItemProps>\n\nconst SpaceItem = defineComponent({\n  name: 'ElSpaceItem',\n\n  props: spaceItemProps,\n\n  setup(props, { slots }) {\n    const ns = useNamespace('space')\n\n    const classes = computed(() => `${props.prefixCls || ns.b()}__item`)\n\n    return () =>\n      h('div', { class: classes.value }, renderSlot(slots, 'default'))\n  },\n})\nexport type SpaceItemInstance = InstanceType<typeof SpaceItem>\n\nexport default SpaceItem\n", "import { computed, ref, watchEffect } from 'vue'\nimport { isArray, isNumber } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\n\nimport type { SpaceProps } from './space'\nimport type { CSSProperties, StyleValue } from 'vue'\n\nconst SIZE_MAP = {\n  small: 8,\n  default: 12,\n  large: 16,\n} as const\n\nexport function useSpace(props: SpaceProps) {\n  const ns = useNamespace('space')\n\n  const classes = computed(() => [ns.b(), ns.m(props.direction), props.class])\n\n  const horizontalSize = ref(0)\n  const verticalSize = ref(0)\n\n  const containerStyle = computed<StyleValue>(() => {\n    const wrapKls: CSSProperties =\n      props.wrap || props.fill ? { flexWrap: 'wrap' } : {}\n    const alignment: CSSProperties = {\n      alignItems: props.alignment,\n    }\n    const gap: CSSProperties = {\n      rowGap: `${verticalSize.value}px`,\n      columnGap: `${horizontalSize.value}px`,\n    }\n    return [wrapKls, alignment, gap, props.style]\n  })\n\n  const itemStyle = computed<StyleValue>(() => {\n    return props.fill ? { flexGrow: 1, minWidth: `${props.fillRatio}%` } : {}\n  })\n\n  watchEffect(() => {\n    const { size = 'small', wrap, direction: dir, fill } = props\n\n    // when the specified size have been given\n    if (isArray(size)) {\n      const [h = 0, v = 0] = size\n      horizontalSize.value = h\n      verticalSize.value = v\n    } else {\n      let val: number\n      if (isNumber(size)) {\n        val = size\n      } else {\n        val = SIZE_MAP[size || 'small'] || SIZE_MAP.small\n      }\n\n      if ((wrap || fill) && dir === 'horizontal') {\n        horizontalSize.value = verticalSize.value = val\n      } else {\n        if (dir === 'horizontal') {\n          horizontalSize.value = val\n          verticalSize.value = 0\n        } else {\n          verticalSize.value = val\n          horizontalSize.value = 0\n        }\n      }\n    }\n  })\n\n  return {\n    classes,\n    containerStyle,\n    itemStyle,\n  }\n}\n", "import {\n  createTextVNode,\n  createVNode,\n  defineComponent,\n  isVNode,\n  renderSlot,\n} from 'vue'\nimport {\n  PatchFlags,\n  buildProps,\n  definePropType,\n  isArray,\n  isFragment,\n  isNumber,\n  isString,\n  isValidElementNode,\n} from '@element-plus/utils'\nimport { componentSizes } from '@element-plus/constants'\nimport Item from './item'\nimport { useSpace } from './use-space'\n\nimport type {\n  ExtractPropTypes,\n  StyleValue,\n  VNode,\n  VNodeArrayChildren,\n  VNodeChild,\n} from 'vue'\nimport type { Arrayable } from '@element-plus/utils'\nimport type { AlignItemsProperty } from 'csstype'\n\nexport const spaceProps = buildProps({\n  /**\n   * @description Placement direction\n   */\n  direction: {\n    type: String,\n    values: ['horizontal', 'vertical'],\n    default: 'horizontal',\n  },\n  /**\n   * @description Classname\n   */\n  class: {\n    type: definePropType<Arrayable<Record<string, boolean> | string>>([\n      String,\n      Object,\n      Array,\n    ]),\n    default: '',\n  },\n  /**\n   * @description Extra style rules\n   */\n  style: {\n    type: definePropType<StyleValue>([String, Array, Object]),\n    default: '',\n  },\n  /**\n   * @description Controls the alignment of items\n   */\n  alignment: {\n    type: definePropType<AlignItemsProperty>(String),\n    default: 'center',\n  },\n  /**\n   * @description Prefix for space-items\n   */\n  prefixCls: {\n    type: String,\n  },\n  /**\n   * @description Spacer\n   */\n  spacer: {\n    type: definePropType<VNodeChild>([Object, String, Number, Array]),\n    default: null,\n    validator: (val: unknown) => isVNode(val) || isNumber(val) || isString(val),\n  },\n  /**\n   * @description Auto wrapping\n   */\n  wrap: Boolean,\n  /**\n   * @description Whether to fill the container\n   */\n  fill: Boolean,\n  /**\n   * @description Ratio of fill\n   */\n  fillRatio: {\n    type: Number,\n    default: 100,\n  },\n  /**\n   * @description Spacing size\n   */\n  size: {\n    type: [String, Array, Number],\n    values: componentSizes,\n    validator: (val: unknown): val is [number, number] | number => {\n      return (\n        isNumber(val) ||\n        (isArray(val) && val.length === 2 && val.every(isNumber))\n      )\n    },\n  },\n} as const)\nexport type SpaceProps = ExtractPropTypes<typeof spaceProps>\n\nconst Space = defineComponent({\n  name: 'ElSpace',\n\n  props: spaceProps,\n\n  setup(props, { slots }) {\n    const { classes, containerStyle, itemStyle } = useSpace(props)\n\n    // retrieve the children out via a simple for loop\n    // the edge case here is that when users uses directives like <v-for>, <v-if>\n    // we need to go deeper until the child is not the Fragment type\n    function extractChildren(\n      children: VNodeArrayChildren,\n      parentKey = '',\n      extractedChildren: VNode[] = []\n    ) {\n      const { prefixCls } = props\n      children.forEach((child, loopKey) => {\n        if (isFragment(child)) {\n          if (isArray(child.children)) {\n            child.children.forEach((nested, key) => {\n              if (isFragment(nested) && isArray(nested.children)) {\n                extractChildren(\n                  nested.children,\n                  `${parentKey + key}-`,\n                  extractedChildren\n                )\n              } else {\n                extractedChildren.push(\n                  createVNode(\n                    Item,\n                    {\n                      style: itemStyle.value,\n                      prefixCls,\n                      key: `nested-${parentKey + key}`,\n                    },\n                    {\n                      default: () => [nested],\n                    },\n                    PatchFlags.PROPS | PatchFlags.STYLE,\n                    ['style', 'prefixCls']\n                  )\n                )\n              }\n            })\n          }\n          // if the current child is valid vnode, then append this current vnode\n          // to item as child node.\n        } else if (isValidElementNode(child)) {\n          extractedChildren.push(\n            createVNode(\n              Item,\n              {\n                style: itemStyle.value,\n                prefixCls,\n                key: `LoopKey${parentKey + loopKey}`,\n              },\n              {\n                default: () => [child],\n              },\n              PatchFlags.PROPS | PatchFlags.STYLE,\n              ['style', 'prefixCls']\n            )\n          )\n        }\n      })\n\n      return extractedChildren\n    }\n\n    return () => {\n      const { spacer, direction } = props\n\n      const children = renderSlot(slots, 'default', { key: 0 }, () => [])\n\n      if ((children.children ?? []).length === 0) return null\n      // loop the children, if current children is rendered via `renderList` or `<v-for>`\n      if (isArray(children.children)) {\n        let extractedChildren = extractChildren(children.children)\n\n        if (spacer) {\n          // track the current rendering index, when encounters the last element\n          // then no need to add a spacer after it.\n          const len = extractedChildren.length - 1\n          extractedChildren = extractedChildren.reduce<VNode[]>(\n            (acc, child, idx) => {\n              const children = [...acc, child]\n              if (idx !== len) {\n                children.push(\n                  createVNode(\n                    'span',\n                    // adding width 100% for vertical alignment,\n                    // when the spacer inherit the width from the\n                    // parent, this span's width was not set, so space\n                    // might disappear\n                    {\n                      style: [\n                        itemStyle.value,\n                        direction === 'vertical' ? 'width: 100%' : null,\n                      ],\n                      key: idx,\n                    },\n                    [\n                      // if spacer is already a valid vnode, then append it to the current\n                      // span element.\n                      // otherwise, treat it as string.\n                      isVNode(spacer)\n                        ? spacer\n                        : createTextVNode(spacer as string, PatchFlags.TEXT),\n                    ],\n                    PatchFlags.STYLE\n                  )\n                )\n              }\n              return children\n            },\n            []\n          )\n        }\n\n        // spacer container.\n        return createVNode(\n          'div',\n          {\n            class: classes.value,\n            style: containerStyle.value,\n          },\n          extractedChildren,\n          PatchFlags.STYLE | PatchFlags.CLASS\n        )\n      }\n\n      return children.children\n    }\n  },\n})\n\nexport type SpaceInstance = InstanceType<typeof Space>\n\nexport default Space\n", "import { withInstall } from '@element-plus/utils'\n\nimport Space from './src/space'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElSpace: SFCWithInstall<typeof Space> = withInstall(Space)\nexport default ElSpace\n\nexport * from './src/space'\nexport * from './src/item'\nexport * from './src/use-space'\n", "import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, StyleValue } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type Statistic from './statistic.vue'\n\nexport const statisticProps = buildProps({\n  /**\n   * @description Setting the decimal point\n   */\n  decimalSeparator: {\n    type: String,\n    default: '.',\n  },\n  /**\n   * @description Sets the thousandth identifier\n   */\n  groupSeparator: {\n    type: String,\n    default: ',',\n  },\n  /**\n   * @description numerical precision\n   */\n  precision: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description Custom numerical presentation\n   */\n  formatter: Function,\n  /**\n   * @description Numerical content\n   */\n  value: {\n    type: definePropType<number | Dayjs>([Number, Object]),\n    default: 0,\n  },\n  /**\n   * @description Sets the prefix of a number\n   */\n  prefix: String,\n\n  /**\n   * @description  Sets the suffix of a number\n   */\n  suffix: String,\n  /**\n   * @description Numeric titles\n   */\n  title: String,\n  /**\n   * @description Styles numeric values\n   */\n  valueStyle: {\n    type: definePropType<StyleValue>([String, Object, Array]),\n  },\n} as const)\nexport type StatisticProps = ExtractPropTypes<typeof statisticProps>\n\nexport type StatisticInstance = InstanceType<typeof Statistic>\n", "<template>\n  <div :class=\"ns.b()\">\n    <div v-if=\"$slots.title || title\" :class=\"ns.e('head')\">\n      <slot name=\"title\">\n        {{ title }}\n      </slot>\n    </div>\n    <div :class=\"ns.e('content')\">\n      <div v-if=\"$slots.prefix || prefix\" :class=\"ns.e('prefix')\">\n        <slot name=\"prefix\">\n          <span>{{ prefix }}</span>\n        </slot>\n      </div>\n      <span :class=\"ns.e('number')\" :style=\"valueStyle\">\n        {{ displayValue }}\n      </span>\n      <div v-if=\"$slots.suffix || suffix\" :class=\"ns.e('suffix')\">\n        <slot name=\"suffix\">\n          <span>{{ suffix }}</span>\n        </slot>\n      </div>\n    </div>\n  </div>\n</template>\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { isFunction, isNumber } from '@element-plus/utils'\nimport { statisticProps } from './statistic'\n\ndefineOptions({\n  name: 'ElStatistic',\n})\n\nconst props = defineProps(statisticProps)\nconst ns = useNamespace('statistic')\n\nconst displayValue = computed(() => {\n  const { value, formatter, precision, decimalSeparator, groupSeparator } =\n    props\n\n  if (isFunction(formatter)) return formatter(value)\n\n  // https://github.com/element-plus/element-plus/issues/17784\n  if (!isNumber(value) || Number.isNaN(value)) return value\n\n  let [integer, decimal = ''] = String(value).split('.')\n  decimal = decimal\n    .padEnd(precision, '0')\n    .slice(0, precision > 0 ? precision : 0)\n  integer = integer.replace(/\\B(?=(\\d{3})+(?!\\d))/g, groupSeparator)\n  return [integer, decimal].join(decimal ? decimalSeparator : '')\n})\n\ndefineExpose({\n  /**\n   * @description current display value\n   */\n  displayValue,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Statistic from './src/statistic.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElStatistic: SFCWithInstall<typeof Statistic> =\n  withInstall(Statistic)\n\nexport default ElStatistic\nexport * from './src/statistic'\n", "import { buildProps, definePropType, isNumber } from '@element-plus/utils'\nimport { CHANGE_EVENT } from '@element-plus/constants'\n\nimport type { ExtractPropTypes, StyleValue } from 'vue'\nimport type { Dayjs } from 'dayjs'\nimport type Countdown from './countdown.vue'\n\nexport const countdownProps = buildProps({\n  /**\n   * @description Formatting the countdown display\n   */\n  format: {\n    type: String,\n    default: 'HH:mm:ss',\n  },\n  /**\n   * @description Sets the prefix of a countdown\n   */\n  prefix: String,\n  /**\n   * @description Sets the suffix of a countdown\n   */\n  suffix: String,\n  /**\n   * @description countdown titles\n   */\n  title: String,\n  /**\n   * @description target time\n   */\n  value: {\n    type: definePropType<number | Dayjs>([Number, Object]),\n    default: 0,\n  },\n  /**\n   * @description Styles countdown values\n   */\n  valueStyle: {\n    type: definePropType<StyleValue>([String, Object, Array]),\n  },\n} as const)\nexport type CountdownProps = ExtractPropTypes<typeof countdownProps>\n\nexport const countdownEmits = {\n  finish: () => true,\n  [CHANGE_EVENT]: (value: number) => isNumber(value),\n}\nexport type CountdownEmits = typeof countdownEmits\n\nexport type CountdownInstance = InstanceType<typeof Countdown>\n", "import { isNumber } from '@element-plus/utils'\n\nimport type { Dayjs } from 'dayjs'\n\nconst timeUnits = [\n  ['Y', 1000 * 60 * 60 * 24 * 365], // years\n  ['M', 1000 * 60 * 60 * 24 * 30], // months\n  ['D', 1000 * 60 * 60 * 24], // days\n  ['H', 1000 * 60 * 60], // hours\n  ['m', 1000 * 60], // minutes\n  ['s', 1000], // seconds\n  ['S', 1], // million seconds\n] as const\n\nexport const getTime = (value: number | Dayjs) => {\n  return isNumber(value) ? new Date(value).getTime() : value.valueOf()\n}\n\nexport const formatTime = (timestamp: number, format: string) => {\n  let timeLeft = timestamp\n  const escapeRegex = /\\[([^\\]]*)]/g\n\n  const replacedText = timeUnits.reduce((current, [name, unit]) => {\n    const replaceRegex = new RegExp(`${name}+(?![^\\\\[\\\\]]*\\\\])`, 'g')\n    if (replaceRegex.test(current)) {\n      const value = Math.floor(timeLeft / unit)\n      timeLeft -= value * unit\n      return current.replace(replaceRegex, (match) =>\n        String(value).padStart(match.length, '0')\n      )\n    }\n    return current\n  }, format)\n\n  return replacedText.replace(escapeRegex, '$1')\n}\n", "<template>\n  <el-statistic\n    :value=\"rawValue\"\n    :title=\"title\"\n    :prefix=\"prefix\"\n    :suffix=\"suffix\"\n    :value-style=\"valueStyle\"\n    :formatter=\"formatter\"\n  >\n    <template v-for=\"(_, name) in $slots\" #[name]>\n      <slot :name=\"name\" />\n    </template>\n  </el-statistic>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, onBeforeUnmount, onMounted, ref, watch } from 'vue'\nimport { ElStatistic } from '@element-plus/components/statistic'\nimport { cAF, rAF } from '@element-plus/utils'\nimport { countdownEmits, countdownProps } from './countdown'\nimport { formatTime, getTime } from './utils'\n\ndefineOptions({\n  name: 'ElCountdown',\n})\n\nconst props = defineProps(countdownProps)\nconst emit = defineEmits(countdownEmits)\n\nlet timer: ReturnType<typeof rAF> | undefined\nconst rawValue = ref<number>(0)\nconst displayValue = computed(() => formatTime(rawValue.value, props.format))\n\nconst formatter = (val: number) => formatTime(val, props.format)\n\nconst stopTimer = () => {\n  if (timer) {\n    cAF(timer)\n    timer = undefined\n  }\n}\n\nconst startTimer = () => {\n  const timestamp = getTime(props.value)\n  const frameFunc = () => {\n    let diff = timestamp - Date.now()\n    emit('change', diff)\n    if (diff <= 0) {\n      diff = 0\n      stopTimer()\n      emit('finish')\n    } else {\n      timer = rAF(frameFunc)\n    }\n    rawValue.value = diff\n  }\n  timer = rAF(frameFunc)\n}\n\nonMounted(() => {\n  rawValue.value = getTime(props.value) - Date.now()\n\n  watch(\n    () => [props.value, props.format],\n    () => {\n      stopTimer()\n      startTimer()\n    },\n    {\n      immediate: true,\n    }\n  )\n})\n\nonBeforeUnmount(() => {\n  stopTimer()\n})\n\ndefineExpose({\n  /**\n   * @description current display value\n   */\n  displayValue,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Countdown from './src/countdown.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElCountdown: SFCWithInstall<typeof Countdown> =\n  withInstall(Countdown)\nexport default ElCountdown\n\nexport * from './src/countdown'\n", "import { CHANGE_EVENT } from '@element-plus/constants'\nimport { buildProps, isNumber } from '@element-plus/utils'\nimport type Steps from './steps.vue'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const stepsProps = buildProps({\n  /**\n   * @description the spacing of each step, will be responsive if omitted. Supports percentage.\n   */\n  space: {\n    type: [Number, String],\n    default: '',\n  },\n  /**\n   * @description current activation step\n   */\n  active: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description display direction\n   */\n  direction: {\n    type: String,\n    default: 'horizontal',\n    values: ['horizontal', 'vertical'],\n  },\n  /**\n   * @description center title and description\n   */\n  alignCenter: {\n    type: Boolean,\n  },\n  /**\n   * @description whether to apply simple theme\n   */\n  simple: {\n    type: Boolean,\n  },\n  /**\n   * @description status of end step\n   */\n  finishStatus: {\n    type: String,\n    values: ['wait', 'process', 'finish', 'error', 'success'],\n    default: 'finish',\n  },\n  /**\n   * @description status of current step\n   */\n  processStatus: {\n    type: String,\n    values: ['wait', 'process', 'finish', 'error', 'success'],\n    default: 'process',\n  },\n} as const)\nexport type StepsProps = ExtractPropTypes<typeof stepsProps>\n\nexport const stepsEmits = {\n  [CHANGE_EVENT]: (newVal: number, oldVal: number) =>\n    [newVal, oldVal].every(isNumber),\n}\nexport type StepsEmits = typeof stepsEmits\n\nexport type StepsInstance = InstanceType<typeof Steps>\n", "<template>\n  <div :class=\"[ns.b(), ns.m(simple ? 'simple' : direction)]\">\n    <slot />\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { getCurrentInstance, provide, watch } from 'vue'\nimport { CHANGE_EVENT } from '@element-plus/constants'\nimport { useNamespace, useOrderedChildren } from '@element-plus/hooks'\nimport { stepsEmits, stepsProps } from './steps'\n\nimport type { StepItemState } from './item.vue'\n\ndefineOptions({\n  name: 'ElSteps',\n})\n\nconst props = defineProps(stepsProps)\nconst emit = defineEmits(stepsEmits)\n\nconst ns = useNamespace('steps')\nconst {\n  children: steps,\n  addChild: addStep,\n  removeChild: removeStep,\n} = useOrderedChildren<StepItemState>(getCurrentInstance()!, 'ElStep')\n\nwatch(steps, () => {\n  steps.value.forEach((instance: StepItemState, index: number) => {\n    instance.setIndex(index)\n  })\n})\n\nprovide('ElSteps', { props, steps, addStep, removeStep })\n\nwatch(\n  () => props.active,\n  (newVal: number, oldVal: number) => {\n    emit(CHANGE_EVENT, newVal, oldVal)\n  }\n)\n</script>\n", "import { buildProps, iconPropType } from '@element-plus/utils'\nimport type Step from './item.vue'\nimport type { ExtractPropTypes } from 'vue'\n\nexport const stepProps = buildProps({\n  /**\n   * @description step title\n   */\n  title: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description step custom icon. Icons can be passed via named slot as well\n   */\n  icon: {\n    type: iconPropType,\n  },\n  /**\n   * @description step description\n   */\n  description: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description current status. It will be automatically set by Steps if not configured.\n   */\n  status: {\n    type: String,\n    values: ['', 'wait', 'process', 'finish', 'error', 'success'],\n    default: '',\n  },\n} as const)\n\nexport type StepProps = ExtractPropTypes<typeof stepProps>\n\nexport type StepInstance = InstanceType<typeof Step>\n", "<template>\n  <div :style=\"style\" :class=\"containerKls\">\n    <!-- icon & line -->\n    <div :class=\"[ns.e('head'), ns.is(currentStatus)]\">\n      <div v-if=\"!isSimple\" :class=\"ns.e('line')\">\n        <i :class=\"ns.e('line-inner')\" :style=\"lineStyle\" />\n      </div>\n\n      <div\n        :class=\"[ns.e('icon'), ns.is(icon || $slots.icon ? 'icon' : 'text')]\"\n      >\n        <slot name=\"icon\">\n          <el-icon v-if=\"icon\" :class=\"ns.e('icon-inner')\">\n            <component :is=\"icon\" />\n          </el-icon>\n          <el-icon\n            v-else-if=\"currentStatus === 'success'\"\n            :class=\"[ns.e('icon-inner'), ns.is('status')]\"\n          >\n            <Check />\n          </el-icon>\n          <el-icon\n            v-else-if=\"currentStatus === 'error'\"\n            :class=\"[ns.e('icon-inner'), ns.is('status')]\"\n          >\n            <Close />\n          </el-icon>\n          <div v-else-if=\"!isSimple\" :class=\"ns.e('icon-inner')\">\n            {{ index + 1 }}\n          </div>\n        </slot>\n      </div>\n    </div>\n    <!-- title & description -->\n    <div :class=\"ns.e('main')\">\n      <div :class=\"[ns.e('title'), ns.is(currentStatus)]\">\n        <slot name=\"title\">{{ title }}</slot>\n      </div>\n      <div v-if=\"isSimple\" :class=\"ns.e('arrow')\" />\n      <div v-else :class=\"[ns.e('description'), ns.is(currentStatus)]\">\n        <slot name=\"description\">{{ description }}</slot>\n      </div>\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  getCurrentInstance,\n  inject,\n  onBeforeUnmount,\n  onMounted,\n  reactive,\n  ref,\n  watch,\n} from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { Check, Close } from '@element-plus/icons-vue'\nimport { isNumber } from '@element-plus/utils'\nimport { stepProps } from './item'\n\nimport type { CSSProperties, Ref } from 'vue'\n\nexport interface IStepsProps {\n  space: number | string\n  active: number\n  direction: string\n  alignCenter: boolean\n  simple: boolean\n  finishStatus: string\n  processStatus: string\n}\n\nexport interface StepItemState {\n  uid: number\n  currentStatus: string\n  setIndex: (val: number) => void\n  calcProgress: (status: string) => void\n}\n\nexport interface IStepsInject {\n  props: IStepsProps\n  steps: Ref<StepItemState[]>\n  addStep: (item: StepItemState) => void\n  removeStep: (uid: number) => void\n}\n\ndefineOptions({\n  name: 'ElStep',\n})\n\nconst props = defineProps(stepProps)\nconst ns = useNamespace('step')\nconst index = ref(-1)\nconst lineStyle = ref({})\nconst internalStatus = ref('')\nconst parent = inject('ElSteps') as IStepsInject\nconst currentInstance = getCurrentInstance()\n\nonMounted(() => {\n  watch(\n    [\n      () => parent.props.active,\n      () => parent.props.processStatus,\n      () => parent.props.finishStatus,\n    ],\n    ([active]) => {\n      updateStatus(active)\n    },\n    { immediate: true }\n  )\n})\n\nonBeforeUnmount(() => {\n  parent.removeStep(stepItemState.uid)\n})\n\nconst currentStatus = computed(() => {\n  return props.status || internalStatus.value\n})\n\nconst prevStatus = computed(() => {\n  const prevStep = parent.steps.value[index.value - 1]\n  return prevStep ? prevStep.currentStatus : 'wait'\n})\n\nconst isCenter = computed(() => {\n  return parent.props.alignCenter\n})\n\nconst isVertical = computed(() => {\n  return parent.props.direction === 'vertical'\n})\n\nconst isSimple = computed(() => {\n  return parent.props.simple\n})\n\nconst stepsCount = computed(() => {\n  return parent.steps.value.length\n})\n\nconst isLast = computed(() => {\n  return parent.steps.value[stepsCount.value - 1]?.uid === currentInstance?.uid\n})\n\nconst space = computed(() => {\n  return isSimple.value ? '' : parent.props.space\n})\n\nconst containerKls = computed(() => {\n  return [\n    ns.b(),\n    ns.is(isSimple.value ? 'simple' : parent.props.direction),\n    ns.is('flex', isLast.value && !space.value && !isCenter.value),\n    ns.is('center', isCenter.value && !isVertical.value && !isSimple.value),\n  ]\n})\n\nconst style = computed(() => {\n  const style: CSSProperties = {\n    flexBasis: isNumber(space.value)\n      ? `${space.value}px`\n      : space.value\n      ? space.value\n      : `${100 / (stepsCount.value - (isCenter.value ? 0 : 1))}%`,\n  }\n  if (isVertical.value) return style\n  if (isLast.value) {\n    style.maxWidth = `${100 / stepsCount.value}%`\n  }\n  return style\n})\n\nconst setIndex = (val: number) => {\n  index.value = val\n}\n\nconst calcProgress = (status: string) => {\n  const isWait = status === 'wait'\n  const style: CSSProperties = {\n    transitionDelay: `${isWait ? '-' : ''}${150 * index.value}ms`,\n  }\n  const step = status === parent.props.processStatus || isWait ? 0 : 100\n\n  style.borderWidth = step && !isSimple.value ? '1px' : 0\n  style[parent.props.direction === 'vertical' ? 'height' : 'width'] = `${step}%`\n  lineStyle.value = style\n}\n\nconst updateStatus = (activeIndex: number) => {\n  if (activeIndex > index.value) {\n    internalStatus.value = parent.props.finishStatus\n  } else if (activeIndex === index.value && prevStatus.value !== 'error') {\n    internalStatus.value = parent.props.processStatus\n  } else {\n    internalStatus.value = 'wait'\n  }\n  const prevChild = parent.steps.value[index.value - 1]\n  if (prevChild) prevChild.calcProgress(internalStatus.value)\n}\n\nconst stepItemState = reactive({\n  uid: currentInstance!.uid,\n  currentStatus,\n  setIndex,\n  calcProgress,\n})\n\nparent.addStep(stepItemState)\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\n\nimport Steps from './src/steps.vue'\nimport Step from './src/item.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElSteps: SFCWithInstall<typeof Steps> & {\n  Step: typeof Step\n} = withInstall(Steps, {\n  Step,\n})\nexport default ElSteps\nexport const ElStep: SFCWithInstall<typeof Step> = withNoopInstall(Step)\n\nexport * from './src/item'\nexport * from './src/steps'\n", "import {\n  buildProps,\n  definePropType,\n  iconPropType,\n  isBoolean,\n  isNumber,\n  isString,\n  isValidComponentSize,\n} from '@element-plus/utils'\nimport {\n  CHANGE_EVENT,\n  INPUT_EVENT,\n  UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { useAriaProps } from '@element-plus/hooks'\nimport type { ComponentSize } from '@element-plus/constants'\nimport type Switch from './switch.vue'\nimport type { ExtractPropTypes, PropType } from 'vue'\n\nexport const switchProps = buildProps({\n  /**\n   * @description binding value, it should be equivalent to either `active-value` or `inactive-value`, by default it's `boolean` type\n   */\n  modelValue: {\n    type: [Boolean, String, Number],\n    default: false,\n  },\n  /**\n   * @description whether Switch is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description whether Switch is in loading state\n   */\n  loading: Boolean,\n  /**\n   * @description size of Switch\n   */\n  size: {\n    type: String as PropType<ComponentSize>,\n    validator: isValidComponentSize,\n  },\n  /**\n   * @description width of Switch\n   */\n  width: {\n    type: [String, Number],\n    default: '',\n  },\n  /**\n   * @description whether icon or text is displayed inside dot, only the first character will be rendered for text\n   */\n  inlinePrompt: Boolean,\n  /**\n   * @description component of the icon displayed in action when in `off` state\n   */\n  inactiveActionIcon: {\n    type: iconPropType,\n  },\n  /**\n   * @description component of the icon displayed in action when in `on` state\n   */\n  activeActionIcon: {\n    type: iconPropType,\n  },\n  /**\n   * @description component of the icon displayed when in `on` state, overrides `active-text`\n   */\n  activeIcon: {\n    type: iconPropType,\n  },\n  /**\n   * @description component of the icon displayed when in `off` state, overrides `inactive-text`\n   */\n  inactiveIcon: {\n    type: iconPropType,\n  },\n  /**\n   * @description text displayed when in `on` state\n   */\n  activeText: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description text displayed when in `off` state\n   */\n  inactiveText: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description switch value when in `on` state\n   */\n  activeValue: {\n    type: [Boolean, String, Number],\n    default: true,\n  },\n  /**\n   * @description switch value when in `off` state\n   */\n  inactiveValue: {\n    type: [Boolean, String, Number],\n    default: false,\n  },\n  /**\n   * @description input name of Switch\n   */\n  name: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description before-change hook before the switch state changes. If `false` is returned or a `Promise` is returned and then is rejected, will stop switching\n   */\n  beforeChange: {\n    type: definePropType<() => Promise<boolean> | boolean>(Function),\n  },\n  /**\n   * @description id for input\n   */\n  id: String,\n  /**\n   * @description tabindex for input\n   */\n  tabindex: {\n    type: [String, Number],\n  },\n  ...useAriaProps(['ariaLabel']),\n} as const)\n\nexport type SwitchProps = ExtractPropTypes<typeof switchProps>\n\nexport const switchEmits = {\n  [UPDATE_MODEL_EVENT]: (val: boolean | string | number) =>\n    isBoolean(val) || isString(val) || isNumber(val),\n  [CHANGE_EVENT]: (val: boolean | string | number) =>\n    isBoolean(val) || isString(val) || isNumber(val),\n  [INPUT_EVENT]: (val: boolean | string | number) =>\n    isBoolean(val) || isString(val) || isNumber(val),\n}\nexport type SwitchEmits = typeof switchEmits\n\nexport type SwitchInstance = InstanceType<typeof Switch>\n", "<template>\n  <div :class=\"switchKls\" @click.prevent=\"switchValue\">\n    <input\n      :id=\"inputId\"\n      ref=\"input\"\n      :class=\"ns.e('input')\"\n      type=\"checkbox\"\n      role=\"switch\"\n      :aria-checked=\"checked\"\n      :aria-disabled=\"switchDisabled\"\n      :aria-label=\"ariaLabel\"\n      :name=\"name\"\n      :true-value=\"activeValue\"\n      :false-value=\"inactiveValue\"\n      :disabled=\"switchDisabled\"\n      :tabindex=\"tabindex\"\n      @change=\"handleChange\"\n      @keydown.enter=\"switchValue\"\n    />\n    <span\n      v-if=\"!inlinePrompt && (inactiveIcon || inactiveText)\"\n      :class=\"labelLeftKls\"\n    >\n      <el-icon v-if=\"inactiveIcon\">\n        <component :is=\"inactiveIcon\" />\n      </el-icon>\n      <span v-if=\"!inactiveIcon && inactiveText\" :aria-hidden=\"checked\">{{\n        inactiveText\n      }}</span>\n    </span>\n    <span ref=\"core\" :class=\"ns.e('core')\" :style=\"coreStyle\">\n      <div v-if=\"inlinePrompt\" :class=\"ns.e('inner')\">\n        <template v-if=\"activeIcon || inactiveIcon\">\n          <el-icon :class=\"ns.is('icon')\">\n            <component :is=\"checked ? activeIcon : inactiveIcon\" />\n          </el-icon>\n        </template>\n        <template v-else-if=\"activeText || inactiveText\">\n          <span :class=\"ns.is('text')\" :aria-hidden=\"!checked\">\n            {{ checked ? activeText : inactiveText }}\n          </span>\n        </template>\n      </div>\n      <div :class=\"ns.e('action')\">\n        <el-icon v-if=\"loading\" :class=\"ns.is('loading')\">\n          <loading />\n        </el-icon>\n        <slot v-else-if=\"checked\" name=\"active-action\">\n          <el-icon v-if=\"activeActionIcon\">\n            <component :is=\"activeActionIcon\" />\n          </el-icon>\n        </slot>\n        <slot v-else-if=\"!checked\" name=\"inactive-action\">\n          <el-icon v-if=\"inactiveActionIcon\">\n            <component :is=\"inactiveActionIcon\" />\n          </el-icon>\n        </slot>\n      </div>\n    </span>\n    <span\n      v-if=\"!inlinePrompt && (activeIcon || activeText)\"\n      :class=\"labelRightKls\"\n    >\n      <el-icon v-if=\"activeIcon\">\n        <component :is=\"activeIcon\" />\n      </el-icon>\n      <span v-if=\"!activeIcon && activeText\" :aria-hidden=\"!checked\">{{\n        activeText\n      }}</span>\n    </span>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, nextTick, onMounted, ref, watch } from 'vue'\nimport {\n  addUnit,\n  debugWarn,\n  isBoolean,\n  isPromise,\n  throwError,\n} from '@element-plus/utils'\nimport ElIcon from '@element-plus/components/icon'\nimport {\n  useFormDisabled,\n  useFormItem,\n  useFormItemInputId,\n  useFormSize,\n} from '@element-plus/components/form'\nimport { Loading } from '@element-plus/icons-vue'\nimport {\n  CHANGE_EVENT,\n  INPUT_EVENT,\n  UPDATE_MODEL_EVENT,\n} from '@element-plus/constants'\nimport { useNamespace } from '@element-plus/hooks'\nimport { switchEmits, switchProps } from './switch'\nimport type { CSSProperties } from 'vue'\n\nconst COMPONENT_NAME = 'ElSwitch'\ndefineOptions({\n  name: COMPONENT_NAME,\n})\n\nconst props = defineProps(switchProps)\nconst emit = defineEmits(switchEmits)\n\nconst { formItem } = useFormItem()\nconst switchSize = useFormSize()\nconst ns = useNamespace('switch')\n\nconst { inputId } = useFormItemInputId(props, {\n  formItemContext: formItem,\n})\n\nconst switchDisabled = useFormDisabled(computed(() => props.loading))\nconst isControlled = ref(props.modelValue !== false)\nconst input = ref<HTMLInputElement>()\nconst core = ref<HTMLSpanElement>()\n\nconst switchKls = computed(() => [\n  ns.b(),\n  ns.m(switchSize.value),\n  ns.is('disabled', switchDisabled.value),\n  ns.is('checked', checked.value),\n])\n\nconst labelLeftKls = computed(() => [\n  ns.e('label'),\n  ns.em('label', 'left'),\n  ns.is('active', !checked.value),\n])\n\nconst labelRightKls = computed(() => [\n  ns.e('label'),\n  ns.em('label', 'right'),\n  ns.is('active', checked.value),\n])\n\nconst coreStyle = computed<CSSProperties>(() => ({\n  width: addUnit(props.width),\n}))\n\nwatch(\n  () => props.modelValue,\n  () => {\n    isControlled.value = true\n  }\n)\n\nconst actualValue = computed(() => {\n  return isControlled.value ? props.modelValue : false\n})\n\nconst checked = computed(() => actualValue.value === props.activeValue)\n\nif (![props.activeValue, props.inactiveValue].includes(actualValue.value)) {\n  emit(UPDATE_MODEL_EVENT, props.inactiveValue)\n  emit(CHANGE_EVENT, props.inactiveValue)\n  emit(INPUT_EVENT, props.inactiveValue)\n}\n\nwatch(checked, (val) => {\n  input.value!.checked = val\n\n  if (props.validateEvent) {\n    formItem?.validate?.('change').catch((err) => debugWarn(err))\n  }\n})\n\nconst handleChange = () => {\n  const val = checked.value ? props.inactiveValue : props.activeValue\n  emit(UPDATE_MODEL_EVENT, val)\n  emit(CHANGE_EVENT, val)\n  emit(INPUT_EVENT, val)\n  nextTick(() => {\n    input.value!.checked = checked.value\n  })\n}\n\nconst switchValue = () => {\n  if (switchDisabled.value) return\n\n  const { beforeChange } = props\n  if (!beforeChange) {\n    handleChange()\n    return\n  }\n\n  const shouldChange = beforeChange()\n\n  const isPromiseOrBool = [\n    isPromise(shouldChange),\n    isBoolean(shouldChange),\n  ].includes(true)\n  if (!isPromiseOrBool) {\n    throwError(\n      COMPONENT_NAME,\n      'beforeChange must return type `Promise<boolean>` or `boolean`'\n    )\n  }\n\n  if (isPromise(shouldChange)) {\n    shouldChange\n      .then((result) => {\n        if (result) {\n          handleChange()\n        }\n      })\n      .catch((e) => {\n        debugWarn(COMPONENT_NAME, `some error occurred: ${e}`)\n      })\n  } else if (shouldChange) {\n    handleChange()\n  }\n}\n\nconst focus = (): void => {\n  input.value?.focus?.()\n}\n\nonMounted(() => {\n  input.value!.checked = checked.value\n})\n\ndefineExpose({\n  /**\n   *  @description manual focus to the switch component\n   **/\n  focus,\n  /**\n   * @description whether Switch is checked\n   */\n  checked,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Switch from './src/switch.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElSwitch: SFCWithInstall<typeof Switch> = withInstall(Switch)\nexport default ElSwitch\n\nexport * from './src/switch'\n", "// @ts-nocheck\nimport { createVNode, render } from 'vue'\nimport { flatMap, get } from 'lodash-unified'\nimport {\n  hasOwn,\n  isArray,\n  isBoolean,\n  isObject,\n  throwError,\n} from '@element-plus/utils'\nimport ElTooltip, {\n  type ElTooltipProps,\n} from '@element-plus/components/tooltip'\nimport type { Table, TreeProps } from './table/defaults'\nimport type { TableColumnCtx } from './table-column/defaults'\n\nexport type TableOverflowTooltipOptions = Partial<\n  Pick<\n    ElTooltipProps,\n    | 'appendTo'\n    | 'effect'\n    | 'enterable'\n    | 'hideAfter'\n    | 'offset'\n    | 'placement'\n    | 'popperClass'\n    | 'popperOptions'\n    | 'showAfter'\n    | 'showArrow'\n    | 'transition'\n  >\n>\n\ntype RemovePopperFn = (() => void) & {\n  trigger?: HTMLElement\n}\n\nexport const getCell = function (event: Event) {\n  return (event.target as HTMLElement)?.closest('td')\n}\n\nexport const orderBy = function <T>(\n  array: T[],\n  sortKey: string,\n  reverse: string | number,\n  sortMethod,\n  sortBy: string | (string | ((a: T, b: T, array?: T[]) => number))[]\n) {\n  if (\n    !sortKey &&\n    !sortMethod &&\n    (!sortBy || (Array.isArray(sortBy) && !sortBy.length))\n  ) {\n    return array\n  }\n  if (typeof reverse === 'string') {\n    reverse = reverse === 'descending' ? -1 : 1\n  } else {\n    reverse = reverse && reverse < 0 ? -1 : 1\n  }\n  const getKey = sortMethod\n    ? null\n    : function (value, index) {\n        if (sortBy) {\n          if (!Array.isArray(sortBy)) {\n            sortBy = [sortBy]\n          }\n          return sortBy.map((by) => {\n            if (typeof by === 'string') {\n              return get(value, by)\n            } else {\n              return by(value, index, array)\n            }\n          })\n        }\n        if (sortKey !== '$key') {\n          if (isObject(value) && '$value' in value) value = value.$value\n        }\n        return [isObject(value) ? get(value, sortKey) : value]\n      }\n  const compare = function (a, b) {\n    if (sortMethod) {\n      return sortMethod(a.value, b.value)\n    }\n    for (let i = 0, len = a.key.length; i < len; i++) {\n      if (a.key[i] < b.key[i]) {\n        return -1\n      }\n      if (a.key[i] > b.key[i]) {\n        return 1\n      }\n    }\n    return 0\n  }\n  return array\n    .map((value, index) => {\n      return {\n        value,\n        index,\n        key: getKey ? getKey(value, index) : null,\n      }\n    })\n    .sort((a, b) => {\n      let order = compare(a, b)\n      if (!order) {\n        // make stable https://en.wikipedia.org/wiki/Sorting_algorithm#Stability\n        order = a.index - b.index\n      }\n      return order * +reverse\n    })\n    .map((item) => item.value)\n}\n\nexport const getColumnById = function <T>(\n  table: {\n    columns: TableColumnCtx<T>[]\n  },\n  columnId: string\n): null | TableColumnCtx<T> {\n  let column = null\n  table.columns.forEach((item) => {\n    if (item.id === columnId) {\n      column = item\n    }\n  })\n  return column\n}\n\nexport const getColumnByKey = function <T>(\n  table: {\n    columns: TableColumnCtx<T>[]\n  },\n  columnKey: string\n): TableColumnCtx<T> {\n  let column = null\n  for (let i = 0; i < table.columns.length; i++) {\n    const item = table.columns[i]\n    if (item.columnKey === columnKey) {\n      column = item\n      break\n    }\n  }\n  if (!column)\n    throwError('ElTable', `No column matching with column-key: ${columnKey}`)\n  return column\n}\n\nexport const getColumnByCell = function <T>(\n  table: {\n    columns: TableColumnCtx<T>[]\n  },\n  cell: HTMLElement,\n  namespace: string\n): null | TableColumnCtx<T> {\n  const matches = (cell.className || '').match(\n    new RegExp(`${namespace}-table_[^\\\\s]+`, 'gm')\n  )\n  if (matches) {\n    return getColumnById(table, matches[0])\n  }\n  return null\n}\n\nexport const getRowIdentity = <T>(\n  row: T,\n  rowKey: string | ((row: T) => any)\n): string => {\n  if (!row) throw new Error('Row is required when get row identity')\n  if (typeof rowKey === 'string') {\n    if (!rowKey.includes('.')) {\n      return `${row[rowKey]}`\n    }\n    const key = rowKey.split('.')\n    let current = row\n    for (const element of key) {\n      current = current[element]\n    }\n    return `${current}`\n  } else if (typeof rowKey === 'function') {\n    return rowKey.call(null, row)\n  }\n}\n\nexport const getKeysMap = function <T>(\n  array: T[],\n  rowKey: string\n): Record<string, { row: T; index: number }> {\n  const arrayMap = {}\n  ;(array || []).forEach((row, index) => {\n    arrayMap[getRowIdentity(row, rowKey)] = { row, index }\n  })\n  return arrayMap\n}\n\nexport function mergeOptions<T, K>(defaults: T, config: K): T & K {\n  const options = {} as T & K\n  let key\n  for (key in defaults) {\n    options[key] = defaults[key]\n  }\n  for (key in config) {\n    if (hasOwn(config as unknown as Record<string, any>, key)) {\n      const value = config[key]\n      if (typeof value !== 'undefined') {\n        options[key] = value\n      }\n    }\n  }\n  return options\n}\n\nexport function parseWidth(width: number | string): number | string {\n  if (width === '') return width\n  if (width !== undefined) {\n    width = Number.parseInt(width as string, 10)\n    if (Number.isNaN(width)) {\n      width = ''\n    }\n  }\n  return width\n}\n\nexport function parseMinWidth(minWidth: number | string): number | string {\n  if (minWidth === '') return minWidth\n  if (minWidth !== undefined) {\n    minWidth = parseWidth(minWidth)\n    if (Number.isNaN(minWidth)) {\n      minWidth = 80\n    }\n  }\n  return minWidth\n}\n\nexport function parseHeight(height: number | string) {\n  if (typeof height === 'number') {\n    return height\n  }\n  if (typeof height === 'string') {\n    if (/^\\d+(?:px)?$/.test(height)) {\n      return Number.parseInt(height, 10)\n    } else {\n      return height\n    }\n  }\n  return null\n}\n\n// https://github.com/reduxjs/redux/blob/master/src/compose.js\nexport function compose(...funcs) {\n  if (funcs.length === 0) {\n    return (arg) => arg\n  }\n  if (funcs.length === 1) {\n    return funcs[0]\n  }\n  return funcs.reduce(\n    (a, b) =>\n      (...args) =>\n        a(b(...args))\n  )\n}\n\nexport function toggleRowStatus<T>(\n  statusArr: T[],\n  row: T,\n  newVal?: boolean,\n  tableTreeProps?: TreeProps,\n  selectable?: (row: T, index?: number) => boolean,\n  rowIndex?: number\n): boolean {\n  let _rowIndex = rowIndex ?? 0\n  let changed = false\n  const index = statusArr.indexOf(row)\n  const included = index !== -1\n  const isRowSelectable = selectable?.call(null, row, rowIndex)\n\n  const toggleStatus = (type: 'add' | 'remove') => {\n    if (type === 'add') {\n      statusArr.push(row)\n    } else {\n      statusArr.splice(index, 1)\n    }\n    changed = true\n  }\n  const getChildrenCount = (row: T) => {\n    let count = 0\n    const children = tableTreeProps?.children && row[tableTreeProps.children]\n    if (children && isArray(children)) {\n      count += children.length\n      children.forEach((item) => {\n        count += getChildrenCount(item)\n      })\n    }\n    return count\n  }\n\n  if (!selectable || isRowSelectable) {\n    if (isBoolean(newVal)) {\n      if (newVal && !included) {\n        toggleStatus('add')\n      } else if (!newVal && included) {\n        toggleStatus('remove')\n      }\n    } else {\n      included ? toggleStatus('remove') : toggleStatus('add')\n    }\n  }\n\n  if (\n    !tableTreeProps?.checkStrictly &&\n    tableTreeProps?.children &&\n    isArray(row[tableTreeProps.children])\n  ) {\n    row[tableTreeProps.children].forEach((item) => {\n      toggleRowStatus(\n        statusArr,\n        item,\n        newVal ?? !included,\n        tableTreeProps,\n        selectable,\n        _rowIndex + 1\n      )\n      _rowIndex += getChildrenCount(item) + 1\n    })\n  }\n  return changed\n}\n\nexport function walkTreeNode(\n  root,\n  cb,\n  childrenKey = 'children',\n  lazyKey = 'hasChildren'\n) {\n  const isNil = (array) => !(Array.isArray(array) && array.length)\n\n  function _walker(parent, children, level) {\n    cb(parent, children, level)\n    children.forEach((item) => {\n      if (item[lazyKey]) {\n        cb(item, null, level + 1)\n        return\n      }\n      const children = item[childrenKey]\n      if (!isNil(children)) {\n        _walker(item, children, level + 1)\n      }\n    })\n  }\n\n  root.forEach((item) => {\n    if (item[lazyKey]) {\n      cb(item, null, 0)\n      return\n    }\n    const children = item[childrenKey]\n    if (!isNil(children)) {\n      _walker(item, children, 0)\n    }\n  })\n}\n\nexport let removePopper: RemovePopperFn | null = null\n\nexport function createTablePopper(\n  props: TableOverflowTooltipOptions,\n  popperContent: string,\n  trigger: HTMLElement,\n  table: Table<[]>\n) {\n  if (removePopper?.trigger === trigger) {\n    return\n  }\n  removePopper?.()\n  const parentNode = table?.refs.tableWrapper\n  const ns = parentNode?.dataset.prefix\n  const popperOptions = {\n    strategy: 'fixed',\n    ...props.popperOptions,\n  }\n  const vm = createVNode(ElTooltip, {\n    content: popperContent,\n    virtualTriggering: true,\n    virtualRef: trigger,\n    appendTo: parentNode,\n    placement: 'top',\n    transition: 'none', // Default does not require transition\n    offset: 0,\n    hideAfter: 0,\n    ...props,\n    popperOptions,\n    onHide: () => {\n      removePopper?.()\n    },\n  })\n  vm.appContext = { ...table.appContext, ...table }\n  const container = document.createElement('div')\n  render(vm, container)\n  vm.component!.exposed!.onOpen()\n  const scrollContainer = parentNode?.querySelector(`.${ns}-scrollbar__wrap`)\n  removePopper = () => {\n    render(null, container)\n    scrollContainer?.removeEventListener('scroll', removePopper!)\n    removePopper = null\n  }\n  removePopper.trigger = trigger\n  scrollContainer?.addEventListener('scroll', removePopper)\n}\n\nfunction getCurrentColumns<T>(column: TableColumnCtx<T>): TableColumnCtx<T>[] {\n  if (column.children) {\n    return flatMap(column.children, getCurrentColumns)\n  } else {\n    return [column]\n  }\n}\n\nfunction getColSpan<T>(colSpan: number, column: TableColumnCtx<T>) {\n  return colSpan + column.colSpan\n}\n\nexport const isFixedColumn = <T>(\n  index: number,\n  fixed: string | boolean,\n  store: any,\n  realColumns?: TableColumnCtx<T>[]\n) => {\n  let start = 0\n  let after = index\n  const columns = store.states.columns.value\n  if (realColumns) {\n    // fixed column supported in grouped header\n    const curColumns = getCurrentColumns(realColumns[index])\n    const preColumns = columns.slice(0, columns.indexOf(curColumns[0]))\n\n    start = preColumns.reduce(getColSpan, 0)\n    after = start + curColumns.reduce(getColSpan, 0) - 1\n  } else {\n    start = index\n  }\n  let fixedLayout\n  switch (fixed) {\n    case 'left':\n      if (after < store.states.fixedLeafColumnsLength.value) {\n        fixedLayout = 'left'\n      }\n      break\n    case 'right':\n      if (\n        start >=\n        columns.length - store.states.rightFixedLeafColumnsLength.value\n      ) {\n        fixedLayout = 'right'\n      }\n      break\n    default:\n      if (after < store.states.fixedLeafColumnsLength.value) {\n        fixedLayout = 'left'\n      } else if (\n        start >=\n        columns.length - store.states.rightFixedLeafColumnsLength.value\n      ) {\n        fixedLayout = 'right'\n      }\n  }\n  return fixedLayout\n    ? {\n        direction: fixedLayout,\n        start,\n        after,\n      }\n    : {}\n}\n\nexport const getFixedColumnsClass = <T>(\n  namespace: string,\n  index: number,\n  fixed: string | boolean,\n  store: any,\n  realColumns?: TableColumnCtx<T>[],\n  offset = 0\n) => {\n  const classes: string[] = []\n  const { direction, start, after } = isFixedColumn(\n    index,\n    fixed,\n    store,\n    realColumns\n  )\n  if (direction) {\n    const isLeft = direction === 'left'\n    classes.push(`${namespace}-fixed-column--${direction}`)\n    if (\n      isLeft &&\n      after + offset === store.states.fixedLeafColumnsLength.value - 1\n    ) {\n      classes.push('is-last-column')\n    } else if (\n      !isLeft &&\n      start - offset ===\n        store.states.columns.value.length -\n          store.states.rightFixedLeafColumnsLength.value\n    ) {\n      classes.push('is-first-column')\n    }\n  }\n  return classes\n}\n\nfunction getOffset<T>(offset: number, column: TableColumnCtx<T>) {\n  return (\n    offset +\n    (column.realWidth === null || Number.isNaN(column.realWidth)\n      ? Number(column.width)\n      : column.realWidth)\n  )\n}\n\nexport const getFixedColumnOffset = <T>(\n  index: number,\n  fixed: string | boolean,\n  store: any,\n  realColumns?: TableColumnCtx<T>[]\n) => {\n  const {\n    direction,\n    start = 0,\n    after = 0,\n  } = isFixedColumn(index, fixed, store, realColumns)\n  if (!direction) {\n    return\n  }\n  const styles: any = {}\n  const isLeft = direction === 'left'\n  const columns = store.states.columns.value\n  if (isLeft) {\n    styles.left = columns.slice(0, start).reduce(getOffset, 0)\n  } else {\n    styles.right = columns\n      .slice(after + 1)\n      .reverse()\n      .reduce(getOffset, 0)\n  }\n  return styles\n}\n\nexport const ensurePosition = (style, key: string) => {\n  if (!style) return\n  if (!Number.isNaN(style[key])) {\n    style[key] = `${style[key]}px`\n  }\n}\n", "// @ts-nocheck\nimport { getCurrentInstance, ref } from 'vue'\nimport { getKeysMap, getRowIdentity, toggleRowStatus } from '../util'\n\nimport type { Ref } from 'vue'\nimport type { WatcherPropsData } from '.'\nimport type { Table } from '../table/defaults'\n\nfunction useExpand<T>(watcherData: WatcherPropsData<T>) {\n  const instance = getCurrentInstance() as Table<T>\n  const defaultExpandAll = ref(false)\n  const expandRows: Ref<T[]> = ref([])\n  const updateExpandRows = () => {\n    const data = watcherData.data.value || []\n    const rowKey = watcherData.rowKey.value\n    if (defaultExpandAll.value) {\n      expandRows.value = data.slice()\n    } else if (rowKey) {\n      // TODO:这里的代码可以优化\n      const expandRowsMap = getKeysMap(expandRows.value, rowKey)\n      expandRows.value = data.reduce((prev: T[], row: T) => {\n        const rowId = getRowIdentity(row, rowKey)\n        const rowInfo = expandRowsMap[rowId]\n        if (rowInfo) {\n          prev.push(row)\n        }\n        return prev\n      }, [])\n    } else {\n      expandRows.value = []\n    }\n  }\n\n  const toggleRowExpansion = (row: T, expanded?: boolean) => {\n    const changed = toggleRowStatus(expandRows.value, row, expanded)\n    if (changed) {\n      instance.emit('expand-change', row, expandRows.value.slice())\n    }\n  }\n\n  const setExpandRowKeys = (rowKeys: string[]) => {\n    instance.store.assertRowKey()\n    // TODO:这里的代码可以优化\n    const data = watcherData.data.value || []\n    const rowKey = watcherData.rowKey.value\n    const keysMap = getKeysMap(data, rowKey)\n    expandRows.value = rowKeys.reduce((prev: T[], cur: string) => {\n      const info = keysMap[cur]\n      if (info) {\n        prev.push(info.row)\n      }\n      return prev\n    }, [])\n  }\n\n  const isRowExpanded = (row: T): boolean => {\n    const rowKey = watcherData.rowKey.value\n    if (rowKey) {\n      const expandMap = getKeysMap(expandRows.value, rowKey)\n      return !!expandMap[getRowIdentity(row, rowKey)]\n    }\n    return expandRows.value.includes(row)\n  }\n  return {\n    updateExpandRows,\n    toggleRowExpansion,\n    setExpandRowKeys,\n    isRowExpanded,\n    states: {\n      expandRows,\n      defaultExpandAll,\n    },\n  }\n}\n\nexport default useExpand\n", "// @ts-nocheck\nimport { getCurrentInstance, ref, unref } from 'vue'\nimport { getRowIdentity } from '../util'\n\nimport type { Ref } from 'vue'\nimport type { Table } from '../table/defaults'\nimport type { WatcherPropsData } from '.'\n\nfunction useCurrent<T>(watcherData: WatcherPropsData<T>) {\n  const instance = getCurrentInstance() as Table<T>\n  const _currentRowKey = ref<string>(null)\n  const currentRow: Ref<T> = ref(null)\n\n  const setCurrentRowKey = (key: string) => {\n    instance.store.assertRowKey()\n    _currentRowKey.value = key\n    setCurrentRowByKey(key)\n  }\n\n  const restoreCurrentRowKey = () => {\n    _currentRowKey.value = null\n  }\n\n  const setCurrentRowByKey = (key: string) => {\n    const { data, rowKey } = watcherData\n    let _currentRow = null\n    if (rowKey.value) {\n      _currentRow = (unref(data) || []).find(\n        (item) => getRowIdentity(item, rowKey.value) === key\n      )\n    }\n    currentRow.value = _currentRow\n    instance.emit('current-change', currentRow.value, null)\n  }\n\n  const updateCurrentRow = (_currentRow: T) => {\n    const oldCurrentRow = currentRow.value\n    if (_currentRow && _currentRow !== oldCurrentRow) {\n      currentRow.value = _currentRow\n      instance.emit('current-change', currentRow.value, oldCurrentRow)\n      return\n    }\n    if (!_currentRow && oldCurrentRow) {\n      currentRow.value = null\n      instance.emit('current-change', null, oldCurrentRow)\n    }\n  }\n\n  const updateCurrentRowData = () => {\n    const rowKey = watcherData.rowKey.value\n    // data 为 null 时,解构时的默认值会被忽略\n    const data = watcherData.data.value || []\n    const oldCurrentRow = currentRow.value\n    // 当 currentRow 不在 data 中时尝试更新数据\n    if (!data.includes(oldCurrentRow) && oldCurrentRow) {\n      if (rowKey) {\n        const currentRowKey = getRowIdentity(oldCurrentRow, rowKey)\n        setCurrentRowByKey(currentRowKey)\n      } else {\n        currentRow.value = null\n      }\n      if (currentRow.value === null) {\n        instance.emit('current-change', null, oldCurrentRow)\n      }\n    } else if (_currentRowKey.value) {\n      // 把初始时下设置的 rowKey 转化成 rowData\n      setCurrentRowByKey(_currentRowKey.value)\n      restoreCurrentRowKey()\n    }\n  }\n\n  return {\n    setCurrentRowKey,\n    restoreCurrentRowKey,\n    setCurrentRowByKey,\n    updateCurrentRow,\n    updateCurrentRowData,\n    states: {\n      _currentRowKey,\n      currentRow,\n    },\n  }\n}\n\nexport default useCurrent\n", "// @ts-nocheck\nimport { computed, getCurrentInstance, ref, unref, watch } from 'vue'\nimport { getRowIdentity, walkTreeNode } from '../util'\n\nimport type { WatcherPropsData } from '.'\nimport type { Table, TableProps } from '../table/defaults'\n\nfunction useTree<T>(watcherData: WatcherPropsData<T>) {\n  const expandRowKeys = ref<string[]>([])\n  const treeData = ref<unknown>({})\n  const indent = ref(16)\n  const lazy = ref(false)\n  const lazyTreeNodeMap = ref({})\n  const lazyColumnIdentifier = ref('hasChildren')\n  const childrenColumnName = ref('children')\n  const checkStrictly = ref(false)\n  const instance = getCurrentInstance() as Table<T>\n  const normalizedData = computed(() => {\n    if (!watcherData.rowKey.value) return {}\n    const data = watcherData.data.value || []\n    return normalize(data)\n  })\n  const normalizedLazyNode = computed(() => {\n    const rowKey = watcherData.rowKey.value\n    const keys = Object.keys(lazyTreeNodeMap.value)\n    const res = {}\n    if (!keys.length) return res\n    keys.forEach((key) => {\n      if (lazyTreeNodeMap.value[key].length) {\n        const item = { children: [] }\n        lazyTreeNodeMap.value[key].forEach((row) => {\n          const currentRowKey = getRowIdentity(row, rowKey)\n          item.children.push(currentRowKey)\n          if (row[lazyColumnIdentifier.value] && !res[currentRowKey]) {\n            res[currentRowKey] = { children: [] }\n          }\n        })\n        res[key] = item\n      }\n    })\n    return res\n  })\n\n  const normalize = (data) => {\n    const rowKey = watcherData.rowKey.value\n    const res = {}\n    walkTreeNode(\n      data,\n      (parent, children, level) => {\n        const parentId = getRowIdentity(parent, rowKey)\n        if (Array.isArray(children)) {\n          res[parentId] = {\n            children: children.map((row) => getRowIdentity(row, rowKey)),\n            level,\n          }\n        } else if (lazy.value) {\n          // 当 children 不存在且 lazy 为 true,该节点即为懒加载的节点\n          res[parentId] = {\n            children: [],\n            lazy: true,\n            level,\n          }\n        }\n      },\n      childrenColumnName.value,\n      lazyColumnIdentifier.value\n    )\n    return res\n  }\n\n  const updateTreeData = (\n    ifChangeExpandRowKeys = false,\n    ifExpandAll = instance.store?.states.defaultExpandAll.value\n  ) => {\n    const nested = normalizedData.value\n    const normalizedLazyNode_ = normalizedLazyNode.value\n    const keys = Object.keys(nested)\n    const newTreeData = {}\n    if (keys.length) {\n      const oldTreeData = unref(treeData)\n      const rootLazyRowKeys = []\n      const getExpanded = (oldValue, key) => {\n        if (ifChangeExpandRowKeys) {\n          if (expandRowKeys.value) {\n            return ifExpandAll || expandRowKeys.value.includes(key)\n          } else {\n            return !!(ifExpandAll || oldValue?.expanded)\n          }\n        } else {\n          const included =\n            ifExpandAll ||\n            (expandRowKeys.value && expandRowKeys.value.includes(key))\n          return !!(oldValue?.expanded || included)\n        }\n      }\n      // 合并 expanded 与 display,确保数据刷新后,状态不变\n      keys.forEach((key) => {\n        const oldValue = oldTreeData[key]\n        const newValue = { ...nested[key] }\n        newValue.expanded = getExpanded(oldValue, key)\n        if (newValue.lazy) {\n          const { loaded = false, loading = false } = oldValue || {}\n          newValue.loaded = !!loaded\n          newValue.loading = !!loading\n          rootLazyRowKeys.push(key)\n        }\n        newTreeData[key] = newValue\n      })\n      // 根据懒加载数据更新 treeData\n      const lazyKeys = Object.keys(normalizedLazyNode_)\n      if (lazy.value && lazyKeys.length && rootLazyRowKeys.length) {\n        lazyKeys.forEach((key) => {\n          const oldValue = oldTreeData[key]\n          const lazyNodeChildren = normalizedLazyNode_[key].children\n          if (rootLazyRowKeys.includes(key)) {\n            // 懒加载的 root 节点,更新一下原有的数据,原来的 children 一定是空数组\n            if (newTreeData[key].children.length !== 0) {\n              throw new Error('[ElTable]children must be an empty array.')\n            }\n            newTreeData[key].children = lazyNodeChildren\n          } else {\n            const { loaded = false, loading = false } = oldValue || {}\n            newTreeData[key] = {\n              lazy: true,\n              loaded: !!loaded,\n              loading: !!loading,\n              expanded: getExpanded(oldValue, key),\n              children: lazyNodeChildren,\n              level: '',\n            }\n          }\n        })\n      }\n    }\n    treeData.value = newTreeData\n    instance.store?.updateTableScrollY()\n  }\n\n  watch(\n    () => expandRowKeys.value,\n    () => {\n      updateTreeData(true)\n    }\n  )\n\n  watch(\n    () => normalizedData.value,\n    () => {\n      updateTreeData()\n    }\n  )\n  watch(\n    () => normalizedLazyNode.value,\n    () => {\n      updateTreeData()\n    }\n  )\n\n  const updateTreeExpandKeys = (value: string[]) => {\n    expandRowKeys.value = value\n    updateTreeData()\n  }\n\n  const toggleTreeExpansion = (row: T, expanded?: boolean) => {\n    instance.store.assertRowKey()\n\n    const rowKey = watcherData.rowKey.value\n    const id = getRowIdentity(row, rowKey)\n    const data = id && treeData.value[id]\n    if (id && data && 'expanded' in data) {\n      const oldExpanded = data.expanded\n      expanded = typeof expanded === 'undefined' ? !data.expanded : expanded\n      treeData.value[id].expanded = expanded\n      if (oldExpanded !== expanded) {\n        instance.emit('expand-change', row, expanded)\n      }\n      instance.store.updateTableScrollY()\n    }\n  }\n\n  const loadOrToggle = (row) => {\n    instance.store.assertRowKey()\n    const rowKey = watcherData.rowKey.value\n    const id = getRowIdentity(row, rowKey)\n    const data = treeData.value[id]\n    if (lazy.value && data && 'loaded' in data && !data.loaded) {\n      loadData(row, id, data)\n    } else {\n      toggleTreeExpansion(row, undefined)\n    }\n  }\n\n  const loadData = (row: T, key: string, treeNode) => {\n    const { load } = instance.props as unknown as TableProps<T>\n    if (load && !treeData.value[key].loaded) {\n      treeData.value[key].loading = true\n      load(row, treeNode, (data) => {\n        if (!Array.isArray(data)) {\n          throw new TypeError('[ElTable] data must be an array')\n        }\n        treeData.value[key].loading = false\n        treeData.value[key].loaded = true\n        treeData.value[key].expanded = true\n        if (data.length) {\n          lazyTreeNodeMap.value[key] = data\n        }\n        instance.emit('expand-change', row, true)\n      })\n    }\n  }\n\n  const updateKeyChildren = (key: string, data: T[]) => {\n    const { lazy, rowKey } = instance.props as unknown as TableProps<T>\n    if (!lazy) return\n    if (!rowKey) throw new Error('[Table] rowKey is required in updateKeyChild')\n\n    if (lazyTreeNodeMap.value[key]) {\n      lazyTreeNodeMap.value[key] = data\n    }\n  }\n\n  return {\n    loadData,\n    loadOrToggle,\n    toggleTreeExpansion,\n    updateTreeExpandKeys,\n    updateTreeData,\n    updateKeyChildren,\n    normalize,\n    states: {\n      expandRowKeys,\n      treeData,\n      indent,\n      lazy,\n      lazyTreeNodeMap,\n      lazyColumnIdentifier,\n      childrenColumnName,\n      checkStrictly,\n    },\n  }\n}\n\nexport default useTree\n", "// @ts-nocheck\nimport { getCurrentInstance, ref, toRefs, unref, watch } from 'vue'\nimport { isEqual } from 'lodash-unified'\nimport { hasOwn, isUndefined } from '@element-plus/utils'\nimport {\n  getColumnById,\n  getColumnByKey,\n  getKeysMap,\n  getRowIdentity,\n  orderBy,\n  toggleRowStatus,\n} from '../util'\nimport useExpand from './expand'\nimport useCurrent from './current'\nimport useTree from './tree'\n\nimport type { Ref } from 'vue'\nimport type { TableColumnCtx } from '../table-column/defaults'\nimport type { DefaultRow, Table, TableRefs } from '../table/defaults'\nimport type { StoreFilter } from '.'\n\nconst sortData = (data, states) => {\n  const sortingColumn = states.sortingColumn\n  if (!sortingColumn || typeof sortingColumn.sortable === 'string') {\n    return data\n  }\n  return orderBy(\n    data,\n    states.sortProp,\n    states.sortOrder,\n    sortingColumn.sortMethod,\n    sortingColumn.sortBy\n  )\n}\n\nconst doFlattenColumns = (columns) => {\n  const result = []\n  columns.forEach((column) => {\n    if (column.children && column.children.length > 0) {\n      // eslint-disable-next-line prefer-spread\n      result.push.apply(result, doFlattenColumns(column.children))\n    } else {\n      result.push(column)\n    }\n  })\n  return result\n}\n\nfunction useWatcher<T>() {\n  const instance = getCurrentInstance() as Table<T>\n  const { size: tableSize } = toRefs(instance.proxy?.$props as any)\n  const rowKey: Ref<string> = ref(null)\n  const data: Ref<T[]> = ref([])\n  const _data: Ref<T[]> = ref([])\n  const isComplex = ref(false)\n  const _columns: Ref<TableColumnCtx<T>[]> = ref([])\n  const originColumns: Ref<TableColumnCtx<T>[]> = ref([])\n  const columns: Ref<TableColumnCtx<T>[]> = ref([])\n  const fixedColumns: Ref<TableColumnCtx<T>[]> = ref([])\n  const rightFixedColumns: Ref<TableColumnCtx<T>[]> = ref([])\n  const leafColumns: Ref<TableColumnCtx<T>[]> = ref([])\n  const fixedLeafColumns: Ref<TableColumnCtx<T>[]> = ref([])\n  const rightFixedLeafColumns: Ref<TableColumnCtx<T>[]> = ref([])\n  const updateOrderFns: (() => void)[] = []\n  const leafColumnsLength = ref(0)\n  const fixedLeafColumnsLength = ref(0)\n  const rightFixedLeafColumnsLength = ref(0)\n  const isAllSelected = ref(false)\n  const selection: Ref<T[]> = ref([])\n  const reserveSelection = ref(false)\n  const selectOnIndeterminate = ref(false)\n  const selectable: Ref<(row: T, index: number) => boolean> = ref(null)\n  const filters: Ref<StoreFilter> = ref({})\n  const filteredData = ref(null)\n  const sortingColumn = ref(null)\n  const sortProp = ref(null)\n  const sortOrder = ref(null)\n  const hoverRow = ref(null)\n\n  watch(data, () => instance.state && scheduleLayout(false), {\n    deep: true,\n  })\n\n  // 检查 rowKey 是否存在\n  const assertRowKey = () => {\n    if (!rowKey.value) throw new Error('[ElTable] prop row-key is required')\n  }\n\n  // 更新 fixed\n  const updateChildFixed = (column: TableColumnCtx<T>) => {\n    column.children?.forEach((childColumn) => {\n      childColumn.fixed = column.fixed\n      updateChildFixed(childColumn)\n    })\n  }\n\n  let selectionInitialFixed = undefined\n\n  // 更新列\n  const updateColumns = () => {\n    _columns.value.forEach((column) => {\n      updateChildFixed(column)\n    })\n    fixedColumns.value = _columns.value.filter(\n      (column) => column.fixed === true || column.fixed === 'left'\n    )\n    rightFixedColumns.value = _columns.value.filter(\n      (column) => column.fixed === 'right'\n    )\n\n    if (\n      isUndefined(selectionInitialFixed) &&\n      _columns.value[0] &&\n      _columns.value[0].type === 'selection'\n    ) {\n      selectionInitialFixed = Boolean(_columns.value[0].fixed)\n    }\n\n    if (\n      fixedColumns.value.length > 0 &&\n      _columns.value[0] &&\n      _columns.value[0].type === 'selection'\n    ) {\n      if (!_columns.value[0].fixed) {\n        _columns.value[0].fixed = true\n        fixedColumns.value.unshift(_columns.value[0])\n      } else {\n        const hasNotSelectionColumns = fixedColumns.value.some(\n          (column) => column.type !== 'selection'\n        )\n\n        if (!hasNotSelectionColumns) {\n          _columns.value[0].fixed = selectionInitialFixed\n          if (!selectionInitialFixed) fixedColumns.value.shift()\n        } else {\n          selectionInitialFixed = undefined\n        }\n      }\n    }\n\n    const notFixedColumns = _columns.value.filter((column) => !column.fixed)\n    originColumns.value = []\n      .concat(fixedColumns.value)\n      .concat(notFixedColumns)\n      .concat(rightFixedColumns.value)\n    const leafColumns = doFlattenColumns(notFixedColumns)\n    const fixedLeafColumns = doFlattenColumns(fixedColumns.value)\n    const rightFixedLeafColumns = doFlattenColumns(rightFixedColumns.value)\n\n    leafColumnsLength.value = leafColumns.length\n    fixedLeafColumnsLength.value = fixedLeafColumns.length\n    rightFixedLeafColumnsLength.value = rightFixedLeafColumns.length\n\n    columns.value = []\n      .concat(fixedLeafColumns)\n      .concat(leafColumns)\n      .concat(rightFixedLeafColumns)\n    isComplex.value =\n      fixedColumns.value.length > 0 || rightFixedColumns.value.length > 0\n  }\n\n  // 更新 DOM\n  const scheduleLayout = (needUpdateColumns?: boolean, immediate = false) => {\n    if (needUpdateColumns) {\n      updateColumns()\n    }\n    if (immediate) {\n      instance.state.doLayout()\n    } else {\n      instance.state.debouncedUpdateLayout()\n    }\n  }\n\n  // 选择\n  const isSelected = (row) => {\n    return selection.value.some((item) => isEqual(item, row))\n  }\n\n  const clearSelection = () => {\n    isAllSelected.value = false\n    const oldSelection = selection.value\n    selection.value = []\n    if (oldSelection.length) {\n      instance.emit('selection-change', [])\n    }\n  }\n\n  const cleanSelection = () => {\n    let deleted\n    if (rowKey.value) {\n      deleted = []\n      const selectedMap = getKeysMap(selection.value, rowKey.value)\n      const dataMap = getKeysMap(data.value, rowKey.value)\n      for (const key in selectedMap) {\n        if (hasOwn(selectedMap, key) && !dataMap[key]) {\n          deleted.push(selectedMap[key].row)\n        }\n      }\n    } else {\n      deleted = selection.value.filter((item) => !data.value.includes(item))\n    }\n    if (deleted.length) {\n      const newSelection = selection.value.filter(\n        (item) => !deleted.includes(item)\n      )\n      selection.value = newSelection\n      instance.emit('selection-change', newSelection.slice())\n    }\n  }\n\n  const getSelectionRows = () => {\n    return (selection.value || []).slice()\n  }\n\n  const toggleRowSelection = (\n    row: T,\n    selected?: boolean,\n    emitChange = true,\n    ignoreSelectable = false\n  ) => {\n    const treeProps = {\n      children: instance?.store?.states?.childrenColumnName.value,\n      checkStrictly: instance?.store?.states?.checkStrictly.value,\n    }\n    const changed = toggleRowStatus(\n      selection.value,\n      row,\n      selected,\n      treeProps,\n      ignoreSelectable ? undefined : selectable.value\n    )\n    if (changed) {\n      const newSelection = (selection.value || []).slice()\n      // 调用 API 修改选中值,不触发 select 事件\n      if (emitChange) {\n        instance.emit('select', newSelection, row)\n      }\n      instance.emit('selection-change', newSelection)\n    }\n  }\n\n  const _toggleAllSelection = () => {\n    // when only some rows are selected (but not all), select or deselect all of them\n    // depending on the value of selectOnIndeterminate\n    const value = selectOnIndeterminate.value\n      ? !isAllSelected.value\n      : !(isAllSelected.value || selection.value.length)\n    isAllSelected.value = value\n\n    let selectionChanged = false\n    let childrenCount = 0\n    const rowKey = instance?.store?.states?.rowKey.value\n    const { childrenColumnName } = instance.store.states\n    const treeProps = {\n      children: childrenColumnName.value,\n      checkStrictly: false, // Disable checkStrictly when selecting all\n    }\n\n    data.value.forEach((row, index) => {\n      const rowIndex = index + childrenCount\n      if (\n        toggleRowStatus(\n          selection.value,\n          row,\n          value,\n          treeProps,\n          selectable.value,\n          rowIndex\n        )\n      ) {\n        selectionChanged = true\n      }\n      childrenCount += getChildrenCount(getRowIdentity(row, rowKey))\n    })\n\n    if (selectionChanged) {\n      instance.emit(\n        'selection-change',\n        selection.value ? selection.value.slice() : []\n      )\n    }\n    instance.emit('select-all', (selection.value || []).slice())\n  }\n\n  const updateSelectionByRowKey = () => {\n    const selectedMap = getKeysMap(selection.value, rowKey.value)\n    data.value.forEach((row) => {\n      const rowId = getRowIdentity(row, rowKey.value)\n      const rowInfo = selectedMap[rowId]\n      if (rowInfo) {\n        selection.value[rowInfo.index] = row\n      }\n    })\n  }\n\n  const updateAllSelected = () => {\n    // data 为 null 时,解构时的默认值会被忽略\n    if (data.value?.length === 0) {\n      isAllSelected.value = false\n      return\n    }\n\n    const { childrenColumnName } = instance.store.states\n    const selectedMap = rowKey.value\n      ? getKeysMap(selection.value, rowKey.value)\n      : undefined\n\n    let rowIndex = 0\n    let selectedCount = 0\n\n    const isSelected = (row: DefaultRow) => {\n      if (selectedMap) {\n        return !!selectedMap[getRowIdentity(row, rowKey.value)]\n      } else {\n        return selection.value.includes(row)\n      }\n    }\n    const checkSelectedStatus = (data: DefaultRow[]) => {\n      for (const row of data) {\n        const isRowSelectable =\n          selectable.value && selectable.value.call(null, row, rowIndex)\n\n        if (!isSelected(row)) {\n          if (!selectable.value || isRowSelectable) {\n            return false\n          }\n        } else {\n          selectedCount++\n        }\n        rowIndex++\n\n        if (\n          row[childrenColumnName.value]?.length &&\n          !checkSelectedStatus(row[childrenColumnName.value])\n        ) {\n          return false\n        }\n      }\n      return true\n    }\n\n    const isAllSelected_ = checkSelectedStatus(data.value || [])\n    isAllSelected.value = selectedCount === 0 ? false : isAllSelected_\n  }\n\n  const getChildrenCount = (rowKey: string) => {\n    if (!instance || !instance.store) return 0\n    const { treeData } = instance.store.states\n    let count = 0\n    const children = treeData.value[rowKey]?.children\n    if (children) {\n      count += children.length\n      children.forEach((childKey) => {\n        count += getChildrenCount(childKey)\n      })\n    }\n    return count\n  }\n\n  // 过滤与排序\n  const updateFilters = (columns, values) => {\n    if (!Array.isArray(columns)) {\n      columns = [columns]\n    }\n    const filters_ = {}\n    columns.forEach((col) => {\n      filters.value[col.id] = values\n      filters_[col.columnKey || col.id] = values\n    })\n    return filters_\n  }\n\n  const updateSort = (column, prop, order) => {\n    if (sortingColumn.value && sortingColumn.value !== column) {\n      sortingColumn.value.order = null\n    }\n    sortingColumn.value = column\n    sortProp.value = prop\n    sortOrder.value = order\n  }\n\n  const execFilter = () => {\n    let sourceData = unref(_data)\n    Object.keys(filters.value).forEach((columnId) => {\n      const values = filters.value[columnId]\n      if (!values || values.length === 0) return\n      const column = getColumnById(\n        {\n          columns: columns.value,\n        },\n        columnId\n      )\n      if (column && column.filterMethod) {\n        sourceData = sourceData.filter((row) => {\n          return values.some((value) =>\n            column.filterMethod.call(null, value, row, column)\n          )\n        })\n      }\n    })\n\n    filteredData.value = sourceData\n  }\n\n  const execSort = () => {\n    data.value = sortData(filteredData.value, {\n      sortingColumn: sortingColumn.value,\n      sortProp: sortProp.value,\n      sortOrder: sortOrder.value,\n    })\n  }\n\n  // 根据 filters 与 sort 去过滤 data\n  const execQuery = (ignore = undefined) => {\n    if (!(ignore && ignore.filter)) {\n      execFilter()\n    }\n    execSort()\n  }\n\n  const clearFilter = (columnKeys) => {\n    const { tableHeaderRef } = instance.refs as TableRefs\n    if (!tableHeaderRef) return\n    const panels = Object.assign({}, tableHeaderRef.filterPanels)\n\n    const keys = Object.keys(panels)\n    if (!keys.length) return\n\n    if (typeof columnKeys === 'string') {\n      columnKeys = [columnKeys]\n    }\n\n    if (Array.isArray(columnKeys)) {\n      const columns_ = columnKeys.map((key) =>\n        getColumnByKey(\n          {\n            columns: columns.value,\n          },\n          key\n        )\n      )\n      keys.forEach((key) => {\n        const column = columns_.find((col) => col.id === key)\n        if (column) {\n          column.filteredValue = []\n        }\n      })\n      instance.store.commit('filterChange', {\n        column: columns_,\n        values: [],\n        silent: true,\n        multi: true,\n      })\n    } else {\n      keys.forEach((key) => {\n        const column = columns.value.find((col) => col.id === key)\n        if (column) {\n          column.filteredValue = []\n        }\n      })\n\n      filters.value = {}\n      instance.store.commit('filterChange', {\n        column: {},\n        values: [],\n        silent: true,\n      })\n    }\n  }\n\n  const clearSort = () => {\n    if (!sortingColumn.value) return\n\n    updateSort(null, null, null)\n    instance.store.commit('changeSortCondition', {\n      silent: true,\n    })\n  }\n  const {\n    setExpandRowKeys,\n    toggleRowExpansion,\n    updateExpandRows,\n    states: expandStates,\n    isRowExpanded,\n  } = useExpand({\n    data,\n    rowKey,\n  })\n  const {\n    updateTreeExpandKeys,\n    toggleTreeExpansion,\n    updateTreeData,\n    updateKeyChildren,\n    loadOrToggle,\n    states: treeStates,\n  } = useTree({\n    data,\n    rowKey,\n  })\n  const {\n    updateCurrentRowData,\n    updateCurrentRow,\n    setCurrentRowKey,\n    states: currentData,\n  } = useCurrent({\n    data,\n    rowKey,\n  })\n  // 适配层,expand-row-keys 在 Expand 与 TreeTable 中都有使用\n  const setExpandRowKeysAdapter = (val: string[]) => {\n    // 这里会触发额外的计算,但为了兼容性,暂时这么做\n    setExpandRowKeys(val)\n    updateTreeExpandKeys(val)\n  }\n\n  // 展开行与 TreeTable 都要使用\n  const toggleRowExpansionAdapter = (row: T, expanded?: boolean) => {\n    const hasExpandColumn = columns.value.some(({ type }) => type === 'expand')\n    if (hasExpandColumn) {\n      toggleRowExpansion(row, expanded)\n    } else {\n      toggleTreeExpansion(row, expanded)\n    }\n  }\n\n  return {\n    assertRowKey,\n    updateColumns,\n    scheduleLayout,\n    isSelected,\n    clearSelection,\n    cleanSelection,\n    getSelectionRows,\n    toggleRowSelection,\n    _toggleAllSelection,\n    toggleAllSelection: null,\n    updateSelectionByRowKey,\n    updateAllSelected,\n    updateFilters,\n    updateCurrentRow,\n    updateSort,\n    execFilter,\n    execSort,\n    execQuery,\n    clearFilter,\n    clearSort,\n    toggleRowExpansion,\n    setExpandRowKeysAdapter,\n    setCurrentRowKey,\n    toggleRowExpansionAdapter,\n    isRowExpanded,\n    updateExpandRows,\n    updateCurrentRowData,\n    loadOrToggle,\n    updateTreeData,\n    updateKeyChildren,\n    states: {\n      tableSize,\n      rowKey,\n      data,\n      _data,\n      isComplex,\n      _columns,\n      originColumns,\n      columns,\n      fixedColumns,\n      rightFixedColumns,\n      leafColumns,\n      fixedLeafColumns,\n      rightFixedLeafColumns,\n      updateOrderFns,\n      leafColumnsLength,\n      fixedLeafColumnsLength,\n      rightFixedLeafColumnsLength,\n      isAllSelected,\n      selection,\n      reserveSelection,\n      selectOnIndeterminate,\n      selectable,\n      filters,\n      filteredData,\n      sortingColumn,\n      sortProp,\n      sortOrder,\n      hoverRow,\n      ...expandStates,\n      ...treeStates,\n      ...currentData,\n    },\n  }\n}\n\nexport default useWatcher\n", "// @ts-nocheck\nimport { getCurrentInstance, nextTick, unref } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport useWatcher from './watcher'\n\nimport type { Ref } from 'vue'\nimport type { TableColumnCtx } from '../table-column/defaults'\nimport type { Filter, Sort, Table } from '../table/defaults'\n\ninterface WatcherPropsData<T> {\n  data: Ref<T[]>\n  rowKey: Ref<string>\n}\n\nfunction replaceColumn<T>(\n  array: TableColumnCtx<T>[],\n  column: TableColumnCtx<T>\n) {\n  return array.map((item) => {\n    if (item.id === column.id) {\n      return column\n    } else if (item.children?.length) {\n      item.children = replaceColumn(item.children, column)\n    }\n    return item\n  })\n}\n\nfunction sortColumn<T>(array: TableColumnCtx<T>[]) {\n  array.forEach((item) => {\n    item.no = item.getColumnIndex?.()\n    if (item.children?.length) {\n      sortColumn(item.children)\n    }\n  })\n  array.sort((cur, pre) => cur.no - pre.no)\n}\n\nfunction useStore<T>() {\n  const instance = getCurrentInstance() as Table<T>\n  const watcher = useWatcher<T>()\n  const ns = useNamespace('table')\n  type StoreStates = typeof watcher.states\n  const mutations = {\n    setData(states: StoreStates, data: T[]) {\n      const dataInstanceChanged = unref(states._data) !== data\n      states.data.value = data\n      states._data.value = data\n      instance.store.execQuery()\n      // 数据变化,更新部分数据。\n      // 没有使用 computed,而是手动更新部分数据 https://github.com/vuejs/vue/issues/6660#issuecomment-331417140\n      instance.store.updateCurrentRowData()\n      instance.store.updateExpandRows()\n      instance.store.updateTreeData(\n        instance.store.states.defaultExpandAll.value\n      )\n      if (unref(states.reserveSelection)) {\n        instance.store.assertRowKey()\n        instance.store.updateSelectionByRowKey()\n      } else {\n        if (dataInstanceChanged) {\n          instance.store.clearSelection()\n        } else {\n          instance.store.cleanSelection()\n        }\n      }\n      instance.store.updateAllSelected()\n      if (instance.$ready) {\n        instance.store.scheduleLayout()\n      }\n    },\n\n    insertColumn(\n      states: StoreStates,\n      column: TableColumnCtx<T>,\n      parent: TableColumnCtx<T>,\n      updateColumnOrder: () => void\n    ) {\n      const array = unref(states._columns)\n      let newColumns = []\n      if (!parent) {\n        array.push(column)\n        newColumns = array\n      } else {\n        if (parent && !parent.children) {\n          parent.children = []\n        }\n        parent.children.push(column)\n        newColumns = replaceColumn(array, parent)\n      }\n      sortColumn(newColumns)\n      states._columns.value = newColumns\n      states.updateOrderFns.push(updateColumnOrder)\n      if (column.type === 'selection') {\n        states.selectable.value = column.selectable\n        states.reserveSelection.value = column.reserveSelection\n      }\n      if (instance.$ready) {\n        instance.store.updateColumns() // hack for dynamics insert column\n        instance.store.scheduleLayout()\n      }\n    },\n\n    updateColumnOrder(states: StoreStates, column: TableColumnCtx<T>) {\n      const newColumnIndex = column.getColumnIndex?.()\n      if (newColumnIndex === column.no) return\n\n      sortColumn(states._columns.value)\n\n      if (instance.$ready) {\n        instance.store.updateColumns()\n      }\n    },\n\n    removeColumn(\n      states: StoreStates,\n      column: TableColumnCtx<T>,\n      parent: TableColumnCtx<T>,\n      updateColumnOrder: () => void\n    ) {\n      const array = unref(states._columns) || []\n      if (parent) {\n        parent.children.splice(\n          parent.children.findIndex((item) => item.id === column.id),\n          1\n        )\n        // fix #10699, delete parent.children immediately will trigger again\n        nextTick(() => {\n          if (parent.children?.length === 0) {\n            delete parent.children\n          }\n        })\n        states._columns.value = replaceColumn(array, parent)\n      } else {\n        const index = array.indexOf(column)\n        if (index > -1) {\n          array.splice(index, 1)\n          states._columns.value = array\n        }\n      }\n\n      const updateFnIndex = states.updateOrderFns.indexOf(updateColumnOrder)\n      updateFnIndex > -1 && states.updateOrderFns.splice(updateFnIndex, 1)\n\n      if (instance.$ready) {\n        instance.store.updateColumns() // hack for dynamics remove column\n        instance.store.scheduleLayout()\n      }\n    },\n\n    sort(states: StoreStates, options: Sort) {\n      const { prop, order, init } = options\n      if (prop) {\n        const column = unref(states.columns).find(\n          (column) => column.property === prop\n        )\n        if (column) {\n          column.order = order\n          instance.store.updateSort(column, prop, order)\n          instance.store.commit('changeSortCondition', { init })\n        }\n      }\n    },\n\n    changeSortCondition(states: StoreStates, options: Sort) {\n      // 修复 pr https://github.com/ElemeFE/element/pull/15012 导致的 bug\n      // https://github.com/element-plus/element-plus/pull/4640\n      const { sortingColumn, sortProp, sortOrder } = states\n      const columnValue = unref(sortingColumn),\n        propValue = unref(sortProp),\n        orderValue = unref(sortOrder)\n      if (orderValue === null) {\n        states.sortingColumn.value = null\n        states.sortProp.value = null\n      }\n      const ignore = { filter: true }\n      instance.store.execQuery(ignore)\n\n      if (!options || !(options.silent || options.init)) {\n        instance.emit('sort-change', {\n          column: columnValue,\n          prop: propValue,\n          order: orderValue,\n        })\n      }\n\n      instance.store.updateTableScrollY()\n    },\n\n    filterChange(_states: StoreStates, options: Filter<T>) {\n      const { column, values, silent } = options\n      const newFilters = instance.store.updateFilters(column, values)\n      instance.store.execQuery()\n\n      if (!silent) {\n        instance.emit('filter-change', newFilters)\n      }\n      instance.store.updateTableScrollY()\n    },\n\n    toggleAllSelection() {\n      instance.store.toggleAllSelection()\n    },\n\n    rowSelectedChanged(_states, row: T) {\n      instance.store.toggleRowSelection(row)\n      instance.store.updateAllSelected()\n    },\n\n    setHoverRow(states: StoreStates, row: T) {\n      states.hoverRow.value = row\n    },\n\n    setCurrentRow(_states, row: T) {\n      instance.store.updateCurrentRow(row)\n    },\n  }\n  const commit = function (name: keyof typeof mutations, ...args) {\n    const mutations = instance.store.mutations\n    if (mutations[name]) {\n      mutations[name].apply(instance, [instance.store.states].concat(args))\n    } else {\n      throw new Error(`Action not found: ${name}`)\n    }\n  }\n  const updateTableScrollY = function () {\n    nextTick(() => instance.layout.updateScrollY.apply(instance.layout))\n  }\n  return {\n    ns,\n    ...watcher,\n    mutations,\n    commit,\n    updateTableScrollY,\n  }\n}\n\nexport default useStore\n\nclass HelperStore<T> {\n  Return = useStore<T>()\n}\n\ntype StoreFilter = Record<string, string[]>\ntype Store<T> = HelperStore<T>['Return']\nexport type { WatcherPropsData, Store, StoreFilter }\n", "// @ts-nocheck\nimport { watch } from 'vue'\nimport { debounce } from 'lodash-unified'\nimport useStore from '.'\n\nimport type { Store } from '.'\nimport type { Table, TableProps } from '../table/defaults'\n\nconst InitialStateMap = {\n  rowKey: 'rowKey',\n  defaultExpandAll: 'defaultExpandAll',\n  selectOnIndeterminate: 'selectOnIndeterminate',\n  indent: 'indent',\n  lazy: 'lazy',\n  data: 'data',\n  ['treeProps.hasChildren']: {\n    key: 'lazyColumnIdentifier',\n    default: 'hasChildren',\n  },\n  ['treeProps.children']: {\n    key: 'childrenColumnName',\n    default: 'children',\n  },\n  ['treeProps.checkStrictly']: {\n    key: 'checkStrictly',\n    default: false,\n  },\n}\n\nexport function createStore<T>(table: Table<T>, props: TableProps<T>) {\n  if (!table) {\n    throw new Error('Table is required.')\n  }\n\n  const store = useStore<T>()\n  // fix https://github.com/ElemeFE/element/issues/14075\n  // related pr https://github.com/ElemeFE/element/pull/14146\n  store.toggleAllSelection = debounce(store._toggleAllSelection, 10)\n  Object.keys(InitialStateMap).forEach((key) => {\n    handleValue(getArrKeysValue(props, key), key, store)\n  })\n  proxyTableProps(store, props)\n  return store\n}\n\nfunction proxyTableProps<T>(store: Store<T>, props: TableProps<T>) {\n  Object.keys(InitialStateMap).forEach((key) => {\n    watch(\n      () => getArrKeysValue(props, key),\n      (value) => {\n        handleValue(value, key, store)\n      }\n    )\n  })\n}\n\nfunction handleValue<T>(value, propsKey: string, store: Store<T>) {\n  let newVal = value\n  let storeKey = InitialStateMap[propsKey]\n  if (typeof InitialStateMap[propsKey] === 'object') {\n    storeKey = storeKey.key\n    newVal = newVal || InitialStateMap[propsKey].default\n  }\n  store.states[storeKey].value = newVal\n}\n\nfunction getArrKeysValue<T>(props: TableProps<T>, keys: string) {\n  if (keys.includes('.')) {\n    const keyList = keys.split('.')\n    let value = props\n    keyList.forEach((key) => {\n      value = value[key]\n    })\n    return value\n  } else {\n    return props[keys]\n  }\n}\n", "// @ts-nocheck\nimport { isRef, nextTick, ref } from 'vue'\nimport { hasOwn, isClient } from '@element-plus/utils'\nimport { parseHeight } from './util'\nimport type { Ref } from 'vue'\n\nimport type { TableColumnCtx } from './table-column/defaults'\nimport type { TableHeader } from './table-header'\nimport type { Table } from './table/defaults'\nimport type { Store } from './store'\nclass TableLayout<T> {\n  observers: TableHeader[]\n  table: Table<T>\n  store: Store<T>\n  columns: TableColumnCtx<T>[]\n  fit: boolean\n  showHeader: boolean\n\n  height: Ref<null | number>\n  scrollX: Ref<boolean>\n  scrollY: Ref<boolean>\n  bodyWidth: Ref<null | number>\n  fixedWidth: Ref<null | number>\n  rightFixedWidth: Ref<null | number>\n  tableHeight: Ref<null | number>\n  headerHeight: Ref<null | number> // Table Header Height\n  appendHeight: Ref<null | number> // Append Slot Height\n  footerHeight: Ref<null | number> // Table Footer Height\n  gutterWidth: number\n  constructor(options: Record<string, any>) {\n    this.observers = []\n    this.table = null\n    this.store = null\n    this.columns = []\n    this.fit = true\n    this.showHeader = true\n    this.height = ref(null)\n    this.scrollX = ref(false)\n    this.scrollY = ref(false)\n    this.bodyWidth = ref(null)\n    this.fixedWidth = ref(null)\n    this.rightFixedWidth = ref(null)\n    this.gutterWidth = 0\n    for (const name in options) {\n      if (hasOwn(options, name)) {\n        if (isRef(this[name])) {\n          this[name as string].value = options[name]\n        } else {\n          this[name as string] = options[name]\n        }\n      }\n    }\n    if (!this.table) {\n      throw new Error('Table is required for Table Layout')\n    }\n    if (!this.store) {\n      throw new Error('Store is required for Table Layout')\n    }\n  }\n\n  updateScrollY() {\n    const height = this.height.value\n    /**\n     * When the height is not initialized, it is null.\n     * After the table is initialized, when the height is not configured, the height is 0.\n     */\n    if (height === null) return false\n    const scrollBarRef = this.table.refs.scrollBarRef\n    if (this.table.vnode.el && scrollBarRef?.wrapRef) {\n      let scrollY = true\n      const prevScrollY = this.scrollY.value\n      scrollY =\n        scrollBarRef.wrapRef.scrollHeight > scrollBarRef.wrapRef.clientHeight\n      this.scrollY.value = scrollY\n      return prevScrollY !== scrollY\n    }\n    return false\n  }\n\n  setHeight(value: string | number, prop = 'height') {\n    if (!isClient) return\n    const el = this.table.vnode.el\n    value = parseHeight(value)\n    this.height.value = Number(value)\n\n    if (!el && (value || value === 0))\n      return nextTick(() => this.setHeight(value, prop))\n\n    if (typeof value === 'number') {\n      el.style[prop] = `${value}px`\n      this.updateElsHeight()\n    } else if (typeof value === 'string') {\n      el.style[prop] = value\n      this.updateElsHeight()\n    }\n  }\n\n  setMaxHeight(value: string | number) {\n    this.setHeight(value, 'max-height')\n  }\n\n  getFlattenColumns(): TableColumnCtx<T>[] {\n    const flattenColumns = []\n    const columns = this.table.store.states.columns.value\n    columns.forEach((column) => {\n      if (column.isColumnGroup) {\n        // eslint-disable-next-line prefer-spread\n        flattenColumns.push.apply(flattenColumns, column.columns)\n      } else {\n        flattenColumns.push(column)\n      }\n    })\n\n    return flattenColumns\n  }\n\n  updateElsHeight() {\n    this.updateScrollY()\n    this.notifyObservers('scrollable')\n  }\n\n  headerDisplayNone(elm: HTMLElement) {\n    if (!elm) return true\n    let headerChild = elm\n    while (headerChild.tagName !== 'DIV') {\n      if (getComputedStyle(headerChild).display === 'none') {\n        return true\n      }\n      headerChild = headerChild.parentElement\n    }\n    return false\n  }\n\n  updateColumnsWidth() {\n    if (!isClient) return\n    const fit = this.fit\n    const bodyWidth = this.table.vnode.el.clientWidth\n    let bodyMinWidth = 0\n\n    const flattenColumns = this.getFlattenColumns()\n    const flexColumns = flattenColumns.filter(\n      (column) => typeof column.width !== 'number'\n    )\n    flattenColumns.forEach((column) => {\n      // Clean those columns whose width changed from flex to unflex\n      if (typeof column.width === 'number' && column.realWidth)\n        column.realWidth = null\n    })\n    if (flexColumns.length > 0 && fit) {\n      flattenColumns.forEach((column) => {\n        bodyMinWidth += Number(column.width || column.minWidth || 80)\n      })\n      if (bodyMinWidth <= bodyWidth) {\n        // DON'T HAVE SCROLL BAR\n        this.scrollX.value = false\n\n        const totalFlexWidth = bodyWidth - bodyMinWidth\n\n        if (flexColumns.length === 1) {\n          flexColumns[0].realWidth =\n            Number(flexColumns[0].minWidth || 80) + totalFlexWidth\n        } else {\n          const allColumnsWidth = flexColumns.reduce(\n            (prev, column) => prev + Number(column.minWidth || 80),\n            0\n          )\n          const flexWidthPerPixel = totalFlexWidth / allColumnsWidth\n          let noneFirstWidth = 0\n\n          flexColumns.forEach((column, index) => {\n            if (index === 0) return\n            const flexWidth = Math.floor(\n              Number(column.minWidth || 80) * flexWidthPerPixel\n            )\n            noneFirstWidth += flexWidth\n            column.realWidth = Number(column.minWidth || 80) + flexWidth\n          })\n\n          flexColumns[0].realWidth =\n            Number(flexColumns[0].minWidth || 80) +\n            totalFlexWidth -\n            noneFirstWidth\n        }\n      } else {\n        // HAVE HORIZONTAL SCROLL BAR\n        this.scrollX.value = true\n        flexColumns.forEach((column) => {\n          column.realWidth = Number(column.minWidth)\n        })\n      }\n\n      this.bodyWidth.value = Math.max(bodyMinWidth, bodyWidth)\n      this.table.state.resizeState.value.width = this.bodyWidth.value\n    } else {\n      flattenColumns.forEach((column) => {\n        if (!column.width && !column.minWidth) {\n          column.realWidth = 80\n        } else {\n          column.realWidth = Number(column.width || column.minWidth)\n        }\n        bodyMinWidth += column.realWidth\n      })\n      this.scrollX.value = bodyMinWidth > bodyWidth\n\n      this.bodyWidth.value = bodyMinWidth\n    }\n\n    const fixedColumns = this.store.states.fixedColumns.value\n\n    if (fixedColumns.length > 0) {\n      let fixedWidth = 0\n      fixedColumns.forEach((column) => {\n        fixedWidth += Number(column.realWidth || column.width)\n      })\n\n      this.fixedWidth.value = fixedWidth\n    }\n\n    const rightFixedColumns = this.store.states.rightFixedColumns.value\n    if (rightFixedColumns.length > 0) {\n      let rightFixedWidth = 0\n      rightFixedColumns.forEach((column) => {\n        rightFixedWidth += Number(column.realWidth || column.width)\n      })\n\n      this.rightFixedWidth.value = rightFixedWidth\n    }\n    this.notifyObservers('columns')\n  }\n\n  addObserver(observer: TableHeader) {\n    this.observers.push(observer)\n  }\n\n  removeObserver(observer: TableHeader) {\n    const index = this.observers.indexOf(observer)\n    if (index !== -1) {\n      this.observers.splice(index, 1)\n    }\n  }\n\n  notifyObservers(event: string) {\n    const observers = this.observers\n    observers.forEach((observer) => {\n      switch (event) {\n        case 'columns':\n          observer.state?.onColumnsChange(this)\n          break\n        case 'scrollable':\n          observer.state?.onScrollableChange(this)\n          break\n        default:\n          throw new Error(`Table Layout don't have event ${event}.`)\n      }\n    })\n  }\n}\n\nexport default TableLayout\n", "<template>\n  <el-tooltip\n    ref=\"tooltip\"\n    :visible=\"tooltipVisible\"\n    :offset=\"0\"\n    :placement=\"placement\"\n    :show-arrow=\"false\"\n    :stop-popper-mouse-event=\"false\"\n    teleported\n    effect=\"light\"\n    pure\n    :popper-class=\"filterClassName\"\n    persistent\n    :append-to=\"appendTo\"\n  >\n    <template #content>\n      <div v-if=\"multiple\">\n        <div :class=\"ns.e('content')\">\n          <el-scrollbar :wrap-class=\"ns.e('wrap')\">\n            <el-checkbox-group\n              v-model=\"filteredValue\"\n              :class=\"ns.e('checkbox-group')\"\n            >\n              <el-checkbox\n                v-for=\"filter in filters\"\n                :key=\"filter.value\"\n                :value=\"filter.value\"\n              >\n                {{ filter.text }}\n              </el-checkbox>\n            </el-checkbox-group>\n          </el-scrollbar>\n        </div>\n        <div :class=\"ns.e('bottom')\">\n          <button\n            :class=\"{ [ns.is('disabled')]: filteredValue.length === 0 }\"\n            :disabled=\"filteredValue.length === 0\"\n            type=\"button\"\n            @click=\"handleConfirm\"\n          >\n            {{ t('el.table.confirmFilter') }}\n          </button>\n          <button type=\"button\" @click=\"handleReset\">\n            {{ t('el.table.resetFilter') }}\n          </button>\n        </div>\n      </div>\n      <ul v-else :class=\"ns.e('list')\">\n        <li\n          :class=\"[\n            ns.e('list-item'),\n            {\n              [ns.is('active')]:\n                filterValue === undefined || filterValue === null,\n            },\n          ]\"\n          @click=\"handleSelect(null)\"\n        >\n          {{ t('el.table.clearFilter') }}\n        </li>\n        <li\n          v-for=\"filter in filters\"\n          :key=\"filter.value\"\n          :class=\"[ns.e('list-item'), ns.is('active', isActive(filter))]\"\n          :label=\"filter.value\"\n          @click=\"handleSelect(filter.value)\"\n        >\n          {{ filter.text }}\n        </li>\n      </ul>\n    </template>\n    <template #default>\n      <span\n        v-click-outside:[popperPaneRef]=\"hideFilterPanel\"\n        :class=\"[\n          `${ns.namespace.value}-table__column-filter-trigger`,\n          `${ns.namespace.value}-none-outline`,\n        ]\"\n        @click=\"showFilterPanel\"\n      >\n        <el-icon>\n          <slot name=\"filter-icon\">\n            <arrow-up v-if=\"column.filterOpened\" />\n            <arrow-down v-else />\n          </slot>\n        </el-icon>\n      </span>\n    </template>\n  </el-tooltip>\n</template>\n\n<script lang=\"ts\">\n// @ts-nocheck\nimport { computed, defineComponent, getCurrentInstance, ref, watch } from 'vue'\nimport ElCheckbox from '@element-plus/components/checkbox'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { ArrowDown, ArrowUp } from '@element-plus/icons-vue'\nimport { ClickOutside } from '@element-plus/directives'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport type { Placement } from '@element-plus/components/popper'\n\nimport type { PropType, WritableComputedRef } from 'vue'\nimport type { TableColumnCtx } from './table-column/defaults'\nimport type { TableHeader } from './table-header'\nimport type { Store } from './store'\n\nconst { CheckboxGroup: ElCheckboxGroup } = ElCheckbox\n\nexport default defineComponent({\n  name: 'ElTableFilterPanel',\n  components: {\n    ElCheckbox,\n    ElCheckboxGroup,\n    ElScrollbar,\n    ElTooltip,\n    ElIcon,\n    ArrowDown,\n    ArrowUp,\n  },\n  directives: { ClickOutside },\n  props: {\n    placement: {\n      type: String as PropType<Placement>,\n      default: 'bottom-start',\n    },\n    store: {\n      type: Object as PropType<Store<unknown>>,\n    },\n    column: {\n      type: Object as PropType<TableColumnCtx<unknown>>,\n    },\n    upDataColumn: {\n      type: Function,\n    },\n    appendTo: {\n      type: String,\n    },\n  },\n  setup(props) {\n    const instance = getCurrentInstance()\n    const { t } = useLocale()\n    const ns = useNamespace('table-filter')\n    const parent = instance?.parent as TableHeader\n    if (!parent.filterPanels.value[props.column.id]) {\n      parent.filterPanels.value[props.column.id] = instance\n    }\n    const tooltipVisible = ref(false)\n    const tooltip = ref<InstanceType<typeof ElTooltip> | null>(null)\n    const filters = computed(() => {\n      return props.column && props.column.filters\n    })\n    const filterClassName = computed(() => {\n      if (props.column.filterClassName) {\n        return `${ns.b()} ${props.column.filterClassName}`\n      }\n      return ns.b()\n    })\n    const filterValue = computed({\n      get: () => (props.column?.filteredValue || [])[0],\n      set: (value: string) => {\n        if (filteredValue.value) {\n          if (typeof value !== 'undefined' && value !== null) {\n            filteredValue.value.splice(0, 1, value)\n          } else {\n            filteredValue.value.splice(0, 1)\n          }\n        }\n      },\n    })\n    const filteredValue: WritableComputedRef<unknown[]> = computed({\n      get() {\n        if (props.column) {\n          return props.column.filteredValue || []\n        }\n        return []\n      },\n      set(value: unknown[]) {\n        if (props.column) {\n          props.upDataColumn('filteredValue', value)\n        }\n      },\n    })\n    const multiple = computed(() => {\n      if (props.column) {\n        return props.column.filterMultiple\n      }\n      return true\n    })\n    const isActive = (filter) => {\n      return filter.value === filterValue.value\n    }\n    const hidden = () => {\n      tooltipVisible.value = false\n    }\n    const showFilterPanel = (e: MouseEvent) => {\n      e.stopPropagation()\n      tooltipVisible.value = !tooltipVisible.value\n    }\n    const hideFilterPanel = () => {\n      tooltipVisible.value = false\n    }\n    const handleConfirm = () => {\n      confirmFilter(filteredValue.value)\n      hidden()\n    }\n    const handleReset = () => {\n      filteredValue.value = []\n      confirmFilter(filteredValue.value)\n      hidden()\n    }\n    const handleSelect = (_filterValue?: string) => {\n      filterValue.value = _filterValue\n      if (typeof _filterValue !== 'undefined' && _filterValue !== null) {\n        confirmFilter(filteredValue.value)\n      } else {\n        confirmFilter([])\n      }\n      hidden()\n    }\n    const confirmFilter = (filteredValue: unknown[]) => {\n      props.store.commit('filterChange', {\n        column: props.column,\n        values: filteredValue,\n      })\n      props.store.updateAllSelected()\n    }\n    watch(\n      tooltipVisible,\n      (value) => {\n        // todo\n        if (props.column) {\n          props.upDataColumn('filterOpened', value)\n        }\n      },\n      {\n        immediate: true,\n      }\n    )\n\n    const popperPaneRef = computed(() => {\n      return tooltip.value?.popperRef?.contentRef\n    })\n\n    return {\n      tooltipVisible,\n      multiple,\n      filterClassName,\n      filteredValue,\n      filterValue,\n      filters,\n      handleConfirm,\n      handleReset,\n      handleSelect,\n      isActive,\n      t,\n      ns,\n      showFilterPanel,\n      hideFilterPanel,\n      popperPaneRef,\n      tooltip,\n    }\n  },\n})\n</script>\n", "// @ts-nocheck\nimport {\n  computed,\n  getCurrentInstance,\n  onBeforeMount,\n  onMounted,\n  onUnmounted,\n  onUpdated,\n} from 'vue'\n\nimport type { TableHeader } from './table-header'\nimport type TableLayout from './table-layout'\nimport type { Table } from './table/defaults'\n\nfunction useLayoutObserver<T>(root: Table<T>) {\n  const instance = getCurrentInstance() as TableHeader\n  onBeforeMount(() => {\n    tableLayout.value.addObserver(instance)\n  })\n  onMounted(() => {\n    onColumnsChange(tableLayout.value)\n    onScrollableChange(tableLayout.value)\n  })\n  onUpdated(() => {\n    onColumnsChange(tableLayout.value)\n    onScrollableChange(tableLayout.value)\n  })\n  onUnmounted(() => {\n    tableLayout.value.removeObserver(instance)\n  })\n  const tableLayout = computed(() => {\n    const layout = root.layout as TableLayout<T>\n    if (!layout) {\n      throw new Error('Can not find table layout.')\n    }\n    return layout\n  })\n  const onColumnsChange = (layout: TableLayout<T>) => {\n    const cols = root.vnode.el?.querySelectorAll('colgroup > col') || []\n    if (!cols.length) return\n    const flattenColumns = layout.getFlattenColumns()\n    const columnsMap = {}\n    flattenColumns.forEach((column) => {\n      columnsMap[column.id] = column\n    })\n    for (let i = 0, j = cols.length; i < j; i++) {\n      const col = cols[i]\n      const name = col.getAttribute('name')\n      const column = columnsMap[name]\n      if (column) {\n        col.setAttribute('width', column.realWidth || column.width)\n      }\n    }\n  }\n\n  const onScrollableChange = (layout: TableLayout<T>) => {\n    const cols =\n      root.vnode.el?.querySelectorAll('colgroup > col[name=gutter]') || []\n    for (let i = 0, j = cols.length; i < j; i++) {\n      const col = cols[i]\n      col.setAttribute('width', layout.scrollY.value ? layout.gutterWidth : '0')\n    }\n    const ths = root.vnode.el?.querySelectorAll('th.gutter') || []\n    for (let i = 0, j = ths.length; i < j; i++) {\n      const th = ths[i]\n      th.style.width = layout.scrollY.value ? `${layout.gutterWidth}px` : '0'\n      th.style.display = layout.scrollY.value ? '' : 'none'\n    }\n  }\n\n  return {\n    tableLayout: tableLayout.value,\n    onColumnsChange,\n    onScrollableChange,\n  }\n}\n\nexport default useLayoutObserver\n", "import type { InjectionKey } from 'vue'\nimport type { DefaultRow, Table } from './table/defaults'\n\nexport const TABLE_INJECTION_KEY: InjectionKey<Table<DefaultRow>> =\n  Symbol('ElTable')\n", "// @ts-nocheck\nimport { getCurrentInstance, inject, ref } from 'vue'\nimport {\n  addClass,\n  hasClass,\n  isClient,\n  isElement,\n  removeClass,\n} from '@element-plus/utils'\nimport { TABLE_INJECTION_KEY } from '../tokens'\nimport type { TableHeaderProps } from '.'\nimport type { TableColumnCtx } from '../table-column/defaults'\n\nfunction useEvent<T>(props: TableHeaderProps<T>, emit) {\n  const instance = getCurrentInstance()\n  const parent = inject(TABLE_INJECTION_KEY)\n  const handleFilterClick = (event: Event) => {\n    event.stopPropagation()\n    return\n  }\n\n  const handleHeaderClick = (event: Event, column: TableColumnCtx<T>) => {\n    if (!column.filters && column.sortable) {\n      handleSortClick(event, column, false)\n    } else if (column.filterable && !column.sortable) {\n      handleFilterClick(event)\n    }\n    parent?.emit('header-click', column, event)\n  }\n\n  const handleHeaderContextMenu = (event: Event, column: TableColumnCtx<T>) => {\n    parent?.emit('header-contextmenu', column, event)\n  }\n  const draggingColumn = ref(null)\n  const dragging = ref(false)\n  const dragState = ref({})\n  const handleMouseDown = (event: MouseEvent, column: TableColumnCtx<T>) => {\n    if (!isClient) return\n    if (column.children && column.children.length > 0) return\n    /* istanbul ignore if */\n    if (draggingColumn.value && props.border) {\n      dragging.value = true\n\n      const table = parent\n      emit('set-drag-visible', true)\n      const tableEl = table?.vnode.el\n      const tableLeft = tableEl.getBoundingClientRect().left\n      const columnEl = instance.vnode.el.querySelector(`th.${column.id}`)\n      const columnRect = columnEl.getBoundingClientRect()\n      const minLeft = columnRect.left - tableLeft + 30\n\n      addClass(columnEl, 'noclick')\n\n      dragState.value = {\n        startMouseLeft: event.clientX,\n        startLeft: columnRect.right - tableLeft,\n        startColumnLeft: columnRect.left - tableLeft,\n        tableLeft,\n      }\n      const resizeProxy = table?.refs.resizeProxy as HTMLElement\n      resizeProxy.style.left = `${(dragState.value as any).startLeft}px`\n\n      document.onselectstart = function () {\n        return false\n      }\n      document.ondragstart = function () {\n        return false\n      }\n\n      const handleMouseMove = (event: MouseEvent) => {\n        const deltaLeft =\n          event.clientX - (dragState.value as any).startMouseLeft\n        const proxyLeft = (dragState.value as any).startLeft + deltaLeft\n\n        resizeProxy.style.left = `${Math.max(minLeft, proxyLeft)}px`\n      }\n\n      const handleMouseUp = () => {\n        if (dragging.value) {\n          const { startColumnLeft, startLeft } = dragState.value as any\n          const finalLeft = Number.parseInt(resizeProxy.style.left, 10)\n          const columnWidth = finalLeft - startColumnLeft\n          column.width = column.realWidth = columnWidth\n          table?.emit(\n            'header-dragend',\n            column.width,\n            startLeft - startColumnLeft,\n            column,\n            event\n          )\n          requestAnimationFrame(() => {\n            props.store.scheduleLayout(false, true)\n          })\n          document.body.style.cursor = ''\n          dragging.value = false\n          draggingColumn.value = null\n          dragState.value = {}\n          emit('set-drag-visible', false)\n        }\n\n        document.removeEventListener('mousemove', handleMouseMove)\n        document.removeEventListener('mouseup', handleMouseUp)\n        document.onselectstart = null\n        document.ondragstart = null\n\n        setTimeout(() => {\n          removeClass(columnEl, 'noclick')\n        }, 0)\n      }\n\n      document.addEventListener('mousemove', handleMouseMove)\n      document.addEventListener('mouseup', handleMouseUp)\n    }\n  }\n\n  const handleMouseMove = (event: MouseEvent, column: TableColumnCtx<T>) => {\n    if (column.children && column.children.length > 0) return\n    const el = event.target as HTMLElement\n    if (!isElement(el)) {\n      return\n    }\n    const target = el?.closest('th')\n\n    if (!column || !column.resizable) return\n\n    if (!dragging.value && props.border) {\n      const rect = target.getBoundingClientRect()\n\n      const bodyStyle = document.body.style\n      if (rect.width > 12 && rect.right - event.pageX < 8) {\n        bodyStyle.cursor = 'col-resize'\n        if (hasClass(target, 'is-sortable')) {\n          target.style.cursor = 'col-resize'\n        }\n        draggingColumn.value = column\n      } else if (!dragging.value) {\n        bodyStyle.cursor = ''\n        if (hasClass(target, 'is-sortable')) {\n          target.style.cursor = 'pointer'\n        }\n        draggingColumn.value = null\n      }\n    }\n  }\n\n  const handleMouseOut = () => {\n    if (!isClient) return\n    document.body.style.cursor = ''\n  }\n  const toggleOrder = ({ order, sortOrders }) => {\n    if (order === '') return sortOrders[0]\n    const index = sortOrders.indexOf(order || null)\n    return sortOrders[index > sortOrders.length - 2 ? 0 : index + 1]\n  }\n  const handleSortClick = (\n    event: Event,\n    column: TableColumnCtx<T>,\n    givenOrder: string | boolean\n  ) => {\n    event.stopPropagation()\n    const order =\n      column.order === givenOrder ? null : givenOrder || toggleOrder(column)\n    const target = (event.target as HTMLElement)?.closest('th')\n\n    if (target) {\n      if (hasClass(target, 'noclick')) {\n        removeClass(target, 'noclick')\n        return\n      }\n    }\n\n    if (!column.sortable) return\n\n    const clickTarget = event.currentTarget\n\n    if (\n      ['ascending', 'descending'].some(\n        (str) => hasClass(clickTarget, str) && !column.sortOrders.includes(str)\n      )\n    ) {\n      return\n    }\n\n    const states = props.store.states\n    let sortProp = states.sortProp.value\n    let sortOrder\n    const sortingColumn = states.sortingColumn.value\n\n    if (\n      sortingColumn !== column ||\n      (sortingColumn === column && sortingColumn.order === null)\n    ) {\n      if (sortingColumn) {\n        sortingColumn.order = null\n      }\n      states.sortingColumn.value = column\n      sortProp = column.property\n    }\n    if (!order) {\n      sortOrder = column.order = null\n    } else {\n      sortOrder = column.order = order\n    }\n\n    states.sortProp.value = sortProp\n    states.sortOrder.value = sortOrder\n\n    parent?.store.commit('changeSortCondition')\n  }\n\n  return {\n    handleHeaderClick,\n    handleHeaderContextMenu,\n    handleMouseDown,\n    handleMouseMove,\n    handleMouseOut,\n    handleSortClick,\n    handleFilterClick,\n  }\n}\n\nexport default useEvent\n", "import { inject } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport {\n  ensurePosition,\n  getFixedColumnOffset,\n  getFixedColumnsClass,\n} from '../util'\nimport { TABLE_INJECTION_KEY } from '../tokens'\nimport type { TableColumnCtx } from '../table-column/defaults'\nimport type { TableHeaderProps } from '.'\n\nfunction useStyle<T>(props: TableHeaderProps<T>) {\n  const parent = inject(TABLE_INJECTION_KEY)\n  const ns = useNamespace('table')\n\n  const getHeaderRowStyle = (rowIndex: number) => {\n    const headerRowStyle = parent?.props.headerRowStyle\n    if (typeof headerRowStyle === 'function') {\n      return headerRowStyle.call(null, { rowIndex })\n    }\n    return headerRowStyle\n  }\n\n  const getHeaderRowClass = (rowIndex: number): string => {\n    const classes: string[] = []\n    const headerRowClassName = parent?.props.headerRowClassName\n    if (typeof headerRowClassName === 'string') {\n      classes.push(headerRowClassName)\n    } else if (typeof headerRowClassName === 'function') {\n      classes.push(headerRowClassName.call(null, { rowIndex }))\n    }\n\n    return classes.join(' ')\n  }\n\n  const getHeaderCellStyle = (\n    rowIndex: number,\n    columnIndex: number,\n    row: T,\n    column: TableColumnCtx<T>\n  ) => {\n    let headerCellStyles = parent?.props.headerCellStyle ?? {}\n    if (typeof headerCellStyles === 'function') {\n      headerCellStyles = headerCellStyles.call(null, {\n        rowIndex,\n        columnIndex,\n        row,\n        column,\n      })\n    }\n    const fixedStyle = getFixedColumnOffset<T>(\n      columnIndex,\n      column.fixed,\n      props.store,\n      row as unknown as TableColumnCtx<T>[]\n    )\n    ensurePosition(fixedStyle, 'left')\n    ensurePosition(fixedStyle, 'right')\n    return Object.assign({}, headerCellStyles, fixedStyle)\n  }\n\n  const getHeaderCellClass = (\n    rowIndex: number,\n    columnIndex: number,\n    row: T,\n    column: TableColumnCtx<T>\n  ) => {\n    const fixedClasses = getFixedColumnsClass<T>(\n      ns.b(),\n      columnIndex,\n      column.fixed,\n      props.store,\n      row as unknown as TableColumnCtx<T>[]\n    )\n    const classes = [\n      column.id,\n      column.order,\n      column.headerAlign,\n      column.className,\n      column.labelClassName,\n      ...fixedClasses,\n    ]\n\n    if (!column.children) {\n      classes.push('is-leaf')\n    }\n\n    if (column.sortable) {\n      classes.push('is-sortable')\n    }\n\n    const headerCellClassName = parent?.props.headerCellClassName\n    if (typeof headerCellClassName === 'string') {\n      classes.push(headerCellClassName)\n    } else if (typeof headerCellClassName === 'function') {\n      classes.push(\n        headerCellClassName.call(null, {\n          rowIndex,\n          columnIndex,\n          row,\n          column,\n        })\n      )\n    }\n\n    classes.push(ns.e('cell'))\n\n    return classes.filter((className) => Boolean(className)).join(' ')\n  }\n\n  return {\n    getHeaderRowStyle,\n    getHeaderRowClass,\n    getHeaderCellStyle,\n    getHeaderCellClass,\n  }\n}\n\nexport default useStyle\n", "// @ts-nocheck\nimport { computed, inject } from 'vue'\nimport { TABLE_INJECTION_KEY } from '../tokens'\nimport type { TableColumnCtx } from '../table-column/defaults'\nimport type { TableHeaderProps } from '.'\n\nconst getAllColumns = <T>(\n  columns: TableColumnCtx<T>[]\n): TableColumnCtx<T>[] => {\n  const result: TableColumnCtx<T>[] = []\n  columns.forEach((column) => {\n    if (column.children) {\n      result.push(column)\n      // eslint-disable-next-line prefer-spread\n      result.push.apply(result, getAllColumns(column.children))\n    } else {\n      result.push(column)\n    }\n  })\n  return result\n}\n\nexport const convertToRows = <T>(\n  originColumns: TableColumnCtx<T>[]\n): TableColumnCtx<T>[] => {\n  let maxLevel = 1\n  const traverse = (column: TableColumnCtx<T>, parent: TableColumnCtx<T>) => {\n    if (parent) {\n      column.level = parent.level + 1\n      if (maxLevel < column.level) {\n        maxLevel = column.level\n      }\n    }\n    if (column.children) {\n      let colSpan = 0\n      column.children.forEach((subColumn) => {\n        traverse(subColumn, column)\n        colSpan += subColumn.colSpan\n      })\n      column.colSpan = colSpan\n    } else {\n      column.colSpan = 1\n    }\n  }\n\n  originColumns.forEach((column) => {\n    column.level = 1\n    traverse(column, undefined)\n  })\n\n  const rows = []\n  for (let i = 0; i < maxLevel; i++) {\n    rows.push([])\n  }\n\n  const allColumns: TableColumnCtx<T>[] = getAllColumns(originColumns)\n\n  allColumns.forEach((column) => {\n    if (!column.children) {\n      column.rowSpan = maxLevel - column.level + 1\n    } else {\n      column.rowSpan = 1\n      column.children.forEach((col) => (col.isSubColumn = true))\n    }\n    rows[column.level - 1].push(column)\n  })\n\n  return rows\n}\n\nfunction useUtils<T>(props: TableHeaderProps<T>) {\n  const parent = inject(TABLE_INJECTION_KEY)\n  const columnRows = computed(() => {\n    return convertToRows(props.store.states.originColumns.value)\n  })\n  const isGroup = computed(() => {\n    const result = columnRows.value.length > 1\n    if (result && parent) {\n      parent.state.isGroup.value = true\n    }\n    return result\n  })\n  const toggleAllSelection = (event: Event) => {\n    event.stopPropagation()\n    parent?.store.commit('toggleAllSelection')\n  }\n  return {\n    isGroup,\n    toggleAllSelection,\n    columnRows,\n  }\n}\n\nexport default useUtils\n", "// @ts-nocheck\nimport {\n  defineComponent,\n  getCurrentInstance,\n  h,\n  inject,\n  nextTick,\n  onMounted,\n  ref,\n} from 'vue'\nimport ElCheckbox from '@element-plus/components/checkbox'\nimport { useNamespace } from '@element-plus/hooks'\nimport FilterPanel from '../filter-panel.vue'\nimport useLayoutObserver from '../layout-observer'\nimport { TABLE_INJECTION_KEY } from '../tokens'\nimport useEvent from './event-helper'\nimport useStyle from './style.helper'\nimport useUtils from './utils-helper'\nimport type { ComponentInternalInstance, PropType, Ref } from 'vue'\nimport type { DefaultRow, Sort } from '../table/defaults'\nimport type { Store } from '../store'\nexport interface TableHeader extends ComponentInternalInstance {\n  state: {\n    onColumnsChange\n    onScrollableChange\n  }\n  filterPanels: Ref<unknown>\n}\nexport interface TableHeaderProps<T> {\n  fixed: string\n  store: Store<T>\n  border: boolean\n  defaultSort: Sort\n}\n\nexport default defineComponent({\n  name: 'ElTableHeader',\n  components: {\n    ElCheckbox,\n  },\n  props: {\n    fixed: {\n      type: String,\n      default: '',\n    },\n    store: {\n      required: true,\n      type: Object as PropType<TableHeaderProps<DefaultRow>['store']>,\n    },\n    border: Boolean,\n    defaultSort: {\n      type: Object as PropType<TableHeaderProps<DefaultRow>['defaultSort']>,\n      default: () => {\n        return {\n          prop: '',\n          order: '',\n        }\n      },\n    },\n    appendFilterPanelTo: {\n      type: String,\n    },\n  },\n  setup(props, { emit }) {\n    const instance = getCurrentInstance() as TableHeader\n    const parent = inject(TABLE_INJECTION_KEY)\n    const ns = useNamespace('table')\n    const filterPanels = ref({})\n    const { onColumnsChange, onScrollableChange } = useLayoutObserver(parent!)\n    onMounted(async () => {\n      // Need double await, because updateColumns is executed after nextTick for now\n      await nextTick()\n      await nextTick()\n      const { prop, order } = props.defaultSort\n      parent?.store.commit('sort', { prop, order, init: true })\n    })\n    const {\n      handleHeaderClick,\n      handleHeaderContextMenu,\n      handleMouseDown,\n      handleMouseMove,\n      handleMouseOut,\n      handleSortClick,\n      handleFilterClick,\n    } = useEvent(props as TableHeaderProps<unknown>, emit)\n    const {\n      getHeaderRowStyle,\n      getHeaderRowClass,\n      getHeaderCellStyle,\n      getHeaderCellClass,\n    } = useStyle(props as TableHeaderProps<unknown>)\n    const { isGroup, toggleAllSelection, columnRows } = useUtils(\n      props as TableHeaderProps<unknown>\n    )\n\n    instance.state = {\n      onColumnsChange,\n      onScrollableChange,\n    }\n    instance.filterPanels = filterPanels\n\n    return {\n      ns,\n      filterPanels,\n      onColumnsChange,\n      onScrollableChange,\n      columnRows,\n      getHeaderRowClass,\n      getHeaderRowStyle,\n      getHeaderCellClass,\n      getHeaderCellStyle,\n      handleHeaderClick,\n      handleHeaderContextMenu,\n      handleMouseDown,\n      handleMouseMove,\n      handleMouseOut,\n      handleSortClick,\n      handleFilterClick,\n      isGroup,\n      toggleAllSelection,\n    }\n  },\n  render() {\n    const {\n      ns,\n      isGroup,\n      columnRows,\n      getHeaderCellStyle,\n      getHeaderCellClass,\n      getHeaderRowClass,\n      getHeaderRowStyle,\n      handleHeaderClick,\n      handleHeaderContextMenu,\n      handleMouseDown,\n      handleMouseMove,\n      handleSortClick,\n      handleMouseOut,\n      store,\n      $parent,\n    } = this\n    let rowSpan = 1\n    return h(\n      'thead',\n      {\n        class: { [ns.is('group')]: isGroup },\n      },\n      columnRows.map((subColumns, rowIndex) =>\n        h(\n          'tr',\n          {\n            class: getHeaderRowClass(rowIndex),\n            key: rowIndex,\n            style: getHeaderRowStyle(rowIndex),\n          },\n          subColumns.map((column, cellIndex) => {\n            if (column.rowSpan > rowSpan) {\n              rowSpan = column.rowSpan\n            }\n            return h(\n              'th',\n              {\n                class: getHeaderCellClass(\n                  rowIndex,\n                  cellIndex,\n                  subColumns,\n                  column\n                ),\n                colspan: column.colSpan,\n                key: `${column.id}-thead`,\n                rowspan: column.rowSpan,\n                style: getHeaderCellStyle(\n                  rowIndex,\n                  cellIndex,\n                  subColumns,\n                  column\n                ),\n                onClick: ($event) => {\n                  if ($event.currentTarget.classList.contains('noclick')) {\n                    return\n                  }\n                  handleHeaderClick($event, column)\n                },\n                onContextmenu: ($event) =>\n                  handleHeaderContextMenu($event, column),\n                onMousedown: ($event) => handleMouseDown($event, column),\n                onMousemove: ($event) => handleMouseMove($event, column),\n                onMouseout: handleMouseOut,\n              },\n              [\n                h(\n                  'div',\n                  {\n                    class: [\n                      'cell',\n                      column.filteredValue && column.filteredValue.length > 0\n                        ? 'highlight'\n                        : '',\n                    ],\n                  },\n                  [\n                    column.renderHeader\n                      ? column.renderHeader({\n                          column,\n                          $index: cellIndex,\n                          store,\n                          _self: $parent,\n                        })\n                      : column.label,\n                    column.sortable &&\n                      h(\n                        'span',\n                        {\n                          onClick: ($event) => handleSortClick($event, column),\n                          class: 'caret-wrapper',\n                        },\n                        [\n                          h('i', {\n                            onClick: ($event) =>\n                              handleSortClick($event, column, 'ascending'),\n                            class: 'sort-caret ascending',\n                          }),\n                          h('i', {\n                            onClick: ($event) =>\n                              handleSortClick($event, column, 'descending'),\n                            class: 'sort-caret descending',\n                          }),\n                        ]\n                      ),\n                    column.filterable &&\n                      h(\n                        FilterPanel,\n                        {\n                          store,\n                          placement: column.filterPlacement || 'bottom-start',\n                          appendTo: $parent.appendFilterPanelTo,\n                          column,\n                          upDataColumn: (key, value) => {\n                            column[key] = value\n                          },\n                        },\n                        {\n                          'filter-icon': () =>\n                            column.renderFilterIcon\n                              ? column.renderFilterIcon({\n                                  filterOpened: column.filterOpened,\n                                })\n                              : null,\n                        }\n                      ),\n                  ]\n                ),\n              ]\n            )\n          })\n        )\n      )\n    )\n  },\n})\n", "// @ts-nocheck\nimport { h, inject, ref } from 'vue'\nimport { debounce } from 'lodash-unified'\nimport { addClass, hasClass, removeClass } from '@element-plus/utils'\nimport { createTablePopper, getCell, getColumnByCell } from '../util'\nimport { TABLE_INJECTION_KEY } from '../tokens'\nimport type { TableColumnCtx } from '../table-column/defaults'\nimport type { TableBodyProps } from './defaults'\nimport type { TableOverflowTooltipOptions } from '../util'\n\nfunction isGreaterThan(a: number, b: number, epsilon = 0.03) {\n  return a - b > epsilon\n}\n\nfunction useEvents<T>(props: Partial<TableBodyProps<T>>) {\n  const parent = inject(TABLE_INJECTION_KEY)\n  const tooltipContent = ref('')\n  const tooltipTrigger = ref(h('div'))\n  const handleEvent = (event: Event, row: T, name: string) => {\n    const table = parent\n    const cell = getCell(event)\n    let column: TableColumnCtx<T>\n    const namespace = table?.vnode.el?.dataset.prefix\n    if (cell) {\n      column = getColumnByCell(\n        {\n          columns: props.store.states.columns.value,\n        },\n        cell,\n        namespace\n      )\n      if (column) {\n        table?.emit(`cell-${name}`, row, column, cell, event)\n      }\n    }\n    table?.emit(`row-${name}`, row, column, event)\n  }\n  const handleDoubleClick = (event: Event, row: T) => {\n    handleEvent(event, row, 'dblclick')\n  }\n  const handleClick = (event: Event, row: T) => {\n    props.store.commit('setCurrentRow', row)\n    handleEvent(event, row, 'click')\n  }\n  const handleContextMenu = (event: Event, row: T) => {\n    handleEvent(event, row, 'contextmenu')\n  }\n  const handleMouseEnter = debounce((index: number) => {\n    props.store.commit('setHoverRow', index)\n  }, 30)\n  const handleMouseLeave = debounce(() => {\n    props.store.commit('setHoverRow', null)\n  }, 30)\n  const getPadding = (el: HTMLElement) => {\n    const style = window.getComputedStyle(el, null)\n    const paddingLeft = Number.parseInt(style.paddingLeft, 10) || 0\n    const paddingRight = Number.parseInt(style.paddingRight, 10) || 0\n    const paddingTop = Number.parseInt(style.paddingTop, 10) || 0\n    const paddingBottom = Number.parseInt(style.paddingBottom, 10) || 0\n    return {\n      left: paddingLeft,\n      right: paddingRight,\n      top: paddingTop,\n      bottom: paddingBottom,\n    }\n  }\n\n  const toggleRowClassByCell = (\n    rowSpan: number,\n    event: MouseEvent,\n    toggle: (el: Element, cls: string) => void\n  ) => {\n    let node = event.target.parentNode\n    while (rowSpan > 1) {\n      node = node?.nextSibling\n      if (!node || node.nodeName !== 'TR') break\n      toggle(node, 'hover-row hover-fixed-row')\n      rowSpan--\n    }\n  }\n\n  const handleCellMouseEnter = (\n    event: MouseEvent,\n    row: T,\n    tooltipOptions: TableOverflowTooltipOptions\n  ) => {\n    const table = parent\n    const cell = getCell(event)\n    const namespace = table?.vnode.el?.dataset.prefix\n    if (cell) {\n      const column = getColumnByCell(\n        {\n          columns: props.store.states.columns.value,\n        },\n        cell,\n        namespace\n      )\n      if (cell.rowSpan > 1) {\n        toggleRowClassByCell(cell.rowSpan, event, addClass)\n      }\n      const hoverState = (table.hoverState = { cell, column, row })\n      table?.emit(\n        'cell-mouse-enter',\n        hoverState.row,\n        hoverState.column,\n        hoverState.cell,\n        event\n      )\n    }\n\n    if (!tooltipOptions) {\n      return\n    }\n\n    // 判断是否text-overflow, 如果是就显示tooltip\n    const cellChild = (event.target as HTMLElement).querySelector(\n      '.cell'\n    ) as HTMLElement\n    if (\n      !(\n        hasClass(cellChild, `${namespace}-tooltip`) &&\n        cellChild.childNodes.length\n      )\n    ) {\n      return\n    }\n    // use range width instead of scrollWidth to determine whether the text is overflowing\n    // to address a potential FireFox bug: https://bugzilla.mozilla.org/show_bug.cgi?id=1074543#c3\n    const range = document.createRange()\n    range.setStart(cellChild, 0)\n    range.setEnd(cellChild, cellChild.childNodes.length)\n    /** detail: https://github.com/element-plus/element-plus/issues/10790\n     *  What went wrong?\n     *  UI > Browser > Zoom, In Blink/WebKit, getBoundingClientRect() sometimes returns inexact values, probably due to lost precision during internal calculations. In the example above:\n     *    - Expected: 188\n     *    - Actual: 188.00000762939453\n     */\n    const { width: rangeWidth, height: rangeHeight } =\n      range.getBoundingClientRect()\n    const { width: cellChildWidth, height: cellChildHeight } =\n      cellChild.getBoundingClientRect()\n\n    const { top, left, right, bottom } = getPadding(cellChild)\n    const horizontalPadding = left + right\n    const verticalPadding = top + bottom\n    if (\n      isGreaterThan(rangeWidth + horizontalPadding, cellChildWidth) ||\n      isGreaterThan(rangeHeight + verticalPadding, cellChildHeight) ||\n      // When using a high-resolution screen, it is possible that a returns cellChild.scrollWidth value of 1921 and\n      // cellChildWidth returns a value of 1920.994140625. #16856 #16673\n      isGreaterThan(cellChild.scrollWidth, cellChildWidth)\n    ) {\n      createTablePopper(\n        tooltipOptions,\n        cell.innerText || cell.textContent,\n        cell,\n        table\n      )\n    }\n  }\n  const handleCellMouseLeave = (event) => {\n    const cell = getCell(event)\n    if (!cell) return\n    if (cell.rowSpan > 1) {\n      toggleRowClassByCell(cell.rowSpan, event, removeClass)\n    }\n    const oldHoverState = parent?.hoverState\n    parent?.emit(\n      'cell-mouse-leave',\n      oldHoverState?.row,\n      oldHoverState?.column,\n      oldHoverState?.cell,\n      event\n    )\n  }\n\n  return {\n    handleDoubleClick,\n    handleClick,\n    handleContextMenu,\n    handleMouseEnter,\n    handleMouseLeave,\n    handleCellMouseEnter,\n    handleCellMouseLeave,\n    tooltipContent,\n    tooltipTrigger,\n  }\n}\n\nexport default useEvents\n", "// @ts-nocheck\nimport { inject } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport {\n  ensurePosition,\n  getFixedColumnOffset,\n  getFixedColumnsClass,\n} from '../util'\nimport { TABLE_INJECTION_KEY } from '../tokens'\nimport type { TableColumnCtx } from '../table-column/defaults'\nimport type { TableBodyProps } from './defaults'\n\nfunction useStyles<T>(props: Partial<TableBodyProps<T>>) {\n  const parent = inject(TABLE_INJECTION_KEY)\n  const ns = useNamespace('table')\n\n  const getRowStyle = (row: T, rowIndex: number) => {\n    const rowStyle = parent?.props.rowStyle\n    if (typeof rowStyle === 'function') {\n      return rowStyle.call(null, {\n        row,\n        rowIndex,\n      })\n    }\n    return rowStyle || null\n  }\n\n  const getRowClass = (row: T, rowIndex: number) => {\n    const classes = [ns.e('row')]\n    if (\n      parent?.props.highlightCurrentRow &&\n      row === props.store.states.currentRow.value\n    ) {\n      classes.push('current-row')\n    }\n\n    if (props.stripe && rowIndex % 2 === 1) {\n      classes.push(ns.em('row', 'striped'))\n    }\n    const rowClassName = parent?.props.rowClassName\n    if (typeof rowClassName === 'string') {\n      classes.push(rowClassName)\n    } else if (typeof rowClassName === 'function') {\n      classes.push(\n        rowClassName.call(null, {\n          row,\n          rowIndex,\n        })\n      )\n    }\n    return classes\n  }\n\n  const getCellStyle = (\n    rowIndex: number,\n    columnIndex: number,\n    row: T,\n    column: TableColumnCtx<T>\n  ) => {\n    const cellStyle = parent?.props.cellStyle\n    let cellStyles = cellStyle ?? {}\n    if (typeof cellStyle === 'function') {\n      cellStyles = cellStyle.call(null, {\n        rowIndex,\n        columnIndex,\n        row,\n        column,\n      })\n    }\n    const fixedStyle = getFixedColumnOffset(\n      columnIndex,\n      props?.fixed,\n      props.store\n    )\n    ensurePosition(fixedStyle, 'left')\n    ensurePosition(fixedStyle, 'right')\n    return Object.assign({}, cellStyles, fixedStyle)\n  }\n\n  const getCellClass = (\n    rowIndex: number,\n    columnIndex: number,\n    row: T,\n    column: TableColumnCtx<T>,\n    offset: number\n  ) => {\n    const fixedClasses = getFixedColumnsClass(\n      ns.b(),\n      columnIndex,\n      props?.fixed,\n      props.store,\n      undefined,\n      offset\n    )\n    const classes = [column.id, column.align, column.className, ...fixedClasses]\n    const cellClassName = parent?.props.cellClassName\n    if (typeof cellClassName === 'string') {\n      classes.push(cellClassName)\n    } else if (typeof cellClassName === 'function') {\n      classes.push(\n        cellClassName.call(null, {\n          rowIndex,\n          columnIndex,\n          row,\n          column,\n        })\n      )\n    }\n    classes.push(ns.e('cell'))\n    return classes.filter((className) => Boolean(className)).join(' ')\n  }\n  const getSpan = (\n    row: T,\n    column: TableColumnCtx<T>,\n    rowIndex: number,\n    columnIndex: number\n  ) => {\n    let rowspan = 1\n    let colspan = 1\n    const fn = parent?.props.spanMethod\n    if (typeof fn === 'function') {\n      const result = fn({\n        row,\n        column,\n        rowIndex,\n        columnIndex,\n      })\n      if (Array.isArray(result)) {\n        rowspan = result[0]\n        colspan = result[1]\n      } else if (typeof result === 'object') {\n        rowspan = result.rowspan\n        colspan = result.colspan\n      }\n    }\n    return { rowspan, colspan }\n  }\n  const getColspanRealWidth = (\n    columns: TableColumnCtx<T>[],\n    colspan: number,\n    index: number\n  ): number => {\n    if (colspan < 1) {\n      return columns[index].realWidth\n    }\n    const widthArr = columns\n      .map(({ realWidth, width }) => realWidth || width)\n      .slice(index, index + colspan)\n    return Number(\n      widthArr.reduce((acc, width) => Number(acc) + Number(width), -1)\n    )\n  }\n\n  return {\n    getRowStyle,\n    getRowClass,\n    getCellStyle,\n    getCellClass,\n    getSpan,\n    getColspanRealWidth,\n  }\n}\n\nexport default useStyles\n", "// @ts-nocheck\nimport { computed, h, inject } from 'vue'\nimport { merge } from 'lodash-unified'\nimport { useNamespace } from '@element-plus/hooks'\nimport { getRowIdentity } from '../util'\nimport { TABLE_INJECTION_KEY } from '../tokens'\nimport useEvents from './events-helper'\nimport useStyles from './styles-helper'\nimport type { TableBodyProps } from './defaults'\nimport type { RenderRowData, TableProps, TreeNode } from '../table/defaults'\n\nfunction useRender<T>(props: Partial<TableBodyProps<T>>) {\n  const parent = inject(TABLE_INJECTION_KEY)\n  const ns = useNamespace('table')\n  const {\n    handleDoubleClick,\n    handleClick,\n    handleContextMenu,\n    handleMouseEnter,\n    handleMouseLeave,\n    handleCellMouseEnter,\n    handleCellMouseLeave,\n    tooltipContent,\n    tooltipTrigger,\n  } = useEvents(props)\n  const {\n    getRowStyle,\n    getRowClass,\n    getCellStyle,\n    getCellClass,\n    getSpan,\n    getColspanRealWidth,\n  } = useStyles(props)\n  const firstDefaultColumnIndex = computed(() => {\n    return props.store.states.columns.value.findIndex(\n      ({ type }) => type === 'default'\n    )\n  })\n  const getKeyOfRow = (row: T, index: number) => {\n    const rowKey = (parent.props as Partial<TableProps<T>>).rowKey\n    if (rowKey) {\n      return getRowIdentity(row, rowKey)\n    }\n    return index\n  }\n  const rowRender = (\n    row: T,\n    $index: number,\n    treeRowData?: TreeNode,\n    expanded = false\n  ) => {\n    const { tooltipEffect, tooltipOptions, store } = props\n    const { indent, columns } = store.states\n    const rowClasses = getRowClass(row, $index)\n    let display = true\n    if (treeRowData) {\n      rowClasses.push(ns.em('row', `level-${treeRowData.level}`))\n      display = treeRowData.display\n    }\n    const displayStyle = display\n      ? null\n      : {\n          display: 'none',\n        }\n    return h(\n      'tr',\n      {\n        style: [displayStyle, getRowStyle(row, $index)],\n        class: rowClasses,\n        key: getKeyOfRow(row, $index),\n        onDblclick: ($event) => handleDoubleClick($event, row),\n        onClick: ($event) => handleClick($event, row),\n        onContextmenu: ($event) => handleContextMenu($event, row),\n        onMouseenter: () => handleMouseEnter($index),\n        onMouseleave: handleMouseLeave,\n      },\n      columns.value.map((column, cellIndex) => {\n        const { rowspan, colspan } = getSpan(row, column, $index, cellIndex)\n        if (!rowspan || !colspan) {\n          return null\n        }\n        const columnData = Object.assign({}, column)\n        columnData.realWidth = getColspanRealWidth(\n          columns.value,\n          colspan,\n          cellIndex\n        )\n        const data: RenderRowData<T> = {\n          store: props.store,\n          _self: props.context || parent,\n          column: columnData,\n          row,\n          $index,\n          cellIndex,\n          expanded,\n        }\n        if (cellIndex === firstDefaultColumnIndex.value && treeRowData) {\n          data.treeNode = {\n            indent: treeRowData.level * indent.value,\n            level: treeRowData.level,\n          }\n          if (typeof treeRowData.expanded === 'boolean') {\n            data.treeNode.expanded = treeRowData.expanded\n            // 表明是懒加载\n            if ('loading' in treeRowData) {\n              data.treeNode.loading = treeRowData.loading\n            }\n            if ('noLazyChildren' in treeRowData) {\n              data.treeNode.noLazyChildren = treeRowData.noLazyChildren\n            }\n          }\n        }\n        const baseKey = `${getKeyOfRow(row, $index)},${cellIndex}`\n        const patchKey = columnData.columnKey || columnData.rawColumnKey || ''\n        const tdChildren = cellChildren(cellIndex, column, data)\n        const mergedTooltipOptions =\n          column.showOverflowTooltip &&\n          merge(\n            {\n              effect: tooltipEffect,\n            },\n            tooltipOptions,\n            column.showOverflowTooltip\n          )\n        return h(\n          'td',\n          {\n            style: getCellStyle($index, cellIndex, row, column),\n            class: getCellClass($index, cellIndex, row, column, colspan - 1),\n            key: `${patchKey}${baseKey}`,\n            rowspan,\n            colspan,\n            onMouseenter: ($event) =>\n              handleCellMouseEnter($event, row, mergedTooltipOptions),\n            onMouseleave: handleCellMouseLeave,\n          },\n          [tdChildren]\n        )\n      })\n    )\n  }\n  const cellChildren = (cellIndex, column, data) => {\n    return column.renderCell(data)\n  }\n\n  const wrappedRowRender = (row: T, $index: number) => {\n    const store = props.store\n    const { isRowExpanded, assertRowKey } = store\n    const { treeData, lazyTreeNodeMap, childrenColumnName, rowKey } =\n      store.states\n    const columns = store.states.columns.value\n    const hasExpandColumn = columns.some(({ type }) => type === 'expand')\n    if (hasExpandColumn) {\n      const expanded = isRowExpanded(row)\n      const tr = rowRender(row, $index, undefined, expanded)\n      const renderExpanded = parent.renderExpanded\n      if (expanded) {\n        if (!renderExpanded) {\n          console.error('[Element Error]renderExpanded is required.')\n          return tr\n        }\n        // 使用二维数组,避免修改 $index\n        // Use a matrix to avoid modifying $index\n        return [\n          [\n            tr,\n            h(\n              'tr',\n              {\n                key: `expanded-row__${tr.key as string}`,\n              },\n              [\n                h(\n                  'td',\n                  {\n                    colspan: columns.length,\n                    class: `${ns.e('cell')} ${ns.e('expanded-cell')}`,\n                  },\n                  [renderExpanded({ row, $index, store, expanded })]\n                ),\n              ]\n            ),\n          ],\n        ]\n      } else {\n        // 使用二维数组,避免修改 $index\n        // Use a two dimensional array avoid modifying $index\n        return [[tr]]\n      }\n    } else if (Object.keys(treeData.value).length) {\n      assertRowKey()\n      // TreeTable 时,rowKey 必须由用户设定,不使用 getKeyOfRow 计算\n      // 在调用 rowRender 函数时,仍然会计算 rowKey,不太好的操作\n      const key = getRowIdentity(row, rowKey.value)\n      let cur = treeData.value[key]\n      let treeRowData = null\n      if (cur) {\n        treeRowData = {\n          expanded: cur.expanded,\n          level: cur.level,\n          display: true,\n        }\n        if (typeof cur.lazy === 'boolean') {\n          if (typeof cur.loaded === 'boolean' && cur.loaded) {\n            treeRowData.noLazyChildren = !(cur.children && cur.children.length)\n          }\n          treeRowData.loading = cur.loading\n        }\n      }\n      const tmp = [rowRender(row, $index, treeRowData)]\n      // 渲染嵌套数据\n      if (cur) {\n        // currentRow 记录的是 index,所以还需主动增加 TreeTable 的 index\n        let i = 0\n        const traverse = (children, parent) => {\n          if (!(children && children.length && parent)) return\n          children.forEach((node) => {\n            // 父节点的 display 状态影响子节点的显示状态\n            const innerTreeRowData = {\n              display: parent.display && parent.expanded,\n              level: parent.level + 1,\n              expanded: false,\n              noLazyChildren: false,\n              loading: false,\n            }\n            const childKey = getRowIdentity(node, rowKey.value)\n            if (childKey === undefined || childKey === null) {\n              throw new Error('For nested data item, row-key is required.')\n            }\n            cur = { ...treeData.value[childKey] }\n            // 对于当前节点,分成有无子节点两种情况。\n            // 如果包含子节点的,设置 expanded 属性。\n            // 对于它子节点的 display 属性由它本身的 expanded 与 display 共同决定。\n            if (cur) {\n              innerTreeRowData.expanded = cur.expanded\n              // 懒加载的某些节点,level 未知\n              cur.level = cur.level || innerTreeRowData.level\n              cur.display = !!(cur.expanded && innerTreeRowData.display)\n              if (typeof cur.lazy === 'boolean') {\n                if (typeof cur.loaded === 'boolean' && cur.loaded) {\n                  innerTreeRowData.noLazyChildren = !(\n                    cur.children && cur.children.length\n                  )\n                }\n                innerTreeRowData.loading = cur.loading\n              }\n            }\n            i++\n            tmp.push(rowRender(node, $index + i, innerTreeRowData))\n            if (cur) {\n              const nodes =\n                lazyTreeNodeMap.value[childKey] ||\n                node[childrenColumnName.value]\n              traverse(nodes, cur)\n            }\n          })\n        }\n        // 对于 root 节点,display 一定为 true\n        cur.display = true\n        const nodes =\n          lazyTreeNodeMap.value[key] || row[childrenColumnName.value]\n        traverse(nodes, cur)\n      }\n      return tmp\n    } else {\n      return rowRender(row, $index, undefined)\n    }\n  }\n\n  return {\n    wrappedRowRender,\n    tooltipContent,\n    tooltipTrigger,\n  }\n}\n\nexport default useRender\n", "// @ts-nocheck\nimport type { PropType } from 'vue'\nimport type { Store } from '../store'\nimport type {\n  ColumnCls,\n  ColumnStyle,\n  DefaultRow,\n  Table,\n} from '../table/defaults'\nimport type { TableOverflowTooltipOptions } from '../util'\n\ninterface TableBodyProps<T> {\n  store: Store<T>\n  stripe?: boolean\n  context: Table<T>\n  rowClassName: ColumnCls<T>\n  rowStyle: ColumnStyle<T>\n  fixed: string\n  highlight: boolean\n  tooltipEffect?: string\n  tooltipOptions?: TableOverflowTooltipOptions\n}\n\nconst defaultProps = {\n  store: {\n    required: true,\n    type: Object as PropType<TableBodyProps<DefaultRow>['store']>,\n  },\n  stripe: Boolean,\n  tooltipEffect: String,\n  tooltipOptions: {\n    type: Object as PropType<TableBodyProps<DefaultRow>['tooltipOptions']>,\n  },\n  context: {\n    default: () => ({}),\n    type: Object as PropType<TableBodyProps<DefaultRow>['context']>,\n  },\n  rowClassName: [String, Function] as PropType<\n    TableBodyProps<DefaultRow>['rowClassName']\n  >,\n  rowStyle: [Object, Function] as PropType<\n    TableBodyProps<DefaultRow>['rowStyle']\n  >,\n  fixed: {\n    type: String,\n    default: '',\n  },\n  highlight: Boolean,\n}\n\nexport { TableBodyProps }\nexport default defaultProps\n", "// @ts-nocheck\nimport {\n  defineComponent,\n  getCurrentInstance,\n  h,\n  inject,\n  onUnmounted,\n  watch,\n} from 'vue'\nimport { addClass, isClient, rAF, removeClass } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport useLayoutObserver from '../layout-observer'\nimport { removePopper } from '../util'\nimport { TABLE_INJECTION_KEY } from '../tokens'\nimport useRender from './render-helper'\nimport defaultProps from './defaults'\n\nimport type { VNode } from 'vue'\n\nexport default defineComponent({\n  name: 'ElTableBody',\n  props: defaultProps,\n  setup(props) {\n    const instance = getCurrentInstance()\n    const parent = inject(TABLE_INJECTION_KEY)\n    const ns = useNamespace('table')\n    const { wrappedRowRender, tooltipContent, tooltipTrigger } =\n      useRender(props)\n    const { onColumnsChange, onScrollableChange } = useLayoutObserver(parent!)\n\n    const hoveredCellList = []\n    watch(props.store.states.hoverRow, (newVal: any, oldVal: any) => {\n      const el = instance?.vnode.el as HTMLElement\n      const rows = Array.from(el?.children || []).filter((e) =>\n        e?.classList.contains(`${ns.e('row')}`)\n      )\n\n      // hover rowSpan > 1 choose the whole row\n      let rowNum = newVal\n      const childNodes = rows[rowNum]?.childNodes\n      if (childNodes?.length) {\n        let control = 0\n        const indexes = Array.from(childNodes).reduce((acc, item, index) => {\n          // drop colsSpan\n          if (childNodes[index]?.colSpan > 1) {\n            control = childNodes[index]?.colSpan\n          }\n          if (item.nodeName !== 'TD' && control === 0) {\n            acc.push(index)\n          }\n          control > 0 && control--\n          return acc\n        }, [])\n\n        indexes.forEach((rowIndex) => {\n          rowNum = newVal\n          while (rowNum > 0) {\n            // find from previous\n            const preChildNodes = rows[rowNum - 1]?.childNodes\n            if (\n              preChildNodes[rowIndex] &&\n              preChildNodes[rowIndex].nodeName === 'TD' &&\n              preChildNodes[rowIndex].rowSpan > 1\n            ) {\n              addClass(preChildNodes[rowIndex], 'hover-cell')\n              hoveredCellList.push(preChildNodes[rowIndex])\n              break\n            }\n            rowNum--\n          }\n        })\n      } else {\n        hoveredCellList.forEach((item) => removeClass(item, 'hover-cell'))\n        hoveredCellList.length = 0\n      }\n      if (!props.store.states.isComplex.value || !isClient) return\n\n      rAF(() => {\n        // just get first level children; fix #9723\n        const oldRow = rows[oldVal]\n        const newRow = rows[newVal]\n        // when there is fixed row, hover on rowSpan > 1 should not clear the class\n        if (oldRow && !oldRow.classList.contains('hover-fixed-row')) {\n          removeClass(oldRow, 'hover-row')\n        }\n        if (newRow) {\n          addClass(newRow, 'hover-row')\n        }\n      })\n    })\n\n    onUnmounted(() => {\n      removePopper?.()\n    })\n\n    return {\n      ns,\n      onColumnsChange,\n      onScrollableChange,\n      wrappedRowRender,\n      tooltipContent,\n      tooltipTrigger,\n    }\n  },\n  render() {\n    const { wrappedRowRender, store } = this\n    const data = store.states.data.value || []\n    // Why do we need tabIndex: -1 ?\n    // If you set the tabindex attribute on an element ,\n    // then its child content cannot be scrolled with the arrow keys,\n    // unless you set tabindex on the content too\n    // See https://github.com/facebook/react/issues/25462#issuecomment-1274775248 or https://developer.mozilla.org/zh-CN/docs/Web/HTML/Global_attributes/tabindex\n    return h('tbody', { tabIndex: -1 }, [\n      data.reduce((acc: VNode[], row) => {\n        return acc.concat(wrappedRowRender(row, acc.length))\n      }, []),\n    ])\n  },\n})\n", "import { computed, inject } from 'vue'\nimport { TABLE_INJECTION_KEY } from '../tokens'\n\nfunction useMapState() {\n  const table = inject(TABLE_INJECTION_KEY)\n  const store = table?.store\n  const leftFixedLeafCount = computed(() => {\n    return store.states.fixedLeafColumnsLength.value\n  })\n  const rightFixedLeafCount = computed(() => {\n    return store.states.rightFixedColumns.value.length\n  })\n  const columnsCount = computed(() => {\n    return store.states.columns.value.length\n  })\n  const leftFixedCount = computed(() => {\n    return store.states.fixedColumns.value.length\n  })\n  const rightFixedCount = computed(() => {\n    return store.states.rightFixedColumns.value.length\n  })\n\n  return {\n    leftFixedLeafCount,\n    rightFixedLeafCount,\n    columnsCount,\n    leftFixedCount,\n    rightFixedCount,\n    columns: store.states.columns,\n  }\n}\n\nexport default useMapState\n", "import { useNamespace } from '@element-plus/hooks'\nimport {\n  ensurePosition,\n  getFixedColumnOffset,\n  getFixedColumnsClass,\n} from '../util'\nimport useMapState from './mapState-helper'\nimport type { TableColumnCtx } from '../table-column/defaults'\nimport type { TableFooter } from '.'\n\nfunction useStyle<T>(props: TableFooter<T>) {\n  const { columns } = useMapState()\n  const ns = useNamespace('table')\n\n  const getCellClasses = (columns: TableColumnCtx<T>[], cellIndex: number) => {\n    const column = columns[cellIndex]\n    const classes = [\n      ns.e('cell'),\n      column.id,\n      column.align,\n      column.labelClassName,\n      ...getFixedColumnsClass(ns.b(), cellIndex, column.fixed, props.store),\n    ]\n    if (column.className) {\n      classes.push(column.className)\n    }\n    if (!column.children) {\n      classes.push(ns.is('leaf'))\n    }\n    return classes\n  }\n\n  const getCellStyles = (column: TableColumnCtx<T>, cellIndex: number) => {\n    const fixedStyle = getFixedColumnOffset(\n      cellIndex,\n      column.fixed,\n      props.store\n    )\n    ensurePosition(fixedStyle, 'left')\n    ensurePosition(fixedStyle, 'right')\n    return fixedStyle\n  }\n\n  return {\n    getCellClasses,\n    getCellStyles,\n    columns,\n  }\n}\n\nexport default useStyle\n", "// @ts-nocheck\nimport { defineComponent, h } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport useStyle from './style-helper'\nimport type { Store } from '../store'\n\nimport type { PropType } from 'vue'\nimport type { DefaultRow, Sort, SummaryMethod } from '../table/defaults'\nexport interface TableFooter<T> {\n  fixed: string\n  store: Store<T>\n  summaryMethod: SummaryMethod<T>\n  sumText: string\n  border: boolean\n  defaultSort: Sort\n}\n\nexport default defineComponent({\n  name: 'ElTableFooter',\n\n  props: {\n    fixed: {\n      type: String,\n      default: '',\n    },\n    store: {\n      required: true,\n      type: Object as PropType<TableFooter<DefaultRow>['store']>,\n    },\n    summaryMethod: Function as PropType<\n      TableFooter<DefaultRow>['summaryMethod']\n    >,\n    sumText: String,\n    border: Boolean,\n    defaultSort: {\n      type: Object as PropType<TableFooter<DefaultRow>['defaultSort']>,\n      default: () => {\n        return {\n          prop: '',\n          order: '',\n        }\n      },\n    },\n  },\n  setup(props) {\n    const { getCellClasses, getCellStyles, columns } = useStyle(\n      props as TableFooter<DefaultRow>\n    )\n    const ns = useNamespace('table')\n    return {\n      ns,\n      getCellClasses,\n      getCellStyles,\n      columns,\n    }\n  },\n  render() {\n    const { columns, getCellStyles, getCellClasses, summaryMethod, sumText } =\n      this\n    const data = this.store.states.data.value\n    let sums = []\n    if (summaryMethod) {\n      sums = summaryMethod({\n        columns,\n        data,\n      })\n    } else {\n      columns.forEach((column, index) => {\n        if (index === 0) {\n          sums[index] = sumText\n          return\n        }\n        const values = data.map((item) => Number(item[column.property]))\n        const precisions = []\n        let notNumber = true\n        values.forEach((value) => {\n          if (!Number.isNaN(+value)) {\n            notNumber = false\n            const decimal = `${value}`.split('.')[1]\n            precisions.push(decimal ? decimal.length : 0)\n          }\n        })\n        const precision = Math.max.apply(null, precisions)\n        if (!notNumber) {\n          sums[index] = values.reduce((prev, curr) => {\n            const value = Number(curr)\n            if (!Number.isNaN(+value)) {\n              return Number.parseFloat(\n                (prev + curr).toFixed(Math.min(precision, 20))\n              )\n            } else {\n              return prev\n            }\n          }, 0)\n        } else {\n          sums[index] = ''\n        }\n      })\n    }\n    return h(\n      h('tfoot', [\n        h('tr', {}, [\n          ...columns.map((column, cellIndex) =>\n            h(\n              'td',\n              {\n                key: cellIndex,\n                colspan: column.colSpan,\n                rowspan: column.rowSpan,\n                class: getCellClasses(columns, cellIndex),\n                style: getCellStyles(column, cellIndex),\n              },\n              [\n                h(\n                  'div',\n                  {\n                    class: ['cell', column.labelClassName],\n                  },\n                  [sums[cellIndex]]\n                ),\n              ]\n            )\n          ),\n        ]),\n      ])\n    )\n  },\n})\n", "// @ts-nocheck\nimport type { Store } from '../store'\n\nfunction useUtils<T>(store: Store<T>) {\n  const setCurrentRow = (row: T) => {\n    store.commit('setCurrentRow', row)\n  }\n  const getSelectionRows = () => {\n    return store.getSelectionRows()\n  }\n  const toggleRowSelection = (\n    row: T,\n    selected?: boolean,\n    ignoreSelectable = true\n  ) => {\n    store.toggleRowSelection(row, selected, false, ignoreSelectable)\n    store.updateAllSelected()\n  }\n  const clearSelection = () => {\n    store.clearSelection()\n  }\n  const clearFilter = (columnKeys?: string[]) => {\n    store.clearFilter(columnKeys)\n  }\n  const toggleAllSelection = () => {\n    store.commit('toggleAllSelection')\n  }\n  const toggleRowExpansion = (row: T, expanded?: boolean) => {\n    store.toggleRowExpansionAdapter(row, expanded)\n  }\n  const clearSort = () => {\n    store.clearSort()\n  }\n  const sort = (prop: string, order: string) => {\n    store.commit('sort', { prop, order })\n  }\n  const updateKeyChildren = (key: string, data: T[]) => {\n    store.updateKeyChildren(key, data)\n  }\n\n  return {\n    setCurrentRow,\n    getSelectionRows,\n    toggleRowSelection,\n    clearSelection,\n    clearFilter,\n    toggleAllSelection,\n    toggleRowExpansion,\n    clearSort,\n    sort,\n    updateKeyChildren,\n  }\n}\n\nexport default useUtils\n", "// @ts-nocheck\nimport {\n  computed,\n  nextTick,\n  onMounted,\n  ref,\n  unref,\n  watch,\n  watchEffect,\n} from 'vue'\nimport { useEventListener, useResizeObserver } from '@vueuse/core'\nimport { useFormSize } from '@element-plus/components/form'\n\nimport type { Table, TableProps } from './defaults'\nimport type { Store } from '../store'\nimport type TableLayout from '../table-layout'\nimport type { TableColumnCtx } from '../table-column/defaults'\n\nfunction useStyle<T>(\n  props: TableProps<T>,\n  layout: TableLayout<T>,\n  store: Store<T>,\n  table: Table<T>\n) {\n  const isHidden = ref(false)\n  const renderExpanded = ref(null)\n  const resizeProxyVisible = ref(false)\n  const setDragVisible = (visible: boolean) => {\n    resizeProxyVisible.value = visible\n  }\n  const resizeState = ref<{\n    width: null | number\n    height: null | number\n    headerHeight: null | number\n  }>({\n    width: null,\n    height: null,\n    headerHeight: null,\n  })\n  const isGroup = ref(false)\n  const scrollbarViewStyle = {\n    display: 'inline-block',\n    verticalAlign: 'middle',\n  }\n  const tableWidth = ref()\n  const tableScrollHeight = ref(0)\n  const bodyScrollHeight = ref(0)\n  const headerScrollHeight = ref(0)\n  const footerScrollHeight = ref(0)\n  const appendScrollHeight = ref(0)\n\n  watchEffect(() => {\n    layout.setHeight(props.height)\n  })\n  watchEffect(() => {\n    layout.setMaxHeight(props.maxHeight)\n  })\n  watch(\n    () => [props.currentRowKey, store.states.rowKey],\n    ([currentRowKey, rowKey]) => {\n      if (!unref(rowKey) || !unref(currentRowKey)) return\n      store.setCurrentRowKey(`${currentRowKey}`)\n    },\n    {\n      immediate: true,\n    }\n  )\n  watch(\n    () => props.data,\n    (data) => {\n      table.store.commit('setData', data)\n    },\n    {\n      immediate: true,\n      deep: true,\n    }\n  )\n  watchEffect(() => {\n    if (props.expandRowKeys) {\n      store.setExpandRowKeysAdapter(props.expandRowKeys)\n    }\n  })\n\n  const handleMouseLeave = () => {\n    table.store.commit('setHoverRow', null)\n    if (table.hoverState) table.hoverState = null\n  }\n\n  const handleHeaderFooterMousewheel = (event, data) => {\n    const { pixelX, pixelY } = data\n    if (Math.abs(pixelX) >= Math.abs(pixelY)) {\n      table.refs.bodyWrapper.scrollLeft += data.pixelX / 5\n    }\n  }\n\n  const shouldUpdateHeight = computed(() => {\n    return (\n      props.height ||\n      props.maxHeight ||\n      store.states.fixedColumns.value.length > 0 ||\n      store.states.rightFixedColumns.value.length > 0\n    )\n  })\n\n  const tableBodyStyles = computed(() => {\n    return {\n      width: layout.bodyWidth.value ? `${layout.bodyWidth.value}px` : '',\n    }\n  })\n\n  const doLayout = () => {\n    if (shouldUpdateHeight.value) {\n      layout.updateElsHeight()\n    }\n    layout.updateColumnsWidth()\n    requestAnimationFrame(syncPosition)\n  }\n  onMounted(async () => {\n    await nextTick()\n    store.updateColumns()\n    bindEvents()\n    requestAnimationFrame(doLayout)\n\n    const el: HTMLElement = table.vnode.el as HTMLElement\n    const tableHeader: HTMLElement = table.refs.headerWrapper\n    if (props.flexible && el && el.parentElement) {\n      // Automatic minimum size of flex-items\n      // Ensure that the main axis does not follow the width of the items\n      el.parentElement.style.minWidth = '0'\n    }\n\n    resizeState.value = {\n      width: (tableWidth.value = el.offsetWidth),\n      height: el.offsetHeight,\n      headerHeight:\n        props.showHeader && tableHeader ? tableHeader.offsetHeight : null,\n    }\n\n    // init filters\n    store.states.columns.value.forEach((column: TableColumnCtx<T>) => {\n      if (column.filteredValue && column.filteredValue.length) {\n        table.store.commit('filterChange', {\n          column,\n          values: column.filteredValue,\n          silent: true,\n        })\n      }\n    })\n    table.$ready = true\n  })\n  const setScrollClassByEl = (el: HTMLElement, className: string) => {\n    if (!el) return\n    const classList = Array.from(el.classList).filter(\n      (item) => !item.startsWith('is-scrolling-')\n    )\n    classList.push(layout.scrollX.value ? className : 'is-scrolling-none')\n    el.className = classList.join(' ')\n  }\n  const setScrollClass = (className: string) => {\n    const { tableWrapper } = table.refs\n    setScrollClassByEl(tableWrapper, className)\n  }\n  const hasScrollClass = (className: string) => {\n    const { tableWrapper } = table.refs\n    return !!(tableWrapper && tableWrapper.classList.contains(className))\n  }\n  const syncPosition = function () {\n    if (!table.refs.scrollBarRef) return\n    if (!layout.scrollX.value) {\n      const scrollingNoneClass = 'is-scrolling-none'\n      if (!hasScrollClass(scrollingNoneClass)) {\n        setScrollClass(scrollingNoneClass)\n      }\n      return\n    }\n    const scrollContainer = table.refs.scrollBarRef.wrapRef\n    if (!scrollContainer) return\n    const { scrollLeft, offsetWidth, scrollWidth } = scrollContainer\n    const { headerWrapper, footerWrapper } = table.refs\n    if (headerWrapper) headerWrapper.scrollLeft = scrollLeft\n    if (footerWrapper) footerWrapper.scrollLeft = scrollLeft\n    const maxScrollLeftPosition = scrollWidth - offsetWidth - 1\n    if (scrollLeft >= maxScrollLeftPosition) {\n      setScrollClass('is-scrolling-right')\n    } else if (scrollLeft === 0) {\n      setScrollClass('is-scrolling-left')\n    } else {\n      setScrollClass('is-scrolling-middle')\n    }\n  }\n\n  const bindEvents = () => {\n    if (!table.refs.scrollBarRef) return\n    if (table.refs.scrollBarRef.wrapRef) {\n      useEventListener(\n        table.refs.scrollBarRef.wrapRef,\n        'scroll',\n        syncPosition,\n        {\n          passive: true,\n        }\n      )\n    }\n    if (props.fit) {\n      useResizeObserver(table.vnode.el as HTMLElement, resizeListener)\n    } else {\n      useEventListener(window, 'resize', resizeListener)\n    }\n\n    useResizeObserver(table.refs.bodyWrapper, () => {\n      resizeListener()\n      table.refs?.scrollBarRef?.update()\n    })\n  }\n  const resizeListener = () => {\n    const el = table.vnode.el\n    if (!table.$ready || !el) return\n\n    let shouldUpdateLayout = false\n    const {\n      width: oldWidth,\n      height: oldHeight,\n      headerHeight: oldHeaderHeight,\n    } = resizeState.value\n\n    const width = (tableWidth.value = el.offsetWidth)\n    if (oldWidth !== width) {\n      shouldUpdateLayout = true\n    }\n\n    const height = el.offsetHeight\n    if ((props.height || shouldUpdateHeight.value) && oldHeight !== height) {\n      shouldUpdateLayout = true\n    }\n\n    const tableHeader: HTMLElement =\n      props.tableLayout === 'fixed'\n        ? table.refs.headerWrapper\n        : table.refs.tableHeaderRef?.$el\n    if (props.showHeader && tableHeader?.offsetHeight !== oldHeaderHeight) {\n      shouldUpdateLayout = true\n    }\n\n    tableScrollHeight.value = table.refs.tableWrapper?.scrollHeight || 0\n    headerScrollHeight.value = tableHeader?.scrollHeight || 0\n    footerScrollHeight.value = table.refs.footerWrapper?.offsetHeight || 0\n    appendScrollHeight.value = table.refs.appendWrapper?.offsetHeight || 0\n    bodyScrollHeight.value =\n      tableScrollHeight.value -\n      headerScrollHeight.value -\n      footerScrollHeight.value -\n      appendScrollHeight.value\n\n    if (shouldUpdateLayout) {\n      resizeState.value = {\n        width,\n        height,\n        headerHeight: (props.showHeader && tableHeader?.offsetHeight) || 0,\n      }\n      doLayout()\n    }\n  }\n  const tableSize = useFormSize()\n  const bodyWidth = computed(() => {\n    const { bodyWidth: bodyWidth_, scrollY, gutterWidth } = layout\n    return bodyWidth_.value\n      ? `${(bodyWidth_.value as number) - (scrollY.value ? gutterWidth : 0)}px`\n      : ''\n  })\n\n  const tableLayout = computed(() => {\n    if (props.maxHeight) return 'fixed'\n    return props.tableLayout\n  })\n\n  const emptyBlockStyle = computed(() => {\n    if (props.data && props.data.length) return null\n    let height = '100%'\n    if (props.height && bodyScrollHeight.value) {\n      height = `${bodyScrollHeight.value}px`\n    }\n    const width = tableWidth.value\n    return {\n      width: width ? `${width}px` : '',\n      height,\n    }\n  })\n\n  const tableInnerStyle = computed(() => {\n    if (props.height) {\n      return {\n        height: !Number.isNaN(Number(props.height))\n          ? `${props.height}px`\n          : props.height,\n      }\n    }\n    if (props.maxHeight) {\n      return {\n        maxHeight: !Number.isNaN(Number(props.maxHeight))\n          ? `${props.maxHeight}px`\n          : props.maxHeight,\n      }\n    }\n    return {}\n  })\n\n  const scrollbarStyle = computed(() => {\n    if (props.height) {\n      return {\n        height: '100%',\n      }\n    }\n    if (props.maxHeight) {\n      if (!Number.isNaN(Number(props.maxHeight))) {\n        return {\n          maxHeight: `${\n            props.maxHeight -\n            headerScrollHeight.value -\n            footerScrollHeight.value\n          }px`,\n        }\n      } else {\n        return {\n          maxHeight: `calc(${props.maxHeight} - ${\n            headerScrollHeight.value + footerScrollHeight.value\n          }px)`,\n        }\n      }\n    }\n\n    return {}\n  })\n\n  /**\n   * fix layout\n   */\n  const handleFixedMousewheel = (event, data) => {\n    const bodyWrapper = table.refs.bodyWrapper\n    if (Math.abs(data.spinY) > 0) {\n      const currentScrollTop = bodyWrapper.scrollTop\n      if (data.pixelY < 0 && currentScrollTop !== 0) {\n        event.preventDefault()\n      }\n      if (\n        data.pixelY > 0 &&\n        bodyWrapper.scrollHeight - bodyWrapper.clientHeight > currentScrollTop\n      ) {\n        event.preventDefault()\n      }\n      bodyWrapper.scrollTop += Math.ceil(data.pixelY / 5)\n    } else {\n      bodyWrapper.scrollLeft += Math.ceil(data.pixelX / 5)\n    }\n  }\n\n  return {\n    isHidden,\n    renderExpanded,\n    setDragVisible,\n    isGroup,\n    handleMouseLeave,\n    handleHeaderFooterMousewheel,\n    tableSize,\n    emptyBlockStyle,\n    handleFixedMousewheel,\n    resizeProxyVisible,\n    bodyWidth,\n    resizeState,\n    doLayout,\n    tableBodyStyles,\n    tableLayout,\n    scrollbarViewStyle,\n    tableInnerStyle,\n    scrollbarStyle,\n  }\n}\n\nexport default useStyle\n", "import { onMounted, onUnmounted, ref } from 'vue'\nimport type { Table } from './defaults'\n\nexport default function useKeyRender(table: Table<[]>) {\n  const observer = ref<MutationObserver>()\n\n  const initWatchDom = () => {\n    const el = table.vnode.el\n    const columnsWrapper = (el as HTMLElement).querySelector('.hidden-columns')\n    const config = { childList: true, subtree: true }\n    const updateOrderFns = table.store.states.updateOrderFns\n    observer.value = new MutationObserver(() => {\n      updateOrderFns.forEach((fn: () => void) => fn())\n    })\n\n    observer.value.observe(columnsWrapper!, config)\n  }\n\n  onMounted(() => {\n    // fix https://github.com/element-plus/element-plus/issues/8528\n    initWatchDom()\n  })\n\n  onUnmounted(() => {\n    observer.value?.disconnect()\n  })\n}\n", "// @ts-nocheck\nimport { useSizeProp } from '@element-plus/hooks'\nimport type {\n  CSSProperties,\n  ComponentInternalInstance,\n  PropType,\n  Ref,\n  VNode,\n} from 'vue'\nimport type { ComponentSize } from '@element-plus/constants'\nimport type { Nullable } from '@element-plus/utils'\nimport type { Store } from '../store'\nimport type { TableColumnCtx } from '../table-column/defaults'\nimport type TableLayout from '../table-layout'\nimport type { TableOverflowTooltipOptions } from '../util'\n\nexport type DefaultRow = any\n\ninterface TableRefs {\n  tableWrapper: HTMLElement\n  headerWrapper: HTMLElement\n  footerWrapper: HTMLElement\n  fixedBodyWrapper: HTMLElement\n  rightFixedBodyWrapper: HTMLElement\n  bodyWrapper: HTMLElement\n  appendWrapper: HTMLElement\n  [key: string]: any\n}\n\ninterface TableState {\n  isGroup: Ref<boolean>\n  resizeState: Ref<{\n    width: any\n    height: any\n  }>\n  doLayout: () => void\n  debouncedUpdateLayout: () => void\n}\n\ninterface TreeProps {\n  hasChildren?: string\n  children?: string\n  checkStrictly?: boolean\n}\n\ntype HoverState<T> = Nullable<{\n  cell: HTMLElement\n  column: TableColumnCtx<T>\n  row: T\n}>\n\ntype RIS<T> = { row: T; $index: number; store: Store<T>; expanded: boolean }\n\ntype RenderExpanded<T> = ({\n  row,\n  $index,\n  store,\n  expanded: boolean,\n}: RIS<T>) => VNode\n\ntype SummaryMethod<T> = (data: {\n  columns: TableColumnCtx<T>[]\n  data: T[]\n}) => (string | VNode)[]\n\ninterface Table<T> extends ComponentInternalInstance {\n  $ready: boolean\n  hoverState?: HoverState<T>\n  renderExpanded: RenderExpanded<T>\n  store: Store<T>\n  layout: TableLayout<T>\n  refs: TableRefs\n  tableId: string\n  state: TableState\n}\n\ntype ColumnCls<T> = string | ((data: { row: T; rowIndex: number }) => string)\ntype ColumnStyle<T> =\n  | CSSProperties\n  | ((data: { row: T; rowIndex: number }) => CSSProperties)\ntype CellCls<T> =\n  | string\n  | ((data: {\n      row: T\n      rowIndex: number\n      column: TableColumnCtx<T>\n      columnIndex: number\n    }) => string)\ntype CellStyle<T> =\n  | CSSProperties\n  | ((data: {\n      row: T\n      rowIndex: number\n      column: TableColumnCtx<T>\n      columnIndex: number\n    }) => CSSProperties)\ntype Layout = 'fixed' | 'auto'\ninterface TableProps<T> {\n  data: T[]\n  size?: ComponentSize\n  width?: string | number\n  height?: string | number\n  maxHeight?: string | number\n  fit?: boolean\n  stripe?: boolean\n  border?: boolean\n  rowKey?: string | ((row: T) => string)\n  context?: Table<T>\n  showHeader?: boolean\n  showSummary?: boolean\n  sumText?: string\n  summaryMethod?: SummaryMethod<T>\n  rowClassName?: ColumnCls<T>\n  rowStyle?: ColumnStyle<T>\n  cellClassName?: CellCls<T>\n  cellStyle?: CellStyle<T>\n  headerRowClassName?: ColumnCls<T>\n  headerRowStyle?: ColumnStyle<T>\n  headerCellClassName?: CellCls<T>\n  headerCellStyle?: CellStyle<T>\n  highlightCurrentRow?: boolean\n  currentRowKey?: string | number\n  emptyText?: string\n  expandRowKeys?: string[]\n  defaultExpandAll?: boolean\n  defaultSort?: Sort\n  tooltipEffect?: string\n  tooltipOptions?: TableOverflowTooltipOptions\n  spanMethod?: (data: {\n    row: T\n    rowIndex: number\n    column: TableColumnCtx<T>\n    columnIndex: number\n  }) =>\n    | number[]\n    | {\n        rowspan: number\n        colspan: number\n      }\n    | undefined\n  selectOnIndeterminate?: boolean\n  indent?: number\n  treeProps?: TreeProps\n  lazy?: boolean\n  load?: (row: T, treeNode: TreeNode, resolve: (data: T[]) => void) => void\n  className?: string\n  style?: CSSProperties\n  tableLayout?: Layout\n  scrollbarAlwaysOn?: boolean\n  flexible?: boolean\n  showOverflowTooltip?: boolean | TableOverflowTooltipOptions\n  appendFilterPanelTo?: string\n  scrollbarTabindex?: number | string\n}\n\ninterface Sort {\n  prop: string\n  order: 'ascending' | 'descending'\n  init?: any\n  silent?: any\n}\n\ninterface Filter<T> {\n  column: TableColumnCtx<T>\n  values: string[]\n  silent: any\n}\n\ninterface TreeNode {\n  expanded?: boolean\n  loading?: boolean\n  noLazyChildren?: boolean\n  indent?: number\n  level?: number\n  display?: boolean\n}\n\ninterface RenderRowData<T> {\n  store: Store<T>\n  _self: Table<T>\n  column: TableColumnCtx<T>\n  row: T\n  $index: number\n  treeNode?: TreeNode\n  expanded: boolean\n}\n\nexport default {\n  /**\n   * @description table data\n   */\n  data: {\n    type: Array as PropType<DefaultRow[]>,\n    default: () => [],\n  },\n  /**\n   * @description size of Table\n   */\n  size: useSizeProp,\n  width: [String, Number],\n  /**\n   * @description table's height. By default it has an `auto` height. If its value is a number, the height is measured in pixels; if its value is a string, the value will be assigned to element's style.height, the height is affected by external styles\n   */\n  height: [String, Number],\n  /**\n   * @description table's max-height. The legal value is a number or the height in px\n   */\n  maxHeight: [String, Number],\n  /**\n   * @description whether width of column automatically fits its container\n   */\n  fit: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether Table is striped\n   */\n  stripe: Boolean,\n  /**\n   * @description whether Table has vertical border\n   */\n  border: Boolean,\n  /**\n   * @description key of row data, used for optimizing rendering. Required if `reserve-selection` is on or display tree data. When its type is String, multi-level access is supported, e.g. `user.info.id`, but `user.info[0].id` is not supported, in which case `Function` should be used\n   */\n  rowKey: [String, Function] as PropType<TableProps<DefaultRow>['rowKey']>,\n  /**\n   * @description whether Table header is visible\n   */\n  showHeader: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether to display a summary row\n   */\n  showSummary: Boolean,\n  /**\n   * @description displayed text for the first column of summary row\n   */\n  sumText: String,\n  /**\n   * @description custom summary method\n   */\n  summaryMethod: Function as PropType<TableProps<DefaultRow>['summaryMethod']>,\n  /**\n   * @description function that returns custom class names for a row, or a string assigning class names for every row\n   */\n  rowClassName: [String, Function] as PropType<\n    TableProps<DefaultRow>['rowClassName']\n  >,\n  /**\n   * @description function that returns custom style for a row, or an object assigning custom style for every row\n   */\n  rowStyle: [Object, Function] as PropType<TableProps<DefaultRow>['rowStyle']>,\n  /**\n   * @description function that returns custom class names for a cell, or a string assigning class names for every cell\n   */\n  cellClassName: [String, Function] as PropType<\n    TableProps<DefaultRow>['cellClassName']\n  >,\n  /**\n   * @description function that returns custom style for a cell, or an object assigning custom style for every cell\n   */\n  cellStyle: [Object, Function] as PropType<\n    TableProps<DefaultRow>['cellStyle']\n  >,\n  /**\n   * @description function that returns custom class names for a row in table header, or a string assigning class names for every row in table header\n   */\n  headerRowClassName: [String, Function] as PropType<\n    TableProps<DefaultRow>['headerRowClassName']\n  >,\n  /**\n   * @description function that returns custom style for a row in table header, or an object assigning custom style for every row in table header\n   */\n  headerRowStyle: [Object, Function] as PropType<\n    TableProps<DefaultRow>['headerRowStyle']\n  >,\n  /**\n   * @description function that returns custom class names for a cell in table header, or a string assigning class names for every cell in table header\n   */\n  headerCellClassName: [String, Function] as PropType<\n    TableProps<DefaultRow>['headerCellClassName']\n  >,\n  /**\n   * @description function that returns custom style for a cell in table header, or an object assigning custom style for every cell in table header\n   */\n  headerCellStyle: [Object, Function] as PropType<\n    TableProps<DefaultRow>['headerCellStyle']\n  >,\n  /**\n   * @description whether current row is highlighted\n   */\n  highlightCurrentRow: Boolean,\n  /**\n   * @description key of current row, a set only prop\n   */\n  currentRowKey: [String, Number],\n  /**\n   * @description displayed text when data is empty. You can customize this area with `#empty`\n   */\n  emptyText: String,\n  /**\n   * @description set expanded rows by this prop, prop's value is the keys of expand rows, you should set row-key before using this prop\n   */\n  expandRowKeys: Array as PropType<TableProps<DefaultRow>['expandRowKeys']>,\n  /**\n   * @description whether expand all rows by default, works when the table has a column type=\"expand\" or contains tree structure data\n   */\n  defaultExpandAll: Boolean,\n  /**\n   * @description set the default sort column and order. property `prop` is used to set default sort column, property `order` is used to set default sort order\n   */\n  defaultSort: Object as PropType<TableProps<DefaultRow>['defaultSort']>,\n  /**\n   * @description the `effect` of the overflow tooltip\n   */\n  tooltipEffect: String,\n  /**\n   * @description the options for the overflow tooltip, [see the following tooltip component](tooltip.html#attributes)\n   */\n  tooltipOptions: Object as PropType<TableProps<DefaultRow>['tooltipOptions']>,\n  /**\n   * @description method that returns rowspan and colspan\n   */\n  spanMethod: Function as PropType<TableProps<DefaultRow>['spanMethod']>,\n  /**\n   * @description controls the behavior of master checkbox in multi-select tables when only some rows are selected (but not all). If true, all rows will be selected, else deselected\n   */\n  selectOnIndeterminate: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description horizontal indentation of tree data\n   */\n  indent: {\n    type: Number,\n    default: 16,\n  },\n  /**\n   * @description configuration for rendering nested data\n   */\n  treeProps: {\n    type: Object as PropType<TableProps<DefaultRow>['treeProps']>,\n    default: () => {\n      return {\n        hasChildren: 'hasChildren',\n        children: 'children',\n        checkStrictly: false,\n      }\n    },\n  },\n  /**\n   * @description whether to lazy loading data\n   */\n  lazy: Boolean,\n  /**\n   * @description method for loading child row data, only works when `lazy` is true\n   */\n  load: Function as PropType<TableProps<DefaultRow>['load']>,\n  style: {\n    type: Object as PropType<CSSProperties>,\n    default: () => ({}),\n  },\n  className: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description sets the algorithm used to lay out table cells, rows, and columns\n   */\n  tableLayout: {\n    type: String as PropType<Layout>,\n    default: 'fixed',\n  },\n  /**\n   * @description always show scrollbar\n   */\n  scrollbarAlwaysOn: Boolean,\n  /**\n   * @description ensure main axis minimum-size doesn't follow the content\n   */\n  flexible: Boolean,\n  /**\n   * @description whether to hide extra content and show them in a tooltip when hovering on the cell.It will affect all the table columns\n   */\n  showOverflowTooltip: [Boolean, Object] as PropType<\n    TableProps<DefaultRow>['showOverflowTooltip']\n  >,\n  appendFilterPanelTo: String,\n  scrollbarTabindex: {\n    type: [Number, String],\n    default: undefined,\n  },\n}\nexport type {\n  SummaryMethod,\n  Table,\n  TableProps,\n  TableRefs,\n  ColumnCls,\n  ColumnStyle,\n  CellCls,\n  CellStyle,\n  TreeNode,\n  RenderRowData,\n  Sort,\n  Filter,\n  TableColumnCtx,\n  TreeProps,\n}\n", "// @ts-nocheck\nimport { h } from 'vue'\nexport function hColgroup(props) {\n  const isAuto = props.tableLayout === 'auto'\n  let columns = props.columns || []\n  if (isAuto) {\n    if (columns.every((column) => column.width === undefined)) {\n      columns = []\n    }\n  }\n  const getPropsData = (column) => {\n    const propsData = {\n      key: `${props.tableLayout}_${column.id}`,\n      style: {},\n      name: undefined,\n    }\n    if (isAuto) {\n      propsData.style = {\n        width: `${column.width}px`,\n      }\n    } else {\n      propsData.name = column.id\n    }\n    return propsData\n  }\n\n  return h(\n    'colgroup',\n    {},\n    columns.map((column) => h('col', getPropsData(column)))\n  )\n}\n\nhColgroup.props = ['columns', 'tableLayout']\n", "import { ref } from 'vue'\nimport { isNumber } from '@element-plus/utils'\n\nexport const useScrollbar = () => {\n  const scrollBarRef = ref()\n\n  const scrollTo = (options: ScrollToOptions | number, yCoord?: number) => {\n    const scrollbar = scrollBarRef.value\n    if (scrollbar) {\n      scrollbar.scrollTo(options, yCoord)\n    }\n  }\n\n  const setScrollPosition = (position: 'Top' | 'Left', offset?: number) => {\n    const scrollbar = scrollBarRef.value\n    if (scrollbar && isNumber(offset) && ['Top', 'Left'].includes(position)) {\n      scrollbar[`setScroll${position}`](offset)\n    }\n  }\n\n  const setScrollTop = (top?: number) => setScrollPosition('Top', top)\n  const setScrollLeft = (left?: number) => setScrollPosition('Left', left)\n\n  return {\n    scrollBarRef,\n    scrollTo,\n    setScrollTop,\n    setScrollLeft,\n  }\n}\n", "<template>\n  <div\n    ref=\"tableWrapper\"\n    :class=\"[\n      {\n        [ns.m('fit')]: fit,\n        [ns.m('striped')]: stripe,\n        [ns.m('border')]: border || isGroup,\n        [ns.m('hidden')]: isHidden,\n        [ns.m('group')]: isGroup,\n        [ns.m('fluid-height')]: maxHeight,\n        [ns.m('scrollable-x')]: layout.scrollX.value,\n        [ns.m('scrollable-y')]: layout.scrollY.value,\n        [ns.m('enable-row-hover')]: !store.states.isComplex.value,\n        [ns.m('enable-row-transition')]:\n          (store.states.data.value || []).length !== 0 &&\n          (store.states.data.value || []).length < 100,\n        'has-footer': showSummary,\n      },\n      ns.m(tableSize),\n      className,\n      ns.b(),\n      ns.m(`layout-${tableLayout}`),\n    ]\"\n    :style=\"style\"\n    :data-prefix=\"ns.namespace.value\"\n    @mouseleave=\"handleMouseLeave\"\n  >\n    <div :class=\"ns.e('inner-wrapper')\" :style=\"tableInnerStyle\">\n      <div ref=\"hiddenColumns\" class=\"hidden-columns\">\n        <slot />\n      </div>\n      <div\n        v-if=\"showHeader && tableLayout === 'fixed'\"\n        ref=\"headerWrapper\"\n        v-mousewheel=\"handleHeaderFooterMousewheel\"\n        :class=\"ns.e('header-wrapper')\"\n      >\n        <table\n          ref=\"tableHeader\"\n          :class=\"ns.e('header')\"\n          :style=\"tableBodyStyles\"\n          border=\"0\"\n          cellpadding=\"0\"\n          cellspacing=\"0\"\n        >\n          <hColgroup\n            :columns=\"store.states.columns.value\"\n            :table-layout=\"tableLayout\"\n          />\n          <table-header\n            ref=\"tableHeaderRef\"\n            :border=\"border\"\n            :default-sort=\"defaultSort\"\n            :store=\"store\"\n            :append-filter-panel-to=\"appendFilterPanelTo\"\n            @set-drag-visible=\"setDragVisible\"\n          />\n        </table>\n      </div>\n      <div ref=\"bodyWrapper\" :class=\"ns.e('body-wrapper')\">\n        <el-scrollbar\n          ref=\"scrollBarRef\"\n          :view-style=\"scrollbarViewStyle\"\n          :wrap-style=\"scrollbarStyle\"\n          :always=\"scrollbarAlwaysOn\"\n          :tabindex=\"scrollbarTabindex\"\n        >\n          <table\n            ref=\"tableBody\"\n            :class=\"ns.e('body')\"\n            cellspacing=\"0\"\n            cellpadding=\"0\"\n            border=\"0\"\n            :style=\"{\n              width: bodyWidth,\n              tableLayout,\n            }\"\n          >\n            <hColgroup\n              :columns=\"store.states.columns.value\"\n              :table-layout=\"tableLayout\"\n            />\n            <table-header\n              v-if=\"showHeader && tableLayout === 'auto'\"\n              ref=\"tableHeaderRef\"\n              :class=\"ns.e('body-header')\"\n              :border=\"border\"\n              :default-sort=\"defaultSort\"\n              :store=\"store\"\n              :append-filter-panel-to=\"appendFilterPanelTo\"\n              @set-drag-visible=\"setDragVisible\"\n            />\n            <table-body\n              :context=\"context\"\n              :highlight=\"highlightCurrentRow\"\n              :row-class-name=\"rowClassName\"\n              :tooltip-effect=\"tooltipEffect\"\n              :tooltip-options=\"tooltipOptions\"\n              :row-style=\"rowStyle\"\n              :store=\"store\"\n              :stripe=\"stripe\"\n            />\n            <table-footer\n              v-if=\"showSummary && tableLayout === 'auto'\"\n              :class=\"ns.e('body-footer')\"\n              :border=\"border\"\n              :default-sort=\"defaultSort\"\n              :store=\"store\"\n              :sum-text=\"computedSumText\"\n              :summary-method=\"summaryMethod\"\n            />\n          </table>\n          <div\n            v-if=\"isEmpty\"\n            ref=\"emptyBlock\"\n            :style=\"emptyBlockStyle\"\n            :class=\"ns.e('empty-block')\"\n          >\n            <span :class=\"ns.e('empty-text')\">\n              <slot name=\"empty\">{{ computedEmptyText }}</slot>\n            </span>\n          </div>\n          <div\n            v-if=\"$slots.append\"\n            ref=\"appendWrapper\"\n            :class=\"ns.e('append-wrapper')\"\n          >\n            <slot name=\"append\" />\n          </div>\n        </el-scrollbar>\n      </div>\n      <div\n        v-if=\"showSummary && tableLayout === 'fixed'\"\n        v-show=\"!isEmpty\"\n        ref=\"footerWrapper\"\n        v-mousewheel=\"handleHeaderFooterMousewheel\"\n        :class=\"ns.e('footer-wrapper')\"\n      >\n        <table\n          :class=\"ns.e('footer')\"\n          cellspacing=\"0\"\n          cellpadding=\"0\"\n          border=\"0\"\n          :style=\"tableBodyStyles\"\n        >\n          <hColgroup\n            :columns=\"store.states.columns.value\"\n            :table-layout=\"tableLayout\"\n          />\n          <table-footer\n            :border=\"border\"\n            :default-sort=\"defaultSort\"\n            :store=\"store\"\n            :sum-text=\"computedSumText\"\n            :summary-method=\"summaryMethod\"\n          />\n        </table>\n      </div>\n      <div v-if=\"border || isGroup\" :class=\"ns.e('border-left-patch')\" />\n    </div>\n    <div\n      v-show=\"resizeProxyVisible\"\n      ref=\"resizeProxy\"\n      :class=\"ns.e('column-resize-proxy')\"\n    />\n  </div>\n</template>\n\n<script lang=\"ts\">\n// @ts-nocheck\nimport { computed, defineComponent, getCurrentInstance, provide } from 'vue'\nimport { debounce } from 'lodash-unified'\nimport { Mousewheel } from '@element-plus/directives'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport { createStore } from './store/helper'\nimport TableLayout from './table-layout'\nimport TableHeader from './table-header'\nimport TableBody from './table-body'\nimport TableFooter from './table-footer'\nimport useUtils from './table/utils-helper'\nimport { convertToRows } from './table-header/utils-helper'\nimport useStyle from './table/style-helper'\nimport useKeyRender from './table/key-render-helper'\nimport defaultProps from './table/defaults'\nimport { TABLE_INJECTION_KEY } from './tokens'\nimport { hColgroup } from './h-helper'\nimport { useScrollbar } from './composables/use-scrollbar'\n\nimport type { Table } from './table/defaults'\n\nlet tableIdSeed = 1\nexport default defineComponent({\n  name: 'ElTable',\n  directives: {\n    Mousewheel,\n  },\n  components: {\n    TableHeader,\n    TableBody,\n    TableFooter,\n    ElScrollbar,\n    hColgroup,\n  },\n  props: defaultProps,\n  emits: [\n    'select',\n    'select-all',\n    'selection-change',\n    'cell-mouse-enter',\n    'cell-mouse-leave',\n    'cell-contextmenu',\n    'cell-click',\n    'cell-dblclick',\n    'row-click',\n    'row-contextmenu',\n    'row-dblclick',\n    'header-click',\n    'header-contextmenu',\n    'sort-change',\n    'filter-change',\n    'current-change',\n    'header-dragend',\n    'expand-change',\n  ],\n  setup(props) {\n    type Row = typeof props.data[number]\n    const { t } = useLocale()\n    const ns = useNamespace('table')\n    const table = getCurrentInstance() as Table<Row>\n    provide(TABLE_INJECTION_KEY, table)\n    const store = createStore<Row>(table, props)\n    table.store = store\n    const layout = new TableLayout<Row>({\n      store: table.store,\n      table,\n      fit: props.fit,\n      showHeader: props.showHeader,\n    })\n    table.layout = layout\n\n    const isEmpty = computed(() => (store.states.data.value || []).length === 0)\n\n    /**\n     * open functions\n     */\n    const {\n      setCurrentRow,\n      getSelectionRows,\n      toggleRowSelection,\n      clearSelection,\n      clearFilter,\n      toggleAllSelection,\n      toggleRowExpansion,\n      clearSort,\n      sort,\n      updateKeyChildren,\n    } = useUtils<Row>(store)\n    const {\n      isHidden,\n      renderExpanded,\n      setDragVisible,\n      isGroup,\n      handleMouseLeave,\n      handleHeaderFooterMousewheel,\n      tableSize,\n      emptyBlockStyle,\n      handleFixedMousewheel,\n      resizeProxyVisible,\n      bodyWidth,\n      resizeState,\n      doLayout,\n      tableBodyStyles,\n      tableLayout,\n      scrollbarViewStyle,\n      tableInnerStyle,\n      scrollbarStyle,\n    } = useStyle<Row>(props, layout, store, table)\n\n    const { scrollBarRef, scrollTo, setScrollLeft, setScrollTop } =\n      useScrollbar()\n\n    const debouncedUpdateLayout = debounce(doLayout, 50)\n\n    const tableId = `${ns.namespace.value}-table_${tableIdSeed++}`\n    table.tableId = tableId\n    table.state = {\n      isGroup,\n      resizeState,\n      doLayout,\n      debouncedUpdateLayout,\n    }\n    const computedSumText = computed(\n      () => props.sumText ?? t('el.table.sumText')\n    )\n\n    const computedEmptyText = computed(() => {\n      return props.emptyText ?? t('el.table.emptyText')\n    })\n\n    const columns = computed(() => {\n      return convertToRows(store.states.originColumns.value)[0]\n    })\n\n    useKeyRender(table)\n\n    return {\n      ns,\n      layout,\n      store,\n      columns,\n      handleHeaderFooterMousewheel,\n      handleMouseLeave,\n      tableId,\n      tableSize,\n      isHidden,\n      isEmpty,\n      renderExpanded,\n      resizeProxyVisible,\n      resizeState,\n      isGroup,\n      bodyWidth,\n      tableBodyStyles,\n      emptyBlockStyle,\n      debouncedUpdateLayout,\n      handleFixedMousewheel,\n      /**\n       * @description used in single selection Table, set a certain row selected. If called without any parameter, it will clear selection\n       */\n      setCurrentRow,\n      /**\n       * @description returns the currently selected rows\n       */\n      getSelectionRows,\n      /**\n       * @description used in multiple selection Table, toggle if a certain row is selected. With the second parameter, you can directly set if this row is selected\n       */\n      toggleRowSelection,\n      /**\n       * @description used in multiple selection Table, clear user selection\n       */\n      clearSelection,\n      /**\n       * @description clear filters of the columns whose `columnKey` are passed in. If no params, clear all filters\n       */\n      clearFilter,\n      /**\n       * @description used in multiple selection Table, toggle select all and deselect all\n       */\n      toggleAllSelection,\n      /**\n       * @description used in expandable Table or tree Table, toggle if a certain row is expanded. With the second parameter, you can directly set if this row is expanded or collapsed\n       */\n      toggleRowExpansion,\n      /**\n       * @description clear sorting, restore data to the original order\n       */\n      clearSort,\n      /**\n       * @description refresh the layout of Table. When the visibility of Table changes, you may need to call this method to get a correct layout\n       */\n      doLayout,\n      /**\n       * @description sort Table manually. Property `prop` is used to set sort column, property `order` is used to set sort order\n       */\n      sort,\n      /**\n       * @description used in lazy Table, must set `rowKey`, update key children\n       */\n      updateKeyChildren,\n      t,\n      setDragVisible,\n      context: table,\n      computedSumText,\n      computedEmptyText,\n      tableLayout,\n      scrollbarViewStyle,\n      tableInnerStyle,\n      scrollbarStyle,\n      scrollBarRef,\n      /**\n       * @description scrolls to a particular set of coordinates\n       */\n      scrollTo,\n      /**\n       * @description set horizontal scroll position\n       */\n      setScrollLeft,\n      /**\n       * @description set vertical scroll position\n       */\n      setScrollTop,\n    }\n  },\n})\n</script>\n", "// @ts-nocheck\nimport { h } from 'vue'\nimport ElCheckbox from '@element-plus/components/checkbox'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { ArrowRight, Loading } from '@element-plus/icons-vue'\nimport { getProp } from '@element-plus/utils'\n\nimport type { VNode } from 'vue'\nimport type { TableColumnCtx } from './table-column/defaults'\nimport type { Store } from './store'\nimport type { TreeNode } from './table/defaults'\n\nconst defaultClassNames = {\n  selection: 'table-column--selection',\n  expand: 'table__expand-column',\n}\n\nexport const cellStarts = {\n  default: {\n    order: '',\n  },\n  selection: {\n    width: 48,\n    minWidth: 48,\n    realWidth: 48,\n    order: '',\n  },\n  expand: {\n    width: 48,\n    minWidth: 48,\n    realWidth: 48,\n    order: '',\n  },\n  index: {\n    width: 48,\n    minWidth: 48,\n    realWidth: 48,\n    order: '',\n  },\n}\n\nexport const getDefaultClassName = (type) => {\n  return defaultClassNames[type] || ''\n}\n\n// 这些选项不应该被覆盖\nexport const cellForced = {\n  selection: {\n    renderHeader<T>({ store, column }: { store: Store<T> }) {\n      function isDisabled() {\n        return store.states.data.value && store.states.data.value.length === 0\n      }\n      return h(ElCheckbox, {\n        disabled: isDisabled(),\n        size: store.states.tableSize.value,\n        indeterminate:\n          store.states.selection.value.length > 0 &&\n          !store.states.isAllSelected.value,\n        'onUpdate:modelValue': store.toggleAllSelection,\n        modelValue: store.states.isAllSelected.value,\n        ariaLabel: column.label,\n      })\n    },\n    renderCell<T>({\n      row,\n      column,\n      store,\n      $index,\n    }: {\n      row: T\n      column: TableColumnCtx<T>\n      store: Store<T>\n      $index: string\n    }) {\n      return h(ElCheckbox, {\n        disabled: column.selectable\n          ? !column.selectable.call(null, row, $index)\n          : false,\n        size: store.states.tableSize.value,\n        onChange: () => {\n          store.commit('rowSelectedChanged', row)\n        },\n        onClick: (event: Event) => event.stopPropagation(),\n        modelValue: store.isSelected(row),\n        ariaLabel: column.label,\n      })\n    },\n    sortable: false,\n    resizable: false,\n  },\n  index: {\n    renderHeader<T>({ column }: { column: TableColumnCtx<T> }) {\n      return column.label || '#'\n    },\n    renderCell<T>({\n      column,\n      $index,\n    }: {\n      column: TableColumnCtx<T>\n      $index: number\n    }) {\n      let i = $index + 1\n      const index = column.index\n\n      if (typeof index === 'number') {\n        i = $index + index\n      } else if (typeof index === 'function') {\n        i = index($index)\n      }\n      return h('div', {}, [i])\n    },\n    sortable: false,\n  },\n  expand: {\n    renderHeader<T>({ column }: { column: TableColumnCtx<T> }) {\n      return column.label || ''\n    },\n    renderCell<T>({\n      row,\n      store,\n      expanded,\n    }: {\n      row: T\n      store: Store<T>\n      expanded: boolean\n    }) {\n      const { ns } = store\n      const classes = [ns.e('expand-icon')]\n      if (expanded) {\n        classes.push(ns.em('expand-icon', 'expanded'))\n      }\n      const callback = function (e: Event) {\n        e.stopPropagation()\n        store.toggleRowExpansion(row)\n      }\n      return h(\n        'div',\n        {\n          class: classes,\n          onClick: callback,\n        },\n        {\n          default: () => {\n            return [\n              h(ElIcon, null, {\n                default: () => {\n                  return [h(ArrowRight)]\n                },\n              }),\n            ]\n          },\n        }\n      )\n    },\n    sortable: false,\n    resizable: false,\n  },\n}\n\nexport function defaultRenderCell<T>({\n  row,\n  column,\n  $index,\n}: {\n  row: T\n  column: TableColumnCtx<T>\n  $index: number\n}) {\n  const property = column.property\n  const value = property && getProp(row, property).value\n  if (column && column.formatter) {\n    return column.formatter(row, column, value, $index)\n  }\n  return value?.toString?.() || ''\n}\n\nexport function treeCellPrefix<T>(\n  {\n    row,\n    treeNode,\n    store,\n  }: {\n    row: T\n    treeNode: TreeNode\n    store: Store<T>\n  },\n  createPlaceholder = false\n) {\n  const { ns } = store\n  if (!treeNode) {\n    if (createPlaceholder) {\n      return [\n        h('span', {\n          class: ns.e('placeholder'),\n        }),\n      ]\n    }\n    return null\n  }\n  const ele: VNode[] = []\n  const callback = function (e) {\n    e.stopPropagation()\n    if (treeNode.loading) {\n      return\n    }\n    store.loadOrToggle(row)\n  }\n  if (treeNode.indent) {\n    ele.push(\n      h('span', {\n        class: ns.e('indent'),\n        style: { 'padding-left': `${treeNode.indent}px` },\n      })\n    )\n  }\n  if (typeof treeNode.expanded === 'boolean' && !treeNode.noLazyChildren) {\n    const expandClasses = [\n      ns.e('expand-icon'),\n      treeNode.expanded ? ns.em('expand-icon', 'expanded') : '',\n    ]\n    let icon = ArrowRight\n    if (treeNode.loading) {\n      icon = Loading\n    }\n\n    ele.push(\n      h(\n        'div',\n        {\n          class: expandClasses,\n          onClick: callback,\n        },\n        {\n          default: () => {\n            return [\n              h(\n                ElIcon,\n                { class: { [ns.is('loading')]: treeNode.loading } },\n                {\n                  default: () => [h(icon)],\n                }\n              ),\n            ]\n          },\n        }\n      )\n    )\n  } else {\n    ele.push(\n      h('span', {\n        class: ns.e('placeholder'),\n      })\n    )\n  }\n  return ele\n}\n", "// @ts-nocheck\nimport { getCurrentInstance, watch } from 'vue'\nimport { hasOwn } from '@element-plus/utils'\nimport { parseMinWidth, parseWidth } from '../util'\n\nimport type { ComputedRef } from 'vue'\nimport type { TableColumn, TableColumnCtx, ValueOf } from './defaults'\n\nfunction getAllAliases(props, aliases) {\n  return props.reduce((prev, cur) => {\n    prev[cur] = cur\n    return prev\n  }, aliases)\n}\nfunction useWatcher<T>(\n  owner: ComputedRef<any>,\n  props_: Partial<TableColumnCtx<T>>\n) {\n  const instance = getCurrentInstance() as TableColumn<T>\n  const registerComplexWatchers = () => {\n    const props = ['fixed']\n    const aliases = {\n      realWidth: 'width',\n      realMinWidth: 'minWidth',\n    }\n    const allAliases = getAllAliases(props, aliases)\n    Object.keys(allAliases).forEach((key) => {\n      const columnKey = aliases[key]\n      if (hasOwn(props_, columnKey)) {\n        watch(\n          () => props_[columnKey],\n          (newVal) => {\n            let value: ValueOf<TableColumnCtx<T>> = newVal\n            if (columnKey === 'width' && key === 'realWidth') {\n              value = parseWidth(newVal)\n            }\n            if (columnKey === 'minWidth' && key === 'realMinWidth') {\n              value = parseMinWidth(newVal)\n            }\n            instance.columnConfig.value[columnKey as any] = value\n            instance.columnConfig.value[key] = value\n            const updateColumns = columnKey === 'fixed'\n            owner.value.store.scheduleLayout(updateColumns)\n          }\n        )\n      }\n    })\n  }\n  const registerNormalWatchers = () => {\n    const props = [\n      'label',\n      'filters',\n      'filterMultiple',\n      'filteredValue',\n      'sortable',\n      'index',\n      'formatter',\n      'className',\n      'labelClassName',\n      'filterClassName',\n      'showOverflowTooltip',\n    ]\n    const aliases = {\n      property: 'prop',\n      align: 'realAlign',\n      headerAlign: 'realHeaderAlign',\n    }\n    const allAliases = getAllAliases(props, aliases)\n    Object.keys(allAliases).forEach((key) => {\n      const columnKey = aliases[key]\n      if (hasOwn(props_, columnKey)) {\n        watch(\n          () => props_[columnKey],\n          (newVal) => {\n            instance.columnConfig.value[key] = newVal\n          }\n        )\n      }\n    })\n  }\n\n  return {\n    registerComplexWatchers,\n    registerNormalWatchers,\n  }\n}\n\nexport default useWatcher\n", "// @ts-nocheck\nimport {\n  Comment,\n  computed,\n  getCurrentInstance,\n  h,\n  ref,\n  renderSlot,\n  unref,\n  watchEffect,\n} from 'vue'\nimport { debugWarn } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport {\n  cellForced,\n  defaultRenderCell,\n  getDefaultClassName,\n  treeCellPrefix,\n} from '../config'\nimport { parseMinWidth, parseWidth } from '../util'\nimport type { ComputedRef } from 'vue'\nimport type { TableColumn, TableColumnCtx } from './defaults'\n\nfunction useRender<T>(\n  props: TableColumnCtx<T>,\n  slots,\n  owner: ComputedRef<any>\n) {\n  const instance = getCurrentInstance() as TableColumn<T>\n  const columnId = ref('')\n  const isSubColumn = ref(false)\n  const realAlign = ref<string>()\n  const realHeaderAlign = ref<string>()\n  const ns = useNamespace('table')\n  watchEffect(() => {\n    realAlign.value = props.align ? `is-${props.align}` : null\n    // nextline help render\n    realAlign.value\n  })\n  watchEffect(() => {\n    realHeaderAlign.value = props.headerAlign\n      ? `is-${props.headerAlign}`\n      : realAlign.value\n    // nextline help render\n    realHeaderAlign.value\n  })\n  const columnOrTableParent = computed(() => {\n    let parent: any = instance.vnode.vParent || instance.parent\n    while (parent && !parent.tableId && !parent.columnId) {\n      parent = parent.vnode.vParent || parent.parent\n    }\n    return parent\n  })\n  const hasTreeColumn = computed<boolean>(() => {\n    const { store } = instance.parent\n    if (!store) return false\n    const { treeData } = store.states\n    const treeDataValue = treeData.value\n    return treeDataValue && Object.keys(treeDataValue).length > 0\n  })\n\n  const realWidth = ref(parseWidth(props.width))\n  const realMinWidth = ref(parseMinWidth(props.minWidth))\n  const setColumnWidth = (column: TableColumnCtx<T>) => {\n    if (realWidth.value) column.width = realWidth.value\n    if (realMinWidth.value) {\n      column.minWidth = realMinWidth.value\n    }\n    if (!realWidth.value && realMinWidth.value) {\n      column.width = undefined\n    }\n    if (!column.minWidth) {\n      column.minWidth = 80\n    }\n    column.realWidth = Number(\n      column.width === undefined ? column.minWidth : column.width\n    )\n    return column\n  }\n  const setColumnForcedProps = (column: TableColumnCtx<T>) => {\n    // 对于特定类型的 column,某些属性不允许设置\n    const type = column.type\n    const source = cellForced[type] || {}\n    Object.keys(source).forEach((prop) => {\n      const value = source[prop]\n      if (prop !== 'className' && value !== undefined) {\n        column[prop] = value\n      }\n    })\n    const className = getDefaultClassName(type)\n    if (className) {\n      const forceClass = `${unref(ns.namespace)}-${className}`\n      column.className = column.className\n        ? `${column.className} ${forceClass}`\n        : forceClass\n    }\n    return column\n  }\n\n  const checkSubColumn = (children: TableColumn<T> | TableColumn<T>[]) => {\n    if (Array.isArray(children)) {\n      children.forEach((child) => check(child))\n    } else {\n      check(children)\n    }\n    function check(item: TableColumn<T>) {\n      if (item?.type?.name === 'ElTableColumn') {\n        item.vParent = instance\n      }\n    }\n  }\n  const setColumnRenders = (column: TableColumnCtx<T>) => {\n    // renderHeader 属性不推荐使用。\n    if (props.renderHeader) {\n      debugWarn(\n        'TableColumn',\n        'Comparing to render-header, scoped-slot header is easier to use. We recommend users to use scoped-slot header.'\n      )\n    } else if (column.type !== 'selection') {\n      column.renderHeader = (scope) => {\n        // help render\n        instance.columnConfig.value['label']\n        return renderSlot(slots, 'header', scope, () => [column.label])\n      }\n    }\n\n    if (slots['filter-icon']) {\n      column.renderFilterIcon = (scope) => {\n        return renderSlot(slots, 'filter-icon', scope)\n      }\n    }\n\n    let originRenderCell = column.renderCell\n    // TODO: 这里的实现调整\n    if (column.type === 'expand') {\n      // 对于展开行,renderCell 不允许配置的。在上一步中已经设置过,这里需要简单封装一下。\n      column.renderCell = (data) =>\n        h(\n          'div',\n          {\n            class: 'cell',\n          },\n          [originRenderCell(data)]\n        )\n      owner.value.renderExpanded = (data) => {\n        return slots.default ? slots.default(data) : slots.default\n      }\n    } else {\n      originRenderCell = originRenderCell || defaultRenderCell\n      // 对 renderCell 进行包装\n      column.renderCell = (data) => {\n        let children = null\n        if (slots.default) {\n          const vnodes = slots.default(data)\n          children = vnodes.some((v) => v.type !== Comment)\n            ? vnodes\n            : originRenderCell(data)\n        } else {\n          children = originRenderCell(data)\n        }\n\n        const { columns } = owner.value.store.states\n        const firstUserColumnIndex = columns.value.findIndex(\n          (item) => item.type === 'default'\n        )\n        const shouldCreatePlaceholder =\n          hasTreeColumn.value && data.cellIndex === firstUserColumnIndex\n        const prefix = treeCellPrefix(data, shouldCreatePlaceholder)\n        const props = {\n          class: 'cell',\n          style: {},\n        }\n        if (column.showOverflowTooltip) {\n          props.class = `${props.class} ${unref(ns.namespace)}-tooltip`\n          props.style = {\n            width: `${\n              (data.column.realWidth || Number(data.column.width)) - 1\n            }px`,\n          }\n        }\n        checkSubColumn(children)\n        return h('div', props, [prefix, children])\n      }\n    }\n    return column\n  }\n  const getPropsData = (...propsKey: unknown[]) => {\n    return propsKey.reduce((prev, cur) => {\n      if (Array.isArray(cur)) {\n        cur.forEach((key) => {\n          prev[key] = props[key]\n        })\n      }\n      return prev\n    }, {})\n  }\n  const getColumnElIndex = (children, child) => {\n    return Array.prototype.indexOf.call(children, child)\n  }\n\n  const updateColumnOrder = () => {\n    owner.value.store.commit('updateColumnOrder', instance.columnConfig.value)\n  }\n\n  return {\n    columnId,\n    realAlign,\n    isSubColumn,\n    realHeaderAlign,\n    columnOrTableParent,\n    setColumnWidth,\n    setColumnForcedProps,\n    setColumnRenders,\n    getPropsData,\n    getColumnElIndex,\n    updateColumnOrder,\n  }\n}\n\nexport default useRender\n", "// @ts-nocheck\nimport type { ComponentInternalInstance, PropType, Ref, VNode } from 'vue'\nimport type { DefaultRow, Table } from '../table/defaults'\nimport type { TableOverflowTooltipOptions } from '../util'\n\ntype CI<T> = { column: TableColumnCtx<T>; $index: number }\n\ntype Filters = {\n  text: string\n  value: string\n}[]\n\ntype FilterMethods<T> = (value, row: T, column: TableColumnCtx<T>) => void\n\ntype ValueOf<T> = T[keyof T]\n\ninterface TableColumnCtx<T> {\n  id: string\n  realWidth: number\n  type: string\n  label: string\n  className: string\n  labelClassName: string\n  property: string\n  prop: string\n  width: string | number\n  minWidth: string | number\n  renderHeader: (data: CI<T>) => VNode\n  sortable: boolean | string\n  sortMethod: (a: T, b: T) => number\n  sortBy: string | ((row: T, index: number) => string) | string[]\n  resizable: boolean\n  columnKey: string\n  rawColumnKey: string\n  align: string\n  headerAlign: string\n  showOverflowTooltip?: boolean | TableOverflowTooltipOptions\n  fixed: boolean | string\n  formatter: (\n    row: T,\n    column: TableColumnCtx<T>,\n    cellValue,\n    index: number\n  ) => VNode | string\n  selectable: (row: T, index: number) => boolean\n  reserveSelection: boolean\n  filterMethod: FilterMethods<T>\n  filteredValue: string[]\n  filters: Filters\n  filterPlacement: string\n  filterMultiple: boolean\n  filterClassName: string\n  index: number | ((index: number) => number)\n  sortOrders: ('ascending' | 'descending' | null)[]\n  renderCell: (data: any) => void\n  colSpan: number\n  rowSpan: number\n  children: TableColumnCtx<T>[]\n  level: number\n  filterable: boolean | FilterMethods<T> | Filters\n  order: string\n  isColumnGroup: boolean\n  isSubColumn: boolean\n  columns: TableColumnCtx<T>[]\n  getColumnIndex: () => number\n  no: number\n  filterOpened?: boolean\n}\n\ninterface TableColumn<T> extends ComponentInternalInstance {\n  vnode: {\n    vParent: TableColumn<T> | Table<T>\n  } & VNode\n  vParent: TableColumn<T> | Table<T>\n  columnId: string\n  columnConfig: Ref<Partial<TableColumnCtx<T>>>\n}\n\nexport type { Filters, FilterMethods, TableColumnCtx, TableColumn, ValueOf }\n\nexport default {\n  /**\n   * @description type of the column. If set to `selection`, the column will display checkbox. If set to `index`, the column will display index of the row (staring from 1). If set to `expand`, the column will display expand icon\n   */\n  type: {\n    type: String,\n    default: 'default',\n  },\n  /**\n   * @description column label\n   */\n  label: String,\n  /**\n   * @description class name of cells in the column\n   */\n  className: String,\n  /**\n   * @description class name of the label of this column\n   */\n  labelClassName: String,\n  /**\n   * @description\n   */\n  property: String,\n  /**\n   * @description field name. You can also use its alias: `property`\n   */\n  prop: String,\n  /**\n   * @description column width\n   */\n  width: {\n    type: [String, Number],\n    default: '',\n  },\n  /**\n   * @description column minimum width. Columns with `width` has a fixed width, while columns with `min-width` has a width that is distributed in proportion\n   */\n  minWidth: {\n    type: [String, Number],\n    default: '',\n  },\n  /**\n   * @description render function for table header of this column\n   */\n  renderHeader: Function as PropType<\n    TableColumnCtx<DefaultRow>['renderHeader']\n  >,\n  /**\n   * @description whether column can be sorted. Remote sorting can be done by setting this attribute to 'custom' and listening to the `sort-change` event of Table\n   */\n  sortable: {\n    type: [Boolean, String],\n    default: false,\n  },\n  /**\n   * @description sorting method, works when `sortable` is `true`. Should return a number, just like Array.sort\n   */\n  sortMethod: Function as PropType<TableColumnCtx<DefaultRow>['sortMethod']>,\n  /**\n   * @description specify which property to sort by, works when `sortable` is `true` and `sort-method` is `undefined`. If set to an Array, the column will sequentially sort by the next property if the previous one is equal\n   */\n  sortBy: [String, Function, Array] as PropType<\n    TableColumnCtx<DefaultRow>['sortBy']\n  >,\n  /**\n   * @description whether column width can be resized, works when `border` of `el-table` is `true`\n   */\n  resizable: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description column's key. If you need to use the filter-change event, you need this attribute to identify which column is being filtered\n   */\n  columnKey: String,\n  /**\n   * @description alignment, the value should be 'left' \\/ 'center' \\/ 'right'\n   */\n  align: String,\n  /**\n   * @description alignment of the table header. If omitted, the value of the above `align` attribute will be applied, the value should be 'left' \\/ 'center' \\/ 'right'\n   */\n  headerAlign: String,\n  /**\n   * @description whether to hide extra content and show them in a tooltip when hovering on the cell\n   */\n  showOverflowTooltip: {\n    type: [Boolean, Object] as PropType<\n      TableColumnCtx<DefaultRow>['showOverflowTooltip']\n    >,\n    default: undefined,\n  },\n  /**\n   * @description whether column is fixed at left / right. Will be fixed at left if `true`\n   */\n  fixed: [Boolean, String],\n  /**\n   * @description function that formats cell content\n   */\n  formatter: Function as PropType<TableColumnCtx<DefaultRow>['formatter']>,\n  /**\n   * @description function that determines if a certain row can be selected, works when `type` is 'selection'\n   */\n  selectable: Function as PropType<TableColumnCtx<DefaultRow>['selectable']>,\n  /**\n   * @description whether to reserve selection after data refreshing, works when `type` is 'selection'. Note that `row-key` is required for this to work\n   */\n  reserveSelection: Boolean,\n  /**\n   * @description data filtering method. If `filter-multiple` is on, this method will be called multiple times for each row, and a row will display if one of the calls returns `true`\n   */\n  filterMethod: Function as PropType<\n    TableColumnCtx<DefaultRow>['filterMethod']\n  >,\n  /**\n   * @description filter value for selected data, might be useful when table header is rendered with `render-header`\n   */\n  filteredValue: Array as PropType<TableColumnCtx<DefaultRow>['filteredValue']>,\n  /**\n   * @description an array of data filtering options. For each element in this array, `text` and `value` are required\n   */\n  filters: Array as PropType<TableColumnCtx<DefaultRow>['filters']>,\n  /**\n   * @description placement for the filter dropdown\n   */\n  filterPlacement: String,\n  /**\n   * @description whether data filtering supports multiple options\n   */\n  filterMultiple: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description className for the filter dropdown\n   */\n  filterClassName: String,\n  /**\n   * @description customize indices for each row, works on columns with `type=index`\n   */\n  index: [Number, Function] as PropType<TableColumnCtx<DefaultRow>['index']>,\n  /**\n   * @description the order of the sorting strategies used when sorting the data, works when `sortable` is `true`. Accepts an array, as the user clicks on the header, the column is sorted in order of the elements in the array\n   */\n  sortOrders: {\n    type: Array as PropType<TableColumnCtx<DefaultRow>['sortOrders']>,\n    default: () => {\n      return ['ascending', 'descending', null]\n    },\n    validator: (val: TableColumnCtx<unknown>['sortOrders']) => {\n      return val.every((order: string) =>\n        ['ascending', 'descending', null].includes(order)\n      )\n    },\n  },\n}\n", "// @ts-nocheck\nimport {\n  Fragment,\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  h,\n  onBeforeMount,\n  onBeforeUnmount,\n  onMounted,\n  ref,\n} from 'vue'\nimport ElCheckbox from '@element-plus/components/checkbox'\nimport { isString, isUndefined } from '@element-plus/utils'\nimport { cellStarts } from '../config'\nimport { compose, mergeOptions } from '../util'\nimport useWatcher from './watcher-helper'\nimport useRender from './render-helper'\nimport defaultProps from './defaults'\nimport type { TableColumn, TableColumnCtx } from './defaults'\n\nimport type { DefaultRow } from '../table/defaults'\n\nlet columnIdSeed = 1\n\nexport default defineComponent({\n  name: 'ElTableColumn',\n  components: {\n    ElCheckbox,\n  },\n  props: defaultProps,\n  setup(props, { slots }) {\n    const instance = getCurrentInstance() as TableColumn<DefaultRow>\n    const columnConfig = ref<Partial<TableColumnCtx<DefaultRow>>>({})\n    const owner = computed(() => {\n      let parent = instance.parent as any\n      while (parent && !parent.tableId) {\n        parent = parent.parent\n      }\n      return parent\n    })\n\n    const { registerNormalWatchers, registerComplexWatchers } = useWatcher(\n      owner,\n      props\n    )\n    const {\n      columnId,\n      isSubColumn,\n      realHeaderAlign,\n      columnOrTableParent,\n      setColumnWidth,\n      setColumnForcedProps,\n      setColumnRenders,\n      getPropsData,\n      getColumnElIndex,\n      realAlign,\n      updateColumnOrder,\n    } = useRender(props as unknown as TableColumnCtx<unknown>, slots, owner)\n\n    const parent = columnOrTableParent.value\n    columnId.value = `${\n      parent.tableId || parent.columnId\n    }_column_${columnIdSeed++}`\n    onBeforeMount(() => {\n      isSubColumn.value = owner.value !== parent\n\n      const type = props.type || 'default'\n      const sortable = props.sortable === '' ? true : props.sortable\n      const showOverflowTooltip = isUndefined(props.showOverflowTooltip)\n        ? parent.props.showOverflowTooltip\n        : props.showOverflowTooltip\n      const defaults = {\n        ...cellStarts[type],\n        id: columnId.value,\n        type,\n        property: props.prop || props.property,\n        align: realAlign,\n        headerAlign: realHeaderAlign,\n        showOverflowTooltip,\n        // filter 相关属性\n        filterable: props.filters || props.filterMethod,\n        filteredValue: [],\n        filterPlacement: '',\n        filterClassName: '',\n        isColumnGroup: false,\n        isSubColumn: false,\n        filterOpened: false,\n        // sort 相关属性\n        sortable,\n        // index 列\n        index: props.index,\n        // <el-table-column key=\"xxx\" />\n        rawColumnKey: instance.vnode.key,\n      }\n\n      const basicProps = [\n        'columnKey',\n        'label',\n        'className',\n        'labelClassName',\n        'type',\n        'renderHeader',\n        'formatter',\n        'fixed',\n        'resizable',\n      ]\n      const sortProps = ['sortMethod', 'sortBy', 'sortOrders']\n      const selectProps = ['selectable', 'reserveSelection']\n      const filterProps = [\n        'filterMethod',\n        'filters',\n        'filterMultiple',\n        'filterOpened',\n        'filteredValue',\n        'filterPlacement',\n        'filterClassName',\n      ]\n\n      let column = getPropsData(basicProps, sortProps, selectProps, filterProps)\n\n      column = mergeOptions(defaults, column)\n      // 注意 compose 中函数执行的顺序是从右到左\n      const chains = compose(\n        setColumnRenders,\n        setColumnWidth,\n        setColumnForcedProps\n      )\n      column = chains(column)\n      columnConfig.value = column\n\n      // 注册 watcher\n      registerNormalWatchers()\n      registerComplexWatchers()\n    })\n    onMounted(() => {\n      const parent = columnOrTableParent.value\n      const children = isSubColumn.value\n        ? parent.vnode.el.children\n        : parent.refs.hiddenColumns?.children\n      const getColumnIndex = () =>\n        getColumnElIndex(children || [], instance.vnode.el)\n      columnConfig.value.getColumnIndex = getColumnIndex\n      const columnIndex = getColumnIndex()\n      columnIndex > -1 &&\n        owner.value.store.commit(\n          'insertColumn',\n          columnConfig.value,\n          isSubColumn.value ? parent.columnConfig.value : null,\n          updateColumnOrder\n        )\n    })\n    onBeforeUnmount(() => {\n      const getColumnIndex = columnConfig.value.getColumnIndex\n      const columnIndex = getColumnIndex ? getColumnIndex() : -1\n      columnIndex > -1 &&\n        owner.value.store.commit(\n          'removeColumn',\n          columnConfig.value,\n          isSubColumn.value ? parent.columnConfig.value : null,\n          updateColumnOrder\n        )\n    })\n    instance.columnId = columnId.value\n\n    instance.columnConfig = columnConfig\n    return\n  },\n  render() {\n    try {\n      const renderDefault = this.$slots.default?.({\n        row: {},\n        column: {},\n        $index: -1,\n      })\n      const children = []\n      if (Array.isArray(renderDefault)) {\n        for (const childNode of renderDefault) {\n          if (\n            childNode.type?.name === 'ElTableColumn' ||\n            childNode.shapeFlag & 2\n          ) {\n            children.push(childNode)\n          } else if (\n            childNode.type === Fragment &&\n            Array.isArray(childNode.children)\n          ) {\n            childNode.children.forEach((vnode) => {\n              // No rendering when vnode is dynamic slot or text\n              if (vnode?.patchFlag !== 1024 && !isString(vnode?.children)) {\n                children.push(vnode)\n              }\n            })\n          }\n        }\n      }\n      const vnode = h('div', children)\n      return vnode\n    } catch {\n      return h('div', [])\n    }\n  },\n})\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Table from './src/table.vue'\nimport TableColumn from './src/tableColumn'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTable: SFCWithInstall<typeof Table> & {\n  TableColumn: typeof TableColumn\n} = withInstall(Table, {\n  TableColumn,\n})\nexport default ElTable\nexport const ElTableColumn: SFCWithInstall<typeof TableColumn> =\n  withNoopInstall(TableColumn)\n\nexport type TableInstance = InstanceType<typeof Table>\n\nexport type TableColumnInstance = InstanceType<typeof TableColumn>\n\nexport type {\n  SummaryMethod,\n  Table,\n  TableProps,\n  TableRefs,\n  ColumnCls,\n  ColumnStyle,\n  CellCls,\n  CellStyle,\n  TreeNode,\n  RenderRowData,\n  Sort,\n  Filter,\n  TableColumnCtx,\n} from './src/table/defaults'\n", "export enum SortOrder {\n  ASC = 'asc',\n  DESC = 'desc',\n}\n\nexport enum Alignment {\n  CENTER = 'center',\n  RIGHT = 'right',\n}\n\nexport enum FixedDir {\n  LEFT = 'left',\n  RIGHT = 'right',\n}\n\nexport const oppositeOrderMap = {\n  [SortOrder.ASC]: SortOrder.DESC,\n  [SortOrder.DESC]: SortOrder.ASC,\n}\n\nexport const sortOrders = [SortOrder.ASC, SortOrder.DESC] as const\n", "export const placeholderSign = Symbol('placeholder')\n", "import type { CSSProperties } from 'vue'\nimport type { AnyColumns } from '../types'\n\nexport const calcColumnStyle = (\n  column: AnyColumns[number],\n  fixedColumn: boolean,\n  fixed: boolean\n): CSSProperties => {\n  const flex = {\n    flexGrow: 0,\n    flexShrink: 0,\n    ...(fixed\n      ? {}\n      : {\n          flexGrow: column.flexGrow || 0,\n          flexShrink: column.flexShrink || 1,\n        }),\n  }\n\n  if (!fixed) {\n    flex.flexShrink = 1\n  }\n\n  const style = {\n    ...(column.style ?? {}),\n    ...flex,\n    flexBasis: 'auto',\n    width: column.width,\n  }\n\n  if (!fixedColumn) {\n    if (column.maxWidth) style.maxWidth = column.maxWidth\n    if (column.minWidth) style.minWidth = column.minWidth\n  }\n\n  return style\n}\n", "// @ts-nocheck\nimport { computed, unref } from 'vue'\nimport { isObject } from '@element-plus/utils'\nimport { SortOrder, oppositeOrderMap } from '../constants'\nimport { placeholderSign } from '../private'\nimport { calcColumnStyle } from './utils'\n\nimport type { CSSProperties, Ref } from 'vue'\nimport type { TableV2Props } from '../table'\nimport type { AnyColumns, Column, KeyType } from '../types'\n\nfunction useColumns(\n  props: TableV2Props,\n  columns: Ref<AnyColumns>,\n  fixed: Ref<boolean>\n) {\n  const _columns = computed(() =>\n    unref(columns).map((column, index) => ({\n      ...column,\n      key: column.key ?? column.dataKey ?? index,\n    }))\n  )\n\n  const visibleColumns = computed(() => {\n    return unref(_columns).filter((column) => !column.hidden)\n  })\n\n  const fixedColumnsOnLeft = computed(() =>\n    unref(visibleColumns).filter(\n      (column) => column.fixed === 'left' || column.fixed === true\n    )\n  )\n\n  const fixedColumnsOnRight = computed(() =>\n    unref(visibleColumns).filter((column) => column.fixed === 'right')\n  )\n\n  const normalColumns = computed(() =>\n    unref(visibleColumns).filter((column) => !column.fixed)\n  )\n\n  const mainColumns = computed(() => {\n    const ret: AnyColumns = []\n\n    unref(fixedColumnsOnLeft).forEach((column) => {\n      ret.push({\n        ...column,\n        placeholderSign,\n      })\n    })\n\n    unref(normalColumns).forEach((column) => {\n      ret.push(column)\n    })\n\n    unref(fixedColumnsOnRight).forEach((column) => {\n      ret.push({\n        ...column,\n        placeholderSign,\n      })\n    })\n\n    return ret\n  })\n\n  const hasFixedColumns = computed(() => {\n    return unref(fixedColumnsOnLeft).length || unref(fixedColumnsOnRight).length\n  })\n\n  const columnsStyles = computed(() => {\n    return unref(_columns).reduce<Record<Column<any>['key'], CSSProperties>>(\n      (style, column) => {\n        style[column.key] = calcColumnStyle(column, unref(fixed), props.fixed)\n        return style\n      },\n      {}\n    )\n  })\n\n  const columnsTotalWidth = computed(() => {\n    return unref(visibleColumns).reduce(\n      (width, column) => width + column.width,\n      0\n    )\n  })\n\n  const getColumn = (key: KeyType) => {\n    return unref(_columns).find((column) => column.key === key)\n  }\n\n  const getColumnStyle = (key: KeyType) => {\n    return unref(columnsStyles)[key]\n  }\n\n  const updateColumnWidth = (column: Column<any>, width: number) => {\n    column.width = width\n  }\n\n  function onColumnSorted(e: MouseEvent) {\n    const { key } = (e.currentTarget as HTMLElement).dataset\n    if (!key) return\n    const { sortState, sortBy } = props\n\n    let order = SortOrder.ASC\n\n    if (isObject(sortState)) {\n      order = oppositeOrderMap[sortState[key]]\n    } else {\n      order = oppositeOrderMap[sortBy.order]\n    }\n\n    props.onColumnSort?.({ column: getColumn(key)!, key, order })\n  }\n\n  return {\n    columns: _columns,\n    columnsStyles,\n    columnsTotalWidth,\n    fixedColumnsOnLeft,\n    fixedColumnsOnRight,\n    hasFixedColumns,\n    mainColumns,\n    normalColumns,\n    visibleColumns,\n\n    getColumn,\n    getColumnStyle,\n    updateColumnWidth,\n    onColumnSorted,\n  }\n}\n\nexport { useColumns }\nexport type UseColumnsReturn = ReturnType<typeof useColumns>\n", "import { ref, unref, watch } from 'vue'\n\nimport type { Ref } from 'vue'\nimport type { Alignment as ScrollStrategy } from '@element-plus/components/virtual-list'\nimport type { TableV2Props } from '../table'\nimport type { TableGridInstance } from '../table-grid'\n\nexport type ScrollPos = { scrollLeft: number; scrollTop: number }\ntype GridInstanceRef = Ref<TableGridInstance | undefined>\n\ntype UseScrollBarProps = {\n  mainTableRef: GridInstanceRef\n  leftTableRef: GridInstanceRef\n  rightTableRef: GridInstanceRef\n\n  onMaybeEndReached: () => void\n}\n\nexport type { ScrollStrategy }\n\nexport const useScrollbar = (\n  props: TableV2Props,\n  {\n    mainTableRef,\n    leftTableRef,\n    rightTableRef,\n    onMaybeEndReached,\n  }: UseScrollBarProps\n) => {\n  const scrollPos = ref<ScrollPos>({ scrollLeft: 0, scrollTop: 0 })\n\n  function doScroll(params: ScrollPos) {\n    const { scrollTop } = params\n\n    mainTableRef.value?.scrollTo(params)\n    leftTableRef.value?.scrollToTop(scrollTop)\n    rightTableRef.value?.scrollToTop(scrollTop)\n  }\n\n  // methods\n  function scrollTo(params: ScrollPos) {\n    scrollPos.value = params\n\n    doScroll(params)\n  }\n\n  function scrollToTop(scrollTop: number) {\n    scrollPos.value.scrollTop = scrollTop\n\n    doScroll(unref(scrollPos))\n  }\n\n  function scrollToLeft(scrollLeft: number) {\n    scrollPos.value.scrollLeft = scrollLeft\n\n    mainTableRef.value?.scrollTo?.(unref(scrollPos))\n  }\n\n  function onScroll(params: ScrollPos) {\n    scrollTo(params)\n    props.onScroll?.(params)\n  }\n\n  function onVerticalScroll({ scrollTop }: ScrollPos) {\n    const { scrollTop: currentScrollTop } = unref(scrollPos)\n    if (scrollTop !== currentScrollTop) scrollToTop(scrollTop)\n  }\n\n  function scrollToRow(row: number, strategy: ScrollStrategy = 'auto') {\n    mainTableRef.value?.scrollToRow(row, strategy)\n  }\n\n  // When scrollTop changes, maybe reaching the bottom\n  watch(\n    () => unref(scrollPos).scrollTop,\n    (cur, prev) => {\n      if (cur > prev) onMaybeEndReached()\n    }\n  )\n\n  return {\n    scrollPos,\n\n    scrollTo,\n    scrollToLeft,\n    scrollToTop,\n    scrollToRow,\n    onScroll,\n    onVerticalScroll,\n  }\n}\n", "import { computed, getCurrentInstance, ref, shallowRef, unref } from 'vue'\nimport { debounce } from 'lodash-unified'\nimport { isNumber } from '@element-plus/utils'\nimport { FixedDir } from '../constants'\n\nimport type { ComponentInternalInstance, Ref, ShallowRef } from 'vue'\nimport type { TableV2Props } from '../table'\nimport type {\n  RowExpandParams,\n  RowHeightChangedParams,\n  RowHoverParams,\n} from '../row'\nimport type { FixedDirection, KeyType } from '../types'\nimport type { onRowRenderedParams } from '../grid'\nimport type { TableGridInstance } from '../table-grid'\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\n\ntype Heights = Record<KeyType, number>\ntype GridInstanceRef = Ref<TableGridInstance | undefined>\n\ntype UseRowProps = {\n  mainTableRef: GridInstanceRef\n  leftTableRef: GridInstanceRef\n  rightTableRef: GridInstanceRef\n  tableInstance: ComponentInternalInstance\n  ns: UseNamespaceReturn\n  isScrolling: ShallowRef<boolean>\n}\n\nexport const useRow = (\n  props: TableV2Props,\n  {\n    mainTableRef,\n    leftTableRef,\n    rightTableRef,\n    tableInstance,\n    ns,\n    isScrolling,\n  }: UseRowProps\n) => {\n  const vm = getCurrentInstance()!\n  const { emit } = vm\n  const isResetting = shallowRef(false)\n  const expandedRowKeys = ref<KeyType[]>(props.defaultExpandedRowKeys || [])\n  const lastRenderedRowIndex = ref(-1)\n  const resetIndex = shallowRef<number | null>(null)\n  const rowHeights = ref<Heights>({})\n  const pendingRowHeights = ref<Heights>({})\n  const leftTableHeights = shallowRef<Heights>({})\n  const mainTableHeights = shallowRef<Heights>({})\n  const rightTableHeights = shallowRef<Heights>({})\n  const isDynamic = computed(() => isNumber(props.estimatedRowHeight))\n\n  function onRowsRendered(params: onRowRenderedParams) {\n    props.onRowsRendered?.(params)\n\n    if (params.rowCacheEnd > unref(lastRenderedRowIndex)) {\n      lastRenderedRowIndex.value = params.rowCacheEnd\n    }\n  }\n\n  function onRowHovered({ hovered, rowKey }: RowHoverParams) {\n    if (isScrolling.value) {\n      return\n    }\n    const tableRoot = tableInstance!.vnode.el as HTMLElement\n    const rows = tableRoot.querySelectorAll(`[rowkey=\"${String(rowKey)}\"]`)\n    rows.forEach((row) => {\n      if (hovered) {\n        row.classList.add(ns.is('hovered'))\n      } else {\n        row.classList.remove(ns.is('hovered'))\n      }\n    })\n  }\n\n  function onRowExpanded({\n    expanded,\n    rowData,\n    rowIndex,\n    rowKey,\n  }: RowExpandParams) {\n    const _expandedRowKeys = [...unref(expandedRowKeys)]\n    const currentKeyIndex = _expandedRowKeys.indexOf(rowKey)\n    if (expanded) {\n      if (currentKeyIndex === -1) _expandedRowKeys.push(rowKey)\n    } else {\n      if (currentKeyIndex > -1) _expandedRowKeys.splice(currentKeyIndex, 1)\n    }\n    expandedRowKeys.value = _expandedRowKeys\n\n    emit('update:expandedRowKeys', _expandedRowKeys)\n    props.onRowExpand?.({\n      expanded,\n      rowData,\n      rowIndex,\n      rowKey,\n    })\n    // If this is not controlled, then use this to notify changes\n    props.onExpandedRowsChange?.(_expandedRowKeys)\n  }\n\n  const flushingRowHeights = debounce(() => {\n    isResetting.value = true\n    rowHeights.value = { ...unref(rowHeights), ...unref(pendingRowHeights) }\n    resetAfterIndex(unref(resetIndex)!, false)\n    pendingRowHeights.value = {}\n    // force update\n    resetIndex.value = null\n    mainTableRef.value?.forceUpdate()\n    leftTableRef.value?.forceUpdate()\n    rightTableRef.value?.forceUpdate()\n    vm.proxy?.$forceUpdate()\n    isResetting.value = false\n  }, 0)\n\n  function resetAfterIndex(index: number, forceUpdate = false) {\n    if (!unref(isDynamic)) return\n    ;[mainTableRef, leftTableRef, rightTableRef].forEach((tableRef) => {\n      const table = unref(tableRef)\n      if (table) table.resetAfterRowIndex(index, forceUpdate)\n    })\n  }\n\n  function resetHeights(rowKey: KeyType, height: number, rowIdx: number) {\n    const resetIdx = unref(resetIndex)\n    if (resetIdx === null) {\n      resetIndex.value = rowIdx\n    } else {\n      if (resetIdx > rowIdx) {\n        resetIndex.value = rowIdx\n      }\n    }\n\n    pendingRowHeights.value[rowKey] = height\n  }\n\n  function onRowHeightChange(\n    { rowKey, height, rowIndex }: RowHeightChangedParams,\n    fixedDir: FixedDirection\n  ) {\n    if (!fixedDir) {\n      mainTableHeights.value[rowKey] = height\n    } else {\n      if (fixedDir === FixedDir.RIGHT) {\n        rightTableHeights.value[rowKey] = height\n      } else {\n        leftTableHeights.value[rowKey] = height\n      }\n    }\n\n    const maximumHeight = Math.max(\n      ...[leftTableHeights, rightTableHeights, mainTableHeights].map(\n        (records) => records.value[rowKey] || 0\n      )\n    )\n\n    if (unref(rowHeights)[rowKey] !== maximumHeight) {\n      resetHeights(rowKey, maximumHeight, rowIndex)\n      flushingRowHeights()\n    }\n  }\n\n  return {\n    expandedRowKeys,\n    lastRenderedRowIndex,\n    isDynamic,\n    isResetting,\n    rowHeights,\n\n    resetAfterIndex,\n    onRowExpanded,\n    onRowHovered,\n    onRowsRendered,\n    onRowHeightChange,\n  }\n}\n\nexport type UseRowReturn = ReturnType<typeof useRow>\n", "import { computed, ref, unref, watch } from 'vue'\n\nimport type { TableV2Props } from '../table'\nimport type { KeyType } from '../types'\nimport type { UseRowReturn } from './use-row'\n\ntype UseDataProps = {\n  expandedRowKeys: UseRowReturn['expandedRowKeys']\n  lastRenderedRowIndex: UseRowReturn['lastRenderedRowIndex']\n  resetAfterIndex: UseRowReturn['resetAfterIndex']\n}\n\nexport const useData = (\n  props: TableV2Props,\n  { expandedRowKeys, lastRenderedRowIndex, resetAfterIndex }: UseDataProps\n) => {\n  const depthMap = ref<Record<KeyType, number>>({})\n\n  const flattenedData = computed(() => {\n    const depths: Record<KeyType, number> = {}\n    const { data, rowKey } = props\n\n    const _expandedRowKeys = unref(expandedRowKeys)\n\n    if (!_expandedRowKeys || !_expandedRowKeys.length) return data\n\n    const array: any[] = []\n    const keysSet = new Set()\n    _expandedRowKeys.forEach((x) => keysSet.add(x))\n\n    let copy: any[] = data.slice()\n    copy.forEach((x) => (depths[x[rowKey]] = 0))\n    while (copy.length > 0) {\n      const item = copy.shift()!\n\n      array.push(item)\n      if (\n        keysSet.has(item[rowKey]) &&\n        Array.isArray(item.children) &&\n        item.children.length > 0\n      ) {\n        copy = [...item.children, ...copy]\n        item.children.forEach(\n          (child: any) => (depths[child[rowKey]] = depths[item[rowKey]] + 1)\n        )\n      }\n    }\n\n    depthMap.value = depths\n    return array\n  })\n\n  const data = computed(() => {\n    const { data, expandColumnKey } = props\n    return expandColumnKey ? unref(flattenedData) : data\n  })\n\n  watch(data, (val, prev) => {\n    if (val !== prev) {\n      lastRenderedRowIndex.value = -1\n      resetAfterIndex(0, true)\n    }\n  })\n\n  return {\n    data,\n    depthMap,\n  }\n}\n\nexport type UseDataReturn = ReturnType<typeof useData>\n", "import { h, isVNode } from 'vue'\nimport { addUnit, isArray, isFunction } from '@element-plus/utils'\n\nimport type { CSSProperties, Component, Slot } from 'vue'\n\nconst sumReducer = (sum: number, num: number) => sum + num\n\nexport const sum = (listLike: number | number[]) => {\n  return isArray(listLike) ? listLike.reduce(sumReducer, 0) : listLike\n}\n\nexport const tryCall = <T>(\n  fLike: T,\n  params: T extends (...args: infer K) => unknown ? K : any,\n  defaultRet = {}\n) => {\n  return isFunction(fLike) ? fLike(params) : fLike ?? defaultRet\n}\n\nexport const enforceUnit = (style: CSSProperties) => {\n  ;(['width', 'maxWidth', 'minWidth', 'height'] as const).forEach((key) => {\n    style[key] = addUnit(style[key])\n  })\n\n  return style\n}\n\nexport const componentToSlot = <T>(\n  ComponentLike: JSX.Element | ((props: T) => Component<T>) | undefined\n) =>\n  isVNode(ComponentLike)\n    ? (props: T) => h(ComponentLike, props)\n    : (ComponentLike as Slot)\n", "import { computed, unref } from 'vue'\nimport { addUnit, isNumber } from '@element-plus/utils'\nimport { enforceUnit, sum } from '../utils'\n\nimport type { CSSProperties } from 'vue'\nimport type { TableV2Props } from '../table'\nimport type { UseColumnsReturn } from './use-columns'\nimport type { UseDataReturn } from './use-data'\n\ntype UseStyleProps = {\n  columnsTotalWidth: UseColumnsReturn['columnsTotalWidth']\n  data: UseDataReturn['data']\n  fixedColumnsOnLeft: UseColumnsReturn['fixedColumnsOnLeft']\n  fixedColumnsOnRight: UseColumnsReturn['fixedColumnsOnRight']\n}\n\nexport const useStyles = (\n  props: TableV2Props,\n  {\n    columnsTotalWidth,\n    data,\n    fixedColumnsOnLeft,\n    fixedColumnsOnRight,\n  }: UseStyleProps\n) => {\n  const bodyWidth = computed(() => {\n    const { fixed, width, vScrollbarSize } = props\n    const ret = width - vScrollbarSize\n    return fixed ? Math.max(Math.round(unref(columnsTotalWidth)), ret) : ret\n  })\n\n  const headerWidth = computed(() => unref(bodyWidth) + props.vScrollbarSize)\n\n  const mainTableHeight = computed(() => {\n    const { height = 0, maxHeight = 0, footerHeight, hScrollbarSize } = props\n\n    if (maxHeight > 0) {\n      const _fixedRowsHeight = unref(fixedRowsHeight)\n      const _rowsHeight = unref(rowsHeight)\n      const _headerHeight = unref(headerHeight)\n      const total =\n        _headerHeight + _fixedRowsHeight + _rowsHeight + hScrollbarSize\n\n      return Math.min(total, maxHeight - footerHeight)\n    }\n\n    return height - footerHeight\n  })\n\n  const rowsHeight = computed(() => {\n    const { rowHeight, estimatedRowHeight } = props\n    const _data = unref(data)\n    if (isNumber(estimatedRowHeight)) {\n      return _data.length * estimatedRowHeight\n    }\n\n    return _data.length * rowHeight\n  })\n\n  const fixedTableHeight = computed(() => {\n    const { maxHeight } = props\n    const tableHeight = unref(mainTableHeight)\n    if (isNumber(maxHeight) && maxHeight > 0) return tableHeight\n\n    const totalHeight =\n      unref(rowsHeight) + unref(headerHeight) + unref(fixedRowsHeight)\n\n    return Math.min(tableHeight, totalHeight)\n  })\n\n  const mapColumn = (column: TableV2Props['columns'][number]) => column.width\n\n  const leftTableWidth = computed(() =>\n    sum(unref(fixedColumnsOnLeft).map(mapColumn))\n  )\n\n  const rightTableWidth = computed(() =>\n    sum(unref(fixedColumnsOnRight).map(mapColumn))\n  )\n\n  const headerHeight = computed(() => sum(props.headerHeight))\n\n  const fixedRowsHeight = computed(() => {\n    return (props.fixedData?.length || 0) * props.rowHeight\n  })\n\n  const windowHeight = computed(() => {\n    return unref(mainTableHeight) - unref(headerHeight) - unref(fixedRowsHeight)\n  })\n\n  const rootStyle = computed<CSSProperties>(() => {\n    const { style = {}, height, width } = props\n    return enforceUnit({\n      ...style,\n      height,\n      width,\n    })\n  })\n\n  const footerHeight = computed(() =>\n    enforceUnit({ height: props.footerHeight })\n  )\n\n  const emptyStyle = computed<CSSProperties>(() => ({\n    top: addUnit(unref(headerHeight)),\n    bottom: addUnit(props.footerHeight),\n    width: addUnit(props.width),\n  }))\n\n  return {\n    bodyWidth,\n    fixedTableHeight,\n    mainTableHeight,\n    leftTableWidth,\n    rightTableWidth,\n    headerWidth,\n    rowsHeight,\n    windowHeight,\n    footerHeight,\n    emptyStyle,\n    rootStyle,\n    headerHeight,\n  }\n}\n\nexport type UseStyleReturn = ReturnType<typeof useStyles>\n", "import { onBeforeUnmount, onMounted, ref, watch } from 'vue'\nimport { useResizeObserver } from '@vueuse/core'\n\nimport type { AutoResizerProps } from '../auto-resizer'\n\nconst useAutoResize = (props: AutoResizerProps) => {\n  const sizer = ref<HTMLElement>()\n  const width$ = ref(0)\n  const height$ = ref(0)\n\n  let resizerStopper: ReturnType<typeof useResizeObserver>['stop']\n  onMounted(() => {\n    resizerStopper = useResizeObserver(sizer, ([entry]) => {\n      const { width, height } = entry.contentRect\n      const { paddingLeft, paddingRight, paddingTop, paddingBottom } =\n        getComputedStyle(entry.target)\n\n      const left = Number.parseInt(paddingLeft) || 0\n      const right = Number.parseInt(paddingRight) || 0\n      const top = Number.parseInt(paddingTop) || 0\n      const bottom = Number.parseInt(paddingBottom) || 0\n\n      width$.value = width - left - right\n      height$.value = height - top - bottom\n    }).stop\n  })\n\n  onBeforeUnmount(() => {\n    resizerStopper?.()\n  })\n\n  watch([width$, height$], ([width, height]) => {\n    props.onResize?.({\n      width,\n      height,\n    })\n  })\n\n  return {\n    sizer,\n    width: width$,\n    height: height$,\n  }\n}\n\nexport { useAutoResize }\n", "import {\n  computed,\n  getCurrentInstance,\n  ref,\n  shallowRef,\n  toRef,\n  unref,\n  watch,\n} from 'vue'\nimport { isArray } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport {\n  useColumns,\n  useData,\n  useRow,\n  useScrollbar,\n  useStyles,\n} from './composables'\n\nimport type { TableV2Props } from './table'\nimport type { TableGridInstance } from './table-grid'\n\nfunction useTable(props: TableV2Props) {\n  const mainTableRef = ref<TableGridInstance>()\n  const leftTableRef = ref<TableGridInstance>()\n  const rightTableRef = ref<TableGridInstance>()\n  const {\n    columns,\n    columnsStyles,\n    columnsTotalWidth,\n    fixedColumnsOnLeft,\n    fixedColumnsOnRight,\n    hasFixedColumns,\n    mainColumns,\n\n    onColumnSorted,\n  } = useColumns(props, toRef(props, 'columns'), toRef(props, 'fixed'))\n\n  const {\n    scrollTo,\n    scrollToLeft,\n    scrollToTop,\n    scrollToRow,\n    onScroll,\n    onVerticalScroll,\n    scrollPos,\n  } = useScrollbar(props, {\n    mainTableRef,\n    leftTableRef,\n    rightTableRef,\n\n    onMaybeEndReached,\n  })\n\n  const ns = useNamespace('table-v2')\n  const instance = getCurrentInstance()!\n\n  // state\n  const isScrolling = shallowRef(false)\n\n  const {\n    expandedRowKeys,\n    lastRenderedRowIndex,\n    isDynamic,\n    isResetting,\n    rowHeights,\n    resetAfterIndex,\n    onRowExpanded,\n    onRowHeightChange,\n    onRowHovered,\n    onRowsRendered,\n  } = useRow(props, {\n    mainTableRef,\n    leftTableRef,\n    rightTableRef,\n    tableInstance: instance,\n    ns,\n    isScrolling,\n  })\n\n  const { data, depthMap } = useData(props, {\n    expandedRowKeys,\n    lastRenderedRowIndex,\n    resetAfterIndex,\n  })\n\n  const {\n    bodyWidth,\n    fixedTableHeight,\n    mainTableHeight,\n    leftTableWidth,\n    rightTableWidth,\n    headerWidth,\n    rowsHeight,\n    windowHeight,\n    footerHeight,\n    emptyStyle,\n    rootStyle,\n    headerHeight,\n  } = useStyles(props, {\n    columnsTotalWidth,\n    data,\n    fixedColumnsOnLeft,\n    fixedColumnsOnRight,\n  })\n\n  // DOM/Component refs\n  const containerRef = ref()\n\n  const showEmpty = computed(() => {\n    const noData = unref(data).length === 0\n\n    return isArray(props.fixedData)\n      ? props.fixedData.length === 0 && noData\n      : noData\n  })\n\n  function getRowHeight(rowIndex: number) {\n    const { estimatedRowHeight, rowHeight, rowKey } = props\n\n    if (!estimatedRowHeight) return rowHeight\n\n    return (\n      unref(rowHeights)[unref(data)[rowIndex][rowKey]] || estimatedRowHeight\n    )\n  }\n\n  function onMaybeEndReached() {\n    const { onEndReached } = props\n    if (!onEndReached) return\n\n    const { scrollTop } = unref(scrollPos)\n\n    const _totalHeight = unref(rowsHeight)\n    const clientHeight = unref(windowHeight)\n\n    const heightUntilEnd =\n      _totalHeight - (scrollTop + clientHeight) + props.hScrollbarSize\n\n    if (\n      unref(lastRenderedRowIndex) >= 0 &&\n      _totalHeight === scrollTop + unref(mainTableHeight) - unref(headerHeight)\n    ) {\n      onEndReached(heightUntilEnd)\n    }\n  }\n\n  // events\n\n  watch(\n    () => props.expandedRowKeys,\n    (val) => (expandedRowKeys.value = val),\n    {\n      deep: true,\n    }\n  )\n\n  return {\n    // models\n    columns,\n    containerRef,\n    mainTableRef,\n    leftTableRef,\n    rightTableRef,\n    // states\n    isDynamic,\n    isResetting,\n    isScrolling,\n    hasFixedColumns,\n    // records\n    columnsStyles,\n    columnsTotalWidth,\n    data,\n    expandedRowKeys,\n    depthMap,\n    fixedColumnsOnLeft,\n    fixedColumnsOnRight,\n    mainColumns,\n    // metadata\n    bodyWidth,\n    emptyStyle,\n    rootStyle,\n    headerWidth,\n    footerHeight,\n    mainTableHeight,\n    fixedTableHeight,\n    leftTableWidth,\n    rightTableWidth,\n    // flags\n    showEmpty,\n\n    // methods\n    getRowHeight,\n\n    // event handlers\n    onColumnSorted,\n    onRowHovered,\n    onRowExpanded,\n    onRowsRendered,\n    onRowHeightChange,\n    // use scrollbars\n    scrollTo,\n    scrollToLeft,\n    scrollToTop,\n    scrollToRow,\n    onScroll,\n    onVerticalScroll,\n  }\n}\n\nexport { useTable }\n\nexport type UseTableReturn = ReturnType<typeof useTable>\n", "import type { InjectionKey, Ref } from 'vue'\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\n\nexport type TableV2Context = {\n  isScrolling: Ref<boolean>\n  isResetting: Ref<boolean>\n  ns: UseNamespaceReturn\n}\n\nexport const TableV2InjectionKey: InjectionKey<TableV2Context> =\n  Symbol('tableV2')\n", "import { definePropType, mutable } from '@element-plus/utils'\n\nimport type { CSSProperties } from 'vue'\nimport type { Column, KeyType } from './types'\n\nexport type AnyColumn = Column<any>\n\n/**\n * @Note even though we can use `string[] | string` as the type but for\n * convenience here we only use `string` as the acceptable value here.\n */\nexport const classType = String\n\nexport const columns = {\n  type: definePropType<AnyColumn[]>(Array),\n  required: true,\n} as const\n\nexport const column = {\n  type: definePropType<AnyColumn>(Object),\n} as const\n\nexport const fixedDataType = {\n  type: definePropType<any[]>(Array),\n} as const\n\nexport const dataType = {\n  ...fixedDataType,\n  required: true,\n} as const\n\nexport const expandColumnKey = String\n\nexport const expandKeys = {\n  type: definePropType<KeyType[]>(Array),\n  default: () => mutable([]),\n} as const\n\nexport const requiredNumber = {\n  type: Number,\n  required: true,\n} as const\n\nexport const rowKey = {\n  type: definePropType<KeyType>([String, Number, Symbol]),\n  default: 'id',\n} as const\n\n/**\n * @note even though we can use `StyleValue` but that would be difficult for us to mapping them,\n * so we only use `CSSProperties` as the acceptable value here.\n */\nexport const styleType = {\n  type: definePropType<CSSProperties>(Object),\n}\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { virtualizedGridProps } from '@element-plus/components/virtual-list'\nimport { columns, expandColumnKey, rowKey } from './common'\n\nimport type { CSSProperties, ExtractPropTypes } from 'vue'\nimport type { FixedDirection, KeyType, RowCommonParams } from './types'\n\nexport type RowExpandParams = {\n  expanded: boolean\n  rowKey: KeyType\n} & RowCommonParams\n\nexport type RowHoverParams = {\n  event: MouseEvent\n  hovered: boolean\n  rowKey: KeyType\n} & RowCommonParams\n\nexport type RowEventHandlerParams = {\n  rowKey: KeyType\n  event: Event\n} & RowCommonParams\n\nexport type RowHeightChangedParams = {\n  rowKey: KeyType\n  height: number\n  rowIndex: number\n}\n\nexport type RowExpandHandler = (params: RowExpandParams) => void\nexport type RowHoverHandler = (params: RowHoverParams) => void\nexport type RowEventHandler = (params: RowEventHandlerParams) => void\nexport type RowHeightChangeHandler = (\n  row: RowHeightChangedParams,\n  fixedDirection: boolean | FixedDirection | undefined\n) => void\n\nexport type RowEventHandlers = {\n  onClick?: RowEventHandler\n  onContextmenu?: RowEventHandler\n  onDblclick?: RowEventHandler\n  onMouseenter?: RowEventHandler\n  onMouseleave?: RowEventHandler\n}\n\nexport const tableV2RowProps = buildProps({\n  class: String,\n  columns,\n  columnsStyles: {\n    type: definePropType<Record<KeyType, CSSProperties>>(Object),\n    required: true,\n  },\n  depth: Number,\n  expandColumnKey,\n  estimatedRowHeight: {\n    ...virtualizedGridProps.estimatedRowHeight,\n    default: undefined,\n  },\n  isScrolling: Boolean,\n  onRowExpand: {\n    type: definePropType<RowExpandHandler>(Function),\n  },\n  onRowHover: {\n    type: definePropType<RowHoverHandler>(Function),\n  },\n  onRowHeightChange: {\n    type: definePropType<RowHeightChangeHandler>(Function),\n  },\n  rowData: {\n    type: definePropType<any>(Object),\n    required: true,\n  },\n  rowEventHandlers: {\n    type: definePropType<RowEventHandlers>(Object),\n  },\n  rowIndex: {\n    type: Number,\n    required: true,\n  },\n  /**\n   * Unique item key\n   */\n  rowKey,\n  style: {\n    type: definePropType<CSSProperties>(Object),\n  },\n} as const)\n\nexport type TableV2RowProps = ExtractPropTypes<typeof tableV2RowProps>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { columns } from './common'\n\nimport type { ExtractPropTypes } from 'vue'\n\nconst requiredNumberType = {\n  type: Number,\n  required: true,\n} as const\n\nexport const tableV2HeaderProps = buildProps({\n  class: String,\n  columns,\n  fixedHeaderData: {\n    type: definePropType<any[]>(Array),\n  },\n  headerData: {\n    type: definePropType<any[]>(Array),\n    required: true,\n  },\n  headerHeight: {\n    type: definePropType<number | number[]>([Number, Array]),\n    default: 50,\n  },\n  rowWidth: requiredNumberType,\n  rowHeight: {\n    type: Number,\n    default: 50,\n  },\n  height: requiredNumberType,\n  width: requiredNumberType,\n} as const)\n\nexport type TableV2HeaderProps = ExtractPropTypes<typeof tableV2HeaderProps>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport {\n  virtualizedGridProps,\n  virtualizedListProps,\n} from '@element-plus/components/virtual-list'\nimport {\n  classType,\n  columns,\n  dataType,\n  fixedDataType,\n  requiredNumber,\n  styleType,\n} from './common'\nimport { tableV2HeaderProps } from './header'\nimport { tableV2RowProps } from './row'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { ItemSize } from '@element-plus/components/virtual-list'\n\nexport type onRowRenderedParams = {\n  rowCacheStart: number\n  rowCacheEnd: number\n  rowVisibleStart: number\n  rowVisibleEnd: number\n}\n\nexport const tableV2GridProps = buildProps({\n  columns,\n  data: dataType,\n  fixedData: fixedDataType,\n  estimatedRowHeight: tableV2RowProps.estimatedRowHeight,\n\n  /**\n   * Size related attributes\n   */\n  width: requiredNumber,\n  height: requiredNumber,\n\n  headerWidth: requiredNumber,\n  headerHeight: tableV2HeaderProps.headerHeight,\n\n  bodyWidth: requiredNumber,\n  rowHeight: requiredNumber,\n\n  /**\n   * Special attributes\n   */\n  cache: virtualizedListProps.cache,\n  useIsScrolling: Boolean,\n  scrollbarAlwaysOn: virtualizedGridProps.scrollbarAlwaysOn,\n  scrollbarStartGap: virtualizedGridProps.scrollbarStartGap,\n  scrollbarEndGap: virtualizedGridProps.scrollbarEndGap,\n\n  /**\n   * CSS attributes\n   */\n  class: classType,\n  style: styleType,\n  containerStyle: styleType,\n\n  getRowHeight: {\n    type: definePropType<ItemSize>(Function),\n    required: true,\n  },\n  rowKey: tableV2RowProps.rowKey,\n\n  /**\n   * Event handlers\n   */\n  onRowsRendered: {\n    type: definePropType<(params: onRowRenderedParams) => void>(Function),\n  },\n  onScroll: {\n    type: definePropType<(...args: any[]) => void>(Function),\n  },\n} as const)\n\nexport type TableV2GridProps = ExtractPropTypes<typeof tableV2GridProps>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport {\n  virtualizedGridProps,\n  virtualizedScrollbarProps,\n} from '@element-plus/components/virtual-list'\nimport {\n  classType,\n  columns,\n  dataType,\n  expandKeys,\n  fixedDataType,\n  requiredNumber,\n  rowKey,\n} from './common'\nimport { tableV2RowProps } from './row'\nimport { tableV2HeaderProps } from './header'\nimport { tableV2GridProps } from './grid'\n\nimport type { CSSProperties, ExtractPropTypes } from 'vue'\nimport type { SortOrder } from './constants'\nimport type {\n  Column,\n  ColumnCommonParams,\n  DataGetter,\n  KeyType,\n  RowCommonParams,\n  SortBy,\n  SortState,\n} from './types'\n\n/**\n * Param types\n */\nexport type ColumnSortParams<T> = {\n  column: Column<T>\n  key: KeyType\n  order: SortOrder\n}\n\n/**\n * Renderer/Getter types\n */\n\nexport type ExtraCellPropGetter<T> = (\n  params: ColumnCommonParams<T> &\n    RowCommonParams & { cellData: T; rowData: any }\n) => any\n\nexport type ExtractHeaderPropGetter<T> = (params: {\n  columns: Column<T>[]\n  headerIndex: number\n}) => any\n\nexport type ExtractHeaderCellPropGetter<T> = (\n  params: ColumnCommonParams<T> & { headerIndex: number }\n) => any\n\nexport type ExtractRowPropGetter<T> = (\n  params: { columns: Column<T>[] } & RowCommonParams\n) => any\n\nexport type HeaderClassNameGetter<T> = (params: {\n  columns: Column<T>[]\n  headerIndex: number\n}) => string\n\nexport type RowClassNameGetter<T> = (\n  params: { columns: Column<T>[] } & RowCommonParams\n) => string\n\n/**\n * Handler types\n */\nexport type ColumnSortHandler<T> = (params: ColumnSortParams<T>) => void\nexport type ColumnResizeHandler<T> = (column: Column<T>, width: number) => void\nexport type ExpandedRowsChangeHandler = (expandedRowKeys: KeyType[]) => void\n\nexport const tableV2Props = buildProps({\n  cache: tableV2GridProps.cache,\n  estimatedRowHeight: tableV2RowProps.estimatedRowHeight,\n  rowKey,\n  // Header attributes\n  headerClass: {\n    type: definePropType<string | HeaderClassNameGetter<any>>([\n      String,\n      Function,\n    ]),\n  },\n  headerProps: {\n    type: definePropType<any | ExtractHeaderPropGetter<any>>([\n      Object,\n      Function,\n    ]),\n  },\n  headerCellProps: {\n    type: definePropType<any | ExtractHeaderCellPropGetter<any>>([\n      Object,\n      Function,\n    ]),\n  },\n  headerHeight: tableV2HeaderProps.headerHeight,\n  /**\n   * Footer attributes\n   */\n  footerHeight: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * Row attributes\n   */\n  rowClass: {\n    type: definePropType<string | RowClassNameGetter<any>>([String, Function]),\n  },\n  rowProps: {\n    type: definePropType<ExtractRowPropGetter<any> | any>([Object, Function]),\n  },\n  rowHeight: {\n    type: Number,\n    default: 50,\n  },\n\n  /**\n   * Cell attributes\n   */\n  cellProps: {\n    type: definePropType<Record<string, any> | ExtraCellPropGetter<any>>([\n      Object,\n      Function,\n    ]),\n  },\n  /**\n   * Data models\n   */\n  columns,\n  data: dataType,\n  dataGetter: {\n    type: definePropType<DataGetter<any>>(Function),\n  },\n  fixedData: fixedDataType,\n  /**\n   * Expanded keys\n   */\n  expandColumnKey: tableV2RowProps.expandColumnKey,\n  expandedRowKeys: expandKeys,\n  defaultExpandedRowKeys: expandKeys,\n\n  /**\n   * Attributes\n   */\n  class: classType,\n  // disabled: Boolean,\n  fixed: Boolean,\n  style: {\n    type: definePropType<CSSProperties>(Object),\n  },\n  width: requiredNumber,\n  height: requiredNumber,\n  maxHeight: Number,\n  useIsScrolling: Boolean,\n  indentSize: {\n    type: Number,\n    default: 12,\n  },\n  iconSize: {\n    type: Number,\n    default: 12,\n  },\n  hScrollbarSize: virtualizedGridProps.hScrollbarSize,\n  vScrollbarSize: virtualizedGridProps.vScrollbarSize,\n  scrollbarAlwaysOn: virtualizedScrollbarProps.alwaysOn,\n\n  /**\n   * Sorting\n   */\n  sortBy: {\n    type: definePropType<SortBy>(Object),\n    default: () => ({} as { key: KeyType; order: SortOrder }),\n  },\n  sortState: {\n    type: definePropType<SortState>(Object),\n    default: undefined,\n  },\n\n  /**\n   * Handlers\n   */\n  onColumnSort: {\n    type: definePropType<ColumnSortHandler<any>>(Function),\n  },\n  onExpandedRowsChange: {\n    type: definePropType<ExpandedRowsChangeHandler>(Function),\n  },\n  onEndReached: {\n    type: definePropType<(distance: number) => void>(Function),\n  },\n  onRowExpand: tableV2RowProps.onRowExpand,\n  onScroll: tableV2GridProps.onScroll,\n  onRowsRendered: tableV2GridProps.onRowsRendered,\n  rowEventHandlers: tableV2RowProps.rowEventHandlers,\n} as const)\n\nexport type TableV2Props = ExtractPropTypes<typeof tableV2Props>\n", "import { renderSlot } from 'vue'\nimport type { FunctionalComponent } from 'vue'\nimport type { TableV2CellProps } from '../cell'\n\nconst TableV2Cell: FunctionalComponent<TableV2CellProps> = (\n  props: TableV2CellProps,\n  { slots }\n) => {\n  const { cellData, style } = props\n  const displayText = cellData?.toString?.() || ''\n  const defaultSlot = renderSlot(slots, 'default', props, () => [displayText])\n  return (\n    <div class={props.class} title={displayText} style={style}>\n      {defaultSlot}\n    </div>\n  )\n}\n\nTableV2Cell.displayName = 'ElTableV2Cell'\nTableV2Cell.inheritAttrs = false\n\nexport default TableV2Cell\n", "import { renderSlot } from 'vue'\nimport type { FunctionalComponent } from 'vue'\nimport type { TableV2HeaderCell } from '../header-cell'\n\nconst HeaderCell: FunctionalComponent<TableV2HeaderCell> = (props, { slots }) =>\n  renderSlot(slots, 'default', props, () => [\n    <div class={props.class} title={props.column?.title}>\n      {props.column?.title}\n    </div>,\n  ])\n\nHeaderCell.displayName = 'ElTableV2HeaderCell'\nHeaderCell.inheritAttrs = false\n\nexport default HeaderCell\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { columns } from './common'\n\nimport type { CSSProperties, ExtractPropTypes } from 'vue'\nimport type { KeyType } from './types'\n\nexport const tableV2HeaderRowProps = buildProps({\n  class: String,\n  columns,\n  columnsStyles: {\n    type: definePropType<Record<KeyType, CSSProperties>>(Object),\n    required: true,\n  },\n  headerIndex: Number,\n  style: { type: definePropType<CSSProperties>(Object) },\n} as const)\n\nexport type TableV2HeaderRowProps = ExtractPropTypes<\n  typeof tableV2HeaderRowProps\n>\n", "import { defineComponent } from 'vue'\nimport { isArray } from '@element-plus/utils'\nimport { tableV2HeaderRowProps } from '../header-row'\n\nimport type { CSSProperties } from 'vue'\nimport type { ColumnCellsType } from '../types'\nimport type { TableV2HeaderRowProps } from '../header-row'\n\nconst TableV2HeaderRow = defineComponent({\n  name: 'ElTableV2HeaderRow',\n  props: tableV2HeaderRowProps,\n  setup(props, { slots }) {\n    return () => {\n      const { columns, columnsStyles, headerIndex, style } = props\n      let Cells: ColumnCellsType = columns.map((column, columnIndex) => {\n        return slots.cell!({\n          columns,\n          column,\n          columnIndex,\n          headerIndex,\n          style: columnsStyles[column.key!],\n        })\n      })\n\n      if (slots.header) {\n        Cells = slots.header({\n          cells: Cells.map((node) => {\n            if (isArray(node) && node.length === 1) {\n              return node[0]\n            }\n            return node\n          }),\n          columns,\n          headerIndex,\n        })\n      }\n\n      return (\n        <div class={props.class} style={style} role=\"row\">\n          {Cells}\n        </div>\n      )\n    }\n  },\n})\n\nexport default TableV2HeaderRow\n\nexport type TableV2HeaderRowCellRendererParams = {\n  columns: TableV2HeaderRowProps['columns']\n  column: TableV2HeaderRowProps['columns'][number]\n  columnIndex: number\n  headerIndex: number\n  style: CSSProperties\n}\n\nexport type TableV2HeaderRowRendererParams = {\n  cells: ColumnCellsType\n  columns: TableV2HeaderRowProps['columns']\n  headerIndex: number\n}\n", "import { computed, defineComponent, nextTick, ref, unref } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { ensureArray } from '@element-plus/utils'\nimport { tableV2HeaderProps } from '../header'\nimport { enforceUnit } from '../utils'\n\nimport type { CSSProperties, UnwrapRef } from 'vue'\nimport type { TableV2HeaderProps } from '../header'\nimport type { UseColumnsReturn } from '../composables/use-columns'\n\nconst COMPONENT_NAME = 'ElTableV2Header'\nconst TableV2Header = defineComponent({\n  name: COMPONENT_NAME,\n  props: tableV2HeaderProps,\n  setup(props, { slots, expose }) {\n    const ns = useNamespace('table-v2')\n\n    const headerRef = ref<HTMLElement>()\n\n    const headerStyle = computed(() =>\n      enforceUnit({\n        width: props.width,\n        height: props.height,\n      })\n    )\n\n    const rowStyle = computed(() =>\n      enforceUnit({\n        width: props.rowWidth,\n        height: props.height,\n      })\n    )\n\n    const headerHeights = computed(() => ensureArray(unref(props.headerHeight)))\n\n    const scrollToLeft = (left?: number) => {\n      const headerEl = unref(headerRef)\n      nextTick(() => {\n        headerEl?.scroll &&\n          headerEl.scroll({\n            left,\n          })\n      })\n    }\n\n    const renderFixedRows = () => {\n      const fixedRowClassName = ns.e('fixed-header-row')\n\n      const { columns, fixedHeaderData, rowHeight } = props\n\n      return fixedHeaderData?.map((fixedRowData, fixedRowIndex) => {\n        const style: CSSProperties = enforceUnit({\n          height: rowHeight,\n          width: '100%',\n        })\n\n        return slots.fixed?.({\n          class: fixedRowClassName,\n          columns,\n          rowData: fixedRowData,\n          rowIndex: -(fixedRowIndex + 1),\n          style,\n        })\n      })\n    }\n\n    const renderDynamicRows = () => {\n      const dynamicRowClassName = ns.e('dynamic-header-row')\n      const { columns } = props\n\n      return unref(headerHeights).map((rowHeight, rowIndex) => {\n        const style: CSSProperties = enforceUnit({\n          width: '100%',\n          height: rowHeight,\n        })\n\n        return slots.dynamic?.({\n          class: dynamicRowClassName,\n          columns,\n          headerIndex: rowIndex,\n          style,\n        })\n      })\n    }\n\n    expose({\n      /**\n       * @description scroll to position based on the provided value\n       */\n      scrollToLeft,\n    })\n\n    return () => {\n      if (props.height <= 0) return\n\n      return (\n        <div\n          ref={headerRef}\n          class={props.class}\n          style={unref(headerStyle)}\n          role=\"rowgroup\"\n        >\n          <div style={unref(rowStyle)} class={ns.e('header')}>\n            {renderDynamicRows()}\n            {renderFixedRows()}\n          </div>\n        </div>\n      )\n    }\n  },\n})\n\nexport default TableV2Header\n\nexport type TableV2HeaderInstance = InstanceType<typeof TableV2Header> & {\n  /**\n   * @description scroll to position based on the provided value\n   */\n  scrollToLeft: (left?: number) => void\n}\n\nexport type TableV2HeaderRendererParams = {\n  class: string\n  columns: TableV2HeaderProps['columns']\n  columnsStyles: UnwrapRef<UseColumnsReturn['columnsStyles']>\n  headerIndex: number\n  style: CSSProperties\n}\n\nexport type TableV2HeaderRowRendererParams = {\n  rowData: any\n  rowIndex: number\n} & Omit<TableV2HeaderRendererParams, 'headerIndex'>\n", "import {\n  computed,\n  defineComponent,\n  inject,\n  nextTick,\n  onMounted,\n  ref,\n  unref,\n} from 'vue'\nimport { isArray, isFunction, isNumber } from '@element-plus/utils'\nimport { tableV2RowProps } from '../row'\nimport { TableV2InjectionKey } from '../tokens'\nimport { placeholderSign } from '../private'\n\nimport type { CSSProperties, RendererElement, RendererNode, VNode } from 'vue'\nimport type { RowEventHandlers, TableV2RowProps } from '../row'\n\ntype CustomizedCellsType = VNode<\n  RendererNode,\n  RendererElement,\n  {\n    [key: string]: any\n  }\n>[]\n\ntype DefaultCellsType = VNode<\n  RendererNode,\n  RendererElement,\n  {\n    [key: string]: any\n  }\n>[][]\n\ntype ColumnCellsType = DefaultCellsType | CustomizedCellsType\n\nconst useTableRow = (props: TableV2RowProps) => {\n  const { isScrolling } = inject(TableV2InjectionKey)!\n\n  const measured = ref(false)\n  const rowRef = ref<HTMLElement>()\n  const measurable = computed(() => {\n    return isNumber(props.estimatedRowHeight) && props.rowIndex >= 0\n  })\n\n  const doMeasure = (isInit = false) => {\n    const $rowRef = unref(rowRef)\n    if (!$rowRef) return\n    const { columns, onRowHeightChange, rowKey, rowIndex, style } = props\n    const { height } = $rowRef.getBoundingClientRect()\n    measured.value = true\n\n    nextTick(() => {\n      if (isInit || height !== Number.parseInt(style!.height as string)) {\n        const firstColumn = columns[0]\n        const isPlaceholder = firstColumn?.placeholderSign === placeholderSign\n        onRowHeightChange?.(\n          { rowKey, height, rowIndex },\n          firstColumn && !isPlaceholder && firstColumn.fixed\n        )\n      }\n    })\n  }\n\n  const eventHandlers = computed(() => {\n    const { rowData, rowIndex, rowKey, onRowHover } = props\n    const handlers = props.rowEventHandlers || ({} as RowEventHandlers)\n    const eventHandlers = {} as {\n      [key in keyof RowEventHandlers]: (e: Event) => void\n    }\n\n    Object.entries(handlers).forEach(([eventName, handler]) => {\n      if (isFunction(handler)) {\n        eventHandlers[eventName as keyof RowEventHandlers] = (event: Event) => {\n          handler({\n            event,\n            rowData,\n            rowIndex,\n            rowKey,\n          })\n        }\n      }\n    })\n\n    if (onRowHover) {\n      ;(\n        [\n          { name: 'onMouseleave', hovered: false },\n          { name: 'onMouseenter', hovered: true },\n        ] as const\n      ).forEach(({ name, hovered }) => {\n        const existedHandler = eventHandlers[name]\n        eventHandlers[name] = ((event: MouseEvent) => {\n          onRowHover({\n            event,\n            hovered,\n            rowData,\n            rowIndex,\n            rowKey,\n          })\n\n          existedHandler?.(event)\n        }) as any\n      })\n    }\n    return eventHandlers\n  })\n\n  const onExpand = (expanded: boolean) => {\n    const { onRowExpand, rowData, rowIndex, rowKey } = props\n\n    onRowExpand?.({\n      expanded,\n      rowData,\n      rowIndex,\n      rowKey,\n    })\n  }\n\n  onMounted(() => {\n    if (unref(measurable)) {\n      doMeasure(true)\n    }\n  })\n\n  return { isScrolling, measurable, measured, rowRef, eventHandlers, onExpand }\n}\n\nconst COMPONENT_NAME = 'ElTableV2TableRow'\n\nconst TableV2Row = defineComponent({\n  name: COMPONENT_NAME,\n  props: tableV2RowProps,\n  setup(props, { expose, slots, attrs }) {\n    const {\n      eventHandlers,\n      isScrolling,\n      measurable,\n      measured,\n      rowRef,\n\n      onExpand,\n    } = useTableRow(props)\n\n    expose({\n      /**\n       * @description manually dispatching expand action on row.\n       */\n      onExpand,\n    })\n\n    return () => {\n      const {\n        columns,\n        columnsStyles,\n        expandColumnKey,\n        depth,\n        rowData,\n        rowIndex,\n        style,\n      } = props\n\n      let ColumnCells: ColumnCellsType = columns.map((column, columnIndex) => {\n        const expandable =\n          isArray(rowData.children) &&\n          rowData.children.length > 0 &&\n          column.key === expandColumnKey\n\n        return slots.cell!({\n          column,\n          columns,\n          columnIndex,\n          depth,\n          style: columnsStyles[column.key!],\n          rowData,\n          rowIndex,\n          isScrolling: unref(isScrolling),\n          expandIconProps: expandable\n            ? {\n                rowData,\n                rowIndex,\n                onExpand,\n              }\n            : undefined,\n        })\n      })\n\n      if (slots.row) {\n        ColumnCells = slots.row({\n          cells: ColumnCells.map((node) => {\n            if (isArray(node) && node.length === 1) {\n              return node[0]\n            }\n            return node\n          }),\n          style,\n          columns,\n          depth,\n          rowData,\n          rowIndex,\n          isScrolling: unref(isScrolling),\n        })\n      }\n\n      if (unref(measurable)) {\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        const { height, ...exceptHeightStyle } = style || {}\n        const _measured = unref(measured)\n        return (\n          <div\n            ref={rowRef}\n            class={props.class}\n            style={_measured ? style : exceptHeightStyle}\n            role=\"row\"\n            {...attrs}\n            {...unref(eventHandlers)}\n          >\n            {ColumnCells}\n          </div>\n        )\n      }\n\n      return (\n        <div\n          {...attrs}\n          ref={rowRef}\n          class={props.class}\n          style={style}\n          role=\"row\"\n          {...unref(eventHandlers)}\n        >\n          {ColumnCells}\n        </div>\n      )\n    }\n  },\n})\n\nexport default TableV2Row\n\nexport type TableV2RowCellRenderParam = {\n  column: TableV2RowProps['columns'][number]\n  columns: TableV2RowProps['columns']\n  columnIndex: number\n  depth: number\n  style: CSSProperties\n  rowData: any\n  rowIndex: number\n  isScrolling: boolean\n  expandIconProps?: {\n    rowData: any\n    rowIndex: number\n    onExpand: (expand: boolean) => void\n  }\n}\n", "import ElIcon from '@element-plus/components/icon'\nimport { SortDown, SortUp } from '@element-plus/icons-vue'\nimport { SortOrder } from '../constants'\n\nimport type { FunctionalComponent } from 'vue'\n\nexport type SortIconProps = {\n  sortOrder: SortOrder\n  class?: JSX.IntrinsicAttributes['class']\n}\n\nconst SortIcon: FunctionalComponent<SortIconProps> = (props) => {\n  const { sortOrder } = props\n\n  return (\n    <ElIcon size={14} class={props.class}>\n      {sortOrder === SortOrder.ASC ? <SortUp /> : <SortDown />}\n    </ElIcon>\n  )\n}\n\nexport default SortIcon\n", "import ElIcon from '@element-plus/components/icon'\nimport { ArrowRight } from '@element-plus/icons-vue'\n\nimport type { StyleValue } from 'vue'\nimport type { TableV2RowCellRenderParam } from './row'\n\nconst ExpandIcon = (\n  props: TableV2RowCellRenderParam['expandIconProps'] & {\n    class?: string | string[]\n    style: StyleValue\n    size: number\n    expanded: boolean\n    expandable: boolean\n  }\n) => {\n  const { expanded, expandable, onExpand, style, size } = props\n\n  const expandIconProps = {\n    onClick: expandable ? () => onExpand(!expanded) : undefined,\n    class: props.class,\n  } as any\n\n  return (\n    <ElIcon {...expandIconProps} size={size} style={style}>\n      <ArrowRight />\n    </ElIcon>\n  )\n}\n\nexport default ExpandIcon\n\nexport type ExpandIconInstance = ReturnType<typeof ExpandIcon>\n", "import { computed, defineComponent, inject, ref, unref } from 'vue'\nimport {\n  DynamicSizeGrid,\n  FixedSizeGrid,\n} from '@element-plus/components/virtual-list'\nimport { isNumber, isObject } from '@element-plus/utils'\nimport { Header } from './components'\nimport { TableV2InjectionKey } from './tokens'\nimport { tableV2GridProps } from './grid'\nimport { sum } from './utils'\n\nimport type { UnwrapRef } from 'vue'\nimport type {\n  DynamicSizeGridInstance,\n  GridDefaultSlotParams,\n  GridItemKeyGetter,\n  GridItemRenderedEvtParams,\n  GridScrollOptions,\n  ResetAfterIndex,\n  Alignment as ScrollStrategy,\n} from '@element-plus/components/virtual-list'\nimport type { TableV2HeaderInstance } from './components'\nimport type { TableV2GridProps } from './grid'\n\nconst COMPONENT_NAME = 'ElTableV2Grid'\n\nconst useTableGrid = (props: TableV2GridProps) => {\n  const headerRef = ref<TableV2HeaderInstance>()\n  const bodyRef = ref<DynamicSizeGridInstance>()\n\n  const totalHeight = computed(() => {\n    const { data, rowHeight, estimatedRowHeight } = props\n\n    if (estimatedRowHeight) {\n      return\n    }\n\n    return data.length * (rowHeight as number)\n  })\n\n  const fixedRowHeight = computed(() => {\n    const { fixedData, rowHeight } = props\n\n    return (fixedData?.length || 0) * (rowHeight as number)\n  })\n\n  const headerHeight = computed(() => sum(props.headerHeight))\n\n  const gridHeight = computed(() => {\n    const { height } = props\n    return Math.max(0, height - unref(headerHeight) - unref(fixedRowHeight))\n  })\n\n  const hasHeader = computed(() => {\n    return unref(headerHeight) + unref(fixedRowHeight) > 0\n  })\n\n  const itemKey: GridItemKeyGetter = ({ data, rowIndex }) =>\n    data[rowIndex][props.rowKey]\n\n  function onItemRendered({\n    rowCacheStart,\n    rowCacheEnd,\n    rowVisibleStart,\n    rowVisibleEnd,\n  }: GridItemRenderedEvtParams) {\n    props.onRowsRendered?.({\n      rowCacheStart,\n      rowCacheEnd,\n      rowVisibleStart,\n      rowVisibleEnd,\n    })\n  }\n\n  function resetAfterRowIndex(index: number, forceUpdate: boolean) {\n    bodyRef.value?.resetAfterRowIndex(index, forceUpdate)\n  }\n\n  function scrollTo(x: number, y: number): void\n  function scrollTo(options: GridScrollOptions): void\n  function scrollTo(leftOrOptions: number | GridScrollOptions, top?: number) {\n    const header$ = unref(headerRef)\n    const body$ = unref(bodyRef)\n\n    if (isObject(leftOrOptions)) {\n      header$?.scrollToLeft(leftOrOptions.scrollLeft)\n      body$?.scrollTo(leftOrOptions)\n    } else {\n      header$?.scrollToLeft(leftOrOptions)\n      body$?.scrollTo({\n        scrollLeft: leftOrOptions,\n        scrollTop: top,\n      })\n    }\n  }\n\n  function scrollToTop(scrollTop: number) {\n    unref(bodyRef)?.scrollTo({\n      scrollTop,\n    })\n  }\n\n  function scrollToRow(row: number, strategy: ScrollStrategy) {\n    unref(bodyRef)?.scrollToItem(row, 1, strategy)\n  }\n\n  function forceUpdate() {\n    unref(bodyRef)?.$forceUpdate()\n    unref(headerRef)?.$forceUpdate()\n  }\n\n  return {\n    bodyRef,\n    forceUpdate,\n    fixedRowHeight,\n    gridHeight,\n    hasHeader,\n    headerHeight,\n    headerRef,\n    totalHeight,\n\n    itemKey,\n    onItemRendered,\n    resetAfterRowIndex,\n    scrollTo,\n    scrollToTop,\n    scrollToRow,\n  }\n}\n\nconst TableGrid = defineComponent({\n  name: COMPONENT_NAME,\n  props: tableV2GridProps,\n  setup(props, { slots, expose }) {\n    const { ns } = inject(TableV2InjectionKey)!\n\n    const {\n      bodyRef,\n      fixedRowHeight,\n      gridHeight,\n      hasHeader,\n      headerRef,\n      headerHeight,\n      totalHeight,\n\n      forceUpdate,\n      itemKey,\n      onItemRendered,\n      resetAfterRowIndex,\n      scrollTo,\n      scrollToTop,\n      scrollToRow,\n    } = useTableGrid(props)\n\n    expose({\n      forceUpdate,\n      /**\n       * @description fetch total height\n       */\n      totalHeight,\n      /**\n       * @description scroll to a position\n       */\n      scrollTo,\n      /**\n       * @description scroll vertically to position y\n       */\n      scrollToTop,\n      /**\n       * @description scroll to a given row\n       * @params row {Number} which row to scroll to\n       * @params strategy {ScrollStrategy} use what strategy to scroll to\n       */\n      scrollToRow,\n      /**\n       * @description reset rendered state after row index\n       */\n      resetAfterRowIndex,\n    })\n\n    const getColumnWidth = () => props.bodyWidth\n\n    return () => {\n      const {\n        cache,\n        columns,\n        data,\n        fixedData,\n        useIsScrolling,\n        scrollbarAlwaysOn,\n        scrollbarEndGap,\n        scrollbarStartGap,\n        style,\n        rowHeight,\n        bodyWidth,\n        estimatedRowHeight,\n        headerWidth,\n        height,\n        width,\n\n        getRowHeight,\n        onScroll,\n      } = props\n\n      const isDynamicRowEnabled = isNumber(estimatedRowHeight)\n      const Grid = isDynamicRowEnabled ? DynamicSizeGrid : FixedSizeGrid\n      const _headerHeight = unref(headerHeight)\n\n      return (\n        <div role=\"table\" class={[ns.e('table'), props.class]} style={style}>\n          <Grid\n            ref={bodyRef}\n            // special attrs\n            data={data}\n            useIsScrolling={useIsScrolling}\n            itemKey={itemKey}\n            // column attrs\n            columnCache={0}\n            columnWidth={isDynamicRowEnabled ? getColumnWidth : bodyWidth}\n            totalColumn={1}\n            // row attrs\n            totalRow={data.length}\n            rowCache={cache}\n            rowHeight={isDynamicRowEnabled ? getRowHeight : rowHeight}\n            // DOM attrs\n            width={width}\n            height={unref(gridHeight)}\n            class={ns.e('body')}\n            role=\"rowgroup\"\n            scrollbarStartGap={scrollbarStartGap}\n            scrollbarEndGap={scrollbarEndGap}\n            scrollbarAlwaysOn={scrollbarAlwaysOn}\n            // handlers\n            onScroll={onScroll}\n            onItemRendered={onItemRendered}\n            perfMode={false}\n          >\n            {{\n              default: (params: GridDefaultSlotParams) => {\n                const rowData = data[params.rowIndex]\n                return slots.row?.({\n                  ...params,\n                  columns,\n                  rowData,\n                })\n              },\n            }}\n          </Grid>\n          {unref(hasHeader) && (\n            <Header\n              ref={headerRef}\n              class={ns.e('header-wrapper')}\n              columns={columns}\n              headerData={data}\n              headerHeight={props.headerHeight}\n              fixedHeaderData={fixedData}\n              rowWidth={headerWidth}\n              rowHeight={rowHeight}\n              width={width}\n              height={Math.min(_headerHeight + unref(fixedRowHeight), height)}\n            >\n              {{\n                dynamic: slots.header,\n                fixed: slots.row,\n              }}\n            </Header>\n          )}\n        </div>\n      )\n    }\n  },\n})\n\nexport default TableGrid\n\nexport type TableGridRowSlotParams = {\n  columns: TableV2GridProps['columns']\n  rowData: any\n} & GridDefaultSlotParams\n\nexport type TableGridInstance = InstanceType<typeof TableGrid> &\n  UnwrapRef<{\n    forceUpdate: () => void\n    /**\n     * @description fetch total height\n     */\n    totalHeight: number\n\n    /**\n     * @description scrollTo a position\n     * @param { number | ScrollToOptions } arg1\n     * @param { number } arg2\n     */\n    scrollTo(leftOrOptions: number | GridScrollOptions, top?: number): void\n\n    /**\n     * @description scroll vertically to position y\n     */\n    scrollToTop(scrollTop: number): void\n    /**\n     * @description scroll to a given row\n     * @params row {Number} which row to scroll to\n     * @params @optional strategy {ScrollStrategy} use what strategy to scroll to\n     */\n    scrollToRow(row: number, strategy: ScrollStrategy): void\n    /**\n     * @description reset rendered state after row index\n     * @param { number } rowIndex\n     * @param { boolean } forceUpdate\n     */\n    resetAfterRowIndex: ResetAfterIndex\n  }>\n", "import Table from '../table-grid'\n\nimport type { FunctionalComponent, Ref } from 'vue'\nimport type { TableV2GridProps } from '../grid'\nimport type { TableGridInstance } from '../table-grid'\n\nexport type MainTableRendererProps = TableV2GridProps & {\n  mainTableRef: Ref<TableGridInstance | undefined>\n}\n\nconst MainTable: FunctionalComponent<MainTableRendererProps> = (\n  props: MainTableRendererProps,\n  { slots }\n) => {\n  const { mainTableRef, ...rest } = props\n  return (\n    <Table ref={mainTableRef} {...rest}>\n      {slots}\n    </Table>\n  )\n}\n\nexport default MainTable\n", "import Table from '../table-grid'\n\nimport type { FunctionalComponent, Ref } from 'vue'\nimport type { TableV2GridProps } from '../grid'\nimport type { TableGridInstance } from '../table-grid'\n\ntype LeftTableProps = TableV2GridProps & {\n  leftTableRef: Ref<TableGridInstance | undefined>\n}\n\nconst LeftTable: FunctionalComponent<LeftTableProps> = (props, { slots }) => {\n  if (!props.columns.length) return\n\n  const { leftTableRef, ...rest } = props\n\n  return (\n    <Table ref={leftTableRef} {...rest}>\n      {slots}\n    </Table>\n  )\n}\n\nexport default LeftTable\n", "import Table from '../table-grid'\n\nimport type { FunctionalComponent, Ref } from 'vue'\nimport type { TableV2GridProps } from '../grid'\nimport type { TableGridInstance } from '../table-grid'\n\ntype LeftTableProps = TableV2GridProps & {\n  rightTableRef: Ref<TableGridInstance | undefined>\n}\n\nconst LeftTable: FunctionalComponent<LeftTableProps> = (props, { slots }) => {\n  if (!props.columns.length) return\n\n  const { rightTableRef, ...rest } = props\n\n  return (\n    <Table ref={rightTableRef} {...rest}>\n      {slots}\n    </Table>\n  )\n}\n\nexport default LeftTable\n", "import { Row } from '../components'\nimport { tryCall } from '../utils'\n\nimport type {\n  ComponentInternalInstance,\n  FunctionalComponent,\n  UnwrapNestedRefs,\n} from 'vue'\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\nimport type { UseTableReturn } from '../use-table'\nimport type { TableV2Props } from '../table'\nimport type { TableGridRowSlotParams } from '../table-grid'\n\ntype RowRendererProps = TableGridRowSlotParams &\n  Pick<\n    TableV2Props,\n    | 'expandColumnKey'\n    | 'estimatedRowHeight'\n    | 'rowProps'\n    | 'rowClass'\n    | 'rowKey'\n    | 'rowEventHandlers'\n  > &\n  UnwrapNestedRefs<\n    Pick<\n      UseTableReturn,\n      | 'depthMap'\n      | 'expandedRowKeys'\n      | 'hasFixedColumns'\n      | 'onRowHovered'\n      | 'onRowExpanded'\n      | 'columnsStyles'\n    >\n  > & {\n    ns: UseNamespaceReturn\n    tableInstance: null | ComponentInternalInstance\n  }\n\nconst RowRenderer: FunctionalComponent<RowRendererProps> = (\n  props,\n  { slots }\n) => {\n  const {\n    columns,\n    columnsStyles,\n    depthMap,\n    expandColumnKey,\n    expandedRowKeys,\n    estimatedRowHeight,\n    hasFixedColumns,\n    rowData,\n    rowIndex,\n    style,\n    isScrolling,\n    rowProps,\n    rowClass,\n    rowKey,\n    rowEventHandlers,\n    ns,\n    onRowHovered,\n    onRowExpanded,\n  } = props\n\n  const rowKls = tryCall(rowClass, { columns, rowData, rowIndex }, '')\n  const additionalProps = tryCall(rowProps, {\n    columns,\n    rowData,\n    rowIndex,\n  })\n  const _rowKey = rowData[rowKey]\n  const depth = depthMap[_rowKey] || 0\n  const canExpand = Boolean(expandColumnKey)\n  const isFixedRow = rowIndex < 0\n  const kls = [\n    ns.e('row'),\n    rowKls,\n    {\n      [ns.e(`row-depth-${depth}`)]: canExpand && rowIndex >= 0,\n      [ns.is('expanded')]: canExpand && expandedRowKeys.includes(_rowKey),\n      [ns.is('fixed')]: !depth && isFixedRow,\n      [ns.is('customized')]: Boolean(slots.row),\n    },\n  ]\n\n  const onRowHover = hasFixedColumns ? onRowHovered : undefined\n\n  const _rowProps = {\n    ...additionalProps,\n    columns,\n    columnsStyles,\n    class: kls,\n    depth,\n    expandColumnKey,\n    estimatedRowHeight: isFixedRow ? undefined : estimatedRowHeight,\n    isScrolling,\n    rowIndex,\n    rowData,\n    rowKey: _rowKey,\n    rowEventHandlers,\n    style,\n  }\n\n  const handlerMosueEnter = (e: MouseEvent) => {\n    onRowHover?.({\n      hovered: true,\n      rowKey: _rowKey,\n      event: e,\n      rowData,\n      rowIndex,\n    })\n  }\n\n  const handlerMouseLeave = (e: MouseEvent) => {\n    onRowHover?.({\n      hovered: false,\n      rowKey: _rowKey,\n      event: e,\n      rowData,\n      rowIndex,\n    })\n  }\n\n  return (\n    <Row\n      {..._rowProps}\n      onRowExpand={onRowExpanded}\n      onMouseenter={handlerMosueEnter}\n      onMouseleave={handlerMouseLeave}\n      rowkey={_rowKey}\n    >\n      {slots}\n    </Row>\n  )\n}\n\nexport default RowRenderer\n", "import { renderSlot } from 'vue'\nimport { get } from 'lodash-unified'\nimport { isFunction, isObject } from '@element-plus/utils'\nimport { ExpandIcon, TableCell } from '../components'\nimport { Alignment } from '../constants'\nimport { placeholderSign } from '../private'\nimport { componentToSlot, enforceUnit, tryCall } from '../utils'\n\nimport type { FunctionalComponent, UnwrapNestedRefs, VNode } from 'vue'\nimport type { TableV2RowCellRenderParam } from '../components'\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\nimport type { UseTableReturn } from '../use-table'\nimport type { TableV2Props } from '../table'\n\ntype CellRendererProps = TableV2RowCellRenderParam &\n  Pick<\n    TableV2Props,\n    'cellProps' | 'expandColumnKey' | 'indentSize' | 'iconSize' | 'rowKey'\n  > &\n  UnwrapNestedRefs<Pick<UseTableReturn, 'expandedRowKeys'>> & {\n    ns: UseNamespaceReturn\n  }\n\nconst CellRenderer: FunctionalComponent<CellRendererProps> = (\n  {\n    // renderer props\n    columns,\n    column,\n    columnIndex,\n    depth,\n    expandIconProps,\n    isScrolling,\n    rowData,\n    rowIndex,\n    // from use-table\n    style,\n    expandedRowKeys,\n    ns,\n    // derived props\n    cellProps: _cellProps,\n    expandColumnKey,\n    indentSize,\n    iconSize,\n    rowKey,\n  },\n  { slots }\n) => {\n  const cellStyle = enforceUnit(style)\n\n  if (column.placeholderSign === placeholderSign) {\n    return <div class={ns.em('row-cell', 'placeholder')} style={cellStyle} />\n  }\n  const { cellRenderer, dataKey, dataGetter } = column\n\n  const cellData = isFunction(dataGetter)\n    ? dataGetter({ columns, column, columnIndex, rowData, rowIndex })\n    : get(rowData, dataKey ?? '')\n\n  const extraCellProps = tryCall(_cellProps, {\n    cellData,\n    columns,\n    column,\n    columnIndex,\n    rowIndex,\n    rowData,\n  })\n\n  const cellProps = {\n    class: ns.e('cell-text'),\n    columns,\n    column,\n    columnIndex,\n    cellData,\n    isScrolling,\n    rowData,\n    rowIndex,\n  }\n  const columnCellRenderer = componentToSlot<typeof cellProps>(cellRenderer)\n  const Cell = columnCellRenderer\n    ? columnCellRenderer(cellProps)\n    : renderSlot(slots, 'default', cellProps, () => [\n        <TableCell {...cellProps}></TableCell>,\n      ])\n\n  const kls = [\n    ns.e('row-cell'),\n    column.class,\n    column.align === Alignment.CENTER && ns.is('align-center'),\n    column.align === Alignment.RIGHT && ns.is('align-right'),\n  ]\n\n  const expandable =\n    rowIndex >= 0 && expandColumnKey && column.key === expandColumnKey\n  const expanded = rowIndex >= 0 && expandedRowKeys.includes(rowData[rowKey])\n\n  let IconOrPlaceholder: VNode | undefined\n  const iconStyle = `margin-inline-start: ${depth * indentSize}px;`\n  if (expandable) {\n    if (isObject(expandIconProps)) {\n      IconOrPlaceholder = (\n        <ExpandIcon\n          {...expandIconProps}\n          class={[ns.e('expand-icon'), ns.is('expanded', expanded)]}\n          size={iconSize}\n          expanded={expanded}\n          style={iconStyle}\n          expandable\n        />\n      )\n    } else {\n      IconOrPlaceholder = (\n        <div\n          style={[\n            iconStyle,\n            `width: ${iconSize}px; height: ${iconSize}px;`,\n          ].join(' ')}\n        />\n      )\n    }\n  }\n\n  return (\n    <div class={kls} style={cellStyle} {...extraCellProps} role=\"cell\">\n      {IconOrPlaceholder}\n      {Cell}\n    </div>\n  )\n}\n\nCellRenderer.inheritAttrs = false\n\nexport default CellRenderer\n", "import { HeaderRow } from '../components'\nimport { tryCall } from '../utils'\n\nimport type { FunctionalComponent } from 'vue'\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\nimport type { TableV2HeaderRendererParams } from '../components'\nimport type { TableV2Props } from '../table'\n\ntype HeaderRendererProps = TableV2HeaderRendererParams &\n  Pick<TableV2Props, 'headerClass' | 'headerProps'> & {\n    ns: UseNamespaceReturn\n  }\n\nconst HeaderRenderer: FunctionalComponent<HeaderRendererProps> = (\n  {\n    columns,\n    columnsStyles,\n    headerIndex,\n    style,\n    // derived from root\n    headerClass,\n    headerProps,\n\n    ns,\n  },\n  { slots }\n) => {\n  const param = { columns, headerIndex }\n\n  const kls = [\n    ns.e('header-row'),\n    tryCall(headerClass, param, ''),\n    {\n      // [ns.is('resizing')]: Boolean(resizingKey),\n      [ns.is('customized')]: Boolean(slots.header),\n    },\n  ]\n\n  const extraProps = {\n    ...tryCall(headerProps, param),\n    columnsStyles,\n    class: kls,\n    columns,\n    headerIndex,\n    style,\n  }\n\n  return <HeaderRow {...extraProps}>{slots}</HeaderRow>\n}\n\nexport default HeaderRenderer\n", "import { renderSlot } from 'vue'\nimport { HeaderCell, SortIcon } from '../components'\n// import ColumnResizer from '../table-column-resizer'\nimport { Alignment, SortOrder, oppositeOrderMap } from '../constants'\nimport { placeholderSign } from '../private'\nimport { componentToSlot, enforceUnit, tryCall } from '../utils'\n\nimport type { FunctionalComponent, UnwrapNestedRefs } from 'vue'\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\nimport type { TableV2HeaderRowCellRendererParams } from '../components'\nimport type { UseTableReturn } from '../use-table'\nimport type { TableV2Props } from '../table'\n\nexport type HeaderCellRendererProps = TableV2HeaderRowCellRendererParams &\n  UnwrapNestedRefs<Pick<UseTableReturn, 'onColumnSorted'>> &\n  Pick<TableV2Props, 'sortBy' | 'sortState' | 'headerCellProps'> & {\n    ns: UseNamespaceReturn\n  }\n\nconst HeaderCellRenderer: FunctionalComponent<HeaderCellRendererProps> = (\n  props,\n  { slots }\n) => {\n  const { column, ns, style, onColumnSorted } = props\n\n  const cellStyle = enforceUnit(style)\n\n  if (column.placeholderSign === placeholderSign) {\n    return (\n      <div class={ns.em('header-row-cell', 'placeholder')} style={cellStyle} />\n    )\n  }\n\n  const { headerCellRenderer, headerClass, sortable } = column\n\n  /**\n   * render Cell children\n   */\n\n  const cellProps = {\n    ...props,\n    class: ns.e('header-cell-text'),\n  }\n\n  const columnCellRenderer =\n    componentToSlot<typeof cellProps>(headerCellRenderer)\n\n  const Cell = columnCellRenderer\n    ? columnCellRenderer(cellProps)\n    : renderSlot(slots, 'default', cellProps, () => [\n        <HeaderCell {...cellProps} />,\n      ])\n\n  /**\n   * Render cell container and sort indicator\n   */\n  const { sortBy, sortState, headerCellProps } = props\n\n  let sorting: boolean, sortOrder: SortOrder\n  if (sortState) {\n    const order = sortState[column.key!]\n    sorting = Boolean(oppositeOrderMap[order])\n    sortOrder = sorting ? order : SortOrder.ASC\n  } else {\n    sorting = column.key === sortBy.key\n    sortOrder = sorting ? sortBy.order : SortOrder.ASC\n  }\n\n  const cellKls = [\n    ns.e('header-cell'),\n    tryCall(headerClass, props, ''),\n    column.align === Alignment.CENTER && ns.is('align-center'),\n    column.align === Alignment.RIGHT && ns.is('align-right'),\n    sortable && ns.is('sortable'),\n  ]\n\n  const cellWrapperProps = {\n    ...tryCall(headerCellProps, props),\n    onClick: column.sortable ? onColumnSorted : undefined,\n    class: cellKls,\n    style: cellStyle,\n    ['data-key']: column.key,\n  }\n\n  // For now we don't deliver resizable column feature since it has some UX issue.\n  return (\n    <div {...cellWrapperProps} role=\"columnheader\">\n      {Cell}\n\n      {sortable && (\n        <SortIcon\n          class={[ns.e('sort-icon'), sorting && ns.is('sorting')]}\n          sortOrder={sortOrder}\n        />\n      )}\n    </div>\n  )\n}\n\nexport default HeaderCellRenderer\nexport type HeaderCellSlotProps = HeaderCellRendererProps & { class: string }\n", "import type { CSSProperties, FunctionalComponent } from 'vue'\n\ntype FooterRendererProps = {\n  class?: JSX.IntrinsicAttributes['class']\n  style: CSSProperties\n}\n\nconst Footer: FunctionalComponent<FooterRendererProps> = (props, { slots }) => {\n  return (\n    <div class={props.class} style={props.style}>\n      {slots.default?.()}\n    </div>\n  )\n}\n\nFooter.displayName = 'ElTableV2Footer'\n\nexport default Footer\n", "import { renderSlot } from 'vue'\nimport ElEmpty from '@element-plus/components/empty'\nimport type { CSSProperties, FunctionalComponent } from 'vue'\n\ntype EmptyRendererProps = {\n  class?: JSX.IntrinsicAttributes['class']\n  style?: CSSProperties\n}\n\nconst Footer: FunctionalComponent<EmptyRendererProps> = (props, { slots }) => {\n  const defaultSlot = renderSlot(slots, 'default', {}, () => [<ElEmpty />])\n  return (\n    <div class={props.class} style={props.style}>\n      {defaultSlot}\n    </div>\n  )\n}\n\nFooter.displayName = 'ElTableV2Empty'\n\nexport default Footer\n", "import type { SimpleFunctionalComponent } from '../types'\n\nconst Overlay: SimpleFunctionalComponent = (props, { slots }) => {\n  return (\n    <div class={props.class} style={props.style}>\n      {slots.default?.()}\n    </div>\n  )\n}\n\nOverlay.displayName = 'ElTableV2Overlay'\n\nexport default Overlay\n", "// @ts-nocheck\nimport { defineComponent, provide, unref } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useTable } from './use-table'\nimport { TableV2InjectionKey } from './tokens'\nimport { tableV2Props } from './table'\n// renderers\nimport MainTable from './renderers/main-table'\nimport LeftTable from './renderers/left-table'\nimport RightTable from './renderers/right-table'\nimport Row from './renderers/row'\nimport Cell from './renderers/cell'\nimport Header from './renderers/header'\nimport HeaderCell from './renderers/header-cell'\nimport Footer from './renderers/footer'\nimport Empty from './renderers/empty'\nimport Overlay from './renderers/overlay'\n\nimport type { TableGridRowSlotParams } from './table-grid'\nimport type { ScrollStrategy } from './composables/use-scrollbar'\nimport type {\n  TableV2HeaderRendererParams,\n  TableV2HeaderRowCellRendererParams,\n  TableV2RowCellRenderParam,\n} from './components'\n\nconst COMPONENT_NAME = 'ElTableV2'\n\nconst TableV2 = defineComponent({\n  name: COMPONENT_NAME,\n  props: tableV2Props,\n  setup(props, { slots, expose }) {\n    const ns = useNamespace('table-v2')\n\n    const {\n      columnsStyles,\n      fixedColumnsOnLeft,\n      fixedColumnsOnRight,\n      mainColumns,\n      mainTableHeight,\n      fixedTableHeight,\n      leftTableWidth,\n      rightTableWidth,\n      data,\n      depthMap,\n      expandedRowKeys,\n      hasFixedColumns,\n      mainTableRef,\n      leftTableRef,\n      rightTableRef,\n      isDynamic,\n      isResetting,\n      isScrolling,\n\n      bodyWidth,\n      emptyStyle,\n      rootStyle,\n      headerWidth,\n      footerHeight,\n\n      showEmpty,\n\n      // exposes\n      scrollTo,\n      scrollToLeft,\n      scrollToTop,\n      scrollToRow,\n\n      getRowHeight,\n      onColumnSorted,\n      onRowHeightChange,\n      onRowHovered,\n      onRowExpanded,\n      onRowsRendered,\n      onScroll,\n      onVerticalScroll,\n    } = useTable(props)\n\n    expose({\n      /**\n       * @description scroll to a given position\n       * @params params {{ scrollLeft?: number, scrollTop?: number }} where to scroll to.\n       */\n      scrollTo,\n      /**\n       * @description scroll to a given position horizontally\n       * @params scrollLeft {Number} where to scroll to.\n       */\n      scrollToLeft,\n      /**\n       * @description scroll to a given position vertically\n       * @params scrollTop { Number } where to scroll to.\n       */\n      scrollToTop,\n      /**\n       * @description scroll to a given row\n       * @params row {Number} which row to scroll to\n       * @params @optional strategy {ScrollStrategy} use what strategy to scroll to\n       */\n      scrollToRow,\n    })\n\n    provide(TableV2InjectionKey, {\n      ns,\n      isResetting,\n      isScrolling,\n    })\n\n    return () => {\n      const {\n        cache,\n        cellProps,\n        estimatedRowHeight,\n        expandColumnKey,\n        fixedData,\n        headerHeight,\n        headerClass,\n        headerProps,\n        headerCellProps,\n        sortBy,\n        sortState,\n        rowHeight,\n        rowClass,\n        rowEventHandlers,\n        rowKey,\n        rowProps,\n        scrollbarAlwaysOn,\n        indentSize,\n        iconSize,\n        useIsScrolling,\n        vScrollbarSize,\n        width,\n      } = props\n\n      const _data = unref(data)\n\n      const mainTableProps = {\n        cache,\n        class: ns.e('main'),\n        columns: unref(mainColumns),\n        data: _data,\n        fixedData,\n        estimatedRowHeight,\n        bodyWidth: unref(bodyWidth) + vScrollbarSize,\n        headerHeight,\n        headerWidth: unref(headerWidth),\n        height: unref(mainTableHeight),\n        mainTableRef,\n        rowKey,\n        rowHeight,\n        scrollbarAlwaysOn,\n        scrollbarStartGap: 2,\n        scrollbarEndGap: vScrollbarSize,\n        useIsScrolling,\n        width,\n        getRowHeight,\n        onRowsRendered,\n        onScroll,\n      }\n\n      const leftColumnsWidth = unref(leftTableWidth)\n      const _fixedTableHeight = unref(fixedTableHeight)\n\n      const leftTableProps = {\n        cache,\n        class: ns.e('left'),\n        columns: unref(fixedColumnsOnLeft),\n        data: _data,\n        estimatedRowHeight,\n        leftTableRef,\n        rowHeight,\n        bodyWidth: leftColumnsWidth,\n        headerWidth: leftColumnsWidth,\n        headerHeight,\n        height: _fixedTableHeight,\n        rowKey,\n        scrollbarAlwaysOn,\n        scrollbarStartGap: 2,\n        scrollbarEndGap: vScrollbarSize,\n        useIsScrolling,\n        width: leftColumnsWidth,\n        getRowHeight,\n        onScroll: onVerticalScroll,\n      }\n\n      const rightColumnsWidth = unref(rightTableWidth)\n      const rightColumnsWidthWithScrollbar = rightColumnsWidth + vScrollbarSize\n\n      const rightTableProps = {\n        cache,\n        class: ns.e('right'),\n        columns: unref(fixedColumnsOnRight),\n        data: _data,\n        estimatedRowHeight,\n        rightTableRef,\n        rowHeight,\n        bodyWidth: rightColumnsWidthWithScrollbar,\n        headerWidth: rightColumnsWidthWithScrollbar,\n        headerHeight,\n        height: _fixedTableHeight,\n        rowKey,\n        scrollbarAlwaysOn,\n        scrollbarStartGap: 2,\n        scrollbarEndGap: vScrollbarSize,\n        width: rightColumnsWidthWithScrollbar,\n        style: `--${unref(\n          ns.namespace\n        )}-table-scrollbar-size: ${vScrollbarSize}px`,\n        useIsScrolling,\n        getRowHeight,\n        onScroll: onVerticalScroll,\n      }\n      const _columnsStyles = unref(columnsStyles)\n\n      const tableRowProps = {\n        ns,\n        depthMap: unref(depthMap),\n        columnsStyles: _columnsStyles,\n        expandColumnKey,\n        expandedRowKeys: unref(expandedRowKeys),\n        estimatedRowHeight,\n        hasFixedColumns: unref(hasFixedColumns),\n        rowProps,\n        rowClass,\n        rowKey,\n        rowEventHandlers,\n        onRowHovered,\n        onRowExpanded,\n        onRowHeightChange,\n      }\n\n      const tableCellProps = {\n        cellProps,\n        expandColumnKey,\n        indentSize,\n        iconSize,\n        rowKey,\n        expandedRowKeys: unref(expandedRowKeys),\n        ns,\n      }\n\n      const tableHeaderProps = {\n        ns,\n        headerClass,\n        headerProps,\n        columnsStyles: _columnsStyles,\n      }\n\n      const tableHeaderCellProps = {\n        ns,\n\n        sortBy,\n        sortState,\n        headerCellProps,\n        onColumnSorted,\n      }\n\n      const tableSlots = {\n        row: (props: TableGridRowSlotParams) => (\n          <Row {...props} {...tableRowProps}>\n            {{\n              row: slots.row,\n              cell: (props: TableV2RowCellRenderParam) =>\n                slots.cell ? (\n                  <Cell\n                    {...props}\n                    {...tableCellProps}\n                    style={_columnsStyles[props.column.key]}\n                  >\n                    {slots.cell(props)}\n                  </Cell>\n                ) : (\n                  <Cell\n                    {...props}\n                    {...tableCellProps}\n                    style={_columnsStyles[props.column.key]}\n                  />\n                ),\n            }}\n          </Row>\n        ),\n        header: (props: TableV2HeaderRendererParams) => (\n          <Header {...props} {...tableHeaderProps}>\n            {{\n              header: slots.header,\n              cell: (props: TableV2HeaderRowCellRendererParams) =>\n                slots['header-cell'] ? (\n                  <HeaderCell\n                    {...props}\n                    {...tableHeaderCellProps}\n                    style={_columnsStyles[props.column.key]}\n                  >\n                    {slots['header-cell'](props)}\n                  </HeaderCell>\n                ) : (\n                  <HeaderCell\n                    {...props}\n                    {...tableHeaderCellProps}\n                    style={_columnsStyles[props.column.key]}\n                  />\n                ),\n            }}\n          </Header>\n        ),\n      }\n\n      const rootKls = [\n        props.class,\n        ns.b(),\n        ns.e('root'),\n        {\n          [ns.is('dynamic')]: unref(isDynamic),\n        },\n      ]\n\n      const footerProps = {\n        class: ns.e('footer'),\n        style: unref(footerHeight),\n      }\n\n      return (\n        <div class={rootKls} style={unref(rootStyle)}>\n          <MainTable {...mainTableProps}>{tableSlots}</MainTable>\n          <LeftTable {...leftTableProps}>{tableSlots}</LeftTable>\n          <RightTable {...rightTableProps}>{tableSlots}</RightTable>\n          {slots.footer && (\n            <Footer {...footerProps}>{{ default: slots.footer }}</Footer>\n          )}\n          {unref(showEmpty) && (\n            <Empty class={ns.e('empty')} style={unref(emptyStyle)}>\n              {{ default: slots.empty }}\n            </Empty>\n          )}\n          {slots.overlay && (\n            <Overlay class={ns.e('overlay')}>\n              {{ default: slots.overlay }}\n            </Overlay>\n          )}\n        </div>\n      )\n    }\n  },\n})\n\nexport default TableV2\n\nexport type TableV2Instance = InstanceType<typeof TableV2> & {\n  /**\n   * @description scroll to a given position\n   * @params params {{ scrollLeft?: number, scrollTop?: number }} where to scroll to.\n   */\n  scrollTo: (param: { scrollLeft?: number; scrollTop?: number }) => void\n  /**\n   * @description scroll to a given position horizontally\n   * @params scrollLeft {Number} where to scroll to.\n   */\n  scrollToLeft: (scrollLeft: number) => void\n  /**\n   * @description scroll to a given position vertically\n   * @params scrollTop { Number } where to scroll to.\n   */\n  scrollToTop: (scrollTop: number) => void\n  /**\n   * @description scroll to a given row\n   * @params row {Number} which row to scroll to\n   * @params strategy {ScrollStrategy} use what strategy to scroll to\n   */\n  scrollToRow(row: number, strategy?: ScrollStrategy): void\n}\n", "import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\n\ntype AutoResizeHandler = (event: { height: number; width: number }) => void\n\nexport const autoResizerProps = buildProps({\n  disableWidth: Boolean,\n  disableHeight: Boolean,\n  onResize: {\n    type: definePropType<AutoResizeHandler>(Function),\n  },\n} as const)\n\nexport type AutoResizerProps = ExtractPropTypes<typeof autoResizerProps>\n", "import { defineComponent } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { autoResizerProps } from '../auto-resizer'\nimport { useAutoResize } from '../composables'\n\nconst AutoResizer = defineComponent({\n  name: 'ElAutoResizer',\n  props: autoResizerProps,\n  setup(props, { slots }) {\n    const ns = useNamespace('auto-resizer')\n    const { height, width, sizer } = useAutoResize(props)\n    const style = {\n      width: '100%',\n      height: '100%',\n    }\n\n    return () => {\n      return (\n        <div ref={sizer} class={ns.b()} style={style}>\n          {slots.default?.({\n            height: height.value,\n            width: width.value,\n          })}\n        </div>\n      )\n    }\n  },\n})\n\nexport default AutoResizer\n", "import { withInstall } from '@element-plus/utils'\nimport TableV2 from './src/table-v2'\nimport AutoResizer from './src/components/auto-resizer'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport {\n  Alignment as TableV2Alignment,\n  FixedDir as TableV2FixedDir,\n  SortOrder as TableV2SortOrder,\n} from './src/constants'\nexport { default as TableV2 } from './src/table-v2'\nexport * from './src/auto-resizer'\nexport { placeholderSign as TableV2Placeholder } from './src/private'\n\nexport const ElTableV2: SFCWithInstall<typeof TableV2> = withInstall(TableV2)\nexport const ElAutoResizer: SFCWithInstall<typeof AutoResizer> =\n  withInstall(AutoResizer)\n\nexport type {\n  Column,\n  Columns,\n  SortBy,\n  SortState,\n  TableV2CustomizedHeaderSlotParam,\n} from './src/types'\nexport type { TableV2Instance } from './src/table-v2'\nexport * from './src/table'\nexport * from './src/row'\n\nexport type { HeaderCellSlotProps } from './src/renderers/header-cell'\n", "import type { ComputedRef, InjectionKey, Ref, Slots, UnwrapRef } from 'vue'\nimport type { TabsProps } from './tabs'\nimport type { TabPaneProps } from './tab-pane'\n\nexport type TabsPaneContext = UnwrapRef<{\n  uid: number\n  slots: Slots\n  props: TabPaneProps\n  paneName: ComputedRef<string | number | undefined>\n  active: ComputedRef<boolean>\n  index: Ref<string | undefined>\n  isClosable: ComputedRef<boolean>\n}>\n\nexport interface TabsRootContext {\n  props: TabsProps\n  currentName: Ref<string | number>\n  registerPane: (pane: TabsPaneContext) => void\n  sortPane: (pane: TabsPaneContext) => void\n  unregisterPane: (uid: number) => void\n}\n\nexport const tabsRootContextKey: InjectionKey<TabsRootContext> =\n  Symbol('tabsRootContextKey')\n", "import { buildProps, definePropType, mutable } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type { TabsPaneContext } from './constants'\nimport type TabBar from './tab-bar.vue'\n\nexport const tabBarProps = buildProps({\n  tabs: {\n    type: definePropType<TabsPaneContext[]>(Array),\n    default: () => mutable([] as const),\n  },\n} as const)\n\nexport type TabBarProps = ExtractPropTypes<typeof tabBarProps>\nexport type TabBarInstance = InstanceType<typeof TabBar>\n", "<template>\n  <div\n    ref=\"barRef\"\n    :class=\"[ns.e('active-bar'), ns.is(rootTabs.props.tabPosition)]\"\n    :style=\"barStyle\"\n  />\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  getCurrentInstance,\n  inject,\n  nextTick,\n  onBeforeUnmount,\n  ref,\n  watch,\n} from 'vue'\nimport { useResizeObserver } from '@vueuse/core'\nimport { capitalize, throwError } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { tabsRootContextKey } from './constants'\nimport { tabBarProps } from './tab-bar'\n\nimport type { CSSProperties } from 'vue'\n\nconst COMPONENT_NAME = 'ElTabBar'\ndefineOptions({\n  name: COMPONENT_NAME,\n})\nconst props = defineProps(tabBarProps)\n\nconst instance = getCurrentInstance()!\nconst rootTabs = inject(tabsRootContextKey)\nif (!rootTabs) throwError(COMPONENT_NAME, '<el-tabs><el-tab-bar /></el-tabs>')\n\nconst ns = useNamespace('tabs')\n\nconst barRef = ref<HTMLDivElement>()\nconst barStyle = ref<CSSProperties>()\n\nconst getBarStyle = (): CSSProperties => {\n  let offset = 0\n  let tabSize = 0\n\n  const sizeName = ['top', 'bottom'].includes(rootTabs.props.tabPosition)\n    ? 'width'\n    : 'height'\n  const sizeDir = sizeName === 'width' ? 'x' : 'y'\n  const position = sizeDir === 'x' ? 'left' : 'top'\n\n  props.tabs.every((tab) => {\n    const $el = instance.parent?.refs?.[`tab-${tab.uid}`] as HTMLElement\n    if (!$el) return false\n\n    if (!tab.active) {\n      return true\n    }\n\n    offset = $el[`offset${capitalize(position)}`]\n    tabSize = $el[`client${capitalize(sizeName)}`]\n\n    const tabStyles = window.getComputedStyle($el)\n\n    if (sizeName === 'width') {\n      tabSize -=\n        Number.parseFloat(tabStyles.paddingLeft) +\n        Number.parseFloat(tabStyles.paddingRight)\n      offset += Number.parseFloat(tabStyles.paddingLeft)\n    }\n    return false\n  })\n\n  return {\n    [sizeName]: `${tabSize}px`,\n    transform: `translate${capitalize(sizeDir)}(${offset}px)`,\n  }\n}\n\nconst update = () => (barStyle.value = getBarStyle())\n\nconst saveObserver = [] as ReturnType<typeof useResizeObserver>[]\nconst observerTabs = () => {\n  saveObserver.forEach((observer) => observer.stop())\n  saveObserver.length = 0\n  const list = instance.parent?.refs as Record<string, HTMLElement>\n  if (!list) return\n  for (const key in list) {\n    if (key.startsWith('tab-')) {\n      const _el = list[key]\n      if (_el) {\n        saveObserver.push(useResizeObserver(_el, update))\n      }\n    }\n  }\n}\n\nwatch(\n  () => props.tabs,\n  async () => {\n    await nextTick()\n    update()\n\n    observerTabs()\n  },\n  { immediate: true }\n)\nconst barObserever = useResizeObserver(barRef, () => update())\n\nonBeforeUnmount(() => {\n  saveObserver.forEach((observer) => observer.stop())\n  saveObserver.length = 0\n  barObserever.stop()\n})\n\ndefineExpose({\n  /** @description tab root html element */\n  ref: barRef,\n  /** @description method to manually update tab bar style */\n  update,\n})\n</script>\n", "import {\n  computed,\n  defineComponent,\n  inject,\n  nextTick,\n  onMounted,\n  onUpdated,\n  ref,\n  watch,\n} from 'vue'\nimport {\n  useDocumentVisibility,\n  useResizeObserver,\n  useWindowFocus,\n} from '@vueuse/core'\nimport {\n  buildProps,\n  capitalize,\n  definePropType,\n  mutable,\n  throwError,\n} from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { ArrowLeft, ArrowRight, Close } from '@element-plus/icons-vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport TabBar from './tab-bar.vue'\nimport { tabsRootContextKey } from './constants'\n\nimport type { CSSProperties, ExtractPropTypes } from 'vue'\nimport type { TabsPaneContext } from './constants'\nimport type { TabPaneName } from './tabs'\n\ninterface Scrollable {\n  next?: boolean\n  prev?: number\n}\n\nexport const tabNavProps = buildProps({\n  panes: {\n    type: definePropType<TabsPaneContext[]>(Array),\n    default: () => mutable([] as const),\n  },\n  currentName: {\n    type: [String, Number],\n    default: '',\n  },\n  editable: Boolean,\n  type: {\n    type: String,\n    values: ['card', 'border-card', ''],\n    default: '',\n  },\n  stretch: Boolean,\n} as const)\n\nexport const tabNavEmits = {\n  tabClick: (tab: TabsPaneContext, tabName: TabPaneName, ev: Event) =>\n    ev instanceof Event,\n  tabRemove: (tab: TabsPaneContext, ev: Event) => ev instanceof Event,\n}\n\nexport type TabNavProps = ExtractPropTypes<typeof tabNavProps>\nexport type TabNavEmits = typeof tabNavEmits\n\nconst COMPONENT_NAME = 'ElTabNav'\nconst TabNav = defineComponent({\n  name: COMPONENT_NAME,\n  props: tabNavProps,\n  emits: tabNavEmits,\n  setup(props, { expose, emit }) {\n    const rootTabs = inject(tabsRootContextKey)\n    if (!rootTabs) throwError(COMPONENT_NAME, `<el-tabs><tab-nav /></el-tabs>`)\n\n    const ns = useNamespace('tabs')\n    const visibility = useDocumentVisibility()\n    const focused = useWindowFocus()\n\n    const navScroll$ = ref<HTMLDivElement>()\n    const nav$ = ref<HTMLDivElement>()\n    const el$ = ref<HTMLDivElement>()\n\n    const tabBarRef = ref<InstanceType<typeof TabBar>>()\n\n    const scrollable = ref<false | Scrollable>(false)\n    const navOffset = ref(0)\n    const isFocus = ref(false)\n    const focusable = ref(true)\n\n    const sizeName = computed(() =>\n      ['top', 'bottom'].includes(rootTabs.props.tabPosition)\n        ? 'width'\n        : 'height'\n    )\n    const navStyle = computed<CSSProperties>(() => {\n      const dir = sizeName.value === 'width' ? 'X' : 'Y'\n      return {\n        transform: `translate${dir}(-${navOffset.value}px)`,\n      }\n    })\n\n    const scrollPrev = () => {\n      if (!navScroll$.value) return\n\n      const containerSize =\n        navScroll$.value[`offset${capitalize(sizeName.value)}`]\n      const currentOffset = navOffset.value\n\n      if (!currentOffset) return\n\n      const newOffset =\n        currentOffset > containerSize ? currentOffset - containerSize : 0\n\n      navOffset.value = newOffset\n    }\n\n    const scrollNext = () => {\n      if (!navScroll$.value || !nav$.value) return\n\n      const navSize = nav$.value[`offset${capitalize(sizeName.value)}`]\n      const containerSize =\n        navScroll$.value[`offset${capitalize(sizeName.value)}`]\n      const currentOffset = navOffset.value\n\n      if (navSize - currentOffset <= containerSize) return\n\n      const newOffset =\n        navSize - currentOffset > containerSize * 2\n          ? currentOffset + containerSize\n          : navSize - containerSize\n\n      navOffset.value = newOffset\n    }\n\n    const scrollToActiveTab = async () => {\n      const nav = nav$.value\n      if (!scrollable.value || !el$.value || !navScroll$.value || !nav) return\n\n      await nextTick()\n\n      const activeTab = el$.value.querySelector('.is-active')\n      if (!activeTab) return\n\n      const navScroll = navScroll$.value\n      const isHorizontal = ['top', 'bottom'].includes(\n        rootTabs.props.tabPosition\n      )\n      const activeTabBounding = activeTab.getBoundingClientRect()\n      const navScrollBounding = navScroll.getBoundingClientRect()\n      const maxOffset = isHorizontal\n        ? nav.offsetWidth - navScrollBounding.width\n        : nav.offsetHeight - navScrollBounding.height\n      const currentOffset = navOffset.value\n      let newOffset = currentOffset\n\n      if (isHorizontal) {\n        if (activeTabBounding.left < navScrollBounding.left) {\n          newOffset =\n            currentOffset - (navScrollBounding.left - activeTabBounding.left)\n        }\n        if (activeTabBounding.right > navScrollBounding.right) {\n          newOffset =\n            currentOffset + activeTabBounding.right - navScrollBounding.right\n        }\n      } else {\n        if (activeTabBounding.top < navScrollBounding.top) {\n          newOffset =\n            currentOffset - (navScrollBounding.top - activeTabBounding.top)\n        }\n        if (activeTabBounding.bottom > navScrollBounding.bottom) {\n          newOffset =\n            currentOffset +\n            (activeTabBounding.bottom - navScrollBounding.bottom)\n        }\n      }\n      newOffset = Math.max(newOffset, 0)\n      navOffset.value = Math.min(newOffset, maxOffset)\n    }\n\n    const update = () => {\n      if (!nav$.value || !navScroll$.value) return\n\n      props.stretch && tabBarRef.value?.update()\n\n      const navSize = nav$.value[`offset${capitalize(sizeName.value)}`]\n      const containerSize =\n        navScroll$.value[`offset${capitalize(sizeName.value)}`]\n      const currentOffset = navOffset.value\n\n      if (containerSize < navSize) {\n        scrollable.value = scrollable.value || {}\n        scrollable.value.prev = currentOffset\n        scrollable.value.next = currentOffset + containerSize < navSize\n        if (navSize - currentOffset < containerSize) {\n          navOffset.value = navSize - containerSize\n        }\n      } else {\n        scrollable.value = false\n        if (currentOffset > 0) {\n          navOffset.value = 0\n        }\n      }\n    }\n\n    const changeTab = (e: KeyboardEvent) => {\n      const code = e.code\n\n      const { up, down, left, right } = EVENT_CODE\n      if (![up, down, left, right].includes(code)) return\n\n      // 左右上下键更换tab\n      const tabList = Array.from(\n        (e.currentTarget as HTMLDivElement).querySelectorAll<HTMLDivElement>(\n          '[role=tab]:not(.is-disabled)'\n        )\n      )\n      const currentIndex = tabList.indexOf(e.target as HTMLDivElement)\n\n      let nextIndex: number\n      if (code === left || code === up) {\n        // left\n        if (currentIndex === 0) {\n          // first\n          nextIndex = tabList.length - 1\n        } else {\n          nextIndex = currentIndex - 1\n        }\n      } else {\n        // right\n        if (currentIndex < tabList.length - 1) {\n          // not last\n          nextIndex = currentIndex + 1\n        } else {\n          nextIndex = 0\n        }\n      }\n      tabList[nextIndex].focus({ preventScroll: true }) // 改变焦点元素\n      tabList[nextIndex].click() // 选中下一个tab\n      setFocus()\n    }\n\n    const setFocus = () => {\n      if (focusable.value) isFocus.value = true\n    }\n    const removeFocus = () => (isFocus.value = false)\n\n    watch(visibility, (visibility) => {\n      if (visibility === 'hidden') {\n        focusable.value = false\n      } else if (visibility === 'visible') {\n        setTimeout(() => (focusable.value = true), 50)\n      }\n    })\n    watch(focused, (focused) => {\n      if (focused) {\n        setTimeout(() => (focusable.value = true), 50)\n      } else {\n        focusable.value = false\n      }\n    })\n\n    useResizeObserver(el$, update)\n\n    onMounted(() => setTimeout(() => scrollToActiveTab(), 0))\n    onUpdated(() => update())\n\n    expose({\n      scrollToActiveTab,\n      removeFocus,\n    })\n\n    return () => {\n      const scrollBtn = scrollable.value\n        ? [\n            <span\n              class={[\n                ns.e('nav-prev'),\n                ns.is('disabled', !scrollable.value.prev),\n              ]}\n              onClick={scrollPrev}\n            >\n              <ElIcon>\n                <ArrowLeft />\n              </ElIcon>\n            </span>,\n            <span\n              class={[\n                ns.e('nav-next'),\n                ns.is('disabled', !scrollable.value.next),\n              ]}\n              onClick={scrollNext}\n            >\n              <ElIcon>\n                <ArrowRight />\n              </ElIcon>\n            </span>,\n          ]\n        : null\n\n      const tabs = props.panes.map((pane, index) => {\n        const uid = pane.uid\n        const disabled = pane.props.disabled\n        const tabName = pane.props.name ?? pane.index ?? `${index}`\n        const closable = !disabled && (pane.isClosable || props.editable)\n        pane.index = `${index}`\n\n        const btnClose = closable ? (\n          <ElIcon\n            class=\"is-icon-close\"\n            // `onClick` not exist when generate dts\n            // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n            // @ts-ignore\n            onClick={(ev: MouseEvent) => emit('tabRemove', pane, ev)}\n          >\n            <Close />\n          </ElIcon>\n        ) : null\n\n        const tabLabelContent = pane.slots.label?.() || pane.props.label\n        const tabindex = !disabled && pane.active ? 0 : -1\n\n        return (\n          <div\n            ref={`tab-${uid}`}\n            class={[\n              ns.e('item'),\n              ns.is(rootTabs.props.tabPosition),\n              ns.is('active', pane.active),\n              ns.is('disabled', disabled),\n              ns.is('closable', closable),\n              ns.is('focus', isFocus.value),\n            ]}\n            id={`tab-${tabName}`}\n            key={`tab-${uid}`}\n            aria-controls={`pane-${tabName}`}\n            role=\"tab\"\n            aria-selected={pane.active}\n            tabindex={tabindex}\n            onFocus={() => setFocus()}\n            onBlur={() => removeFocus()}\n            onClick={(ev: MouseEvent) => {\n              removeFocus()\n              emit('tabClick', pane, tabName, ev)\n            }}\n            onKeydown={(ev: KeyboardEvent) => {\n              if (\n                closable &&\n                (ev.code === EVENT_CODE.delete ||\n                  ev.code === EVENT_CODE.backspace)\n              ) {\n                emit('tabRemove', pane, ev)\n              }\n            }}\n          >\n            {...[tabLabelContent, btnClose]}\n          </div>\n        )\n      })\n\n      return (\n        <div\n          ref={el$}\n          class={[\n            ns.e('nav-wrap'),\n            ns.is('scrollable', !!scrollable.value),\n            ns.is(rootTabs.props.tabPosition),\n          ]}\n        >\n          {scrollBtn}\n          <div class={ns.e('nav-scroll')} ref={navScroll$}>\n            <div\n              class={[\n                ns.e('nav'),\n                ns.is(rootTabs.props.tabPosition),\n                ns.is(\n                  'stretch',\n                  props.stretch &&\n                    ['top', 'bottom'].includes(rootTabs.props.tabPosition)\n                ),\n              ]}\n              ref={nav$}\n              style={navStyle.value}\n              role=\"tablist\"\n              onKeydown={changeTab}\n            >\n              {...[\n                !props.type ? (\n                  <TabBar ref={tabBarRef} tabs={[...props.panes]} />\n                ) : null,\n                tabs,\n              ]}\n            </div>\n          </div>\n        </div>\n      )\n    }\n  },\n})\n\nexport type TabNavInstance = InstanceType<typeof TabNav> & {\n  scrollToActiveTab: () => Promise<void>\n  removeFocus: () => void\n}\nexport default TabNav\n", "import {\n  computed,\n  createVNode,\n  defineComponent,\n  getCurrentInstance,\n  nextTick,\n  provide,\n  ref,\n  renderSlot,\n  watch,\n} from 'vue'\nimport {\n  buildProps,\n  definePropType,\n  isNumber,\n  isString,\n  isUndefined,\n} from '@element-plus/utils'\nimport { EVENT_CODE, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport ElIcon from '@element-plus/components/icon'\nimport { Plus } from '@element-plus/icons-vue'\nimport { useNamespace, useOrderedChildren } from '@element-plus/hooks'\nimport { tabsRootContextKey } from './constants'\nimport TabNav from './tab-nav'\n\nimport type { TabNavInstance } from './tab-nav'\nimport type { TabsPaneContext } from './constants'\nimport type { ExtractPropTypes, FunctionalComponent, VNode } from 'vue'\nimport type { Awaitable } from '@element-plus/utils'\n\nexport type TabPaneName = string | number\n\nexport const tabsProps = buildProps({\n  /**\n   * @description type of Tab\n   */\n  type: {\n    type: String,\n    values: ['card', 'border-card', ''],\n    default: '',\n  },\n  /**\n   * @description whether Tab is closable\n   */\n  closable: Boolean,\n  /**\n   * @description whether Tab is addable\n   */\n  addable: Boolean,\n  /**\n   * @description binding value, name of the selected tab\n   */\n  modelValue: {\n    type: [String, Number],\n  },\n  /**\n   * @description whether Tab is addable and closable\n   */\n  editable: Boolean,\n  /**\n   * @description position of tabs\n   */\n  tabPosition: {\n    type: String,\n    values: ['top', 'right', 'bottom', 'left'],\n    default: 'top',\n  },\n  /**\n   * @description hook function before switching tab. If `false` is returned or a `Promise` is returned and then is rejected, switching will be prevented\n   */\n  beforeLeave: {\n    type: definePropType<\n      (newName: TabPaneName, oldName: TabPaneName) => Awaitable<void | boolean>\n    >(Function),\n    default: () => true,\n  },\n  /**\n   * @description whether width of tab automatically fits its container\n   */\n  stretch: Boolean,\n} as const)\nexport type TabsProps = ExtractPropTypes<typeof tabsProps>\n\nconst isPaneName = (value: unknown): value is string | number =>\n  isString(value) || isNumber(value)\n\nexport const tabsEmits = {\n  [UPDATE_MODEL_EVENT]: (name: TabPaneName) => isPaneName(name),\n  tabClick: (pane: TabsPaneContext, ev: Event) => ev instanceof Event,\n  tabChange: (name: TabPaneName) => isPaneName(name),\n  edit: (paneName: TabPaneName | undefined, action: 'remove' | 'add') =>\n    ['remove', 'add'].includes(action),\n  tabRemove: (name: TabPaneName) => isPaneName(name),\n  tabAdd: () => true,\n}\nexport type TabsEmits = typeof tabsEmits\n\nexport type TabsPanes = Record<number, TabsPaneContext>\n\nconst Tabs = defineComponent({\n  name: 'ElTabs',\n\n  props: tabsProps,\n  emits: tabsEmits,\n\n  setup(props, { emit, slots, expose }) {\n    const ns = useNamespace('tabs')\n\n    const isVertical = computed(() =>\n      ['left', 'right'].includes(props.tabPosition)\n    )\n\n    const {\n      children: panes,\n      addChild: sortPane,\n      removeChild: unregisterPane,\n    } = useOrderedChildren<TabsPaneContext>(getCurrentInstance()!, 'ElTabPane')\n\n    const nav$ = ref<TabNavInstance>()\n    const currentName = ref<TabPaneName>(props.modelValue ?? '0')\n\n    const setCurrentName = async (value?: TabPaneName, trigger = false) => {\n      // should do nothing.\n      if (currentName.value === value || isUndefined(value)) return\n\n      try {\n        const canLeave = await props.beforeLeave?.(value, currentName.value)\n        if (canLeave !== false) {\n          currentName.value = value\n          if (trigger) {\n            emit(UPDATE_MODEL_EVENT, value)\n            emit('tabChange', value)\n          }\n\n          nav$.value?.removeFocus?.()\n        }\n      } catch {}\n    }\n\n    const handleTabClick = (\n      tab: TabsPaneContext,\n      tabName: TabPaneName,\n      event: Event\n    ) => {\n      if (tab.props.disabled) return\n      setCurrentName(tabName, true)\n      emit('tabClick', tab, event)\n    }\n\n    const handleTabRemove = (pane: TabsPaneContext, ev: Event) => {\n      if (pane.props.disabled || isUndefined(pane.props.name)) return\n      ev.stopPropagation()\n      emit('edit', pane.props.name, 'remove')\n      emit('tabRemove', pane.props.name)\n    }\n\n    const handleTabAdd = () => {\n      emit('edit', undefined, 'add')\n      emit('tabAdd')\n    }\n\n    watch(\n      () => props.modelValue,\n      (modelValue) => setCurrentName(modelValue)\n    )\n\n    watch(currentName, async () => {\n      await nextTick()\n      nav$.value?.scrollToActiveTab()\n    })\n\n    provide(tabsRootContextKey, {\n      props,\n      currentName,\n      registerPane: (pane: TabsPaneContext) => {\n        panes.value.push(pane)\n      },\n      sortPane,\n      unregisterPane,\n    })\n\n    expose({\n      currentName,\n    })\n    const TabNavRenderer: FunctionalComponent<{ render: () => VNode }> = ({\n      render,\n    }) => {\n      return render()\n    }\n    return () => {\n      const addSlot = slots['add-icon']\n      const newButton =\n        props.editable || props.addable ? (\n          <div\n            class={[\n              ns.e('new-tab'),\n              isVertical.value && ns.e('new-tab-vertical'),\n            ]}\n            tabindex=\"0\"\n            onClick={handleTabAdd}\n            onKeydown={(ev: KeyboardEvent) => {\n              if (ev.code === EVENT_CODE.enter) handleTabAdd()\n            }}\n          >\n            {addSlot ? (\n              renderSlot(slots, 'add-icon')\n            ) : (\n              <ElIcon class={ns.is('icon-plus')}>\n                <Plus />\n              </ElIcon>\n            )}\n          </div>\n        ) : null\n\n      const header = (\n        <div\n          class={[\n            ns.e('header'),\n            isVertical.value && ns.e('header-vertical'),\n            ns.is(props.tabPosition),\n          ]}\n        >\n          <TabNavRenderer\n            render={() => {\n              const hasLabelSlot = panes.value.some((pane) => pane.slots.label)\n              return createVNode(\n                TabNav,\n                {\n                  ref: nav$,\n                  currentName: currentName.value,\n                  editable: props.editable,\n                  type: props.type,\n                  panes: panes.value,\n                  stretch: props.stretch,\n                  onTabClick: handleTabClick,\n                  onTabRemove: handleTabRemove,\n                },\n                { $stable: !hasLabelSlot }\n              )\n            }}\n          />\n          {newButton}\n        </div>\n      )\n\n      const panels = (\n        <div class={ns.e('content')}>{renderSlot(slots, 'default')}</div>\n      )\n\n      return (\n        <div\n          class={[\n            ns.b(),\n            ns.m(props.tabPosition),\n            {\n              [ns.m('card')]: props.type === 'card',\n              [ns.m('border-card')]: props.type === 'border-card',\n            },\n          ]}\n        >\n          {panels}\n          {header}\n        </div>\n      )\n    }\n  },\n})\n\nexport type TabsInstance = InstanceType<typeof Tabs> & {\n  currentName: TabPaneName\n}\n\nexport default Tabs\n", "import { buildProps } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type TabPane from './tab-pane.vue'\n\nexport const tabPaneProps = buildProps({\n  /**\n   * @description title of the tab\n   */\n  label: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description identifier corresponding to the name of Tabs, representing the alias of the tab-pane, the default is ordinal number of the tab-pane in the sequence, e.g. the first tab-pane is '0'\n   */\n  name: {\n    type: [String, Number],\n  },\n  /**\n   * @description whether Tab is closable\n   */\n  closable: Boolean,\n  /**\n   * @description whether Tab is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description whether Tab is lazily rendered\n   */\n  lazy: Boolean,\n} as const)\n\nexport type TabPaneProps = ExtractPropTypes<typeof tabPaneProps>\n\nexport type TabPaneInstance = InstanceType<typeof TabPane>\n", "<template>\n  <div\n    v-if=\"shouldBeRender\"\n    v-show=\"active\"\n    :id=\"`pane-${paneName}`\"\n    :class=\"ns.b()\"\n    role=\"tabpanel\"\n    :aria-hidden=\"!active\"\n    :aria-labelledby=\"`tab-${paneName}`\"\n  >\n    <slot />\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  getCurrentInstance,\n  inject,\n  onMounted,\n  onUnmounted,\n  reactive,\n  ref,\n  useSlots,\n  watch,\n} from 'vue'\nimport { eagerComputed } from '@vueuse/core'\nimport { throwError } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { tabsRootContextKey } from './constants'\nimport { tabPaneProps } from './tab-pane'\n\nconst COMPONENT_NAME = 'ElTabPane'\ndefineOptions({\n  name: COMPONENT_NAME,\n})\nconst props = defineProps(tabPaneProps)\n\nconst instance = getCurrentInstance()!\nconst slots = useSlots()\n\nconst tabsRoot = inject(tabsRootContextKey)\nif (!tabsRoot)\n  throwError(COMPONENT_NAME, 'usage: <el-tabs><el-tab-pane /></el-tabs/>')\n\nconst ns = useNamespace('tab-pane')\n\nconst index = ref<string>()\nconst isClosable = computed(() => props.closable || tabsRoot.props.closable)\nconst active = eagerComputed(\n  () => tabsRoot.currentName.value === (props.name ?? index.value)\n)\nconst loaded = ref(active.value)\nconst paneName = computed(() => props.name ?? index.value)\nconst shouldBeRender = eagerComputed(\n  () => !props.lazy || loaded.value || active.value\n)\n\nwatch(active, (val) => {\n  if (val) loaded.value = true\n})\n\nconst pane = reactive({\n  uid: instance.uid,\n  slots,\n  props,\n  paneName,\n  active,\n  index,\n  isClosable,\n})\n\ntabsRoot.registerPane(pane)\nonMounted(() => {\n  tabsRoot.sortPane(pane)\n})\n\nonUnmounted(() => {\n  tabsRoot.unregisterPane(pane.uid)\n})\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Tabs from './src/tabs'\nimport TabPane from './src/tab-pane.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTabs: SFCWithInstall<typeof Tabs> & {\n  TabPane: typeof TabPane\n} = withInstall(Tabs, {\n  TabPane,\n})\nexport const ElTabPane: SFCWithInstall<typeof TabPane> =\n  withNoopInstall(TabPane)\nexport default ElTabs\n\nexport * from './src/tabs'\nexport * from './src/tab-bar'\nexport * from './src/tab-nav'\nexport * from './src/tab-pane'\nexport * from './src/constants'\n", "import { buildProps } from '@element-plus/utils'\nimport { componentSizes } from '@element-plus/constants'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const textProps = buildProps({\n  /**\n   * @description text type\n   */\n  type: {\n    type: String,\n    values: ['primary', 'success', 'info', 'warning', 'danger', ''],\n    default: '',\n  },\n  /**\n   * @description text size\n   */\n  size: {\n    type: String,\n    values: componentSizes,\n    default: '',\n  },\n  /**\n   * @description render ellipsis\n   */\n  truncated: Boolean,\n  /**\n   * @description maximum lines\n   */\n  lineClamp: {\n    type: [String, Number],\n  },\n  /**\n   * @description custom element tag\n   */\n  tag: {\n    type: String,\n    default: 'span',\n  },\n} as const)\n\nexport type TextProps = ExtractPropTypes<typeof textProps>\n", "<template>\n  <component\n    :is=\"tag\"\n    :class=\"textKls\"\n    :style=\"{ '-webkit-line-clamp': lineClamp }\"\n  >\n    <slot />\n  </component>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormSize } from '@element-plus/components/form'\nimport { isUndefined } from '@element-plus/utils'\nimport { textProps } from './text'\n\ndefineOptions({\n  name: 'ElText',\n})\n\nconst props = defineProps(textProps)\n\nconst textSize = useFormSize()\nconst ns = useNamespace('text')\n\nconst textKls = computed(() => [\n  ns.b(),\n  ns.m(props.type),\n  ns.m(textSize.value),\n  ns.is('truncated', props.truncated),\n  ns.is('line-clamp', !isUndefined(props.lineClamp)),\n])\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Text from './src/text.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElText: SFCWithInstall<typeof Text> = withInstall(Text)\nexport default ElText\n\nexport * from './src/text'\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { CircleClose, Clock } from '@element-plus/icons-vue'\nimport { useEmptyValuesProps, useSizeProp } from '@element-plus/hooks'\nimport type { PopperEffect } from '@element-plus/components/popper'\nimport type TimeSelect from './time-select.vue'\nimport type { Component, ExtractPropTypes } from 'vue'\n\nexport const timeSelectProps = buildProps({\n  /**\n   * @description set format of time\n   */\n  format: {\n    type: String,\n    default: 'HH:mm',\n  },\n  /**\n   * @description binding value\n   */\n  modelValue: String,\n  /**\n   * @description whether TimeSelect is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description whether the input is editable\n   */\n  editable: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description Tooltip theme, built-in theme: `dark` / `light`\n   */\n  effect: {\n    type: definePropType<PopperEffect | string>(String),\n    default: 'light',\n  },\n  /**\n   * @description whether to show clear button\n   */\n  clearable: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description size of Input\n   */\n  size: useSizeProp,\n  /**\n   * @description placeholder in non-range mode\n   */\n  placeholder: String,\n  /**\n   * @description start time\n   */\n  start: {\n    type: String,\n    default: '09:00',\n  },\n  /**\n   * @description end time\n   */\n  end: {\n    type: String,\n    default: '18:00',\n  },\n  /**\n   * @description time step\n   */\n  step: {\n    type: String,\n    default: '00:30',\n  },\n  /**\n   * @description minimum time, any time before this time will be disabled\n   */\n  minTime: String,\n  /**\n   * @description maximum time, any time after this time will be disabled\n   */\n  maxTime: String,\n  /**\n   * @description same as `name` in native input\n   */\n  name: String,\n  /**\n   * @description custom prefix icon component\n   */\n  prefixIcon: {\n    type: definePropType<string | Component>([String, Object]),\n    default: () => Clock,\n  },\n  /**\n   * @description custom clear icon component\n   */\n  clearIcon: {\n    type: definePropType<string | Component>([String, Object]),\n    default: () => CircleClose,\n  },\n  ...useEmptyValuesProps,\n} as const)\n\nexport type TimeSelectProps = ExtractPropTypes<typeof timeSelectProps>\n\nexport type TimeSelectInstance = InstanceType<typeof TimeSelect>\n", "interface Time {\n  hours: number\n  minutes: number\n}\n\nexport const parseTime = (time: string): null | Time => {\n  const values = (time || '').split(':')\n  if (values.length >= 2) {\n    let hours = Number.parseInt(values[0], 10)\n    const minutes = Number.parseInt(values[1], 10)\n    const timeUpper = time.toUpperCase()\n    if (timeUpper.includes('AM') && hours === 12) {\n      hours = 0\n    } else if (timeUpper.includes('PM') && hours !== 12) {\n      hours += 12\n    }\n    return {\n      hours,\n      minutes,\n    }\n  }\n\n  return null\n}\n\nexport const compareTime = (time1: string, time2: string): number => {\n  const value1 = parseTime(time1)\n  if (!value1) return -1\n  const value2 = parseTime(time2)\n  if (!value2) return -1\n  const minutes1 = value1.minutes + value1.hours * 60\n  const minutes2 = value2.minutes + value2.hours * 60\n  if (minutes1 === minutes2) {\n    return 0\n  }\n  return minutes1 > minutes2 ? 1 : -1\n}\n\nexport const padTime = (time: number | string) => {\n  return `${time}`.padStart(2, '0')\n}\nexport const formatTime = (time: Time): string => {\n  return `${padTime(time.hours)}:${padTime(time.minutes)}`\n}\n\nexport const nextTime = (time: string, step: string): string => {\n  const timeValue = parseTime(time)\n  if (!timeValue) return ''\n\n  const stepValue = parseTime(step)\n  if (!stepValue) return ''\n\n  const next = {\n    hours: timeValue.hours,\n    minutes: timeValue.minutes,\n  }\n  next.minutes += stepValue.minutes\n  next.hours += stepValue.hours\n  next.hours += Math.floor(next.minutes / 60)\n  next.minutes = next.minutes % 60\n  return formatTime(next)\n}\n", "<template>\n  <el-select\n    ref=\"select\"\n    :model-value=\"value\"\n    :disabled=\"_disabled\"\n    :clearable=\"clearable\"\n    :clear-icon=\"clearIcon\"\n    :size=\"size\"\n    :effect=\"effect\"\n    :placeholder=\"placeholder\"\n    default-first-option\n    :filterable=\"editable\"\n    :empty-values=\"emptyValues\"\n    :value-on-clear=\"valueOnClear\"\n    @update:model-value=\"(event) => $emit('update:modelValue', event)\"\n    @change=\"(event) => $emit('change', event)\"\n    @blur=\"(event) => $emit('blur', event)\"\n    @focus=\"(event) => $emit('focus', event)\"\n    @clear=\"() => $emit('clear')\"\n  >\n    <el-option\n      v-for=\"item in items\"\n      :key=\"item.value\"\n      :label=\"item.value\"\n      :value=\"item.value\"\n      :disabled=\"item.disabled\"\n    />\n    <template #prefix>\n      <el-icon v-if=\"prefixIcon\" :class=\"nsInput.e('prefix-icon')\">\n        <component :is=\"prefixIcon\" />\n      </el-icon>\n    </template>\n  </el-select>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, ref } from 'vue'\nimport dayjs from 'dayjs'\nimport customParseFormat from 'dayjs/plugin/customParseFormat.js'\nimport ElSelect from '@element-plus/components/select'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport ElIcon from '@element-plus/components/icon'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { timeSelectProps } from './time-select'\nimport { compareTime, formatTime, nextTime, parseTime } from './utils'\n\ndayjs.extend(customParseFormat)\n\nconst { Option: ElOption } = ElSelect\n\ndefineOptions({\n  name: 'ElTimeSelect',\n})\n\ndefineEmits(['change', 'blur', 'focus', 'clear', 'update:modelValue'])\n\nconst props = defineProps(timeSelectProps)\n\nconst nsInput = useNamespace('input')\nconst select = ref<typeof ElSelect>()\n\nconst _disabled = useFormDisabled()\nconst { lang } = useLocale()\n\nconst value = computed(() => props.modelValue)\nconst start = computed(() => {\n  const time = parseTime(props.start)\n  return time ? formatTime(time) : null\n})\n\nconst end = computed(() => {\n  const time = parseTime(props.end)\n  return time ? formatTime(time) : null\n})\n\nconst step = computed(() => {\n  const time = parseTime(props.step)\n  return time ? formatTime(time) : null\n})\n\nconst minTime = computed(() => {\n  const time = parseTime(props.minTime || '')\n  return time ? formatTime(time) : null\n})\n\nconst maxTime = computed(() => {\n  const time = parseTime(props.maxTime || '')\n  return time ? formatTime(time) : null\n})\n\nconst items = computed(() => {\n  const result: { value: string; disabled: boolean }[] = []\n  if (props.start && props.end && props.step) {\n    let current = start.value\n    let currentTime: string\n    while (current && end.value && compareTime(current, end.value) <= 0) {\n      currentTime = dayjs(current, 'HH:mm')\n        .locale(lang.value)\n        .format(props.format)\n      result.push({\n        value: currentTime,\n        disabled:\n          compareTime(current, minTime.value || '-1:-1') <= 0 ||\n          compareTime(current, maxTime.value || '100:100') >= 0,\n      })\n      current = nextTime(current, step.value!)\n    }\n  }\n  return result\n})\n\nconst blur = () => {\n  select.value?.blur?.()\n}\n\nconst focus = () => {\n  select.value?.focus?.()\n}\n\ndefineExpose({\n  /**\n   * @description focus the Input component\n   */\n  blur,\n  /**\n   * @description blur the Input component\n   */\n  focus,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport TimeSelect from './src/time-select.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTimeSelect: SFCWithInstall<typeof TimeSelect> =\n  withInstall(TimeSelect)\nexport default ElTimeSelect\n\nexport * from './src/time-select'\n", "import { defineComponent, h, provide, renderSlot } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\n\nconst Timeline = defineComponent({\n  name: 'ElTimeline',\n  setup(_, { slots }) {\n    const ns = useNamespace('timeline')\n\n    provide('timeline', slots)\n\n    /**\n     *  Maybe ,this component will not support prop 'reverse', why ?\n     *\n     *  Example 1:\n     *   <component-a>\n     *     <div>1</div>\n     *     <div>2</div>\n     *   </component-a>\n     *\n     *  Example 2:\n     *   <component-a>\n     *     <div v-for=\"i in 2\" :key=\"i\">{{ i }}</div>\n     *   </component-a>\n     *\n     *  'slots.default()' value in example 1 just like [Vnode, Vnode]\n     *  'slots.default()' value in example 2 just like [Vnode]\n     *\n     *   so i can't reverse the slots, when i use 'v-for' directive.\n     */\n\n    return () => {\n      return h('ul', { class: [ns.b()] }, [renderSlot(slots, 'default')])\n    }\n  },\n})\n\nexport default Timeline\nexport type TimelineInstance = InstanceType<typeof Timeline>\n", "import { buildProps, iconPropType } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type TimelineItem from './timeline-item.vue'\n\nexport const timelineItemProps = buildProps({\n  /**\n   * @description timestamp content\n   */\n  timestamp: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description whether to show timestamp\n   */\n  hideTimestamp: Boolean,\n  /**\n   * @description whether vertically centered\n   */\n  center: Boolean,\n  /**\n   * @description position of timestamp\n   */\n  placement: {\n    type: String,\n    values: ['top', 'bottom'],\n    default: 'bottom',\n  },\n  /**\n   * @description node type\n   */\n  type: {\n    type: String,\n    values: ['primary', 'success', 'warning', 'danger', 'info'],\n    default: '',\n  },\n  /**\n   * @description background color of node\n   */\n  color: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description node size\n   */\n  size: {\n    type: String,\n    values: ['normal', 'large'],\n    default: 'normal',\n  },\n  /**\n   * @description icon component\n   */\n  icon: {\n    type: iconPropType,\n  },\n  /**\n   * @description icon is hollow\n   */\n  hollow: Boolean,\n} as const)\nexport type TimelineItemProps = ExtractPropTypes<typeof timelineItemProps>\n\nexport type TimelineItemInstance = InstanceType<typeof TimelineItem>\n", "<template>\n  <li :class=\"[ns.b(), { [ns.e('center')]: center }]\">\n    <div :class=\"ns.e('tail')\" />\n    <div\n      v-if=\"!$slots.dot\"\n      :class=\"defaultNodeKls\"\n      :style=\"{\n        backgroundColor: color,\n      }\"\n    >\n      <el-icon v-if=\"icon\" :class=\"ns.e('icon')\">\n        <component :is=\"icon\" />\n      </el-icon>\n    </div>\n    <div v-if=\"$slots.dot\" :class=\"ns.e('dot')\">\n      <slot name=\"dot\" />\n    </div>\n\n    <div :class=\"ns.e('wrapper')\">\n      <div\n        v-if=\"!hideTimestamp && placement === 'top'\"\n        :class=\"[ns.e('timestamp'), ns.is('top')]\"\n      >\n        {{ timestamp }}\n      </div>\n\n      <div :class=\"ns.e('content')\">\n        <slot />\n      </div>\n\n      <div\n        v-if=\"!hideTimestamp && placement === 'bottom'\"\n        :class=\"[ns.e('timestamp'), ns.is('bottom')]\"\n      >\n        {{ timestamp }}\n      </div>\n    </div>\n  </li>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { useNamespace } from '@element-plus/hooks'\nimport { timelineItemProps } from './timeline-item'\n\ndefineOptions({\n  name: 'ElTimelineItem',\n})\n\nconst props = defineProps(timelineItemProps)\n\nconst ns = useNamespace('timeline-item')\nconst defaultNodeKls = computed(() => [\n  ns.e('node'),\n  ns.em('node', props.size || ''),\n  ns.em('node', props.type || ''),\n  ns.is('hollow', props.hollow),\n])\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Timeline from './src/timeline'\nimport TimelineItem from './src/timeline-item.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTimeline: SFCWithInstall<typeof Timeline> & {\n  TimelineItem: typeof TimelineItem\n} = withInstall(Timeline, {\n  TimelineItem,\n})\nexport default ElTimeline\nexport const ElTimelineItem: SFCWithInstall<typeof TimelineItem> =\n  withNoopInstall(TimelineItem)\n\nexport * from './src/timeline'\nexport * from './src/timeline-item'\n", "import { buildProps } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\n\n/**\n * TODO: make this under constants or tokens\n */\nexport const tooltipV2CommonProps = buildProps({\n  nowrap: Boolean,\n} as const)\n\nexport type TooltipV2CommonProps = ExtractPropTypes<typeof tooltipV2CommonProps>\n\nexport enum TooltipV2Sides {\n  top = 'top',\n  bottom = 'bottom',\n  left = 'left',\n  right = 'right',\n}\n\nexport const tooltipV2Sides = Object.values(TooltipV2Sides)\n\nexport const tooltipV2OppositeSide = {\n  [TooltipV2Sides.top]: TooltipV2Sides.bottom,\n  [TooltipV2Sides.bottom]: TooltipV2Sides.top,\n  [TooltipV2Sides.left]: TooltipV2Sides.right,\n  [TooltipV2Sides.right]: TooltipV2Sides.left,\n} as const\n\nexport const tooltipV2ArrowBorders = {\n  [TooltipV2Sides.top]: [TooltipV2Sides.left, TooltipV2Sides.top],\n  [TooltipV2Sides.bottom]: [TooltipV2Sides.bottom, TooltipV2Sides.right],\n  [TooltipV2Sides.left]: [TooltipV2Sides.bottom, TooltipV2Sides.left],\n  [TooltipV2Sides.right]: [TooltipV2Sides.top, TooltipV2Sides.right],\n} as const\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { tooltipV2Sides } from './common'\n\nimport type { CSSProperties, ExtractPropTypes } from 'vue'\nimport type { TooltipV2Sides } from './common'\n\nexport const tooltipV2ArrowProps = buildProps({\n  width: {\n    type: Number,\n    default: 10,\n  },\n  height: {\n    type: Number,\n    default: 10,\n  },\n  style: {\n    type: definePropType<CSSProperties | null>(Object),\n    default: null,\n  },\n} as const)\n\nexport const tooltipV2ArrowSpecialProps = buildProps({\n  side: {\n    type: definePropType<TooltipV2Sides>(String),\n    values: tooltipV2Sides,\n    required: true,\n  },\n} as const)\n\nexport type TooltipV2ArrowProps = ExtractPropTypes<typeof tooltipV2ArrowProps>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { useAriaProps } from '@element-plus/hooks'\n\nimport type { PopperEffect } from '@element-plus/components/popper'\nimport type { ExtractPropTypes } from 'vue'\nimport type { Placement, Strategy, VirtualElement } from '@floating-ui/dom'\n\nconst tooltipV2Strategies = ['absolute', 'fixed'] as const\n\nconst tooltipV2Placements = [\n  'top-start',\n  'top-end',\n  'top',\n  'bottom-start',\n  'bottom-end',\n  'bottom',\n  'left-start',\n  'left-end',\n  'left',\n  'right-start',\n  'right-end',\n  'right',\n] as const\n\nexport const tooltipV2ContentProps = buildProps({\n  arrowPadding: {\n    type: definePropType<number>(Number),\n    default: 5,\n  },\n  effect: {\n    type: definePropType<PopperEffect | string>(String),\n    default: 'light',\n  },\n  contentClass: String,\n  /**\n   * Placement of tooltip content relative to reference element (when absent it refers to trigger)\n   */\n  placement: {\n    type: definePropType<Placement>(String),\n    values: tooltipV2Placements,\n    default: 'bottom',\n  },\n  /**\n   * Reference element for tooltip content to set its position\n   */\n  reference: {\n    type: definePropType<HTMLElement | VirtualElement | null>(Object),\n    default: null,\n  },\n  offset: {\n    type: Number,\n    default: 8,\n  },\n  strategy: {\n    type: definePropType<Strategy>(String),\n    values: tooltipV2Strategies,\n    default: 'absolute',\n  },\n  showArrow: Boolean,\n  ...useAriaProps(['ariaLabel']),\n} as const)\n\nexport type TooltipV2ContentProps = ExtractPropTypes<\n  typeof tooltipV2ContentProps\n>\n", "import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\n\ntype StateUpdater = (state: boolean) => void\n\nexport const tooltipV2RootProps = buildProps({\n  delayDuration: {\n    type: Number,\n    default: 300,\n  },\n  defaultOpen: Boolean,\n  open: {\n    type: Boolean,\n    default: undefined,\n  },\n  onOpenChange: {\n    type: definePropType<StateUpdater>(Function),\n  },\n  'onUpdate:open': {\n    type: definePropType<StateUpdater>(Function),\n  },\n} as const)\n\nexport type TooltipV2RootProps = ExtractPropTypes<typeof tooltipV2RootProps>\n", "import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\n\nconst EventHandler = {\n  type: definePropType<(e: Event) => boolean | void>(Function),\n} as const\n\nexport const tooltipV2TriggerProps = buildProps({\n  onBlur: EventHandler,\n  onClick: EventHandler,\n  onFocus: EventHandler,\n  onMouseDown: EventHandler,\n  onMouseEnter: EventHandler,\n  onMouseLeave: EventHandler,\n} as const)\n\nexport type TooltipV2TriggerProps = ExtractPropTypes<\n  typeof tooltipV2TriggerProps\n>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { tooltipV2RootProps } from './root'\nimport { tooltipV2TriggerProps } from './trigger'\nimport { tooltipV2ArrowProps } from './arrow'\nimport { tooltipV2ContentProps } from './content'\n\nimport type { ExtractPropTypes, TeleportProps, TransitionProps } from 'vue'\n\nexport const tooltipV2Props = buildProps({\n  ...tooltipV2RootProps,\n  ...tooltipV2ArrowProps,\n  ...tooltipV2TriggerProps,\n  ...tooltipV2ContentProps,\n  alwaysOn: Boolean,\n  fullTransition: Boolean,\n  transitionProps: {\n    type: definePropType<TransitionProps | null>(Object),\n    default: null,\n  },\n  teleported: Boolean,\n  to: {\n    type: definePropType<TeleportProps['to']>(String),\n    default: 'body',\n  },\n} as const)\n\nexport type TooltipV2Props = ExtractPropTypes<typeof tooltipV2Props>\n", "import type { InjectionKey, Ref } from 'vue'\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\n\nexport type TooltipV2Context = {\n  onClose: () => void\n  onDelayOpen: () => void\n  onOpen: () => void\n  contentId: Ref<string>\n  triggerRef: Ref<HTMLElement | null>\n  ns: UseNamespaceReturn\n}\n\nexport type TooltipV2ContentContext = {\n  arrowRef: Ref<HTMLElement | null>\n}\n\nexport const tooltipV2RootKey: InjectionKey<TooltipV2Context> =\n  Symbol('tooltipV2')\n\nexport const tooltipV2ContentKey: InjectionKey<TooltipV2ContentContext> =\n  Symbol('tooltipV2Content')\n\nexport const TOOLTIP_V2_OPEN = 'tooltip_v2.open'\n", "<template>\n  <slot :open=\"open\" />\n</template>\n\n<script setup lang=\"ts\">\nimport {\n  computed,\n  onBeforeUnmount,\n  onMounted,\n  provide,\n  ref,\n  unref,\n  watch,\n} from 'vue'\nimport { useTimeoutFn } from '@vueuse/core'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport { isNumber, isPropAbsent } from '@element-plus/utils'\nimport { TOOLTIP_V2_OPEN, tooltipV2RootKey } from './constants'\nimport { tooltipV2RootProps } from './root'\n\ndefineOptions({\n  name: 'ElTooltipV2Root',\n})\n\nconst props = defineProps(tooltipV2RootProps)\n\n/**\n * internal open state, when no model value was provided, use this as indicator instead\n */\nconst _open = ref(props.defaultOpen)\nconst triggerRef = ref<HTMLElement | null>(null)\n\nconst open = computed<boolean>({\n  get: () => (isPropAbsent(props.open) ? _open.value : props.open),\n  set: (open) => {\n    _open.value = open\n    props['onUpdate:open']?.(open)\n  },\n})\n\nconst isOpenDelayed = computed(\n  () => isNumber(props.delayDuration) && props.delayDuration > 0\n)\n\nconst { start: onDelayedOpen, stop: clearTimer } = useTimeoutFn(\n  () => {\n    open.value = true\n  },\n  computed(() => props.delayDuration),\n  {\n    immediate: false,\n  }\n)\n\nconst ns = useNamespace('tooltip-v2')\n\nconst contentId = useId()\n\nconst onNormalOpen = () => {\n  clearTimer()\n  open.value = true\n}\n\nconst onDelayOpen = () => {\n  unref(isOpenDelayed) ? onDelayedOpen() : onNormalOpen()\n}\n\nconst onOpen = onNormalOpen\n\nconst onClose = () => {\n  clearTimer()\n  open.value = false\n}\n\nconst onChange = (open: boolean) => {\n  if (open) {\n    document.dispatchEvent(new CustomEvent(TOOLTIP_V2_OPEN))\n    onOpen()\n  }\n\n  props.onOpenChange?.(open)\n}\n\nwatch(open, onChange)\n\nonMounted(() => {\n  // Keeps only 1 tooltip open at a time\n  document.addEventListener(TOOLTIP_V2_OPEN, onClose)\n})\n\nonBeforeUnmount(() => {\n  clearTimer()\n  document.removeEventListener(TOOLTIP_V2_OPEN, onClose)\n})\n\nprovide(tooltipV2RootKey, {\n  contentId,\n  triggerRef,\n  ns,\n\n  onClose,\n  onDelayOpen,\n  onOpen,\n})\n\ndefineExpose({\n  /**\n   * @description open tooltip programmatically\n   */\n  onOpen,\n\n  /**\n   * @description close tooltip programmatically\n   */\n  onClose,\n})\n</script>\n", "<template>\n  <span ref=\"arrowRef\" :style=\"arrowStyle\" :class=\"ns.e('arrow')\" />\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, inject } from 'vue'\nimport { tooltipV2ContentKey, tooltipV2RootKey } from './constants'\nimport { tooltipV2ArrowProps, tooltipV2ArrowSpecialProps } from './arrow'\n\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElTooltipV2Arrow',\n})\n\nconst props = defineProps({\n  ...tooltipV2ArrowProps,\n  ...tooltipV2ArrowSpecialProps,\n})\n\nconst { ns } = inject(tooltipV2RootKey)!\nconst { arrowRef } = inject(tooltipV2ContentKey)!\n\nconst arrowStyle = computed<CSSProperties>(() => {\n  const { style, width, height } = props\n  const namespace = ns.namespace.value\n\n  return {\n    [`--${namespace}-tooltip-v2-arrow-width`]: `${width}px`,\n    [`--${namespace}-tooltip-v2-arrow-height`]: `${height}px`,\n    [`--${namespace}-tooltip-v2-arrow-border-width`]: `${width / 2}px`,\n    [`--${namespace}-tooltip-v2-arrow-cover-width`]: width / 2 - 1,\n    ...(style || {}),\n  }\n})\n</script>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport type { StyleValue } from 'vue'\n\nexport const visualHiddenProps = buildProps({\n  style: {\n    type: definePropType<StyleValue>([String, Object, Array]),\n    default: () => ({}),\n  },\n} as const)\n", "<template>\n  <span v-bind=\"$attrs\" :style=\"computedStyle\">\n    <slot />\n  </span>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { visualHiddenProps } from './visual-hidden'\nimport type { StyleValue } from 'vue'\nconst props = defineProps(visualHiddenProps)\n\ndefineOptions({\n  name: 'ElVisuallyHidden',\n})\n\nconst computedStyle = computed<StyleValue>(() => {\n  return [\n    props.style,\n    {\n      position: 'absolute',\n      border: 0,\n      width: 1,\n      height: 1,\n      padding: 0,\n      margin: -1,\n      overflow: 'hidden',\n      clip: 'rect(0, 0, 0, 0)',\n      whiteSpace: 'nowrap',\n      wordWrap: 'normal',\n    },\n  ]\n})\n</script>\n", "<template>\n  <div ref=\"contentRef\" :style=\"contentStyle\" data-tooltip-v2-root>\n    <div v-if=\"!nowrap\" :data-side=\"side\" :class=\"contentClass\">\n      <slot :content-style=\"contentStyle\" :content-class=\"contentClass\" />\n      <el-visually-hidden :id=\"contentId\" role=\"tooltip\">\n        <template v-if=\"ariaLabel\">\n          {{ ariaLabel }}\n        </template>\n        <slot v-else />\n      </el-visually-hidden>\n      <slot name=\"arrow\" :style=\"arrowStyle\" :side=\"side\" />\n    </div>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, inject, onMounted, provide, ref, unref, watch } from 'vue'\nimport { offset } from '@floating-ui/dom'\nimport {\n  arrowMiddleware,\n  useFloating,\n  useNamespace,\n  useZIndex,\n} from '@element-plus/hooks'\nimport ElVisuallyHidden from '@element-plus/components/visual-hidden'\nimport { tooltipV2ContentKey, tooltipV2RootKey } from './constants'\nimport { tooltipV2ContentProps } from './content'\nimport { tooltipV2CommonProps } from './common'\n\nimport type { CSSProperties } from 'vue'\nimport type { Middleware } from '@floating-ui/dom'\n\ndefineOptions({\n  name: 'ElTooltipV2Content',\n})\n\nconst props = defineProps({ ...tooltipV2ContentProps, ...tooltipV2CommonProps })\n\nconst { triggerRef, contentId } = inject(tooltipV2RootKey)!\n\nconst placement = ref(props.placement)\nconst strategy = ref(props.strategy)\nconst arrowRef = ref<HTMLElement | null>(null)\n\nconst { referenceRef, contentRef, middlewareData, x, y, update } = useFloating({\n  placement,\n  strategy,\n  middleware: computed(() => {\n    const middleware: Middleware[] = [offset(props.offset)]\n\n    if (props.showArrow) {\n      middleware.push(\n        arrowMiddleware({\n          arrowRef,\n        })\n      )\n    }\n\n    return middleware\n  }),\n})\n\nconst zIndex = useZIndex().nextZIndex()\n\nconst ns = useNamespace('tooltip-v2')\n\nconst side = computed(() => {\n  return placement.value.split('-')[0]\n})\n\nconst contentStyle = computed<CSSProperties>(() => {\n  return {\n    position: unref(strategy),\n    top: `${unref(y) || 0}px`,\n    left: `${unref(x) || 0}px`,\n    zIndex,\n  }\n})\n\nconst arrowStyle = computed<CSSProperties>(() => {\n  if (!props.showArrow) return {}\n\n  const { arrow } = unref(middlewareData)\n\n  return {\n    [`--${ns.namespace.value}-tooltip-v2-arrow-x`]: `${arrow?.x}px` || '',\n    [`--${ns.namespace.value}-tooltip-v2-arrow-y`]: `${arrow?.y}px` || '',\n  }\n})\n\nconst contentClass = computed(() => [\n  ns.e('content'),\n  ns.is('dark', props.effect === 'dark'),\n  ns.is(unref(strategy)),\n  props.contentClass,\n])\n\nwatch(arrowRef, () => update())\n\nwatch(\n  () => props.placement,\n  (val) => (placement.value = val)\n)\n\nonMounted(() => {\n  watch(\n    () => props.reference || triggerRef.value,\n    (el) => {\n      referenceRef.value = el || undefined\n    },\n    {\n      immediate: true,\n    }\n  )\n})\n\nprovide(tooltipV2ContentKey, { arrowRef })\n</script>\n", "import { Fragment, defineComponent, ref } from 'vue'\nimport {\n  buildProps,\n  composeRefs,\n  definePropType,\n  ensureOnlyChild,\n} from '@element-plus/utils'\n\nimport type { ExtractPropTypes, VNodeArrayChildren } from 'vue'\n\nexport type RefSetter = (el: HTMLElement | null) => void\n\nexport const forwardRefProps = buildProps({\n  setRef: { type: definePropType<RefSetter>(Function), required: true },\n  onlyChild: Boolean,\n} as const)\n\nexport type ForwardRefProps = ExtractPropTypes<typeof forwardRefProps>\n\n// TODO: consider make this component a reusable component without the only child feature.\nexport default defineComponent({\n  props: forwardRefProps,\n  setup(props, { slots }) {\n    const fragmentRef = ref()\n    const setRef = composeRefs(fragmentRef, (el) => {\n      // vue fragments is represented as a text element.\n      // The first element sibling should be the first element children of fragment.\n      // This is how we get the element.\n      if (el) {\n        props.setRef(\n          (el as HTMLElement).nextElementSibling as HTMLElement | null\n        )\n      } else {\n        props.setRef(null)\n      }\n    })\n    return () => {\n      const [firstChild] = slots.default?.() || []\n      const child = props.onlyChild\n        ? ensureOnlyChild(firstChild.children as VNodeArrayChildren)\n        : firstChild.children\n      // Dunno why the ref for jsx complains about the typing issue which was not\n      // in template\n      return <Fragment ref={setRef as any}>{child}</Fragment>\n    }\n  },\n})\n", "<template>\n  <forward-ref v-if=\"nowrap\" :set-ref=\"setTriggerRef\" only-child>\n    <slot />\n  </forward-ref>\n  <button v-else ref=\"triggerRef\" v-bind=\"$attrs\">\n    <slot />\n  </button>\n</template>\n\n<script setup lang=\"ts\">\nimport { inject, onBeforeUnmount, watch } from 'vue'\nimport { composeEventHandlers } from '@element-plus/utils'\nimport { tooltipV2RootKey } from './constants'\nimport ForwardRef from './forward-ref'\nimport { tooltipV2TriggerProps } from './trigger'\nimport { tooltipV2CommonProps } from './common'\n\ndefineOptions({\n  name: 'ElTooltipV2Trigger',\n})\n\nconst props = defineProps({\n  ...tooltipV2CommonProps,\n  ...tooltipV2TriggerProps,\n})\n\n/**\n * onOpen opens the tooltip instantly, onTrigger acts a lil bit differently,\n * it will check if delayDuration is set to greater than 0 and based on that result,\n * if true, it opens the tooltip after delayDuration, otherwise it opens it instantly.\n */\nconst { onClose, onOpen, onDelayOpen, triggerRef, contentId } =\n  inject(tooltipV2RootKey)!\n\nlet isMousedown = false\n\nconst setTriggerRef = (el: HTMLElement | null) => {\n  triggerRef.value = el\n}\n\nconst onMouseup = () => {\n  isMousedown = false\n}\n\nconst onMouseenter = composeEventHandlers(props.onMouseEnter, onDelayOpen)\n\nconst onMouseleave = composeEventHandlers(props.onMouseLeave, onClose)\n\nconst onMousedown = composeEventHandlers(props.onMouseDown, () => {\n  onClose()\n  isMousedown = true\n  document.addEventListener('mouseup', onMouseup, { once: true })\n})\n\nconst onFocus = composeEventHandlers(props.onFocus, () => {\n  if (!isMousedown) onOpen()\n})\n\nconst onBlur = composeEventHandlers(props.onBlur, onClose)\n\nconst onClick = composeEventHandlers(props.onClick, (e) => {\n  if ((e as MouseEvent).detail === 0) onClose()\n})\n\nconst events = {\n  blur: onBlur,\n  click: onClick,\n  focus: onFocus,\n  mousedown: onMousedown,\n  mouseenter: onMouseenter,\n  mouseleave: onMouseleave,\n}\n\nconst setEvents = <T extends (e: Event) => void>(\n  el: HTMLElement | null | undefined,\n  events: Record<string, T>,\n  type: 'addEventListener' | 'removeEventListener'\n) => {\n  if (el) {\n    Object.entries(events).forEach(([name, handler]) => {\n      el[type](name, handler)\n    })\n  }\n}\n\nwatch(triggerRef, (triggerEl, previousTriggerEl) => {\n  setEvents(triggerEl, events, 'addEventListener')\n  setEvents(previousTriggerEl, events, 'removeEventListener')\n\n  if (triggerEl) {\n    triggerEl.setAttribute('aria-describedby', contentId.value)\n  }\n})\n\nonBeforeUnmount(() => {\n  setEvents(triggerRef.value, events, 'removeEventListener')\n  document.removeEventListener('mouseup', onMouseup)\n})\n</script>\n", "<template>\n  <tooltip-v2-root v-bind=\"rootProps\">\n    <template #default=\"{ open }\">\n      <tooltip-v2-trigger v-bind=\"triggerProps\" nowrap>\n        <slot name=\"trigger\" />\n      </tooltip-v2-trigger>\n      <el-teleport :to=\"to\" :disabled=\"!teleported\">\n        <template v-if=\"fullTransition\">\n          <transition v-bind=\"transitionProps\">\n            <tooltip-v2-content v-if=\"alwaysOn || open\" v-bind=\"contentProps\">\n              <slot />\n              <template #arrow=\"{ style, side }\">\n                <tooltip-v2-arrow\n                  v-if=\"showArrow\"\n                  v-bind=\"arrowProps\"\n                  :style=\"style\"\n                  :side=\"side\"\n                />\n              </template>\n            </tooltip-v2-content>\n          </transition>\n        </template>\n        <template v-else>\n          <tooltip-v2-content v-if=\"alwaysOn || open\" v-bind=\"contentProps\">\n            <slot />\n            <template #arrow=\"{ style, side }\">\n              <tooltip-v2-arrow\n                v-if=\"showArrow\"\n                v-bind=\"arrowProps\"\n                :style=\"style\"\n                :side=\"side\"\n              />\n            </template>\n          </tooltip-v2-content>\n        </template>\n      </el-teleport>\n    </template>\n  </tooltip-v2-root>\n</template>\n\n<script setup lang=\"ts\">\n// @ts-nocheck\nimport { reactive, toRefs } from 'vue'\nimport { pick } from 'lodash-unified'\nimport ElTeleport from '@element-plus/components/teleport'\nimport { tooltipV2ArrowProps } from './arrow'\nimport { tooltipV2ContentProps } from './content'\nimport { tooltipV2RootProps } from './root'\nimport { tooltipV2Props } from './tooltip'\nimport { tooltipV2TriggerProps } from './trigger'\nimport TooltipV2Root from './root.vue'\nimport TooltipV2Arrow from './arrow.vue'\nimport TooltipV2Content from './content.vue'\nimport TooltipV2Trigger from './trigger.vue'\n\ndefineOptions({\n  name: 'ElTooltipV2',\n})\n\nconst props = defineProps(tooltipV2Props)\n\nconst refedProps = toRefs(props)\n\nconst arrowProps = reactive(pick(refedProps, Object.keys(tooltipV2ArrowProps)))\n\nconst contentProps = reactive(\n  pick(refedProps, Object.keys(tooltipV2ContentProps))\n)\n\nconst rootProps = reactive(pick(refedProps, Object.keys(tooltipV2RootProps)))\n\nconst triggerProps = reactive(\n  pick(refedProps, Object.keys(tooltipV2TriggerProps))\n)\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport TooltipV2 from './src/tooltip.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTooltipV2: SFCWithInstall<typeof TooltipV2> =\n  withInstall(TooltipV2)\nexport * from './src/arrow'\nexport * from './src/content'\nexport * from './src/root'\nexport * from './src/tooltip'\nexport * from './src/trigger'\nexport * from './src/constants'\n\nexport default ElTooltipV2\n", "import { isNil } from 'lodash-unified'\nimport {\n  buildProps,\n  definePropType,\n  isArray,\n  mutable,\n} from '@element-plus/utils'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\n\nimport type { ExtractPropTypes, h as H, VNode } from 'vue'\nimport type Transfer from './transfer.vue'\n\nexport type TransferKey = string | number\nexport type TransferDirection = 'left' | 'right'\n\nexport type TransferDataItem = Record<string, any>\n\nexport type renderContent = (\n  h: typeof H,\n  option: TransferDataItem\n) => VNode | VNode[]\n\nexport interface TransferFormat {\n  noChecked?: string\n  hasChecked?: string\n}\n\nexport interface TransferPropsAlias {\n  label?: string\n  key?: string\n  disabled?: string\n}\n\nexport interface TransferCheckedState {\n  leftChecked: TransferKey[]\n  rightChecked: TransferKey[]\n}\n\nexport const LEFT_CHECK_CHANGE_EVENT = 'left-check-change'\nexport const RIGHT_CHECK_CHANGE_EVENT = 'right-check-change'\n\nexport const transferProps = buildProps({\n  /**\n   * @description data source\n   */\n  data: {\n    type: definePropType<TransferDataItem[]>(Array),\n    default: () => [],\n  },\n  /**\n   * @description custom list titles\n   */\n  titles: {\n    type: definePropType<[string, string]>(Array),\n    default: () => [],\n  },\n  /**\n   * @description custom button texts\n   */\n  buttonTexts: {\n    type: definePropType<[string, string]>(Array),\n    default: () => [],\n  },\n  /**\n   * @description placeholder for the filter input\n   */\n  filterPlaceholder: String,\n  /**\n   * @description custom filter method\n   */\n  filterMethod: {\n    type: definePropType<(query: string, item: TransferDataItem) => boolean>(\n      Function\n    ),\n  },\n  /**\n   * @description key array of initially checked data items of the left list\n   */\n  leftDefaultChecked: {\n    type: definePropType<TransferKey[]>(Array),\n    default: () => [],\n  },\n  /**\n   * @description key array of initially checked data items of the right list\n   */\n  rightDefaultChecked: {\n    type: definePropType<TransferKey[]>(Array),\n    default: () => [],\n  },\n  /**\n   * @description custom render function for data items\n   */\n  renderContent: {\n    type: definePropType<renderContent>(Function),\n  },\n  /**\n   * @description binding value\n   */\n  modelValue: {\n    type: definePropType<TransferKey[]>(Array),\n    default: () => [],\n  },\n  /**\n   * @description texts for checking status in list header\n   */\n  format: {\n    type: definePropType<TransferFormat>(Object),\n    default: () => ({}),\n  },\n  /**\n   * @description whether Transfer is filterable\n   */\n  filterable: Boolean,\n  /**\n   * @description prop aliases for data source\n   */\n  props: {\n    type: definePropType<TransferPropsAlias>(Object),\n    default: () =>\n      mutable({\n        label: 'label',\n        key: 'key',\n        disabled: 'disabled',\n      } as const),\n  },\n  /**\n   * @description order strategy for elements in the target list. If set to `original`, the elements will keep the same order as the data source. If set to `push`, the newly added elements will be pushed to the bottom. If set to `unshift`, the newly added elements will be inserted on the top\n   */\n  targetOrder: {\n    type: String,\n    values: ['original', 'push', 'unshift'],\n    default: 'original',\n  },\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n} as const)\nexport type TransferProps = ExtractPropTypes<typeof transferProps>\n\nexport const transferCheckedChangeFn = (\n  value: TransferKey[],\n  movedKeys?: TransferKey[]\n) => [value, movedKeys].every(isArray) || (isArray(value) && isNil(movedKeys))\n\nexport const transferEmits = {\n  [CHANGE_EVENT]: (\n    value: TransferKey[],\n    direction: TransferDirection,\n    movedKeys: TransferKey[]\n  ) =>\n    [value, movedKeys].every(isArray) && ['left', 'right'].includes(direction),\n  [UPDATE_MODEL_EVENT]: (value: TransferKey[]) => isArray(value),\n  [LEFT_CHECK_CHANGE_EVENT]: transferCheckedChangeFn,\n  [RIGHT_CHECK_CHANGE_EVENT]: transferCheckedChangeFn,\n}\nexport type TransferEmits = typeof transferEmits\n\nexport type TransferInstance = InstanceType<typeof Transfer>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport { transferCheckedChangeFn, transferProps } from './transfer'\n\nimport type { ExtractPropTypes, VNode } from 'vue'\nimport type { TransferDataItem, TransferKey } from './transfer'\nimport type TransferPanel from './transfer-panel.vue'\n\nexport interface TransferPanelState {\n  checked: TransferKey[]\n  allChecked: boolean\n  query: string\n  checkChangeByUser: boolean\n}\n\nexport const CHECKED_CHANGE_EVENT = 'checked-change'\n\nexport const transferPanelProps = buildProps({\n  data: transferProps.data,\n  optionRender: {\n    type: definePropType<(option: TransferDataItem) => VNode | VNode[]>(\n      Function\n    ),\n  },\n  placeholder: String,\n  title: String,\n  filterable: Boolean,\n  format: transferProps.format,\n  filterMethod: transferProps.filterMethod,\n  defaultChecked: transferProps.leftDefaultChecked,\n  props: transferProps.props,\n} as const)\nexport type TransferPanelProps = ExtractPropTypes<typeof transferPanelProps>\n\nexport const transferPanelEmits = {\n  [CHECKED_CHANGE_EVENT]: transferCheckedChangeFn,\n}\nexport type TransferPanelEmits = typeof transferPanelEmits\n\nexport type TransferPanelInstance = InstanceType<typeof TransferPanel>\n", "import { computed } from 'vue'\n\nimport type { TransferPropsAlias } from '../transfer'\n\nexport const usePropsAlias = (props: { props: TransferPropsAlias }) => {\n  const initProps: Required<TransferPropsAlias> = {\n    label: 'label',\n    key: 'key',\n    disabled: 'disabled',\n  }\n\n  return computed(() => ({\n    ...initProps,\n    ...props.props,\n  }))\n}\n", "import { computed, watch } from 'vue'\nimport { isFunction } from '@element-plus/utils'\nimport { CHECKED_CHANGE_EVENT } from '../transfer-panel'\nimport { usePropsAlias } from './use-props-alias'\n\nimport type { SetupContext } from 'vue'\nimport type { CheckboxValueType } from '@element-plus/components/checkbox'\nimport type { TransferKey } from '../transfer'\nimport type {\n  TransferPanelEmits,\n  TransferPanelProps,\n  TransferPanelState,\n} from '../transfer-panel'\n\nexport const useCheck = (\n  props: TransferPanelProps,\n  panelState: TransferPanelState,\n  emit: SetupContext<TransferPanelEmits>['emit']\n) => {\n  const propsAlias = usePropsAlias(props)\n\n  const filteredData = computed(() => {\n    return props.data.filter((item) => {\n      if (isFunction(props.filterMethod)) {\n        return props.filterMethod(panelState.query, item)\n      } else {\n        const label = String(\n          item[propsAlias.value.label] || item[propsAlias.value.key]\n        )\n        return label.toLowerCase().includes(panelState.query.toLowerCase())\n      }\n    })\n  })\n\n  const checkableData = computed(() =>\n    filteredData.value.filter((item) => !item[propsAlias.value.disabled])\n  )\n\n  const checkedSummary = computed(() => {\n    const checkedLength = panelState.checked.length\n    const dataLength = props.data.length\n    const { noChecked, hasChecked } = props.format\n\n    if (noChecked && hasChecked) {\n      return checkedLength > 0\n        ? hasChecked\n            .replace(/\\${checked}/g, checkedLength.toString())\n            .replace(/\\${total}/g, dataLength.toString())\n        : noChecked.replace(/\\${total}/g, dataLength.toString())\n    } else {\n      return `${checkedLength}/${dataLength}`\n    }\n  })\n\n  const isIndeterminate = computed(() => {\n    const checkedLength = panelState.checked.length\n    return checkedLength > 0 && checkedLength < checkableData.value.length\n  })\n\n  const updateAllChecked = () => {\n    const checkableDataKeys = checkableData.value.map(\n      (item) => item[propsAlias.value.key]\n    )\n    panelState.allChecked =\n      checkableDataKeys.length > 0 &&\n      checkableDataKeys.every((item) => panelState.checked.includes(item))\n  }\n\n  const handleAllCheckedChange = (value: CheckboxValueType) => {\n    panelState.checked = value\n      ? checkableData.value.map((item) => item[propsAlias.value.key])\n      : []\n  }\n\n  watch(\n    () => panelState.checked,\n    (val, oldVal) => {\n      updateAllChecked()\n\n      if (panelState.checkChangeByUser) {\n        const movedKeys = val\n          .concat(oldVal)\n          .filter((v) => !val.includes(v) || !oldVal.includes(v))\n        emit(CHECKED_CHANGE_EVENT, val, movedKeys)\n      } else {\n        emit(CHECKED_CHANGE_EVENT, val)\n        panelState.checkChangeByUser = true\n      }\n    }\n  )\n\n  watch(checkableData, () => {\n    updateAllChecked()\n  })\n\n  watch(\n    () => props.data,\n    () => {\n      const checked: TransferKey[] = []\n      const filteredDataKeys = filteredData.value.map(\n        (item) => item[propsAlias.value.key]\n      )\n      panelState.checked.forEach((item) => {\n        if (filteredDataKeys.includes(item)) {\n          checked.push(item)\n        }\n      })\n      panelState.checkChangeByUser = false\n      panelState.checked = checked\n    }\n  )\n\n  watch(\n    () => props.defaultChecked,\n    (val, oldVal) => {\n      if (\n        oldVal &&\n        val.length === oldVal.length &&\n        val.every((item) => oldVal.includes(item))\n      )\n        return\n\n      const checked: TransferKey[] = []\n      const checkableDataKeys = checkableData.value.map(\n        (item) => item[propsAlias.value.key]\n      )\n\n      val.forEach((item) => {\n        if (checkableDataKeys.includes(item)) {\n          checked.push(item)\n        }\n      })\n      panelState.checkChangeByUser = false\n      panelState.checked = checked\n    },\n    {\n      immediate: true,\n    }\n  )\n\n  return {\n    filteredData,\n    checkableData,\n    checkedSummary,\n    isIndeterminate,\n    updateAllChecked,\n    handleAllCheckedChange,\n  }\n}\n", "import { LEFT_CHECK_CHANGE_EVENT, RIGHT_CHECK_CHANGE_EVENT } from '../transfer'\n\nimport type { SetupContext } from 'vue'\nimport type {\n  TransferCheckedState,\n  TransferEmits,\n  TransferKey,\n} from '../transfer'\n\nexport const useCheckedChange = (\n  checkedState: TransferCheckedState,\n  emit: SetupContext<TransferEmits>['emit']\n) => {\n  const onSourceCheckedChange = (\n    val: TransferKey[],\n    movedKeys?: TransferKey[]\n  ) => {\n    checkedState.leftChecked = val\n    if (!movedKeys) return\n    emit(LEFT_CHECK_CHANGE_EVENT, val, movedKeys)\n  }\n\n  const onTargetCheckedChange = (\n    val: TransferKey[],\n    movedKeys?: TransferKey[]\n  ) => {\n    checkedState.rightChecked = val\n    if (!movedKeys) return\n    emit(RIGHT_CHECK_CHANGE_EVENT, val, movedKeys)\n  }\n\n  return {\n    onSourceCheckedChange,\n    onTargetCheckedChange,\n  }\n}\n", "import { computed } from 'vue'\nimport { usePropsAlias } from './use-props-alias'\n\nimport type { TransferDataItem, TransferKey, TransferProps } from '../transfer'\n\nexport const useComputedData = (props: TransferProps) => {\n  const propsAlias = usePropsAlias(props)\n\n  const dataObj = computed(() =>\n    props.data.reduce((o, cur) => (o[cur[propsAlias.value.key]] = cur) && o, {})\n  )\n\n  const sourceData = computed(() =>\n    props.data.filter(\n      (item) => !props.modelValue.includes(item[propsAlias.value.key])\n    )\n  )\n\n  const targetData = computed(() => {\n    if (props.targetOrder === 'original') {\n      return props.data.filter((item) =>\n        props.modelValue.includes(item[propsAlias.value.key])\n      )\n    } else {\n      return props.modelValue.reduce(\n        (arr: TransferDataItem[], cur: TransferKey) => {\n          const val = dataObj.value[cur]\n          if (val) {\n            arr.push(val)\n          }\n          return arr\n        },\n        []\n      )\n    }\n  })\n\n  return {\n    sourceData,\n    targetData,\n  }\n}\n", "import { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { usePropsAlias } from './use-props-alias'\n\nimport type { SetupContext } from 'vue'\nimport type {\n  TransferCheckedState,\n  TransferDataItem,\n  TransferDirection,\n  TransferEmits,\n  TransferKey,\n  TransferProps,\n} from '../transfer'\n\nexport const useMove = (\n  props: TransferProps,\n  checkedState: TransferCheckedState,\n  emit: SetupContext<TransferEmits>['emit']\n) => {\n  const propsAlias = usePropsAlias(props)\n\n  const _emit = (\n    value: TransferKey[],\n    direction: TransferDirection,\n    movedKeys: TransferKey[]\n  ) => {\n    emit(UPDATE_MODEL_EVENT, value)\n    emit(CHANGE_EVENT, value, direction, movedKeys)\n  }\n\n  const addToLeft = () => {\n    const currentValue = props.modelValue.slice()\n\n    checkedState.rightChecked.forEach((item) => {\n      const index = currentValue.indexOf(item)\n      if (index > -1) {\n        currentValue.splice(index, 1)\n      }\n    })\n    _emit(currentValue, 'left', checkedState.rightChecked)\n  }\n\n  const addToRight = () => {\n    let currentValue = props.modelValue.slice()\n\n    const itemsToBeMoved = props.data\n      .filter((item: TransferDataItem) => {\n        const itemKey = item[propsAlias.value.key]\n        return (\n          checkedState.leftChecked.includes(itemKey) &&\n          !props.modelValue.includes(itemKey)\n        )\n      })\n      .map((item) => item[propsAlias.value.key])\n\n    currentValue =\n      props.targetOrder === 'unshift'\n        ? itemsToBeMoved.concat(currentValue)\n        : currentValue.concat(itemsToBeMoved)\n\n    if (props.targetOrder === 'original') {\n      currentValue = props.data\n        .filter((item) => currentValue.includes(item[propsAlias.value.key]))\n        .map((item) => item[propsAlias.value.key])\n    }\n\n    _emit(currentValue, 'right', checkedState.leftChecked)\n  }\n\n  return {\n    addToLeft,\n    addToRight,\n  }\n}\n", "<template>\n  <div :class=\"ns.b('panel')\">\n    <p :class=\"ns.be('panel', 'header')\">\n      <el-checkbox\n        v-model=\"allChecked\"\n        :indeterminate=\"isIndeterminate\"\n        :validate-event=\"false\"\n        @change=\"handleAllCheckedChange\"\n      >\n        {{ title }}\n        <span>{{ checkedSummary }}</span>\n      </el-checkbox>\n    </p>\n\n    <div :class=\"[ns.be('panel', 'body'), ns.is('with-footer', hasFooter)]\">\n      <el-input\n        v-if=\"filterable\"\n        v-model=\"query\"\n        :class=\"ns.be('panel', 'filter')\"\n        size=\"default\"\n        :placeholder=\"placeholder\"\n        :prefix-icon=\"Search\"\n        clearable\n        :validate-event=\"false\"\n      />\n      <el-checkbox-group\n        v-show=\"!hasNoMatch && !isEmpty(data)\"\n        v-model=\"checked\"\n        :validate-event=\"false\"\n        :class=\"[ns.is('filterable', filterable), ns.be('panel', 'list')]\"\n      >\n        <el-checkbox\n          v-for=\"item in filteredData\"\n          :key=\"item[propsAlias.key]\"\n          :class=\"ns.be('panel', 'item')\"\n          :value=\"item[propsAlias.key]\"\n          :disabled=\"item[propsAlias.disabled]\"\n          :validate-event=\"false\"\n        >\n          <option-content :option=\"optionRender?.(item)\" />\n        </el-checkbox>\n      </el-checkbox-group>\n      <p v-show=\"hasNoMatch || isEmpty(data)\" :class=\"ns.be('panel', 'empty')\">\n        {{ hasNoMatch ? t('el.transfer.noMatch') : t('el.transfer.noData') }}\n      </p>\n    </div>\n    <p v-if=\"hasFooter\" :class=\"ns.be('panel', 'footer')\">\n      <slot />\n    </p>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, reactive, toRefs, useSlots } from 'vue'\nimport { isEmpty } from '@element-plus/utils'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { ElCheckbox, ElCheckboxGroup } from '@element-plus/components/checkbox'\nimport { ElInput } from '@element-plus/components/input'\nimport { Search } from '@element-plus/icons-vue'\nimport { transferPanelEmits, transferPanelProps } from './transfer-panel'\nimport { useCheck, usePropsAlias } from './composables'\n\nimport type { VNode } from 'vue'\nimport type { TransferPanelState } from './transfer-panel'\n\ndefineOptions({\n  name: 'ElTransferPanel',\n})\n\nconst props = defineProps(transferPanelProps)\nconst emit = defineEmits(transferPanelEmits)\nconst slots = useSlots()\n\nconst OptionContent = ({ option }: { option?: VNode | VNode[] }) => option\n\nconst { t } = useLocale()\nconst ns = useNamespace('transfer')\n\nconst panelState = reactive<TransferPanelState>({\n  checked: [],\n  allChecked: false,\n  query: '',\n  checkChangeByUser: true,\n})\n\nconst propsAlias = usePropsAlias(props)\n\nconst {\n  filteredData,\n  checkedSummary,\n  isIndeterminate,\n  handleAllCheckedChange,\n} = useCheck(props, panelState, emit)\n\nconst hasNoMatch = computed(\n  () => !isEmpty(panelState.query) && isEmpty(filteredData.value)\n)\n\nconst hasFooter = computed(() => !isEmpty(slots.default!()[0].children))\n\nconst { checked, allChecked, query } = toRefs(panelState)\n\ndefineExpose({\n  /** @description filter keyword */\n  query,\n})\n</script>\n", "<template>\n  <div :class=\"ns.b()\">\n    <transfer-panel\n      ref=\"leftPanel\"\n      :data=\"sourceData\"\n      :option-render=\"optionRender\"\n      :placeholder=\"panelFilterPlaceholder\"\n      :title=\"leftPanelTitle\"\n      :filterable=\"filterable\"\n      :format=\"format\"\n      :filter-method=\"filterMethod\"\n      :default-checked=\"leftDefaultChecked\"\n      :props=\"props.props\"\n      @checked-change=\"onSourceCheckedChange\"\n    >\n      <slot name=\"left-footer\" />\n    </transfer-panel>\n    <div :class=\"ns.e('buttons')\">\n      <el-button\n        type=\"primary\"\n        :class=\"[ns.e('button'), ns.is('with-texts', hasButtonTexts)]\"\n        :disabled=\"isEmpty(checkedState.rightChecked)\"\n        @click=\"addToLeft\"\n      >\n        <el-icon><arrow-left /></el-icon>\n        <span v-if=\"!isUndefined(buttonTexts[0])\">{{ buttonTexts[0] }}</span>\n      </el-button>\n      <el-button\n        type=\"primary\"\n        :class=\"[ns.e('button'), ns.is('with-texts', hasButtonTexts)]\"\n        :disabled=\"isEmpty(checkedState.leftChecked)\"\n        @click=\"addToRight\"\n      >\n        <span v-if=\"!isUndefined(buttonTexts[1])\">{{ buttonTexts[1] }}</span>\n        <el-icon><arrow-right /></el-icon>\n      </el-button>\n    </div>\n    <transfer-panel\n      ref=\"rightPanel\"\n      :data=\"targetData\"\n      :option-render=\"optionRender\"\n      :placeholder=\"panelFilterPlaceholder\"\n      :filterable=\"filterable\"\n      :format=\"format\"\n      :filter-method=\"filterMethod\"\n      :title=\"rightPanelTitle\"\n      :default-checked=\"rightDefaultChecked\"\n      :props=\"props.props\"\n      @checked-change=\"onTargetCheckedChange\"\n    >\n      <slot name=\"right-footer\" />\n    </transfer-panel>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, h, reactive, ref, useSlots, watch } from 'vue'\nimport { debugWarn, isEmpty, isUndefined } from '@element-plus/utils'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { ElButton } from '@element-plus/components/button'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { useFormItem } from '@element-plus/components/form'\nimport { ArrowLeft, ArrowRight } from '@element-plus/icons-vue'\nimport { transferEmits, transferProps } from './transfer'\nimport {\n  useCheckedChange,\n  useComputedData,\n  useMove,\n  usePropsAlias,\n} from './composables'\nimport TransferPanel from './transfer-panel.vue'\n\nimport type {\n  TransferCheckedState,\n  TransferDataItem,\n  TransferDirection,\n} from './transfer'\nimport type { TransferPanelInstance } from './transfer-panel'\n\ndefineOptions({\n  name: 'ElTransfer',\n})\n\nconst props = defineProps(transferProps)\nconst emit = defineEmits(transferEmits)\nconst slots = useSlots()\n\nconst { t } = useLocale()\nconst ns = useNamespace('transfer')\nconst { formItem } = useFormItem()\n\nconst checkedState = reactive<TransferCheckedState>({\n  leftChecked: [],\n  rightChecked: [],\n})\n\nconst propsAlias = usePropsAlias(props)\n\nconst { sourceData, targetData } = useComputedData(props)\n\nconst { onSourceCheckedChange, onTargetCheckedChange } = useCheckedChange(\n  checkedState,\n  emit\n)\n\nconst { addToLeft, addToRight } = useMove(props, checkedState, emit)\n\nconst leftPanel = ref<TransferPanelInstance>()\nconst rightPanel = ref<TransferPanelInstance>()\n\nconst clearQuery = (which: TransferDirection) => {\n  switch (which) {\n    case 'left':\n      leftPanel.value!.query = ''\n      break\n    case 'right':\n      rightPanel.value!.query = ''\n      break\n  }\n}\n\nconst hasButtonTexts = computed(() => props.buttonTexts.length === 2)\n\nconst leftPanelTitle = computed(\n  () => props.titles[0] || t('el.transfer.titles.0')\n)\n\nconst rightPanelTitle = computed(\n  () => props.titles[1] || t('el.transfer.titles.1')\n)\n\nconst panelFilterPlaceholder = computed(\n  () => props.filterPlaceholder || t('el.transfer.filterPlaceholder')\n)\n\nwatch(\n  () => props.modelValue,\n  () => {\n    if (props.validateEvent) {\n      formItem?.validate?.('change').catch((err) => debugWarn(err))\n    }\n  }\n)\n\nconst optionRender = computed(() => (option: TransferDataItem) => {\n  if (props.renderContent) return props.renderContent(h, option)\n\n  if (slots.default) return slots.default({ option })\n\n  return h(\n    'span',\n    option[propsAlias.value.label] || option[propsAlias.value.key]\n  )\n})\n\ndefineExpose({\n  /** @description clear the filter keyword of a certain panel */\n  clearQuery,\n  /** @description left panel ref */\n  leftPanel,\n  /** @description left panel ref */\n  rightPanel,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\n\nimport Transfer from './src/transfer.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTransfer: SFCWithInstall<typeof Transfer> = withInstall(Transfer)\nexport default ElTransfer\n\nexport * from './src/transfer'\n", "import type { SetupContext } from 'vue'\nimport type Node from './node'\nimport type { RootTreeType, TreeKey, TreeNodeData } from '../tree.type'\n\nexport const NODE_KEY = '$treeNodeId'\n\nexport const markNodeData = function (node: Node, data: TreeNodeData): void {\n  if (!data || data[NODE_KEY]) return\n  Object.defineProperty(data, NODE_KEY, {\n    value: node.id,\n    enumerable: false,\n    configurable: false,\n    writable: false,\n  })\n}\n\nexport const getNodeKey = function (key: TreeKey, data: TreeNodeData): any {\n  if (!key) return data[NODE_KEY]\n  return data[key]\n}\n\nexport const handleCurrentChange = (\n  store: RootTreeType['store'],\n  emit: SetupContext['emit'],\n  setCurrent: () => void\n) => {\n  const preCurrentNode = store.value.currentNode\n  setCurrent()\n  const currentNode = store.value.currentNode\n  if (preCurrentNode === currentNode) return\n\n  emit('current-change', currentNode ? currentNode.data : null, currentNode)\n}\n", "// @ts-nocheck\nimport { reactive } from 'vue'\nimport { hasOwn } from '@element-plus/utils'\nimport { NODE_KEY, markNodeData } from './util'\nimport type TreeStore from './tree-store'\n\nimport type { Nullable } from '@element-plus/utils'\nimport type {\n  FakeNode,\n  TreeKey,\n  TreeNodeChildState,\n  TreeNodeData,\n  TreeNodeLoadedDefaultProps,\n  TreeNodeOptions,\n} from '../tree.type'\n\nexport const getChildState = (node: Node[]): TreeNodeChildState => {\n  let all = true\n  let none = true\n  let allWithoutDisable = true\n  for (let i = 0, j = node.length; i < j; i++) {\n    const n = node[i]\n    if (n.checked !== true || n.indeterminate) {\n      all = false\n      if (!n.disabled) {\n        allWithoutDisable = false\n      }\n    }\n    if (n.checked !== false || n.indeterminate) {\n      none = false\n    }\n  }\n\n  return { all, none, allWithoutDisable, half: !all && !none }\n}\n\nconst reInitChecked = function (node: Node): void {\n  if (node.childNodes.length === 0 || node.loading) return\n\n  const { all, none, half } = getChildState(node.childNodes)\n  if (all) {\n    node.checked = true\n    node.indeterminate = false\n  } else if (half) {\n    node.checked = false\n    node.indeterminate = true\n  } else if (none) {\n    node.checked = false\n    node.indeterminate = false\n  }\n\n  const parent = node.parent\n  if (!parent || parent.level === 0) return\n\n  if (!node.store.checkStrictly) {\n    reInitChecked(parent)\n  }\n}\n\nconst getPropertyFromData = function (node: Node, prop: string): any {\n  const props = node.store.props\n  const data = node.data || {}\n  const config = props[prop]\n\n  if (typeof config === 'function') {\n    return config(data, node)\n  } else if (typeof config === 'string') {\n    return data[config]\n  } else if (typeof config === 'undefined') {\n    const dataProp = data[prop]\n    return dataProp === undefined ? '' : dataProp\n  }\n}\n\nlet nodeIdSeed = 0\n\nclass Node {\n  id: number\n  text: string\n  checked: boolean\n  indeterminate: boolean\n  data: TreeNodeData\n  expanded: boolean\n  parent: Node\n  visible: boolean\n  isCurrent: boolean\n  store: TreeStore\n  isLeafByUser: boolean\n  isLeaf: boolean\n  canFocus: boolean\n\n  level: number\n  loaded: boolean\n  childNodes: Node[]\n  loading: boolean\n\n  constructor(options: TreeNodeOptions) {\n    this.id = nodeIdSeed++\n    this.text = null\n    this.checked = false\n    this.indeterminate = false\n    this.data = null\n    this.expanded = false\n    this.parent = null\n    this.visible = true\n    this.isCurrent = false\n    this.canFocus = false\n\n    for (const name in options) {\n      if (hasOwn(options, name)) {\n        this[name] = options[name]\n      }\n    }\n\n    // internal\n    this.level = 0\n    this.loaded = false\n    this.childNodes = []\n    this.loading = false\n\n    if (this.parent) {\n      this.level = this.parent.level + 1\n    }\n  }\n\n  initialize() {\n    const store = this.store\n    if (!store) {\n      throw new Error('[Node]store is required!')\n    }\n    store.registerNode(this)\n\n    const props = store.props\n    if (props && typeof props.isLeaf !== 'undefined') {\n      const isLeaf = getPropertyFromData(this, 'isLeaf')\n      if (typeof isLeaf === 'boolean') {\n        this.isLeafByUser = isLeaf\n      }\n    }\n\n    if (store.lazy !== true && this.data) {\n      this.setData(this.data)\n\n      if (store.defaultExpandAll) {\n        this.expanded = true\n        this.canFocus = true\n      }\n    } else if (\n      this.level > 0 &&\n      store.lazy &&\n      store.defaultExpandAll &&\n      !this.isLeafByUser\n    ) {\n      this.expand()\n    }\n    if (!Array.isArray(this.data)) {\n      markNodeData(this, this.data)\n    }\n    if (!this.data) return\n\n    const defaultExpandedKeys = store.defaultExpandedKeys\n    const key = store.key\n\n    if (key && defaultExpandedKeys && defaultExpandedKeys.includes(this.key)) {\n      this.expand(null, store.autoExpandParent)\n    }\n\n    if (\n      key &&\n      store.currentNodeKey !== undefined &&\n      this.key === store.currentNodeKey\n    ) {\n      store.currentNode = this\n      store.currentNode.isCurrent = true\n    }\n\n    if (store.lazy) {\n      store._initDefaultCheckedNode(this)\n    }\n\n    this.updateLeafState()\n    if (this.parent && (this.level === 1 || this.parent.expanded === true))\n      this.canFocus = true\n  }\n\n  setData(data: TreeNodeData): void {\n    if (!Array.isArray(data)) {\n      markNodeData(this, data)\n    }\n\n    this.data = data\n    this.childNodes = []\n\n    let children\n    if (this.level === 0 && Array.isArray(this.data)) {\n      children = this.data\n    } else {\n      children = getPropertyFromData(this, 'children') || []\n    }\n\n    for (let i = 0, j = children.length; i < j; i++) {\n      this.insertChild({ data: children[i] })\n    }\n  }\n\n  get label(): string {\n    return getPropertyFromData(this, 'label')\n  }\n\n  get key(): TreeKey {\n    const nodeKey = this.store.key\n    if (this.data) return this.data[nodeKey]\n    return null\n  }\n\n  get disabled(): boolean {\n    return getPropertyFromData(this, 'disabled')\n  }\n\n  get nextSibling(): Nullable<Node> {\n    const parent = this.parent\n    if (parent) {\n      const index = parent.childNodes.indexOf(this)\n      if (index > -1) {\n        return parent.childNodes[index + 1]\n      }\n    }\n    return null\n  }\n\n  get previousSibling(): Nullable<Node> {\n    const parent = this.parent\n    if (parent) {\n      const index = parent.childNodes.indexOf(this)\n      if (index > -1) {\n        return index > 0 ? parent.childNodes[index - 1] : null\n      }\n    }\n    return null\n  }\n\n  contains(target: Node, deep = true): boolean {\n    return (this.childNodes || []).some(\n      (child) => child === target || (deep && child.contains(target))\n    )\n  }\n\n  remove(): void {\n    const parent = this.parent\n    if (parent) {\n      parent.removeChild(this)\n    }\n  }\n\n  insertChild(child?: FakeNode | Node, index?: number, batch?: boolean): void {\n    if (!child) throw new Error('InsertChild error: child is required.')\n\n    if (!(child instanceof Node)) {\n      if (!batch) {\n        const children = this.getChildren(true)\n        if (!children.includes(child.data)) {\n          if (typeof index === 'undefined' || index < 0) {\n            children.push(child.data)\n          } else {\n            children.splice(index, 0, child.data)\n          }\n        }\n      }\n      Object.assign(child, {\n        parent: this,\n        store: this.store,\n      })\n      child = reactive(new Node(child as TreeNodeOptions))\n      if (child instanceof Node) {\n        child.initialize()\n      }\n    }\n\n    ;(child as Node).level = this.level + 1\n\n    if (typeof index === 'undefined' || index < 0) {\n      this.childNodes.push(child as Node)\n    } else {\n      this.childNodes.splice(index, 0, child as Node)\n    }\n\n    this.updateLeafState()\n  }\n\n  insertBefore(child: FakeNode | Node, ref: Node): void {\n    let index\n    if (ref) {\n      index = this.childNodes.indexOf(ref)\n    }\n    this.insertChild(child, index)\n  }\n\n  insertAfter(child: FakeNode | Node, ref: Node): void {\n    let index\n    if (ref) {\n      index = this.childNodes.indexOf(ref)\n      if (index !== -1) index += 1\n    }\n    this.insertChild(child, index)\n  }\n\n  removeChild(child: Node): void {\n    const children = this.getChildren() || []\n    const dataIndex = children.indexOf(child.data)\n    if (dataIndex > -1) {\n      children.splice(dataIndex, 1)\n    }\n\n    const index = this.childNodes.indexOf(child)\n\n    if (index > -1) {\n      this.store && this.store.deregisterNode(child)\n      child.parent = null\n      this.childNodes.splice(index, 1)\n    }\n\n    this.updateLeafState()\n  }\n\n  removeChildByData(data: TreeNodeData): void {\n    let targetNode: Node = null\n\n    for (let i = 0; i < this.childNodes.length; i++) {\n      if (this.childNodes[i].data === data) {\n        targetNode = this.childNodes[i]\n        break\n      }\n    }\n\n    if (targetNode) {\n      this.removeChild(targetNode)\n    }\n  }\n\n  expand(callback?: () => void, expandParent?: boolean): void {\n    const done = (): void => {\n      if (expandParent) {\n        let parent = this.parent\n        while (parent.level > 0) {\n          parent.expanded = true\n          parent = parent.parent\n        }\n      }\n      this.expanded = true\n      if (callback) callback()\n      this.childNodes.forEach((item) => {\n        item.canFocus = true\n      })\n    }\n\n    if (this.shouldLoadData()) {\n      this.loadData((data) => {\n        if (Array.isArray(data)) {\n          if (this.checked) {\n            this.setChecked(true, true)\n          } else if (!this.store.checkStrictly) {\n            reInitChecked(this)\n          }\n          done()\n        }\n      })\n    } else {\n      done()\n    }\n  }\n\n  doCreateChildren(\n    array: TreeNodeData[],\n    defaultProps: TreeNodeLoadedDefaultProps = {}\n  ): void {\n    array.forEach((item) => {\n      this.insertChild(\n        Object.assign({ data: item }, defaultProps),\n        undefined,\n        true\n      )\n    })\n  }\n\n  collapse(): void {\n    this.expanded = false\n    this.childNodes.forEach((item) => {\n      item.canFocus = false\n    })\n  }\n\n  shouldLoadData(): boolean {\n    return this.store.lazy === true && this.store.load && !this.loaded\n  }\n\n  updateLeafState(): void {\n    if (\n      this.store.lazy === true &&\n      this.loaded !== true &&\n      typeof this.isLeafByUser !== 'undefined'\n    ) {\n      this.isLeaf = this.isLeafByUser\n      return\n    }\n    const childNodes = this.childNodes\n    if (\n      !this.store.lazy ||\n      (this.store.lazy === true && this.loaded === true)\n    ) {\n      this.isLeaf = !childNodes || childNodes.length === 0\n      return\n    }\n    this.isLeaf = false\n  }\n\n  setChecked(\n    value?: boolean | string,\n    deep?: boolean,\n    recursion?: boolean,\n    passValue?: boolean\n  ) {\n    this.indeterminate = value === 'half'\n    this.checked = value === true\n\n    if (this.store.checkStrictly) return\n\n    if (!(this.shouldLoadData() && !this.store.checkDescendants)) {\n      const { all, allWithoutDisable } = getChildState(this.childNodes)\n\n      if (!this.isLeaf && !all && allWithoutDisable) {\n        this.checked = false\n        value = false\n      }\n\n      const handleDescendants = (): void => {\n        if (deep) {\n          const childNodes = this.childNodes\n          for (let i = 0, j = childNodes.length; i < j; i++) {\n            const child = childNodes[i]\n            passValue = passValue || value !== false\n            const isCheck = child.disabled ? child.checked : passValue\n            child.setChecked(isCheck, deep, true, passValue)\n          }\n          const { half, all } = getChildState(childNodes)\n          if (!all) {\n            this.checked = all\n            this.indeterminate = half\n          }\n        }\n      }\n\n      if (this.shouldLoadData()) {\n        // Only work on lazy load data.\n        this.loadData(\n          () => {\n            handleDescendants()\n            reInitChecked(this)\n          },\n          {\n            checked: value !== false,\n          }\n        )\n        return\n      } else {\n        handleDescendants()\n      }\n    }\n\n    const parent = this.parent\n    if (!parent || parent.level === 0) return\n\n    if (!recursion) {\n      reInitChecked(parent)\n    }\n  }\n\n  getChildren(forceInit = false): TreeNodeData | TreeNodeData[] {\n    // this is data\n    if (this.level === 0) return this.data\n    const data = this.data\n    if (!data) return null\n\n    const props = this.store.props\n    let children = 'children'\n    if (props) {\n      children = props.children || 'children'\n    }\n\n    if (data[children] === undefined) {\n      data[children] = null\n    }\n\n    if (forceInit && !data[children]) {\n      data[children] = []\n    }\n\n    return data[children]\n  }\n\n  updateChildren(): void {\n    const newData = (this.getChildren() || []) as TreeNodeData[]\n    const oldData = this.childNodes.map((node) => node.data)\n\n    const newDataMap = {}\n    const newNodes = []\n\n    newData.forEach((item, index) => {\n      const key = item[NODE_KEY]\n      const isNodeExists =\n        !!key && oldData.findIndex((data) => data[NODE_KEY] === key) >= 0\n      if (isNodeExists) {\n        newDataMap[key] = { index, data: item }\n      } else {\n        newNodes.push({ index, data: item })\n      }\n    })\n\n    if (!this.store.lazy) {\n      oldData.forEach((item) => {\n        if (!newDataMap[item[NODE_KEY]]) this.removeChildByData(item)\n      })\n    }\n\n    newNodes.forEach(({ index, data }) => {\n      this.insertChild({ data }, index)\n    })\n\n    this.updateLeafState()\n  }\n\n  loadData(\n    callback: (node: Node) => void,\n    defaultProps: TreeNodeLoadedDefaultProps = {}\n  ) {\n    if (\n      this.store.lazy === true &&\n      this.store.load &&\n      !this.loaded &&\n      (!this.loading || Object.keys(defaultProps).length)\n    ) {\n      this.loading = true\n\n      const resolve = (children) => {\n        this.childNodes = []\n\n        this.doCreateChildren(children, defaultProps)\n        this.loaded = true\n        this.loading = false\n\n        this.updateLeafState()\n        if (callback) {\n          callback.call(this, children)\n        }\n      }\n      const reject = () => {\n        this.loading = false\n      }\n\n      this.store.load(this, resolve, reject)\n    } else {\n      if (callback) {\n        callback.call(this)\n      }\n    }\n  }\n\n  eachNode(callback: (node: Node) => void) {\n    const arr: Node[] = [this]\n    while (arr.length) {\n      const node = arr.shift()!\n      arr.unshift(...node.childNodes)\n      callback(node)\n    }\n  }\n\n  reInitChecked() {\n    if (this.store.checkStrictly) return\n    reInitChecked(this)\n  }\n}\n\nexport default Node\n", "// @ts-nocheck\nimport { hasOwn, isObject, isPropAbsent } from '@element-plus/utils'\nimport Node from './node'\nimport { getNodeKey } from './util'\n\nimport type {\n  FilterNodeMethodFunction,\n  FilterValue,\n  LoadFunction,\n  TreeData,\n  TreeKey,\n  TreeNodeData,\n  TreeOptionProps,\n  TreeStoreNodesMap,\n  TreeStoreOptions,\n} from '../tree.type'\n\nexport default class TreeStore {\n  currentNode: Node\n  currentNodeKey: TreeKey\n  nodesMap: TreeStoreNodesMap\n  root: Node\n  data: TreeData\n  lazy: boolean\n  load: LoadFunction\n  filterNodeMethod: FilterNodeMethodFunction\n  key: TreeKey\n  defaultCheckedKeys: TreeKey[]\n  checkStrictly: boolean\n  defaultExpandedKeys: TreeKey[]\n  autoExpandParent: boolean\n  defaultExpandAll: boolean\n  checkDescendants: boolean\n  props: TreeOptionProps\n\n  constructor(options: TreeStoreOptions) {\n    this.currentNode = null\n    this.currentNodeKey = null\n\n    for (const option in options) {\n      if (hasOwn(options, option)) {\n        this[option] = options[option]\n      }\n    }\n\n    this.nodesMap = {}\n  }\n\n  initialize() {\n    this.root = new Node({\n      data: this.data,\n      store: this,\n    })\n    this.root.initialize()\n\n    if (this.lazy && this.load) {\n      const loadFn = this.load\n      loadFn(this.root, (data) => {\n        this.root.doCreateChildren(data)\n        this._initDefaultCheckedNodes()\n      })\n    } else {\n      this._initDefaultCheckedNodes()\n    }\n  }\n\n  filter(value: FilterValue): void {\n    const filterNodeMethod = this.filterNodeMethod\n    const lazy = this.lazy\n    const traverse = function (node: TreeStore | Node) {\n      const childNodes = (node as TreeStore).root\n        ? (node as TreeStore).root.childNodes\n        : (node as Node).childNodes\n\n      childNodes.forEach((child) => {\n        child.visible = filterNodeMethod.call(child, value, child.data, child)\n\n        traverse(child)\n      })\n\n      if (!(node as Node).visible && childNodes.length) {\n        let allHidden = true\n        allHidden = !childNodes.some((child) => child.visible)\n\n        if ((node as TreeStore).root) {\n          ;(node as TreeStore).root.visible = allHidden === false\n        } else {\n          ;(node as Node).visible = allHidden === false\n        }\n      }\n      if (!value) return\n\n      if ((node as Node).visible && !(node as Node).isLeaf) {\n        if (!lazy || node.loaded) {\n          ;(node as Node).expand()\n        }\n      }\n    }\n\n    traverse(this)\n  }\n\n  setData(newVal: TreeData): void {\n    const instanceChanged = newVal !== this.root.data\n    if (instanceChanged) {\n      this.nodesMap = {}\n      this.root.setData(newVal)\n      this._initDefaultCheckedNodes()\n    } else {\n      this.root.updateChildren()\n    }\n  }\n\n  getNode(data: TreeKey | TreeNodeData | Node): Node {\n    if (data instanceof Node) return data\n    const key = isObject(data) ? getNodeKey(this.key, data) : data\n    return this.nodesMap[key] || null\n  }\n\n  insertBefore(\n    data: TreeNodeData,\n    refData: TreeKey | TreeNodeData | Node\n  ): void {\n    const refNode = this.getNode(refData)\n    refNode.parent.insertBefore({ data }, refNode)\n  }\n\n  insertAfter(\n    data: TreeNodeData,\n    refData: TreeKey | TreeNodeData | Node\n  ): void {\n    const refNode = this.getNode(refData)\n    refNode.parent.insertAfter({ data }, refNode)\n  }\n\n  remove(data: TreeNodeData | Node): void {\n    const node = this.getNode(data)\n\n    if (node && node.parent) {\n      if (node === this.currentNode) {\n        this.currentNode = null\n      }\n      node.parent.removeChild(node)\n    }\n  }\n\n  append(data: TreeNodeData, parentData: TreeNodeData | TreeKey | Node): void {\n    const parentNode = !isPropAbsent(parentData)\n      ? this.getNode(parentData)\n      : this.root\n\n    if (parentNode) {\n      parentNode.insertChild({ data })\n    }\n  }\n\n  _initDefaultCheckedNodes(): void {\n    const defaultCheckedKeys = this.defaultCheckedKeys || []\n    const nodesMap = this.nodesMap\n\n    defaultCheckedKeys.forEach((checkedKey) => {\n      const node = nodesMap[checkedKey]\n\n      if (node) {\n        node.setChecked(true, !this.checkStrictly)\n      }\n    })\n  }\n\n  _initDefaultCheckedNode(node: Node): void {\n    const defaultCheckedKeys = this.defaultCheckedKeys || []\n\n    if (defaultCheckedKeys.includes(node.key)) {\n      node.setChecked(true, !this.checkStrictly)\n    }\n  }\n\n  setDefaultCheckedKey(newVal: TreeKey[]): void {\n    if (newVal !== this.defaultCheckedKeys) {\n      this.defaultCheckedKeys = newVal\n      this._initDefaultCheckedNodes()\n    }\n  }\n\n  registerNode(node: Node): void {\n    const key = this.key\n    if (!node || !node.data) return\n\n    if (!key) {\n      this.nodesMap[node.id] = node\n    } else {\n      const nodeKey = node.key\n      if (nodeKey !== undefined) this.nodesMap[node.key] = node\n    }\n  }\n\n  deregisterNode(node: Node): void {\n    const key = this.key\n    if (!key || !node || !node.data) return\n\n    node.childNodes.forEach((child) => {\n      this.deregisterNode(child)\n    })\n\n    delete this.nodesMap[node.key]\n  }\n\n  getCheckedNodes(\n    leafOnly = false,\n    includeHalfChecked = false\n  ): TreeNodeData[] {\n    const checkedNodes: TreeNodeData[] = []\n    const traverse = function (node: TreeStore | Node) {\n      const childNodes = (node as TreeStore).root\n        ? (node as TreeStore).root.childNodes\n        : (node as Node).childNodes\n\n      childNodes.forEach((child) => {\n        if (\n          (child.checked || (includeHalfChecked && child.indeterminate)) &&\n          (!leafOnly || (leafOnly && child.isLeaf))\n        ) {\n          checkedNodes.push(child.data)\n        }\n\n        traverse(child)\n      })\n    }\n\n    traverse(this)\n\n    return checkedNodes\n  }\n\n  getCheckedKeys(leafOnly = false): TreeKey[] {\n    return this.getCheckedNodes(leafOnly).map((data) => (data || {})[this.key])\n  }\n\n  getHalfCheckedNodes(): TreeNodeData[] {\n    const nodes: TreeNodeData[] = []\n    const traverse = function (node: TreeStore | Node) {\n      const childNodes = (node as TreeStore).root\n        ? (node as TreeStore).root.childNodes\n        : (node as Node).childNodes\n\n      childNodes.forEach((child) => {\n        if (child.indeterminate) {\n          nodes.push(child.data)\n        }\n\n        traverse(child)\n      })\n    }\n\n    traverse(this)\n\n    return nodes\n  }\n\n  getHalfCheckedKeys(): TreeKey[] {\n    return this.getHalfCheckedNodes().map((data) => (data || {})[this.key])\n  }\n\n  _getAllNodes(): Node[] {\n    const allNodes: Node[] = []\n    const nodesMap = this.nodesMap\n    for (const nodeKey in nodesMap) {\n      if (hasOwn(nodesMap, nodeKey)) {\n        allNodes.push(nodesMap[nodeKey])\n      }\n    }\n\n    return allNodes\n  }\n\n  updateChildren(key: TreeKey, data: TreeData): void {\n    const node = this.nodesMap[key]\n    if (!node) return\n    const childNodes = node.childNodes\n    for (let i = childNodes.length - 1; i >= 0; i--) {\n      const child = childNodes[i]\n      this.remove(child.data)\n    }\n    for (let i = 0, j = data.length; i < j; i++) {\n      const child = data[i]\n      this.append(child, node.data)\n    }\n  }\n\n  _setCheckedKeys(\n    key: TreeKey,\n    leafOnly = false,\n    checkedKeys: { [key: string]: boolean }\n  ): void {\n    const allNodes = this._getAllNodes().sort((a, b) => a.level - b.level)\n    const cache = Object.create(null)\n    const keys = Object.keys(checkedKeys)\n    allNodes.forEach((node) => node.setChecked(false, false))\n    const cacheCheckedChild = (node) => {\n      node.childNodes.forEach((child) => {\n        cache[child.data[key]] = true\n        if (child.childNodes?.length) {\n          cacheCheckedChild(child)\n        }\n      })\n    }\n    for (let i = 0, j = allNodes.length; i < j; i++) {\n      const node = allNodes[i]\n      const nodeKey = node.data[key].toString()\n      const checked = keys.includes(nodeKey)\n      if (!checked) {\n        if (node.checked && !cache[nodeKey]) {\n          node.setChecked(false, false)\n        }\n        continue\n      }\n\n      if (node.childNodes.length) {\n        cacheCheckedChild(node)\n      }\n\n      if (node.isLeaf || this.checkStrictly) {\n        node.setChecked(true, false)\n        continue\n      }\n      node.setChecked(true, true)\n\n      if (leafOnly) {\n        node.setChecked(false, false)\n        const traverse = function (node: Node): void {\n          const childNodes = node.childNodes\n          childNodes.forEach((child) => {\n            if (!child.isLeaf) {\n              child.setChecked(false, false)\n            }\n            traverse(child)\n          })\n        }\n        traverse(node)\n      }\n    }\n  }\n\n  setCheckedNodes(array: Node[], leafOnly = false): void {\n    const key = this.key\n    const checkedKeys = {}\n    array.forEach((item) => {\n      checkedKeys[(item || {})[key]] = true\n    })\n\n    this._setCheckedKeys(key, leafOnly, checkedKeys)\n  }\n\n  setCheckedKeys(keys: TreeKey[], leafOnly = false): void {\n    this.defaultCheckedKeys = keys\n    const key = this.key\n    const checkedKeys = {}\n    keys.forEach((key) => {\n      checkedKeys[key] = true\n    })\n\n    this._setCheckedKeys(key, leafOnly, checkedKeys)\n  }\n\n  setDefaultExpandedKeys(keys: TreeKey[]) {\n    keys = keys || []\n    this.defaultExpandedKeys = keys\n    keys.forEach((key) => {\n      const node = this.getNode(key)\n      if (node) node.expand(null, this.autoExpandParent)\n    })\n  }\n\n  setChecked(\n    data: TreeKey | TreeNodeData,\n    checked: boolean,\n    deep: boolean\n  ): void {\n    const node = this.getNode(data)\n\n    if (node) {\n      node.setChecked(!!checked, deep)\n    }\n  }\n\n  getCurrentNode(): Node {\n    return this.currentNode\n  }\n\n  setCurrentNode(currentNode: Node): void {\n    const prevCurrentNode = this.currentNode\n    if (prevCurrentNode) {\n      prevCurrentNode.isCurrent = false\n    }\n    this.currentNode = currentNode\n    this.currentNode.isCurrent = true\n  }\n\n  setUserCurrentNode(node: Node, shouldAutoExpandParent = true): void {\n    const key = node[this.key]\n    const currNode = this.nodesMap[key]\n    this.setCurrentNode(currNode)\n    if (shouldAutoExpandParent && this.currentNode.level > 1) {\n      this.currentNode.parent.expand(null, true)\n    }\n  }\n\n  setCurrentNodeKey(key?: TreeKey, shouldAutoExpandParent = true): void {\n    if (key === null || key === undefined) {\n      this.currentNode && (this.currentNode.isCurrent = false)\n      this.currentNode = null\n      return\n    }\n    const node = this.getNode(key)\n    if (node) {\n      this.setCurrentNode(node)\n      if (shouldAutoExpandParent && this.currentNode.level > 1) {\n        this.currentNode.parent.expand(null, true)\n      }\n    }\n  }\n}\n", "<script lang=\"ts\">\n// @ts-nocheck\nimport { defineComponent, h, inject, renderSlot } from 'vue'\n\nimport { useNamespace } from '@element-plus/hooks'\nimport type { ComponentInternalInstance } from 'vue'\nimport type { RootTreeType } from './tree.type'\n\nexport default defineComponent({\n  name: 'ElTreeNodeContent',\n  props: {\n    node: {\n      type: Object,\n      required: true,\n    },\n    renderContent: Function,\n  },\n  setup(props) {\n    const ns = useNamespace('tree')\n    const nodeInstance = inject<ComponentInternalInstance>('NodeInstance')\n    const tree = inject<RootTreeType>('RootTree')\n    return () => {\n      const node = props.node\n      const { data, store } = node\n      return props.renderContent\n        ? props.renderContent(h, { _self: nodeInstance, node, data, store })\n        : renderSlot(tree.ctx.slots, 'default', { node, data }, () => [\n            h('span', { class: ns.be('node', 'label') }, [node.label]),\n          ])\n    }\n  },\n})\n</script>\n", "// @ts-nocheck\nimport { inject, provide } from 'vue'\nimport type Node from '../model/node'\n\ninterface NodeMap {\n  treeNodeExpand(node: Node): void\n  children: NodeMap[]\n}\n\nexport function useNodeExpandEventBroadcast(props) {\n  const parentNodeMap = inject<NodeMap>('TreeNodeMap', null)\n  const currentNodeMap: NodeMap = {\n    treeNodeExpand: (node) => {\n      if (props.node !== node) {\n        props.node.collapse()\n      }\n    },\n    children: [],\n  }\n\n  if (parentNodeMap) {\n    parentNodeMap.children.push(currentNodeMap)\n  }\n\n  provide('TreeNodeMap', currentNodeMap)\n\n  return {\n    broadcastExpanded: (node: Node): void => {\n      if (!props.accordion) return\n      for (const childNode of currentNodeMap.children) {\n        childNode.treeNodeExpand(node)\n      }\n    },\n  }\n}\n", "// @ts-nocheck\nimport { provide, ref } from 'vue'\nimport { addClass, removeClass } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport type { InjectionKey } from 'vue'\nimport type Node from './node'\nimport type { NodeDropType } from '../tree.type'\n\ninterface TreeNode {\n  node: Node\n  $el?: HTMLElement\n}\n\ninterface DragOptions {\n  event: DragEvent\n  treeNode: TreeNode\n}\n\nexport interface DragEvents {\n  treeNodeDragStart: (options: DragOptions) => void\n  treeNodeDragOver: (options: DragOptions) => void\n  treeNodeDragEnd: (event: DragEvent) => void\n}\n\nexport const dragEventsKey: InjectionKey<DragEvents> = Symbol('dragEvents')\n\nexport function useDragNodeHandler({ props, ctx, el$, dropIndicator$, store }) {\n  const ns = useNamespace('tree')\n  const dragState = ref({\n    showDropIndicator: false,\n    draggingNode: null,\n    dropNode: null,\n    allowDrop: true,\n    dropType: null,\n  })\n\n  const treeNodeDragStart = ({ event, treeNode }: DragOptions) => {\n    if (\n      typeof props.allowDrag === 'function' &&\n      !props.allowDrag(treeNode.node)\n    ) {\n      event.preventDefault()\n      return false\n    }\n    event.dataTransfer.effectAllowed = 'move'\n\n    // wrap in try catch to address IE's error when first param is 'text/plain'\n    try {\n      // setData is required for draggable to work in FireFox\n      // the content has to be '' so dragging a node out of the tree won't open a new tab in FireFox\n      event.dataTransfer.setData('text/plain', '')\n    } catch {}\n    dragState.value.draggingNode = treeNode\n    ctx.emit('node-drag-start', treeNode.node, event)\n  }\n\n  const treeNodeDragOver = ({ event, treeNode }: DragOptions) => {\n    const dropNode = treeNode\n    const oldDropNode = dragState.value.dropNode\n    if (oldDropNode && oldDropNode.node.id !== dropNode.node.id) {\n      removeClass(oldDropNode.$el, ns.is('drop-inner'))\n    }\n    const draggingNode = dragState.value.draggingNode\n    if (!draggingNode || !dropNode) return\n\n    let dropPrev = true\n    let dropInner = true\n    let dropNext = true\n    let userAllowDropInner = true\n    if (typeof props.allowDrop === 'function') {\n      dropPrev = props.allowDrop(draggingNode.node, dropNode.node, 'prev')\n      userAllowDropInner = dropInner = props.allowDrop(\n        draggingNode.node,\n        dropNode.node,\n        'inner'\n      )\n      dropNext = props.allowDrop(draggingNode.node, dropNode.node, 'next')\n    }\n    event.dataTransfer.dropEffect =\n      dropInner || dropPrev || dropNext ? 'move' : 'none'\n    if (\n      (dropPrev || dropInner || dropNext) &&\n      oldDropNode?.node.id !== dropNode.node.id\n    ) {\n      if (oldDropNode) {\n        ctx.emit('node-drag-leave', draggingNode.node, oldDropNode.node, event)\n      }\n      ctx.emit('node-drag-enter', draggingNode.node, dropNode.node, event)\n    }\n\n    if (dropPrev || dropInner || dropNext) {\n      dragState.value.dropNode = dropNode\n    } else {\n      // Reset dragState.value.dropNode to null when allowDrop is transfer from true to false.(For issue #14704)\n      dragState.value.dropNode = null\n    }\n\n    if (dropNode.node.nextSibling === draggingNode.node) {\n      dropNext = false\n    }\n    if (dropNode.node.previousSibling === draggingNode.node) {\n      dropPrev = false\n    }\n    if (dropNode.node.contains(draggingNode.node, false)) {\n      dropInner = false\n    }\n    if (\n      draggingNode.node === dropNode.node ||\n      draggingNode.node.contains(dropNode.node)\n    ) {\n      dropPrev = false\n      dropInner = false\n      dropNext = false\n    }\n\n    // find target node without children, just calc content node height\n    const targetPosition = dropNode.$el\n      .querySelector(`.${ns.be('node', 'content')}`)\n      .getBoundingClientRect()\n    const treePosition = el$.value.getBoundingClientRect()\n\n    let dropType: NodeDropType\n    const prevPercent = dropPrev ? (dropInner ? 0.25 : dropNext ? 0.45 : 1) : -1\n    const nextPercent = dropNext ? (dropInner ? 0.75 : dropPrev ? 0.55 : 0) : 1\n\n    let indicatorTop = -9999\n    const distance = event.clientY - targetPosition.top\n    if (distance < targetPosition.height * prevPercent) {\n      dropType = 'before'\n    } else if (distance > targetPosition.height * nextPercent) {\n      dropType = 'after'\n    } else if (dropInner) {\n      dropType = 'inner'\n    } else {\n      dropType = 'none'\n    }\n\n    const iconPosition = dropNode.$el\n      .querySelector(`.${ns.be('node', 'expand-icon')}`)\n      .getBoundingClientRect()\n    const dropIndicator = dropIndicator$.value\n    if (dropType === 'before') {\n      indicatorTop = iconPosition.top - treePosition.top\n    } else if (dropType === 'after') {\n      indicatorTop = iconPosition.bottom - treePosition.top\n    }\n    dropIndicator.style.top = `${indicatorTop}px`\n    dropIndicator.style.left = `${iconPosition.right - treePosition.left}px`\n\n    if (dropType === 'inner') {\n      addClass(dropNode.$el, ns.is('drop-inner'))\n    } else {\n      removeClass(dropNode.$el, ns.is('drop-inner'))\n    }\n\n    dragState.value.showDropIndicator =\n      dropType === 'before' || dropType === 'after'\n    dragState.value.allowDrop =\n      dragState.value.showDropIndicator || userAllowDropInner\n    dragState.value.dropType = dropType\n    ctx.emit('node-drag-over', draggingNode.node, dropNode.node, event)\n  }\n\n  const treeNodeDragEnd = (event: DragEvent) => {\n    const { draggingNode, dropType, dropNode } = dragState.value\n    event.preventDefault()\n\n    // https://bugzilla.mozilla.org/show_bug.cgi?id=1911486\n    if (event.dataTransfer) {\n      event.dataTransfer.dropEffect = 'move'\n    }\n\n    if (draggingNode && dropNode) {\n      const draggingNodeCopy = { data: draggingNode.node.data }\n      if (dropType !== 'none') {\n        draggingNode.node.remove()\n      }\n      if (dropType === 'before') {\n        dropNode.node.parent.insertBefore(draggingNodeCopy, dropNode.node)\n      } else if (dropType === 'after') {\n        dropNode.node.parent.insertAfter(draggingNodeCopy, dropNode.node)\n      } else if (dropType === 'inner') {\n        dropNode.node.insertChild(draggingNodeCopy)\n      }\n      if (dropType !== 'none') {\n        store.value.registerNode(draggingNodeCopy)\n        if (store.value.key) {\n          //restore checkbox state after dragging\n          draggingNode.node.eachNode((node) => {\n            store.value.nodesMap[node.data[store.value.key]]?.setChecked(\n              node.checked,\n              !store.value.checkStrictly\n            )\n          })\n        }\n      }\n\n      removeClass(dropNode.$el, ns.is('drop-inner'))\n\n      ctx.emit(\n        'node-drag-end',\n        draggingNode.node,\n        dropNode.node,\n        dropType,\n        event\n      )\n      if (dropType !== 'none') {\n        ctx.emit('node-drop', draggingNode.node, dropNode.node, dropType, event)\n      }\n    }\n    if (draggingNode && !dropNode) {\n      ctx.emit('node-drag-end', draggingNode.node, null, dropType, event)\n    }\n\n    dragState.value.showDropIndicator = false\n    dragState.value.draggingNode = null\n    dragState.value.dropNode = null\n    dragState.value.allowDrop = true\n  }\n\n  provide(dragEventsKey, {\n    treeNodeDragStart,\n    treeNodeDragOver,\n    treeNodeDragEnd,\n  })\n\n  return {\n    dragState,\n  }\n}\n", "<template>\n  <div\n    v-show=\"node.visible\"\n    ref=\"node$\"\n    :class=\"[\n      ns.b('node'),\n      ns.is('expanded', expanded),\n      ns.is('current', node.isCurrent),\n      ns.is('hidden', !node.visible),\n      ns.is('focusable', !node.disabled),\n      ns.is('checked', !node.disabled && node.checked),\n      getNodeClass(node),\n    ]\"\n    role=\"treeitem\"\n    tabindex=\"-1\"\n    :aria-expanded=\"expanded\"\n    :aria-disabled=\"node.disabled\"\n    :aria-checked=\"node.checked\"\n    :draggable=\"tree.props.draggable\"\n    :data-key=\"getNodeKey(node)\"\n    @click.stop=\"handleClick\"\n    @contextmenu=\"handleContextMenu\"\n    @dragstart.stop=\"handleDragStart\"\n    @dragover.stop=\"handleDragOver\"\n    @dragend.stop=\"handleDragEnd\"\n    @drop.stop=\"handleDrop\"\n  >\n    <div\n      :class=\"ns.be('node', 'content')\"\n      :style=\"{ paddingLeft: (node.level - 1) * tree.props.indent + 'px' }\"\n    >\n      <el-icon\n        v-if=\"tree.props.icon || CaretRight\"\n        :class=\"[\n          ns.be('node', 'expand-icon'),\n          ns.is('leaf', node.isLeaf),\n          {\n            expanded: !node.isLeaf && expanded,\n          },\n        ]\"\n        @click.stop=\"handleExpandIconClick\"\n      >\n        <component :is=\"tree.props.icon || CaretRight\" />\n      </el-icon>\n      <el-checkbox\n        v-if=\"showCheckbox\"\n        :model-value=\"node.checked\"\n        :indeterminate=\"node.indeterminate\"\n        :disabled=\"!!node.disabled\"\n        @click.stop\n        @change=\"handleCheckChange\"\n      />\n      <el-icon\n        v-if=\"node.loading\"\n        :class=\"[ns.be('node', 'loading-icon'), ns.is('loading')]\"\n      >\n        <loading />\n      </el-icon>\n      <node-content :node=\"node\" :render-content=\"renderContent\" />\n    </div>\n    <el-collapse-transition>\n      <div\n        v-if=\"!renderAfterExpand || childNodeRendered\"\n        v-show=\"expanded\"\n        :class=\"ns.be('node', 'children')\"\n        role=\"group\"\n        :aria-expanded=\"expanded\"\n      >\n        <el-tree-node\n          v-for=\"child in node.childNodes\"\n          :key=\"getNodeKey(child)\"\n          :render-content=\"renderContent\"\n          :render-after-expand=\"renderAfterExpand\"\n          :show-checkbox=\"showCheckbox\"\n          :node=\"child\"\n          :accordion=\"accordion\"\n          :props=\"props\"\n          @node-expand=\"handleChildNodeExpand\"\n        />\n      </div>\n    </el-collapse-transition>\n  </div>\n</template>\n<script lang=\"ts\">\n// @ts-nocheck\nimport {\n  defineComponent,\n  getCurrentInstance,\n  inject,\n  nextTick,\n  provide,\n  ref,\n  watch,\n} from 'vue'\nimport { debugWarn, isFunction, isString } from '@element-plus/utils'\nimport ElCollapseTransition from '@element-plus/components/collapse-transition'\nimport ElCheckbox from '@element-plus/components/checkbox'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { CaretRight, Loading } from '@element-plus/icons-vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport NodeContent from './tree-node-content.vue'\nimport { getNodeKey as getNodeKeyUtil, handleCurrentChange } from './model/util'\nimport { useNodeExpandEventBroadcast } from './model/useNodeExpandEventBroadcast'\nimport { dragEventsKey } from './model/useDragNode'\nimport Node from './model/node'\n\nimport type { ComponentInternalInstance, PropType } from 'vue'\nimport type { Nullable } from '@element-plus/utils'\nimport type { RootTreeType, TreeNodeData, TreeOptionProps } from './tree.type'\n\nexport default defineComponent({\n  name: 'ElTreeNode',\n  components: {\n    ElCollapseTransition,\n    ElCheckbox,\n    NodeContent,\n    ElIcon,\n    Loading,\n  },\n  props: {\n    node: {\n      type: Node,\n      default: () => ({}),\n    },\n    props: {\n      type: Object as PropType<TreeOptionProps>,\n      default: () => ({}),\n    },\n    accordion: Boolean,\n    renderContent: Function,\n    renderAfterExpand: Boolean,\n    showCheckbox: {\n      type: Boolean,\n      default: false,\n    },\n  },\n  emits: ['node-expand'],\n  setup(props, ctx) {\n    const ns = useNamespace('tree')\n    const { broadcastExpanded } = useNodeExpandEventBroadcast(props)\n    const tree = inject<RootTreeType>('RootTree')\n    const expanded = ref(false)\n    const childNodeRendered = ref(false)\n    const oldChecked = ref<boolean>(null)\n    const oldIndeterminate = ref<boolean>(null)\n    const node$ = ref<Nullable<HTMLElement>>(null)\n    const dragEvents = inject(dragEventsKey)\n    const instance = getCurrentInstance()\n\n    provide('NodeInstance', instance)\n    if (!tree) {\n      debugWarn('Tree', \"Can not find node's tree.\")\n    }\n\n    if (props.node.expanded) {\n      expanded.value = true\n      childNodeRendered.value = true\n    }\n\n    const childrenKey = tree.props.props['children'] || 'children'\n    watch(\n      () => {\n        const children = props.node.data[childrenKey]\n        return children && [...children]\n      },\n      () => {\n        props.node.updateChildren()\n      }\n    )\n\n    watch(\n      () => props.node.indeterminate,\n      (val) => {\n        handleSelectChange(props.node.checked, val)\n      }\n    )\n\n    watch(\n      () => props.node.checked,\n      (val) => {\n        handleSelectChange(val, props.node.indeterminate)\n      }\n    )\n\n    watch(\n      () => props.node.childNodes.length,\n      () => props.node.reInitChecked()\n    )\n\n    watch(\n      () => props.node.expanded,\n      (val) => {\n        nextTick(() => (expanded.value = val))\n        if (val) {\n          childNodeRendered.value = true\n        }\n      }\n    )\n\n    const getNodeKey = (node: Node): any => {\n      return getNodeKeyUtil(tree.props.nodeKey, node.data)\n    }\n\n    const getNodeClass = (node: Node) => {\n      const nodeClassFunc = props.props.class\n      if (!nodeClassFunc) {\n        return {}\n      }\n      let className\n      if (isFunction(nodeClassFunc)) {\n        const { data } = node\n        className = nodeClassFunc(data, node)\n      } else {\n        className = nodeClassFunc\n      }\n\n      if (isString(className)) {\n        return { [className]: true }\n      } else {\n        return className\n      }\n    }\n\n    const handleSelectChange = (checked: boolean, indeterminate: boolean) => {\n      if (\n        oldChecked.value !== checked ||\n        oldIndeterminate.value !== indeterminate\n      ) {\n        tree.ctx.emit('check-change', props.node.data, checked, indeterminate)\n      }\n      oldChecked.value = checked\n      oldIndeterminate.value = indeterminate\n    }\n\n    const handleClick = (e: MouseEvent) => {\n      handleCurrentChange(tree.store, tree.ctx.emit, () =>\n        tree.store.value.setCurrentNode(props.node)\n      )\n      tree.currentNode.value = props.node\n\n      if (tree.props.expandOnClickNode) {\n        handleExpandIconClick()\n      }\n\n      if (tree.props.checkOnClickNode && !props.node.disabled) {\n        handleCheckChange(null, {\n          target: { checked: !props.node.checked },\n        })\n      }\n      tree.ctx.emit('node-click', props.node.data, props.node, instance, e)\n    }\n\n    const handleContextMenu = (event: Event) => {\n      if (tree.instance.vnode.props['onNodeContextmenu']) {\n        event.stopPropagation()\n        event.preventDefault()\n      }\n      tree.ctx.emit(\n        'node-contextmenu',\n        event,\n        props.node.data,\n        props.node,\n        instance\n      )\n    }\n\n    const handleExpandIconClick = () => {\n      if (props.node.isLeaf) return\n      if (expanded.value) {\n        tree.ctx.emit('node-collapse', props.node.data, props.node, instance)\n        props.node.collapse()\n      } else {\n        props.node.expand(() => {\n          ctx.emit('node-expand', props.node.data, props.node, instance)\n        })\n      }\n    }\n\n    const handleCheckChange = (value, ev) => {\n      props.node.setChecked(ev.target.checked, !tree.props.checkStrictly)\n      nextTick(() => {\n        const store = tree.store.value\n        tree.ctx.emit('check', props.node.data, {\n          checkedNodes: store.getCheckedNodes(),\n          checkedKeys: store.getCheckedKeys(),\n          halfCheckedNodes: store.getHalfCheckedNodes(),\n          halfCheckedKeys: store.getHalfCheckedKeys(),\n        })\n      })\n    }\n\n    const handleChildNodeExpand = (\n      nodeData: TreeNodeData,\n      node: Node,\n      instance: ComponentInternalInstance\n    ) => {\n      broadcastExpanded(node)\n      tree.ctx.emit('node-expand', nodeData, node, instance)\n    }\n\n    const handleDragStart = (event: DragEvent) => {\n      if (!tree.props.draggable) return\n      dragEvents.treeNodeDragStart({ event, treeNode: props })\n    }\n\n    const handleDragOver = (event: DragEvent) => {\n      event.preventDefault()\n      if (!tree.props.draggable) return\n      dragEvents.treeNodeDragOver({\n        event,\n        treeNode: { $el: node$.value, node: props.node },\n      })\n    }\n\n    const handleDrop = (event: DragEvent) => {\n      event.preventDefault()\n    }\n\n    const handleDragEnd = (event: DragEvent) => {\n      if (!tree.props.draggable) return\n      dragEvents.treeNodeDragEnd(event)\n    }\n\n    return {\n      ns,\n      node$,\n      tree,\n      expanded,\n      childNodeRendered,\n      oldChecked,\n      oldIndeterminate,\n      getNodeKey,\n      getNodeClass,\n      handleSelectChange,\n      handleClick,\n      handleContextMenu,\n      handleExpandIconClick,\n      handleCheckChange,\n      handleChildNodeExpand,\n      handleDragStart,\n      handleDragOver,\n      handleDrop,\n      handleDragEnd,\n      CaretRight,\n    }\n  },\n})\n</script>\n", "// @ts-nocheck\nimport { onMounted, onUpdated, shallowRef, watch } from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { useNamespace } from '@element-plus/hooks'\nimport type TreeStore from './tree-store'\n\nimport type { Ref } from 'vue'\nimport type { Nullable } from '@element-plus/utils'\n\ninterface UseKeydownOption {\n  el$: Ref<HTMLElement>\n}\nexport function useKeydown({ el$ }: UseKeydownOption, store: Ref<TreeStore>) {\n  const ns = useNamespace('tree')\n\n  const treeItems = shallowRef<Nullable<HTMLElement>[]>([])\n  const checkboxItems = shallowRef<Nullable<HTMLElement>[]>([])\n\n  onMounted(() => {\n    initTabIndex()\n  })\n\n  onUpdated(() => {\n    treeItems.value = Array.from(el$.value.querySelectorAll('[role=treeitem]'))\n    checkboxItems.value = Array.from(\n      el$.value.querySelectorAll('input[type=checkbox]')\n    )\n  })\n\n  watch(checkboxItems, (val) => {\n    val.forEach((checkbox) => {\n      checkbox.setAttribute('tabindex', '-1')\n    })\n  })\n\n  const handleKeydown = (ev: KeyboardEvent): void => {\n    const currentItem = ev.target as HTMLElement\n    if (!currentItem.className.includes(ns.b('node'))) return\n    const code = ev.code\n    treeItems.value = Array.from(\n      el$.value.querySelectorAll(`.${ns.is('focusable')}[role=treeitem]`)\n    )\n    const currentIndex = treeItems.value.indexOf(currentItem)\n    let nextIndex\n    if ([EVENT_CODE.up, EVENT_CODE.down].includes(code)) {\n      ev.preventDefault()\n      if (code === EVENT_CODE.up) {\n        nextIndex =\n          currentIndex === -1\n            ? 0\n            : currentIndex !== 0\n            ? currentIndex - 1\n            : treeItems.value.length - 1\n        const startIndex = nextIndex\n        while (true) {\n          if (\n            store.value.getNode(treeItems.value[nextIndex].dataset.key).canFocus\n          )\n            break\n          nextIndex--\n          if (nextIndex === startIndex) {\n            nextIndex = -1\n            break\n          }\n          if (nextIndex < 0) {\n            nextIndex = treeItems.value.length - 1\n          }\n        }\n      } else {\n        nextIndex =\n          currentIndex === -1\n            ? 0\n            : currentIndex < treeItems.value.length - 1\n            ? currentIndex + 1\n            : 0\n        const startIndex = nextIndex\n        while (true) {\n          if (\n            store.value.getNode(treeItems.value[nextIndex].dataset.key).canFocus\n          )\n            break\n          nextIndex++\n          if (nextIndex === startIndex) {\n            nextIndex = -1\n            break\n          }\n          if (nextIndex >= treeItems.value.length) {\n            nextIndex = 0\n          }\n        }\n      }\n      nextIndex !== -1 && treeItems.value[nextIndex].focus()\n    }\n    if ([EVENT_CODE.left, EVENT_CODE.right].includes(code)) {\n      ev.preventDefault()\n      currentItem.click()\n    }\n    const hasInput = currentItem.querySelector(\n      '[type=\"checkbox\"]'\n    ) as Nullable<HTMLInputElement>\n    if ([EVENT_CODE.enter, EVENT_CODE.space].includes(code) && hasInput) {\n      ev.preventDefault()\n      hasInput.click()\n    }\n  }\n\n  useEventListener(el$, 'keydown', handleKeydown)\n\n  const initTabIndex = (): void => {\n    treeItems.value = Array.from(\n      el$.value.querySelectorAll(`.${ns.is('focusable')}[role=treeitem]`)\n    )\n    checkboxItems.value = Array.from(\n      el$.value.querySelectorAll('input[type=checkbox]')\n    )\n    const checkedItem = el$.value.querySelectorAll(\n      `.${ns.is('checked')}[role=treeitem]`\n    )\n    if (checkedItem.length) {\n      checkedItem[0].setAttribute('tabindex', '0')\n      return\n    }\n    treeItems.value[0]?.setAttribute('tabindex', '0')\n  }\n}\n", "<template>\n  <div\n    ref=\"el$\"\n    :class=\"[\n      ns.b(),\n      ns.is('dragging', !!dragState.draggingNode),\n      ns.is('drop-not-allow', !dragState.allowDrop),\n      ns.is('drop-inner', dragState.dropType === 'inner'),\n      { [ns.m('highlight-current')]: highlightCurrent },\n    ]\"\n    role=\"tree\"\n  >\n    <el-tree-node\n      v-for=\"child in root.childNodes\"\n      :key=\"getNodeKey(child)\"\n      :node=\"child\"\n      :props=\"props\"\n      :accordion=\"accordion\"\n      :render-after-expand=\"renderAfterExpand\"\n      :show-checkbox=\"showCheckbox\"\n      :render-content=\"renderContent\"\n      @node-expand=\"handleNodeExpand\"\n    />\n    <div v-if=\"isEmpty\" :class=\"ns.e('empty-block')\">\n      <slot name=\"empty\">\n        <span :class=\"ns.e('empty-text')\">\n          {{ emptyText ?? t('el.tree.emptyText') }}\n        </span>\n      </slot>\n    </div>\n    <div\n      v-show=\"dragState.showDropIndicator\"\n      ref=\"dropIndicator$\"\n      :class=\"ns.e('drop-indicator')\"\n    />\n  </div>\n</template>\n<script lang=\"ts\">\n// @ts-nocheck\nimport {\n  computed,\n  defineComponent,\n  getCurrentInstance,\n  inject,\n  provide,\n  ref,\n  watch,\n} from 'vue'\nimport { iconPropType } from '@element-plus/utils'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { formItemContextKey } from '@element-plus/components/form'\nimport { selectKey } from '@element-plus/components/select/src/token'\nimport TreeStore from './model/tree-store'\nimport { getNodeKey as getNodeKeyUtil, handleCurrentChange } from './model/util'\nimport ElTreeNode from './tree-node.vue'\nimport { useNodeExpandEventBroadcast } from './model/useNodeExpandEventBroadcast'\nimport { useDragNodeHandler } from './model/useDragNode'\nimport { useKeydown } from './model/useKeydown'\nimport type Node from './model/node'\n\nimport type { ComponentInternalInstance, PropType } from 'vue'\nimport type { Nullable } from '@element-plus/utils'\nimport type {\n  TreeComponentProps,\n  TreeData,\n  TreeKey,\n  TreeNodeData,\n} from './tree.type'\n\nexport default defineComponent({\n  name: 'ElTree',\n  components: { ElTreeNode },\n  props: {\n    data: {\n      type: Array,\n      default: () => [],\n    },\n    emptyText: {\n      type: String,\n    },\n    renderAfterExpand: {\n      type: Boolean,\n      default: true,\n    },\n    nodeKey: String,\n    checkStrictly: Boolean,\n    defaultExpandAll: Boolean,\n    expandOnClickNode: {\n      type: Boolean,\n      default: true,\n    },\n    checkOnClickNode: Boolean,\n    checkDescendants: {\n      type: Boolean,\n      default: false,\n    },\n    autoExpandParent: {\n      type: Boolean,\n      default: true,\n    },\n    defaultCheckedKeys: Array as PropType<\n      TreeComponentProps['defaultCheckedKeys']\n    >,\n    defaultExpandedKeys: Array as PropType<\n      TreeComponentProps['defaultExpandedKeys']\n    >,\n    currentNodeKey: [String, Number] as PropType<string | number>,\n    renderContent: Function,\n    showCheckbox: {\n      type: Boolean,\n      default: false,\n    },\n    draggable: {\n      type: Boolean,\n      default: false,\n    },\n    allowDrag: Function,\n    allowDrop: Function,\n    props: {\n      type: Object as PropType<TreeComponentProps['props']>,\n      default: () => ({\n        children: 'children',\n        label: 'label',\n        disabled: 'disabled',\n      }),\n    },\n    lazy: {\n      type: Boolean,\n      default: false,\n    },\n    highlightCurrent: Boolean,\n    load: Function as PropType<TreeComponentProps['load']>,\n    filterNodeMethod: Function as PropType<\n      TreeComponentProps['filterNodeMethod']\n    >,\n    accordion: Boolean,\n    indent: {\n      type: Number,\n      default: 18,\n    },\n    icon: {\n      type: iconPropType,\n    },\n  },\n  emits: [\n    'check-change',\n    'current-change',\n    'node-click',\n    'node-contextmenu',\n    'node-collapse',\n    'node-expand',\n    'check',\n    'node-drag-start',\n    'node-drag-end',\n    'node-drop',\n    'node-drag-leave',\n    'node-drag-enter',\n    'node-drag-over',\n  ],\n  setup(props, ctx) {\n    const { t } = useLocale()\n    const ns = useNamespace('tree')\n    const selectInfo = inject(selectKey, null)\n\n    const store = ref<TreeStore>(\n      new TreeStore({\n        key: props.nodeKey,\n        data: props.data,\n        lazy: props.lazy,\n        props: props.props,\n        load: props.load,\n        currentNodeKey: props.currentNodeKey,\n        checkStrictly: props.checkStrictly,\n        checkDescendants: props.checkDescendants,\n        defaultCheckedKeys: props.defaultCheckedKeys,\n        defaultExpandedKeys: props.defaultExpandedKeys,\n        autoExpandParent: props.autoExpandParent,\n        defaultExpandAll: props.defaultExpandAll,\n        filterNodeMethod: props.filterNodeMethod,\n      })\n    )\n\n    store.value.initialize()\n\n    const root = ref<Node>(store.value.root)\n    const currentNode = ref<Node>(null)\n    const el$ = ref<Nullable<HTMLElement>>(null)\n    const dropIndicator$ = ref<Nullable<HTMLElement>>(null)\n\n    const { broadcastExpanded } = useNodeExpandEventBroadcast(props)\n\n    const { dragState } = useDragNodeHandler({\n      props,\n      ctx,\n      el$,\n      dropIndicator$,\n      store,\n    })\n\n    useKeydown({ el$ }, store)\n\n    const isEmpty = computed(() => {\n      const { childNodes } = root.value\n      const hasFilteredOptions = selectInfo\n        ? selectInfo.hasFilteredOptions !== 0\n        : false\n      return (\n        (!childNodes ||\n          childNodes.length === 0 ||\n          childNodes.every(({ visible }) => !visible)) &&\n        !hasFilteredOptions\n      )\n    })\n\n    watch(\n      () => props.currentNodeKey,\n      (newVal) => {\n        store.value.setCurrentNodeKey(newVal)\n      }\n    )\n\n    watch(\n      () => props.defaultCheckedKeys,\n      (newVal) => {\n        store.value.setDefaultCheckedKey(newVal)\n      }\n    )\n\n    watch(\n      () => props.defaultExpandedKeys,\n      (newVal) => {\n        store.value.setDefaultExpandedKeys(newVal)\n      }\n    )\n\n    watch(\n      () => props.data,\n      (newVal) => {\n        store.value.setData(newVal)\n      },\n      { deep: true }\n    )\n\n    watch(\n      () => props.checkStrictly,\n      (newVal) => {\n        store.value.checkStrictly = newVal\n      }\n    )\n\n    const filter = (value) => {\n      if (!props.filterNodeMethod)\n        throw new Error('[Tree] filterNodeMethod is required when filter')\n      store.value.filter(value)\n    }\n\n    const getNodeKey = (node: Node) => {\n      return getNodeKeyUtil(props.nodeKey, node.data)\n    }\n\n    const getNodePath = (data: TreeKey | TreeNodeData) => {\n      if (!props.nodeKey)\n        throw new Error('[Tree] nodeKey is required in getNodePath')\n      const node = store.value.getNode(data)\n      if (!node) return []\n      const path = [node.data]\n      let parent = node.parent\n      while (parent && parent !== root.value) {\n        path.push(parent.data)\n        parent = parent.parent\n      }\n      return path.reverse()\n    }\n\n    const getCheckedNodes = (\n      leafOnly?: boolean,\n      includeHalfChecked?: boolean\n    ): TreeNodeData[] => {\n      return store.value.getCheckedNodes(leafOnly, includeHalfChecked)\n    }\n\n    const getCheckedKeys = (leafOnly?: boolean): TreeKey[] => {\n      return store.value.getCheckedKeys(leafOnly)\n    }\n\n    const getCurrentNode = (): TreeNodeData => {\n      const currentNode = store.value.getCurrentNode()\n      return currentNode ? currentNode.data : null\n    }\n\n    const getCurrentKey = (): any => {\n      if (!props.nodeKey)\n        throw new Error('[Tree] nodeKey is required in getCurrentKey')\n      const currentNode = getCurrentNode()\n      return currentNode ? currentNode[props.nodeKey] : null\n    }\n\n    const setCheckedNodes = (nodes: Node[], leafOnly?: boolean) => {\n      if (!props.nodeKey)\n        throw new Error('[Tree] nodeKey is required in setCheckedNodes')\n      store.value.setCheckedNodes(nodes, leafOnly)\n    }\n\n    const setCheckedKeys = (keys: TreeKey[], leafOnly?: boolean) => {\n      if (!props.nodeKey)\n        throw new Error('[Tree] nodeKey is required in setCheckedKeys')\n      store.value.setCheckedKeys(keys, leafOnly)\n    }\n\n    const setChecked = (\n      data: TreeKey | TreeNodeData,\n      checked: boolean,\n      deep: boolean\n    ) => {\n      store.value.setChecked(data, checked, deep)\n    }\n\n    const getHalfCheckedNodes = (): TreeNodeData[] => {\n      return store.value.getHalfCheckedNodes()\n    }\n\n    const getHalfCheckedKeys = (): TreeKey[] => {\n      return store.value.getHalfCheckedKeys()\n    }\n\n    const setCurrentNode = (node: Node, shouldAutoExpandParent = true) => {\n      if (!props.nodeKey)\n        throw new Error('[Tree] nodeKey is required in setCurrentNode')\n\n      handleCurrentChange(store, ctx.emit, () => {\n        broadcastExpanded(node)\n        store.value.setUserCurrentNode(node, shouldAutoExpandParent)\n      })\n    }\n\n    const setCurrentKey = (key?: TreeKey, shouldAutoExpandParent = true) => {\n      if (!props.nodeKey)\n        throw new Error('[Tree] nodeKey is required in setCurrentKey')\n\n      handleCurrentChange(store, ctx.emit, () => {\n        broadcastExpanded()\n        store.value.setCurrentNodeKey(key, shouldAutoExpandParent)\n      })\n    }\n\n    const getNode = (data: TreeKey | TreeNodeData): Node => {\n      return store.value.getNode(data)\n    }\n\n    const remove = (data: TreeNodeData | Node) => {\n      store.value.remove(data)\n    }\n\n    const append = (\n      data: TreeNodeData,\n      parentNode: TreeNodeData | TreeKey | Node\n    ) => {\n      store.value.append(data, parentNode)\n    }\n\n    const insertBefore = (\n      data: TreeNodeData,\n      refNode: TreeKey | TreeNodeData | Node\n    ) => {\n      store.value.insertBefore(data, refNode)\n    }\n\n    const insertAfter = (\n      data: TreeNodeData,\n      refNode: TreeKey | TreeNodeData | Node\n    ) => {\n      store.value.insertAfter(data, refNode)\n    }\n\n    const handleNodeExpand = (\n      nodeData: TreeNodeData,\n      node: Node,\n      instance: ComponentInternalInstance\n    ) => {\n      broadcastExpanded(node)\n      ctx.emit('node-expand', nodeData, node, instance)\n    }\n\n    const updateKeyChildren = (key: TreeKey, data: TreeData) => {\n      if (!props.nodeKey)\n        throw new Error('[Tree] nodeKey is required in updateKeyChild')\n      store.value.updateChildren(key, data)\n    }\n\n    provide('RootTree', {\n      ctx,\n      props,\n      store,\n      root,\n      currentNode,\n      instance: getCurrentInstance(),\n    } as any)\n\n    provide(formItemContextKey, undefined)\n\n    return {\n      ns,\n      // ref\n      store,\n      root,\n      currentNode,\n      dragState,\n      el$,\n      dropIndicator$,\n\n      // computed\n      isEmpty,\n\n      // methods\n      filter,\n      getNodeKey,\n      getNodePath,\n      getCheckedNodes,\n      getCheckedKeys,\n      getCurrentNode,\n      getCurrentKey,\n      setCheckedNodes,\n      setCheckedKeys,\n      setChecked,\n      getHalfCheckedNodes,\n      getHalfCheckedKeys,\n      setCurrentNode,\n      setCurrentKey,\n      t,\n      getNode,\n      remove,\n      append,\n      insertBefore,\n      insertAfter,\n      handleNodeExpand,\n      updateKeyChildren,\n    }\n  },\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Tree from './src/tree.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTree: SFCWithInstall<typeof Tree> = withInstall(Tree)\n\nexport default ElTree\n\nexport type { TreeInstance } from './src/instance'\n", "// @ts-nocheck\nimport { computed, nextTick, toRefs, watch } from 'vue'\nimport { pick } from 'lodash-unified'\nimport ElSelect from '@element-plus/components/select'\nimport { useNamespace } from '@element-plus/hooks'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport type { Ref } from 'vue'\nimport type ElTree from '@element-plus/components/tree'\n\nexport const useSelect = (\n  props,\n  { attrs, emit },\n  {\n    select,\n    tree,\n    key,\n  }: {\n    select: Ref<InstanceType<typeof ElSelect> | undefined>\n    tree: Ref<InstanceType<typeof ElTree> | undefined>\n    key: Ref<string>\n  }\n) => {\n  const ns = useNamespace('tree-select')\n\n  // update tree data when use filterMethod/remoteMethod\n  watch(\n    () => props.data,\n    () => {\n      if (props.filterable) {\n        nextTick(() => {\n          // let tree node expand only, same with tree filter\n          tree.value?.filter(select.value?.states.inputValue)\n        })\n      }\n    },\n    { flush: 'post' }\n  )\n\n  const result = {\n    ...pick(toRefs(props), Object.keys(ElSelect.props)),\n    ...attrs,\n    // attrs is not reactive, when v-model binding source changes,\n    // this listener is still old, see the bug(or test 'v-model source change'):\n    // https://github.com/element-plus/element-plus/issues/14204\n    'onUpdate:modelValue': (value) => emit(UPDATE_MODEL_EVENT, value),\n    valueKey: key,\n    popperClass: computed(() => {\n      const classes = [ns.e('popper')]\n      if (props.popperClass) classes.push(props.popperClass)\n      return classes.join(' ')\n    }),\n    filterMethod: (keyword = '') => {\n      if (props.filterMethod) {\n        props.filterMethod(keyword)\n      } else if (props.remoteMethod) {\n        props.remoteMethod(keyword)\n      } else {\n        // let tree node expand only, same with tree filter\n        tree.value?.filter(keyword)\n      }\n    },\n  }\n\n  return result\n}\n", "import { defineComponent, getCurrentInstance, nextTick, watch } from 'vue'\nimport { ElOption } from '@element-plus/components/select'\n\nconst component = defineComponent({\n  extends: ElOption,\n  setup(props, ctx) {\n    const result = (ElOption.setup as NonNullable<any>)(props, ctx)\n\n    // use methods.selectOptionClick\n    delete result.selectOptionClick\n\n    const vm = (getCurrentInstance() as NonNullable<any>).proxy\n\n    // Fix: https://github.com/element-plus/element-plus/issues/7917\n    // `el-option` will delete the cache before unmount,\n    // This is normal for flat arrays `<el-select><el-option v-for=\"3\"></el-select>`,\n    // Because the same node key does not create a difference node,\n    // But in tree data, the same key at different levels will create diff nodes,\n    // So the destruction of `el-option` in `nextTick` will be slower than\n    // the creation of new `el-option`, which will delete the new node,\n    // here restore the deleted node.\n    // @link https://github.com/element-plus/element-plus/blob/6df6e49db07b38d6cc3b5e9a960782bd30879c11/packages/components/select/src/option.vue#L78\n    nextTick(() => {\n      if (!result.select.states.cachedOptions.get(vm.value)) {\n        result.select.onOptionCreate(vm)\n      }\n    })\n\n    watch(\n      () => ctx.attrs.visible,\n      (val) => {\n        result.states.visible = val\n      },\n      {\n        immediate: true,\n      }\n    )\n\n    return result\n  },\n  methods: {\n    selectOptionClick() {\n      // $el.parentElement => el-tree-node__content\n      this.$el.parentElement.click()\n    },\n  },\n})\n\nexport default component\n", "import type { TreeNodeData } from '@element-plus/components/tree/src/tree.type'\n\nexport function isValidValue(val: any) {\n  return val || val === 0\n}\n\nexport function isValidArray(val: any) {\n  return Array.isArray(val) && val.length\n}\n\nexport function toValidArray(val: any) {\n  return Array.isArray(val) ? val : isValidValue(val) ? [val] : []\n}\n\ntype TreeCallback<T extends TreeNodeData, R> = (\n  data: T,\n  index: number,\n  array: T[],\n  parent?: T\n) => R\n\ntype TreeFindCallback<T extends TreeNodeData> = TreeCallback<T, boolean>\n\nexport function treeFind<T extends TreeNodeData>(\n  treeData: T[],\n  findCallback: TreeFindCallback<T>,\n  getChildren: (data: T) => T[]\n): T | undefined\nexport function treeFind<T extends TreeNodeData, R>(\n  treeData: T[],\n  findCallback: TreeFindCallback<T>,\n  getChildren: (data: T) => T[],\n  resultCallback?: TreeCallback<T, R>,\n  parent?: T\n): R | undefined\nexport function treeFind<T extends TreeNodeData, R>(\n  treeData: T[],\n  findCallback: TreeFindCallback<T>,\n  getChildren: (data: T) => T[],\n  resultCallback?: TreeCallback<T, R>,\n  parent?: T\n): T | R | undefined {\n  for (let i = 0; i < treeData.length; i++) {\n    const data = treeData[i]\n    if (findCallback(data, i, treeData, parent)) {\n      return resultCallback ? resultCallback(data, i, treeData, parent) : data\n    } else {\n      const children = getChildren(data)\n      if (isValidArray(children)) {\n        const find = treeFind(\n          children,\n          findCallback,\n          getChildren,\n          resultCallback,\n          data\n        )\n        if (find) return find\n      }\n    }\n  }\n}\n\nexport function treeEach<T extends TreeNodeData>(\n  treeData: T[],\n  callback: TreeCallback<T, void>,\n  getChildren: (data: T) => T[],\n  parent?: T\n) {\n  for (let i = 0; i < treeData.length; i++) {\n    const data = treeData[i]\n    callback(data, i, treeData, parent)\n\n    const children = getChildren(data)\n    if (isValidArray(children)) {\n      treeEach(children, callback, getChildren, data)\n    }\n  }\n}\n", "// @ts-nocheck\nimport { computed, nextTick, toRefs, watch } from 'vue'\nimport { isEqual, isNil, pick } from 'lodash-unified'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { escapeStringRegexp, isEmpty, isFunction } from '@element-plus/utils'\nimport ElTree from '@element-plus/components/tree'\nimport TreeSelectOption from './tree-select-option'\nimport {\n  isValidArray,\n  isValidValue,\n  toValidArray,\n  treeEach,\n  treeFind,\n} from './utils'\nimport type { CacheOption } from './cache-options'\nimport type { Ref } from 'vue'\nimport type ElSelect from '@element-plus/components/select'\nimport type Node from '@element-plus/components/tree/src/model/node'\nimport type { TreeNodeData } from '@element-plus/components/tree/src/tree.type'\nimport type { TreeInstance } from '@element-plus/components/tree'\n\nexport const useTree = (\n  props,\n  { attrs, slots, emit },\n  {\n    select,\n    tree,\n    key,\n  }: {\n    select: Ref<InstanceType<typeof ElSelect> | undefined>\n    tree: Ref<TreeInstance | undefined>\n    key: Ref<string>\n  }\n) => {\n  watch(\n    () => props.modelValue,\n    () => {\n      if (props.showCheckbox) {\n        nextTick(() => {\n          const treeInstance = tree.value\n          if (\n            treeInstance &&\n            !isEqual(\n              treeInstance.getCheckedKeys(),\n              toValidArray(props.modelValue)\n            )\n          ) {\n            treeInstance.setCheckedKeys(toValidArray(props.modelValue))\n          }\n        })\n      }\n    },\n    {\n      immediate: true,\n      deep: true,\n    }\n  )\n\n  const propsMap = computed(() => ({\n    value: key.value,\n    label: 'label',\n    children: 'children',\n    disabled: 'disabled',\n    isLeaf: 'isLeaf',\n    ...props.props,\n  }))\n\n  const getNodeValByProp = (\n    prop: 'value' | 'label' | 'children' | 'disabled' | 'isLeaf',\n    data: TreeNodeData\n  ) => {\n    const propVal = propsMap.value[prop]\n    if (isFunction(propVal)) {\n      return propVal(\n        data,\n        tree.value?.getNode(getNodeValByProp('value', data)) as Node\n      )\n    } else {\n      return data[propVal as string]\n    }\n  }\n\n  const defaultExpandedParentKeys = toValidArray(props.modelValue)\n    .map((value) => {\n      return treeFind(\n        props.data || [],\n        (data) => getNodeValByProp('value', data) === value,\n        (data) => getNodeValByProp('children', data),\n        (data, index, array, parent) =>\n          parent && getNodeValByProp('value', parent)\n      )\n    })\n    .filter((item) => isValidValue(item))\n\n  const cacheOptions = computed(() => {\n    if (!props.renderAfterExpand && !props.lazy) return []\n\n    const options: CacheOption[] = []\n\n    treeEach(\n      props.data.concat(props.cacheData),\n      (node) => {\n        const value = getNodeValByProp('value', node)\n        options.push({\n          value,\n          currentLabel: getNodeValByProp('label', node),\n          isDisabled: getNodeValByProp('disabled', node),\n        })\n      },\n      (data) => getNodeValByProp('children', data)\n    )\n\n    return options\n  })\n\n  const getChildCheckedKeys = () => {\n    return tree.value?.getCheckedKeys().filter((checkedKey) => {\n      const node = tree.value?.getNode(checkedKey) as Node\n      return !isNil(node) && isEmpty(node.childNodes)\n    })\n  }\n\n  return {\n    ...pick(toRefs(props), Object.keys(ElTree.props)),\n    ...attrs,\n    nodeKey: key,\n\n    // only expand on click node when the `check-strictly` is false\n    expandOnClickNode: computed(() => {\n      return !props.checkStrictly && props.expandOnClickNode\n    }),\n\n    // show current selected node only first time,\n    // fix the problem of expanding multiple nodes when checking multiple nodes\n    defaultExpandedKeys: computed(() => {\n      return props.defaultExpandedKeys\n        ? props.defaultExpandedKeys.concat(defaultExpandedParentKeys)\n        : defaultExpandedParentKeys\n    }),\n\n    renderContent: (h, { node, data, store }) => {\n      return h(\n        TreeSelectOption,\n        {\n          value: getNodeValByProp('value', data),\n          label: getNodeValByProp('label', data),\n          disabled: getNodeValByProp('disabled', data),\n          visible: node.visible,\n        },\n        props.renderContent\n          ? () => props.renderContent(h, { node, data, store })\n          : slots.default\n          ? () => slots.default({ node, data, store })\n          : undefined\n      )\n    },\n    filterNodeMethod: (value, data, node) => {\n      if (props.filterNodeMethod)\n        return props.filterNodeMethod(value, data, node)\n      if (!value) return true\n      const regexp = new RegExp(escapeStringRegexp(value), 'i')\n      return regexp.test(getNodeValByProp('label', data) || '')\n    },\n    onNodeClick: (data, node, e) => {\n      attrs.onNodeClick?.(data, node, e)\n\n      // `onCheck` is trigger when `checkOnClickNode`\n      if (props.showCheckbox && props.checkOnClickNode) return\n\n      // now `checkOnClickNode` is false, only no checkbox and `checkStrictly` or `isLeaf`\n      if (!props.showCheckbox && (props.checkStrictly || node.isLeaf)) {\n        if (!getNodeValByProp('disabled', data)) {\n          const option = select.value?.states.options.get(\n            getNodeValByProp('value', data)\n          )\n          select.value?.handleOptionSelect(option)\n        }\n      } else if (props.expandOnClickNode) {\n        e.proxy.handleExpandIconClick()\n      }\n      select.value?.focus()\n    },\n    onCheck: (data, params) => {\n      // ignore when no checkbox, like only `checkOnClickNode` is true\n      if (!props.showCheckbox) return\n\n      const dataValue = getNodeValByProp('value', data)\n      const dataMap = {}\n      treeEach(\n        [tree.value.store.root],\n        (node) => (dataMap[node.key] = node),\n        (node) => node.childNodes\n      )\n\n      // fix: checkedKeys has not cached keys\n      const uncachedCheckedKeys = params.checkedKeys\n      const cachedKeys = props.multiple\n        ? toValidArray(props.modelValue).filter(\n            (item) => !(item in dataMap) && !uncachedCheckedKeys.includes(item)\n          )\n        : []\n      const checkedKeys = cachedKeys.concat(uncachedCheckedKeys)\n\n      if (props.checkStrictly) {\n        emit(\n          UPDATE_MODEL_EVENT,\n          // Checking for changes may come from `check-on-node-click`\n          props.multiple\n            ? checkedKeys\n            : checkedKeys.includes(dataValue)\n            ? dataValue\n            : undefined\n        )\n      }\n      // only can select leaf node\n      else {\n        if (props.multiple) {\n          const childKeys = getChildCheckedKeys()\n\n          emit(UPDATE_MODEL_EVENT, cachedKeys.concat(childKeys))\n        } else {\n          // select first leaf node when check parent\n          const firstLeaf = treeFind(\n            [data],\n            (data) =>\n              !isValidArray(getNodeValByProp('children', data)) &&\n              !getNodeValByProp('disabled', data),\n            (data) => getNodeValByProp('children', data)\n          )\n          const firstLeafKey = firstLeaf\n            ? getNodeValByProp('value', firstLeaf)\n            : undefined\n\n          // unselect when any child checked\n          const hasCheckedChild =\n            isValidValue(props.modelValue) &&\n            !!treeFind(\n              [data],\n              (data) => getNodeValByProp('value', data) === props.modelValue,\n              (data) => getNodeValByProp('children', data)\n            )\n\n          emit(\n            UPDATE_MODEL_EVENT,\n            firstLeafKey === props.modelValue || hasCheckedChild\n              ? undefined\n              : firstLeafKey\n          )\n        }\n      }\n\n      nextTick(() => {\n        const checkedKeys = toValidArray(props.modelValue)\n        tree.value.setCheckedKeys(checkedKeys)\n\n        attrs.onCheck?.(data, {\n          checkedKeys: tree.value.getCheckedKeys(),\n          checkedNodes: tree.value.getCheckedNodes(),\n          halfCheckedKeys: tree.value.getHalfCheckedKeys(),\n          halfCheckedNodes: tree.value.getHalfCheckedNodes(),\n        })\n      })\n\n      select.value?.focus()\n    },\n\n    onNodeExpand: (data, node, e) => {\n      attrs.onNodeExpand?.(data, node, e)\n      nextTick(() => {\n        if (\n          !props.checkStrictly &&\n          props.lazy &&\n          props.multiple &&\n          node.checked\n        ) {\n          const dataMap = {}\n          const uncachedCheckedKeys = (\n            tree.value as TreeInstance\n          ).getCheckedKeys()\n\n          treeEach(\n            [tree.value.store.root],\n            (node) => (dataMap[node.key] = node),\n            (node) => node.childNodes\n          )\n\n          const cachedKeys = toValidArray(props.modelValue).filter(\n            (item) => !(item in dataMap) && !uncachedCheckedKeys.includes(item)\n          )\n\n          const childKeys = getChildCheckedKeys()\n          emit(UPDATE_MODEL_EVENT, cachedKeys.concat(childKeys))\n        }\n      })\n    },\n    // else\n    cacheOptions,\n  }\n}\n", "import { defineComponent, inject, watch } from 'vue'\nimport { selectKey } from '@element-plus/components/select'\nimport { isClient } from '@element-plus/utils'\nimport type { SelectContext } from '@element-plus/components/select'\nimport type { PropType } from 'vue'\n\n// same as el-option instance,\n// these are required for `cachedOptions`\nexport type CacheOption = {\n  value: string | number | boolean | object\n  currentLabel: string | number\n  isDisabled: boolean\n}\n\nexport default defineComponent({\n  props: {\n    data: {\n      type: Array as PropType<CacheOption[]>,\n      default: () => [],\n    },\n  },\n  setup(props) {\n    const select = inject(selectKey) as NonNullable<SelectContext>\n\n    watch(\n      () => props.data,\n      () => {\n        props.data.forEach((item) => {\n          if (!select.states.cachedOptions.has(item.value)) {\n            select.states.cachedOptions.set(item.value, item)\n          }\n        })\n\n        // fork from packages/select/src/useSelect.ts#330\n        const inputs = select.selectRef?.querySelectorAll('input') || []\n        if (\n          isClient &&\n          !Array.from(inputs).includes(\n            document.activeElement as HTMLInputElement\n          )\n        ) {\n          select.setSelected()\n        }\n      },\n      { flush: 'post', immediate: true }\n    )\n\n    return () => undefined\n  },\n})\n", "<script lang=\"ts\">\n// @ts-nocheck\nimport { computed, defineComponent, h, onMounted, reactive, ref } from 'vue'\nimport { pick } from 'lodash-unified'\nimport ElSelect from '@element-plus/components/select'\nimport ElTree from '@element-plus/components/tree'\nimport { useSelect } from './select'\nimport { useTree } from './tree'\nimport CacheOptions from './cache-options'\n\nexport default defineComponent({\n  name: 'ElTreeSelect',\n  // disable `ElSelect` inherit current attrs\n  inheritAttrs: false,\n  props: {\n    ...ElSelect.props,\n    ...ElTree.props,\n    /**\n     * @description The cached data of the lazy node, the structure is the same as the data, used to get the label of the unloaded data\n     */\n    cacheData: {\n      type: Array,\n      default: () => [],\n    },\n  },\n  setup(props, context) {\n    const { slots, expose } = context\n\n    const select = ref<InstanceType<typeof ElSelect>>()\n    const tree = ref<InstanceType<typeof ElTree>>()\n\n    const key = computed(() => props.nodeKey || props.valueKey || 'value')\n\n    const selectProps = useSelect(props, context, { select, tree, key })\n    const { cacheOptions, ...treeProps } = useTree(props, context, {\n      select,\n      tree,\n      key,\n    })\n\n    // expose ElTree/ElSelect methods\n    const methods = reactive({})\n    expose(methods)\n    onMounted(() => {\n      Object.assign(methods, {\n        ...pick(tree.value, [\n          'filter',\n          'updateKeyChildren',\n          'getCheckedNodes',\n          'setCheckedNodes',\n          'getCheckedKeys',\n          'setCheckedKeys',\n          'setChecked',\n          'getHalfCheckedNodes',\n          'getHalfCheckedKeys',\n          'getCurrentKey',\n          'getCurrentNode',\n          'setCurrentKey',\n          'setCurrentNode',\n          'getNode',\n          'remove',\n          'append',\n          'insertBefore',\n          'insertAfter',\n        ]),\n        ...pick(select.value, ['focus', 'blur']),\n      })\n    })\n\n    return () =>\n      h(\n        ElSelect,\n        /**\n         * 1. The `props` is processed into `Refs`, but `v-bind` and\n         * render function props cannot read `Refs`, so use `reactive`\n         * unwrap the `Refs` and keep reactive.\n         * 2. The keyword `ref` requires `Ref`, but `reactive` broke it,\n         * so use function.\n         */\n        reactive({\n          ...selectProps,\n          ref: (ref) => (select.value = ref),\n        }),\n        {\n          ...slots,\n          default: () => [\n            h(CacheOptions, { data: cacheOptions.value }),\n            h(\n              ElTree,\n              reactive({\n                ...treeProps,\n                ref: (ref) => (tree.value = ref),\n              })\n            ),\n          ],\n        }\n      )\n  },\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport TreeSelect from './src/tree-select.vue'\n\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTreeSelect: SFCWithInstall<typeof TreeSelect> =\n  withInstall(TreeSelect)\n\nexport default ElTreeSelect\n", "import {\n  buildProps,\n  definePropType,\n  iconPropType,\n  mutable,\n} from '@element-plus/utils'\nimport type { CheckboxValueType } from '@element-plus/components/checkbox'\nimport type { InjectionKey } from 'vue'\nimport type { TreeNodeData } from '@element-plus/components/tree/src/tree.type'\nimport type {\n  CheckedInfo,\n  FilterMethod,\n  TreeContext,\n  TreeData,\n  TreeKey,\n  TreeNode,\n  TreeOptionProps,\n} from './types'\n\n// constants\nexport const ROOT_TREE_INJECTION_KEY: InjectionKey<TreeContext> = Symbol()\nconst EMPTY_NODE = {\n  key: -1,\n  level: -1,\n  data: {},\n} as const\n\n// enums\nexport enum TreeOptionsEnum {\n  KEY = 'id',\n  LABEL = 'label',\n  CHILDREN = 'children',\n  DISABLED = 'disabled',\n}\n\nexport const enum SetOperationEnum {\n  ADD = 'add',\n  DELETE = 'delete',\n}\n\nconst itemSize = {\n  type: Number,\n  default: 26,\n}\n\n// props\nexport const treeProps = buildProps({\n  data: {\n    type: definePropType<TreeData>(Array),\n    default: () => mutable([] as const),\n  },\n  emptyText: {\n    type: String,\n  },\n  height: {\n    type: Number,\n    default: 200,\n  },\n  props: {\n    type: definePropType<TreeOptionProps>(Object),\n    default: () =>\n      mutable({\n        children: TreeOptionsEnum.CHILDREN,\n        label: TreeOptionsEnum.LABEL,\n        disabled: TreeOptionsEnum.DISABLED,\n        value: TreeOptionsEnum.KEY,\n      } as const),\n  },\n  highlightCurrent: {\n    type: Boolean,\n    default: false,\n  },\n  showCheckbox: {\n    type: Boolean,\n    default: false,\n  },\n  defaultCheckedKeys: {\n    type: definePropType<TreeKey[]>(Array),\n    default: () => mutable([] as const),\n  },\n  // Whether checked state of a node not affects its father and\n  // child nodes when show-checkbox is true\n  checkStrictly: {\n    type: Boolean,\n    default: false,\n  },\n  defaultExpandedKeys: {\n    type: definePropType<TreeKey[]>(Array),\n    default: () => mutable([] as const),\n  },\n  indent: {\n    type: Number,\n    default: 16,\n  },\n  itemSize,\n  icon: {\n    type: iconPropType,\n  },\n  expandOnClickNode: {\n    type: Boolean,\n    default: true,\n  },\n  checkOnClickNode: {\n    type: Boolean,\n    default: false,\n  },\n  currentNodeKey: {\n    type: definePropType<TreeKey>([String, Number]),\n  },\n  // TODO need to optimization\n  accordion: {\n    type: Boolean,\n    default: false,\n  },\n  filterMethod: {\n    type: definePropType<FilterMethod>(Function),\n  },\n  // Performance mode will increase memory usage, but scrolling will be smoother\n  perfMode: {\n    type: Boolean,\n    default: true,\n  },\n} as const)\n\nexport const treeNodeProps = buildProps({\n  node: {\n    type: definePropType<TreeNode>(Object),\n    default: () => mutable(EMPTY_NODE),\n  },\n  expanded: {\n    type: Boolean,\n    default: false,\n  },\n  checked: {\n    type: Boolean,\n    default: false,\n  },\n  indeterminate: {\n    type: Boolean,\n    default: false,\n  },\n  showCheckbox: {\n    type: Boolean,\n    default: false,\n  },\n  disabled: {\n    type: Boolean,\n    default: false,\n  },\n  current: {\n    type: Boolean,\n    default: false,\n  },\n  hiddenExpandIcon: {\n    type: Boolean,\n    default: false,\n  },\n  itemSize,\n} as const)\n\nexport const treeNodeContentProps = buildProps({\n  node: {\n    type: definePropType<TreeNode>(Object),\n    required: true,\n  },\n} as const)\n\n// emits\nexport const NODE_CLICK = 'node-click'\nexport const NODE_DROP = 'node-drop'\nexport const NODE_EXPAND = 'node-expand'\nexport const NODE_COLLAPSE = 'node-collapse'\nexport const CURRENT_CHANGE = 'current-change'\nexport const NODE_CHECK = 'check'\nexport const NODE_CHECK_CHANGE = 'check-change'\nexport const NODE_CONTEXTMENU = 'node-contextmenu'\n\nexport const treeEmits = {\n  [NODE_CLICK]: (data: TreeNodeData, node: TreeNode, e: MouseEvent) =>\n    data && node && e,\n  [NODE_DROP]: (data: TreeNodeData, node: TreeNode, e: DragEvent) =>\n    data && node && e,\n  [NODE_EXPAND]: (data: TreeNodeData, node: TreeNode) => data && node,\n  [NODE_COLLAPSE]: (data: TreeNodeData, node: TreeNode) => data && node,\n  [CURRENT_CHANGE]: (data: TreeNodeData, node: TreeNode) => data && node,\n  [NODE_CHECK]: (data: TreeNodeData, checkedInfo: CheckedInfo) =>\n    data && checkedInfo,\n  [NODE_CHECK_CHANGE]: (data: TreeNodeData, checked: boolean) =>\n    data && typeof checked === 'boolean',\n  [NODE_CONTEXTMENU]: (evt: Event, data: TreeNodeData, node: TreeNode) =>\n    evt && data && node,\n}\n\nexport const treeNodeEmits = {\n  click: (node: TreeNode, e: MouseEvent) => !!(node && e),\n  drop: (node: TreeNode, e: DragEvent) => !!(node && e),\n  toggle: (node: TreeNode) => !!node,\n  check: (node: TreeNode, checked: CheckboxValueType) =>\n    node && typeof checked === 'boolean',\n}\n", "import { getCurrentInstance, nextTick, ref, watch } from 'vue'\nimport {\n  NODE_CHECK,\n  NODE_CHECK_CHANGE,\n  SetOperationEnum,\n} from '../virtual-tree'\nimport type { CheckboxValueType } from '@element-plus/components/checkbox'\nimport type { Ref } from 'vue'\nimport type { Tree, TreeKey, TreeNode, TreeNodeData, TreeProps } from '../types'\n\nexport function useCheck(props: TreeProps, tree: Ref<Tree | undefined>) {\n  const checkedKeys = ref<Set<TreeKey>>(new Set())\n  const indeterminateKeys = ref<Set<TreeKey>>(new Set())\n  const { emit } = getCurrentInstance()!\n\n  watch(\n    [() => tree.value, () => props.defaultCheckedKeys],\n    () => {\n      return nextTick(() => {\n        _setCheckedKeys(props.defaultCheckedKeys)\n      })\n    },\n    {\n      immediate: true,\n    }\n  )\n\n  const updateCheckedKeys = () => {\n    if (!tree.value || !props.showCheckbox || props.checkStrictly) {\n      return\n    }\n    const { levelTreeNodeMap, maxLevel } = tree.value\n    const checkedKeySet = checkedKeys.value\n    const indeterminateKeySet = new Set<TreeKey>()\n    // It is easier to determine the indeterminate state by\n    // traversing from bottom to top\n    // leaf nodes not have indeterminate status and can be skipped\n    for (let level = maxLevel - 1; level >= 1; --level) {\n      const nodes = levelTreeNodeMap.get(level)\n      if (!nodes) continue\n      nodes.forEach((node) => {\n        const children = node.children\n        if (children) {\n          // Whether all child nodes are selected\n          let allChecked = true\n          // Whether a child node is selected\n          let hasChecked = false\n          for (const childNode of children) {\n            const key = childNode.key\n            if (checkedKeySet.has(key)) {\n              hasChecked = true\n            } else if (indeterminateKeySet.has(key)) {\n              allChecked = false\n              hasChecked = true\n              break\n            } else {\n              allChecked = false\n            }\n          }\n          if (allChecked) {\n            checkedKeySet.add(node.key)\n          } else if (hasChecked) {\n            indeterminateKeySet.add(node.key)\n            checkedKeySet.delete(node.key)\n          } else {\n            checkedKeySet.delete(node.key)\n            indeterminateKeySet.delete(node.key)\n          }\n        }\n      })\n    }\n    indeterminateKeys.value = indeterminateKeySet\n  }\n\n  const isChecked = (node: TreeNode) => checkedKeys.value.has(node.key)\n\n  const isIndeterminate = (node: TreeNode) =>\n    indeterminateKeys.value.has(node.key)\n\n  const toggleCheckbox = (\n    node: TreeNode,\n    isChecked: CheckboxValueType,\n    nodeClick = true\n  ) => {\n    const checkedKeySet = checkedKeys.value\n    const toggle = (node: TreeNode, checked: CheckboxValueType) => {\n      checkedKeySet[checked ? SetOperationEnum.ADD : SetOperationEnum.DELETE](\n        node.key\n      )\n      const children = node.children\n      if (!props.checkStrictly && children) {\n        children.forEach((childNode) => {\n          if (!childNode.disabled) {\n            toggle(childNode, checked)\n          }\n        })\n      }\n    }\n    toggle(node, isChecked)\n    updateCheckedKeys()\n    if (nodeClick) {\n      afterNodeCheck(node, isChecked)\n    }\n  }\n\n  const afterNodeCheck = (node: TreeNode, checked: CheckboxValueType) => {\n    const { checkedNodes, checkedKeys } = getChecked()\n    const { halfCheckedNodes, halfCheckedKeys } = getHalfChecked()\n    emit(NODE_CHECK, node.data, {\n      checkedKeys,\n      checkedNodes,\n      halfCheckedKeys,\n      halfCheckedNodes,\n    })\n    emit(NODE_CHECK_CHANGE, node.data, checked)\n  }\n\n  // expose\n  function getCheckedKeys(leafOnly = false): TreeKey[] {\n    return getChecked(leafOnly).checkedKeys\n  }\n\n  function getCheckedNodes(leafOnly = false): TreeNodeData[] {\n    return getChecked(leafOnly).checkedNodes\n  }\n\n  function getHalfCheckedKeys(): TreeKey[] {\n    return getHalfChecked().halfCheckedKeys\n  }\n\n  function getHalfCheckedNodes(): TreeNodeData[] {\n    return getHalfChecked().halfCheckedNodes\n  }\n\n  function getChecked(leafOnly = false): {\n    checkedKeys: TreeKey[]\n    checkedNodes: TreeNodeData[]\n  } {\n    const checkedNodes: TreeNodeData[] = []\n    const keys: TreeKey[] = []\n    if (tree?.value && props.showCheckbox) {\n      const { treeNodeMap } = tree.value\n      checkedKeys.value.forEach((key) => {\n        const node = treeNodeMap.get(key)\n        if (node && (!leafOnly || (leafOnly && node.isLeaf))) {\n          keys.push(key)\n          checkedNodes.push(node.data)\n        }\n      })\n    }\n    return {\n      checkedKeys: keys,\n      checkedNodes,\n    }\n  }\n\n  function getHalfChecked(): {\n    halfCheckedKeys: TreeKey[]\n    halfCheckedNodes: TreeNodeData[]\n  } {\n    const halfCheckedNodes: TreeNodeData[] = []\n    const halfCheckedKeys: TreeKey[] = []\n    if (tree?.value && props.showCheckbox) {\n      const { treeNodeMap } = tree.value\n      indeterminateKeys.value.forEach((key) => {\n        const node = treeNodeMap.get(key)\n        if (node) {\n          halfCheckedKeys.push(key)\n          halfCheckedNodes.push(node.data)\n        }\n      })\n    }\n    return {\n      halfCheckedNodes,\n      halfCheckedKeys,\n    }\n  }\n\n  function setCheckedKeys(keys: TreeKey[]) {\n    checkedKeys.value.clear()\n    indeterminateKeys.value.clear()\n    nextTick(() => {\n      _setCheckedKeys(keys)\n    })\n  }\n\n  function setChecked(key: TreeKey, isChecked: boolean) {\n    if (tree?.value && props.showCheckbox) {\n      const node = tree.value.treeNodeMap.get(key)\n      if (node) {\n        toggleCheckbox(node, isChecked, false)\n      }\n    }\n  }\n\n  function _setCheckedKeys(keys: TreeKey[]) {\n    if (tree?.value) {\n      const { treeNodeMap } = tree.value\n      if (props.showCheckbox && treeNodeMap && keys) {\n        for (const key of keys) {\n          const node = treeNodeMap.get(key)\n          if (node && !isChecked(node)) {\n            toggleCheckbox(node, true, false)\n          }\n        }\n      }\n    }\n  }\n\n  return {\n    updateCheckedKeys,\n    toggleCheckbox,\n    isChecked,\n    isIndeterminate,\n    // expose\n    getCheckedKeys,\n    getCheckedNodes,\n    getHalfCheckedKeys,\n    getHalfCheckedNodes,\n    setChecked,\n    setCheckedKeys,\n  }\n}\n", "import { computed, ref } from 'vue'\nimport { isFunction } from '@element-plus/utils'\nimport type { Ref } from 'vue'\nimport type { Tree, TreeKey, TreeNode, TreeProps } from '../types'\n\n// When the data volume is very large using filter will cause lag\n// I haven't found a better way to optimize it for now\n// Maybe this problem should be left to the server side\nexport function useFilter(props: TreeProps, tree: Ref<Tree | undefined>) {\n  const hiddenNodeKeySet = ref<Set<TreeKey>>(new Set([]))\n  const hiddenExpandIconKeySet = ref<Set<TreeKey>>(new Set([]))\n\n  const filterable = computed(() => {\n    return isFunction(props.filterMethod)\n  })\n\n  function doFilter(query: string) {\n    if (!filterable.value) {\n      return\n    }\n    const expandKeySet = new Set<TreeKey>()\n    const hiddenExpandIconKeys = hiddenExpandIconKeySet.value\n    const hiddenKeys = hiddenNodeKeySet.value\n    const family: TreeNode[] = []\n    const nodes = tree.value?.treeNodes || []\n    const filter = props.filterMethod\n    hiddenKeys.clear()\n    function traverse(nodes: TreeNode[]) {\n      nodes.forEach((node) => {\n        family.push(node)\n        if (filter?.(query, node.data)) {\n          family.forEach((member) => {\n            expandKeySet.add(member.key)\n          })\n        } else if (node.isLeaf) {\n          hiddenKeys.add(node.key)\n        }\n        const children = node.children\n        if (children) {\n          traverse(children)\n        }\n        if (!node.isLeaf) {\n          if (!expandKeySet.has(node.key)) {\n            hiddenKeys.add(node.key)\n          } else if (children) {\n            // If all child nodes are hidden, then the expand icon will be hidden\n            let allHidden = true\n            for (const childNode of children) {\n              if (!hiddenKeys.has(childNode.key)) {\n                allHidden = false\n                break\n              }\n            }\n            if (allHidden) {\n              hiddenExpandIconKeys.add(node.key)\n            } else {\n              hiddenExpandIconKeys.delete(node.key)\n            }\n          }\n        }\n        family.pop()\n      })\n    }\n    traverse(nodes)\n    return expandKeySet\n  }\n\n  function isForceHiddenExpandIcon(node: TreeNode): boolean {\n    return hiddenExpandIconKeySet.value.has(node.key)\n  }\n\n  return {\n    hiddenExpandIconKeySet,\n    hiddenNodeKeySet,\n    doFilter,\n    isForceHiddenExpandIcon,\n  }\n}\n", "import { computed, nextTick, ref, shallowRef, watch } from 'vue'\nimport { isObject } from '@element-plus/utils'\nimport {\n  CURRENT_CHANGE,\n  NODE_CLICK,\n  NODE_COLLAPSE,\n  NODE_DROP,\n  NODE_EXPAND,\n  TreeOptionsEnum,\n} from '../virtual-tree'\nimport { useCheck } from './useCheck'\nimport { useFilter } from './useFilter'\nimport type {\n  FixedSizeList,\n  Alignment as ScrollStrategy,\n} from '@element-plus/components/virtual-list'\nimport type { SetupContext } from 'vue'\nimport type { treeEmits } from '../virtual-tree'\nimport type { CheckboxValueType } from '@element-plus/components/checkbox'\nimport type {\n  Tree,\n  TreeData,\n  TreeKey,\n  TreeNode,\n  TreeNodeData,\n  TreeProps,\n} from '../types'\n\nexport function useTree(\n  props: TreeProps,\n  emit: SetupContext<typeof treeEmits>['emit']\n) {\n  const expandedKeySet = ref<Set<TreeKey>>(new Set(props.defaultExpandedKeys))\n  const currentKey = ref<TreeKey | undefined>()\n  const tree = shallowRef<Tree | undefined>()\n  const listRef = ref<typeof FixedSizeList | undefined>()\n\n  watch(\n    () => props.currentNodeKey,\n    (key) => {\n      currentKey.value = key\n    },\n    {\n      immediate: true,\n    }\n  )\n\n  watch(\n    () => props.data,\n    (data: TreeData) => {\n      setData(data)\n    },\n    {\n      immediate: true,\n    }\n  )\n\n  const {\n    isIndeterminate,\n    isChecked,\n    toggleCheckbox,\n    getCheckedKeys,\n    getCheckedNodes,\n    getHalfCheckedKeys,\n    getHalfCheckedNodes,\n    setChecked,\n    setCheckedKeys,\n  } = useCheck(props, tree)\n\n  const { doFilter, hiddenNodeKeySet, isForceHiddenExpandIcon } = useFilter(\n    props,\n    tree\n  )\n\n  const valueKey = computed(() => {\n    return props.props?.value || TreeOptionsEnum.KEY\n  })\n  const childrenKey = computed(() => {\n    return props.props?.children || TreeOptionsEnum.CHILDREN\n  })\n  const disabledKey = computed(() => {\n    return props.props?.disabled || TreeOptionsEnum.DISABLED\n  })\n  const labelKey = computed(() => {\n    return props.props?.label || TreeOptionsEnum.LABEL\n  })\n\n  const flattenTree = computed(() => {\n    const expandedKeys = expandedKeySet.value\n    const hiddenKeys = hiddenNodeKeySet.value\n    const flattenNodes: TreeNode[] = []\n    const nodes = tree.value?.treeNodes || []\n\n    const stack: TreeNode[] = []\n    for (let i = nodes.length - 1; i >= 0; --i) {\n      stack.push(nodes[i])\n    }\n    while (stack.length) {\n      const node = stack.pop()!\n      if (hiddenKeys.has(node.key)) continue\n\n      flattenNodes.push(node)\n      if (node.children && expandedKeys.has(node.key)) {\n        for (let i = node.children.length - 1; i >= 0; --i) {\n          stack.push(node.children[i])\n        }\n      }\n    }\n\n    return flattenNodes\n  })\n\n  const isNotEmpty = computed(() => {\n    return flattenTree.value.length > 0\n  })\n\n  function createTree(data: TreeData): Tree {\n    const treeNodeMap: Map<TreeKey, TreeNode> = new Map()\n    const levelTreeNodeMap: Map<number, TreeNode[]> = new Map()\n    let maxLevel = 1\n    function traverse(\n      nodes: TreeData,\n      level = 1,\n      parent: TreeNode | undefined = undefined\n    ) {\n      const siblings: TreeNode[] = []\n      for (const rawNode of nodes) {\n        const value = getKey(rawNode)\n        const node: TreeNode = {\n          level,\n          key: value,\n          data: rawNode,\n        }\n        node.label = getLabel(rawNode)\n        node.parent = parent\n        const children = getChildren(rawNode)\n        node.disabled = getDisabled(rawNode)\n        node.isLeaf = !children || children.length === 0\n        if (children && children.length) {\n          node.children = traverse(children, level + 1, node)\n        }\n        siblings.push(node)\n        treeNodeMap.set(value, node)\n        if (!levelTreeNodeMap.has(level)) {\n          levelTreeNodeMap.set(level, [])\n        }\n        levelTreeNodeMap.get(level)?.push(node)\n      }\n      if (level > maxLevel) {\n        maxLevel = level\n      }\n      return siblings\n    }\n    const treeNodes: TreeNode[] = traverse(data)\n    return {\n      treeNodeMap,\n      levelTreeNodeMap,\n      maxLevel,\n      treeNodes,\n    }\n  }\n\n  function filter(query: string) {\n    const keys = doFilter(query)\n    if (keys) {\n      expandedKeySet.value = keys\n    }\n  }\n\n  function getChildren(node: TreeNodeData): TreeNodeData[] {\n    return node[childrenKey.value]\n  }\n\n  function getKey(node: TreeNodeData): TreeKey {\n    if (!node) {\n      return ''\n    }\n    return node[valueKey.value]\n  }\n\n  function getDisabled(node: TreeNodeData): boolean {\n    return node[disabledKey.value]\n  }\n\n  function getLabel(node: TreeNodeData): string {\n    return node[labelKey.value]\n  }\n\n  function toggleExpand(node: TreeNode) {\n    const expandedKeys = expandedKeySet.value\n    if (expandedKeys.has(node.key)) {\n      collapseNode(node)\n    } else {\n      expandNode(node)\n    }\n  }\n\n  function setExpandedKeys(keys: TreeKey[]) {\n    const expandedKeys = new Set<TreeKey>()\n    const nodeMap = tree.value!.treeNodeMap\n\n    keys.forEach((k) => {\n      let node = nodeMap.get(k)\n      while (node && !expandedKeys.has(node.key)) {\n        expandedKeys.add(node.key)\n        node = node.parent\n      }\n    })\n\n    expandedKeySet.value = expandedKeys\n  }\n\n  function handleNodeClick(node: TreeNode, e: MouseEvent) {\n    emit(NODE_CLICK, node.data, node, e)\n    handleCurrentChange(node)\n    if (props.expandOnClickNode) {\n      toggleExpand(node)\n    }\n    if (props.showCheckbox && props.checkOnClickNode && !node.disabled) {\n      toggleCheckbox(node, !isChecked(node), true)\n    }\n  }\n\n  function handleNodeDrop(node: TreeNode, e: DragEvent) {\n    emit(NODE_DROP, node.data, node, e)\n  }\n\n  function handleCurrentChange(node: TreeNode) {\n    if (!isCurrent(node)) {\n      currentKey.value = node.key\n      emit(CURRENT_CHANGE, node.data, node)\n    }\n  }\n\n  function handleNodeCheck(node: TreeNode, checked: CheckboxValueType) {\n    toggleCheckbox(node, checked)\n  }\n\n  function expandNode(node: TreeNode) {\n    const keySet = expandedKeySet.value\n    if (tree.value && props.accordion) {\n      // whether only one node among the same level can be expanded at one time\n      const { treeNodeMap } = tree.value\n      keySet.forEach((key) => {\n        const treeNode = treeNodeMap.get(key)\n        if (node && node.level === treeNode?.level) {\n          keySet.delete(key)\n        }\n      })\n    }\n    keySet.add(node.key)\n    emit(NODE_EXPAND, node.data, node)\n  }\n\n  function collapseNode(node: TreeNode) {\n    expandedKeySet.value.delete(node.key)\n    emit(NODE_COLLAPSE, node.data, node)\n  }\n\n  function isExpanded(node: TreeNode): boolean {\n    return expandedKeySet.value.has(node.key)\n  }\n\n  function isDisabled(node: TreeNode): boolean {\n    return !!node.disabled\n  }\n\n  function isCurrent(node: TreeNode): boolean {\n    const current = currentKey.value\n    return current !== undefined && current === node.key\n  }\n\n  function getCurrentNode(): TreeNodeData | undefined {\n    if (!currentKey.value) return undefined\n    return tree.value?.treeNodeMap.get(currentKey.value)?.data\n  }\n\n  function getCurrentKey(): TreeKey | undefined {\n    return currentKey.value\n  }\n\n  function setCurrentKey(key: TreeKey): void {\n    currentKey.value = key\n  }\n\n  function setData(data: TreeData) {\n    nextTick(() => (tree.value = createTree(data)))\n  }\n\n  function getNode(data: TreeKey | TreeNodeData) {\n    const key = isObject(data) ? getKey(data) : data\n    return tree.value?.treeNodeMap.get(key)\n  }\n\n  function scrollToNode(key: TreeKey, strategy: ScrollStrategy = 'auto') {\n    const node = getNode(key)\n    if (node && listRef.value) {\n      listRef.value.scrollToItem(flattenTree.value.indexOf(node), strategy)\n    }\n  }\n\n  function scrollTo(offset: number) {\n    listRef.value?.scrollTo(offset)\n  }\n\n  return {\n    tree,\n    flattenTree,\n    isNotEmpty,\n    listRef,\n    getKey,\n    getChildren,\n    toggleExpand,\n    toggleCheckbox,\n    isExpanded,\n    isChecked,\n    isIndeterminate,\n    isDisabled,\n    isCurrent,\n    isForceHiddenExpandIcon,\n    handleNodeClick,\n    handleNodeDrop,\n    handleNodeCheck,\n    // expose\n    getCurrentNode,\n    getCurrentKey,\n    setCurrentKey,\n    getCheckedKeys,\n    getCheckedNodes,\n    getHalfCheckedKeys,\n    getHalfCheckedNodes,\n    setChecked,\n    setCheckedKeys,\n    filter,\n    setData,\n    getNode,\n    expandNode,\n    collapseNode,\n    setExpandedKeys,\n    scrollToNode,\n    scrollTo,\n  }\n}\n", "import { defineComponent, h, inject } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { ROOT_TREE_INJECTION_KEY, treeNodeContentProps } from './virtual-tree'\n\nexport default defineComponent({\n  name: 'ElTreeNodeContent',\n  props: treeNodeContentProps,\n  setup(props) {\n    const tree = inject(ROOT_TREE_INJECTION_KEY)\n    const ns = useNamespace('tree')\n    return () => {\n      const node = props.node\n      const { data } = node!\n      return tree?.ctx.slots.default\n        ? tree.ctx.slots.default({ node, data })\n        : h('span', { class: ns.be('node', 'label') }, [node?.label])\n    }\n  },\n})\n", "<template>\n  <div\n    ref=\"node$\"\n    :class=\"[\n      ns.b('node'),\n      ns.is('expanded', expanded),\n      ns.is('current', current),\n      ns.is('focusable', !disabled),\n      ns.is('checked', !disabled && checked),\n    ]\"\n    role=\"treeitem\"\n    tabindex=\"-1\"\n    :aria-expanded=\"expanded\"\n    :aria-disabled=\"disabled\"\n    :aria-checked=\"checked\"\n    :data-key=\"node?.key\"\n    @click.stop=\"handleClick\"\n    @contextmenu=\"handleContextMenu\"\n    @dragover.prevent\n    @dragenter.prevent\n    @drop.stop=\"handleDrop\"\n  >\n    <div\n      :class=\"ns.be('node', 'content')\"\n      :style=\"{\n        paddingLeft: `${(node.level - 1) * indent}px`,\n        height: itemSize + 'px',\n      }\"\n    >\n      <el-icon\n        v-if=\"icon\"\n        :class=\"[\n          ns.is('leaf', !!node?.isLeaf),\n          ns.is('hidden', hiddenExpandIcon),\n          {\n            expanded: !node?.isLeaf && expanded,\n          },\n          ns.be('node', 'expand-icon'),\n        ]\"\n        @click.stop=\"handleExpandIconClick\"\n      >\n        <component :is=\"icon\" />\n      </el-icon>\n      <el-checkbox\n        v-if=\"showCheckbox\"\n        :model-value=\"checked\"\n        :indeterminate=\"indeterminate\"\n        :disabled=\"disabled\"\n        @change=\"handleCheckChange\"\n        @click.stop\n      />\n      <el-node-content :node=\"node\" />\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject } from 'vue'\nimport ElIcon from '@element-plus/components/icon'\nimport { CaretRight } from '@element-plus/icons-vue'\nimport ElCheckbox from '@element-plus/components/checkbox'\nimport { useNamespace } from '@element-plus/hooks'\nimport ElNodeContent from './tree-node-content'\nimport {\n  NODE_CONTEXTMENU,\n  ROOT_TREE_INJECTION_KEY,\n  treeNodeEmits,\n  treeNodeProps,\n} from './virtual-tree'\nimport type { CheckboxValueType } from '@element-plus/components/checkbox'\n\ndefineOptions({\n  name: 'ElTreeNode',\n})\n\nconst props = defineProps(treeNodeProps)\nconst emit = defineEmits(treeNodeEmits)\n\nconst tree = inject(ROOT_TREE_INJECTION_KEY)\nconst ns = useNamespace('tree')\n\nconst indent = computed(() => {\n  return tree?.props.indent ?? 16\n})\n\nconst icon = computed(() => {\n  return tree?.props.icon ?? CaretRight\n})\n\nconst handleClick = (e: MouseEvent) => {\n  emit('click', props.node, e)\n}\n\nconst handleDrop = (e: DragEvent) => {\n  emit('drop', props.node, e)\n}\nconst handleExpandIconClick = () => {\n  emit('toggle', props.node)\n}\nconst handleCheckChange = (value: CheckboxValueType) => {\n  emit('check', props.node, value)\n}\nconst handleContextMenu = (event: Event) => {\n  if (tree?.instance?.vnode?.props?.['onNodeContextmenu']) {\n    event.stopPropagation()\n    event.preventDefault()\n  }\n  tree?.ctx.emit(NODE_CONTEXTMENU, event, props.node?.data, props.node)\n}\n</script>\n", "<template>\n  <div\n    :class=\"[ns.b(), { [ns.m('highlight-current')]: highlightCurrent }]\"\n    role=\"tree\"\n  >\n    <fixed-size-list\n      v-if=\"isNotEmpty\"\n      ref=\"listRef\"\n      :class-name=\"ns.b('virtual-list')\"\n      :data=\"flattenTree\"\n      :total=\"flattenTree.length\"\n      :height=\"height\"\n      :item-size=\"treeNodeSize\"\n      :perf-mode=\"perfMode\"\n    >\n      <template #default=\"{ data, index, style }\">\n        <el-tree-node\n          :key=\"data[index].key\"\n          :style=\"style\"\n          :node=\"data[index]\"\n          :expanded=\"isExpanded(data[index])\"\n          :show-checkbox=\"showCheckbox\"\n          :checked=\"isChecked(data[index])\"\n          :indeterminate=\"isIndeterminate(data[index])\"\n          :item-size=\"treeNodeSize\"\n          :disabled=\"isDisabled(data[index])\"\n          :current=\"isCurrent(data[index])\"\n          :hidden-expand-icon=\"isForceHiddenExpandIcon(data[index])\"\n          @click=\"handleNodeClick\"\n          @toggle=\"toggleExpand\"\n          @check=\"handleNodeCheck\"\n          @drop=\"handleNodeDrop\"\n        />\n      </template>\n    </fixed-size-list>\n    <div v-else :class=\"ns.e('empty-block')\">\n      <span :class=\"ns.e('empty-text')\">{{\n        emptyText ?? t('el.tree.emptyText')\n      }}</span>\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, getCurrentInstance, provide, useSlots } from 'vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { formItemContextKey } from '@element-plus/components/form'\nimport { FixedSizeList } from '@element-plus/components/virtual-list'\nimport { useTree } from './composables/useTree'\nimport ElTreeNode from './tree-node.vue'\nimport { ROOT_TREE_INJECTION_KEY, treeEmits, treeProps } from './virtual-tree'\n\ndefineOptions({\n  name: 'ElTreeV2',\n})\n\nconst props = defineProps(treeProps)\nconst emit = defineEmits(treeEmits)\n\nconst slots = useSlots()\n\nconst treeNodeSize = computed(() => props.itemSize)\n\nprovide(ROOT_TREE_INJECTION_KEY, {\n  ctx: {\n    emit,\n    slots,\n  },\n  props,\n  instance: getCurrentInstance()!,\n})\nprovide(formItemContextKey, undefined)\nconst { t } = useLocale()\nconst ns = useNamespace('tree')\nconst {\n  flattenTree,\n  isNotEmpty,\n  listRef,\n  toggleExpand,\n  isExpanded,\n  isIndeterminate,\n  isChecked,\n  isDisabled,\n  isCurrent,\n  isForceHiddenExpandIcon,\n  handleNodeClick,\n  handleNodeDrop,\n  handleNodeCheck,\n  // expose\n  toggleCheckbox,\n  getCurrentNode,\n  getCurrentKey,\n  setCurrentKey,\n  getCheckedKeys,\n  getCheckedNodes,\n  getHalfCheckedKeys,\n  getHalfCheckedNodes,\n  setChecked,\n  setCheckedKeys,\n  filter,\n  setData,\n  getNode,\n  expandNode,\n  collapseNode,\n  setExpandedKeys,\n  scrollToNode,\n  scrollTo,\n} = useTree(props, emit)\n\ndefineExpose({\n  toggleCheckbox,\n  getCurrentNode,\n  getCurrentKey,\n  setCurrentKey,\n  getCheckedKeys,\n  getCheckedNodes,\n  getHalfCheckedKeys,\n  getHalfCheckedNodes,\n  setChecked,\n  setCheckedKeys,\n  filter,\n  setData,\n  getNode,\n  expandNode,\n  collapseNode,\n  setExpandedKeys,\n  scrollToNode,\n  scrollTo,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport TreeV2 from './src/tree.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTreeV2: SFCWithInstall<typeof TreeV2> = withInstall(TreeV2)\nexport default ElTreeV2\n", "import type { ComputedRef, InjectionKey } from 'vue'\n\nexport interface UploadContext {\n  accept: ComputedRef<string>\n}\n\nexport const uploadContextKey: InjectionKey<UploadContext> =\n  Symbol('uploadContextKey')\n", "import { isNil } from 'lodash-unified'\nimport { isArray, throwError } from '@element-plus/utils'\nimport type {\n  UploadProgressEvent,\n  UploadRequestHandler,\n  UploadRequestOptions,\n} from './upload'\n\nconst SCOPE = 'ElUpload'\n\nexport class UploadAjaxError extends Error {\n  name = 'UploadAjaxError'\n  status: number\n  method: string\n  url: string\n\n  constructor(message: string, status: number, method: string, url: string) {\n    super(message)\n    this.status = status\n    this.method = method\n    this.url = url\n  }\n}\n\nfunction getError(\n  action: string,\n  option: UploadRequestOptions,\n  xhr: XMLHttpRequest\n) {\n  let msg: string\n  if (xhr.response) {\n    msg = `${xhr.response.error || xhr.response}`\n  } else if (xhr.responseText) {\n    msg = `${xhr.responseText}`\n  } else {\n    msg = `fail to ${option.method} ${action} ${xhr.status}`\n  }\n\n  return new UploadAjaxError(msg, xhr.status, option.method, action)\n}\n\nfunction getBody(xhr: XMLHttpRequest): XMLHttpRequestResponseType {\n  const text = xhr.responseText || xhr.response\n  if (!text) {\n    return text\n  }\n\n  try {\n    return JSON.parse(text)\n  } catch {\n    return text\n  }\n}\n\nexport const ajaxUpload: UploadRequestHandler = (option) => {\n  if (typeof XMLHttpRequest === 'undefined')\n    throwError(SCOPE, 'XMLHttpRequest is undefined')\n\n  const xhr = new XMLHttpRequest()\n  const action = option.action\n\n  if (xhr.upload) {\n    xhr.upload.addEventListener('progress', (evt) => {\n      const progressEvt = evt as UploadProgressEvent\n      progressEvt.percent = evt.total > 0 ? (evt.loaded / evt.total) * 100 : 0\n      option.onProgress(progressEvt)\n    })\n  }\n\n  const formData = new FormData()\n  if (option.data) {\n    for (const [key, value] of Object.entries(option.data)) {\n      if (isArray(value) && value.length) formData.append(key, ...value)\n      else formData.append(key, value)\n    }\n  }\n  formData.append(option.filename, option.file, option.file.name)\n\n  xhr.addEventListener('error', () => {\n    option.onError(getError(action, option, xhr))\n  })\n\n  xhr.addEventListener('load', () => {\n    if (xhr.status < 200 || xhr.status >= 300) {\n      return option.onError(getError(action, option, xhr))\n    }\n    option.onSuccess(getBody(xhr))\n  })\n\n  xhr.open(option.method, action, true)\n\n  if (option.withCredentials && 'withCredentials' in xhr) {\n    xhr.withCredentials = true\n  }\n\n  const headers = option.headers || {}\n  if (headers instanceof Headers) {\n    headers.forEach((value, key) => xhr.setRequestHeader(key, value))\n  } else {\n    for (const [key, value] of Object.entries(headers)) {\n      if (isNil(value)) continue\n      xhr.setRequestHeader(key, String(value))\n    }\n  }\n\n  xhr.send(formData)\n  return xhr\n}\n", "import { NOOP, buildProps, definePropType, mutable } from '@element-plus/utils'\nimport { ajaxUpload } from './ajax'\nimport type { Awaitable, Mutable } from '@element-plus/utils'\n\nimport type { UploadAjaxError } from './ajax'\nimport type { ExtractPropTypes } from 'vue'\nimport type Upload from './upload.vue'\n\nexport const uploadListTypes = ['text', 'picture', 'picture-card'] as const\n\nlet fileId = 1\nexport const genFileId = () => Date.now() + fileId++\n\nexport type UploadStatus = 'ready' | 'uploading' | 'success' | 'fail'\nexport interface UploadProgressEvent extends ProgressEvent {\n  percent: number\n}\n\nexport interface UploadRequestOptions {\n  action: string\n  method: string\n  data: Record<string, string | Blob | [string | Blob, string]>\n  filename: string\n  file: UploadRawFile\n  headers: Headers | Record<string, string | number | null | undefined>\n  onError: (evt: UploadAjaxError) => void\n  onProgress: (evt: UploadProgressEvent) => void\n  onSuccess: (response: any) => void\n  withCredentials: boolean\n}\nexport interface UploadFile {\n  name: string\n  percentage?: number\n  status: UploadStatus\n  size?: number\n  response?: unknown\n  uid: number\n  url?: string\n  raw?: UploadRawFile\n}\nexport type UploadUserFile = Omit<UploadFile, 'status' | 'uid'> &\n  Partial<Pick<UploadFile, 'status' | 'uid'>>\n\nexport type UploadFiles = UploadFile[]\nexport interface UploadRawFile extends File {\n  uid: number\n}\nexport type UploadRequestHandler = (\n  options: UploadRequestOptions\n) => XMLHttpRequest | Promise<unknown>\nexport interface UploadHooks {\n  beforeUpload: (\n    rawFile: UploadRawFile\n  ) => Awaitable<void | undefined | null | boolean | File | Blob>\n  beforeRemove: (\n    uploadFile: UploadFile,\n    uploadFiles: UploadFiles\n  ) => Awaitable<boolean>\n  onRemove: (uploadFile: UploadFile, uploadFiles: UploadFiles) => void\n  onChange: (uploadFile: UploadFile, uploadFiles: UploadFiles) => void\n  onPreview: (uploadFile: UploadFile) => void\n  onSuccess: (\n    response: any,\n    uploadFile: UploadFile,\n    uploadFiles: UploadFiles\n  ) => void\n  onProgress: (\n    evt: UploadProgressEvent,\n    uploadFile: UploadFile,\n    uploadFiles: UploadFiles\n  ) => void\n  onError: (\n    error: Error,\n    uploadFile: UploadFile,\n    uploadFiles: UploadFiles\n  ) => void\n  onExceed: (files: File[], uploadFiles: UploadUserFile[]) => void\n}\n\nexport type UploadData = Mutable<Record<string, any>>\n\nexport const uploadBaseProps = buildProps({\n  /**\n   * @description request URL\n   */\n  action: {\n    type: String,\n    default: '#',\n  },\n  /**\n   * @description request headers\n   */\n  headers: {\n    type: definePropType<Headers | Record<string, any>>(Object),\n  },\n  /**\n   * @description set upload request method\n   */\n  method: {\n    type: String,\n    default: 'post',\n  },\n  /**\n   * @description additions options of request\n   */\n  data: {\n    type: definePropType<\n      | Awaitable<UploadData>\n      | ((rawFile: UploadRawFile) => Awaitable<UploadData>)\n    >([Object, Function, Promise]),\n    default: () => mutable({} as const),\n  },\n  /**\n   * @description whether uploading multiple files is permitted\n   */\n  multiple: Boolean,\n  /**\n   * @description key name for uploaded file\n   */\n  name: {\n    type: String,\n    default: 'file',\n  },\n  /**\n   * @description whether to activate drag and drop mode\n   */\n  drag: Boolean,\n  /**\n   * @description whether cookies are sent\n   */\n  withCredentials: Boolean,\n  /**\n   * @description whether to show the uploaded file list\n   */\n  showFileList: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description accepted [file types](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#attr-accept), will not work when `thumbnail-mode === true`\n   */\n  accept: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description default uploaded files\n   */\n  fileList: {\n    type: definePropType<UploadUserFile[]>(Array),\n    default: () => mutable([] as const),\n  },\n  /**\n   * @description whether to auto upload file\n   */\n  autoUpload: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description type of file list\n   */\n  listType: {\n    type: String,\n    values: uploadListTypes,\n    default: 'text',\n  },\n  /**\n   * @description override default xhr behavior, allowing you to implement your own upload-file's request\n   */\n  httpRequest: {\n    type: definePropType<UploadRequestHandler>(Function),\n    default: ajaxUpload,\n  },\n  /**\n   * @description whether to disable upload\n   */\n  disabled: Boolean,\n  /**\n   * @description maximum number of uploads allowed\n   */\n  limit: Number,\n} as const)\n\nexport const uploadProps = buildProps({\n  ...uploadBaseProps,\n  /**\n   * @description hook function before uploading with the file to be uploaded as its parameter. If `false` is returned or a `Promise` is returned and then is rejected, uploading will be aborted\n   */\n  beforeUpload: {\n    type: definePropType<UploadHooks['beforeUpload']>(Function),\n    default: NOOP,\n  },\n  /**\n   * @description hook function before removing a file with the file and file list as its parameters. If `false` is returned or a `Promise` is returned and then is rejected, removing will be aborted\n   */\n  beforeRemove: {\n    type: definePropType<UploadHooks['beforeRemove']>(Function),\n  },\n  /**\n   * @description hook function when files are removed\n   */\n  onRemove: {\n    type: definePropType<UploadHooks['onRemove']>(Function),\n    default: NOOP,\n  },\n  /**\n   * @description hook function when select file or upload file success or upload file fail\n   */\n  onChange: {\n    type: definePropType<UploadHooks['onChange']>(Function),\n    default: NOOP,\n  },\n  /**\n   * @description hook function when clicking the uploaded files\n   */\n  onPreview: {\n    type: definePropType<UploadHooks['onPreview']>(Function),\n    default: NOOP,\n  },\n  /**\n   * @description hook function when uploaded successfully\n   */\n  onSuccess: {\n    type: definePropType<UploadHooks['onSuccess']>(Function),\n    default: NOOP,\n  },\n  /**\n   * @description hook function when some progress occurs\n   */\n  onProgress: {\n    type: definePropType<UploadHooks['onProgress']>(Function),\n    default: NOOP,\n  },\n  /**\n   * @description hook function when some errors occurs\n   */\n  onError: {\n    type: definePropType<UploadHooks['onError']>(Function),\n    default: NOOP,\n  },\n  /**\n   * @description hook function when limit is exceeded\n   */\n  onExceed: {\n    type: definePropType<UploadHooks['onExceed']>(Function),\n    default: NOOP,\n  },\n  /**\n   * @description set HTML attribute: crossorigin.\n   */\n  crossorigin: {\n    type: definePropType<'anonymous' | 'use-credentials' | ''>(String),\n  },\n} as const)\n\nexport type UploadProps = ExtractPropTypes<typeof uploadProps>\n\nexport type UploadInstance = InstanceType<typeof Upload>\n", "import { NOOP, buildProps, definePropType, mutable } from '@element-plus/utils'\nimport { uploadListTypes } from './upload'\nimport type { ExtractPropTypes } from 'vue'\nimport type { UploadFile, UploadFiles, UploadHooks } from './upload'\nimport type UploadList from './upload-list.vue'\n\nexport const uploadListProps = buildProps({\n  files: {\n    type: definePropType<UploadFiles>(Array),\n    default: () => mutable([]),\n  },\n  disabled: {\n    type: Boolean,\n    default: false,\n  },\n  handlePreview: {\n    type: definePropType<UploadHooks['onPreview']>(Function),\n    default: NOOP,\n  },\n  listType: {\n    type: String,\n    values: uploadListTypes,\n    default: 'text',\n  },\n  /**\n   * @description set HTML attribute: crossorigin.\n   */\n  crossorigin: {\n    type: definePropType<'anonymous' | 'use-credentials' | ''>(String),\n  },\n} as const)\n\nexport type UploadListProps = ExtractPropTypes<typeof uploadListProps>\nexport const uploadListEmits = {\n  remove: (file: UploadFile) => !!file,\n}\nexport type UploadListEmits = typeof uploadListEmits\nexport type UploadListInstance = InstanceType<typeof UploadList>\n", "<template>\n  <transition-group tag=\"ul\" :class=\"containerKls\" :name=\"nsList.b()\">\n    <li\n      v-for=\"(file, index) in files\"\n      :key=\"file.uid || file.name\"\n      :class=\"[\n        nsUpload.be('list', 'item'),\n        nsUpload.is(file.status),\n        { focusing },\n      ]\"\n      tabindex=\"0\"\n      @keydown.delete=\"!disabled && handleRemove(file)\"\n      @focus=\"focusing = true\"\n      @blur=\"focusing = false\"\n      @click=\"focusing = false\"\n    >\n      <slot :file=\"file\" :index=\"index\">\n        <img\n          v-if=\"\n            listType === 'picture' ||\n            (file.status !== 'uploading' && listType === 'picture-card')\n          \"\n          :class=\"nsUpload.be('list', 'item-thumbnail')\"\n          :src=\"file.url\"\n          :crossorigin=\"crossorigin\"\n          alt=\"\"\n        />\n        <div\n          v-if=\"file.status === 'uploading' || listType !== 'picture-card'\"\n          :class=\"nsUpload.be('list', 'item-info')\"\n        >\n          <a\n            :class=\"nsUpload.be('list', 'item-name')\"\n            @click.prevent=\"handlePreview(file)\"\n          >\n            <el-icon :class=\"nsIcon.m('document')\">\n              <Document />\n            </el-icon>\n            <span\n              :class=\"nsUpload.be('list', 'item-file-name')\"\n              :title=\"file.name\"\n            >\n              {{ file.name }}\n            </span>\n          </a>\n          <el-progress\n            v-if=\"file.status === 'uploading'\"\n            :type=\"listType === 'picture-card' ? 'circle' : 'line'\"\n            :stroke-width=\"listType === 'picture-card' ? 6 : 2\"\n            :percentage=\"Number(file.percentage)\"\n            :style=\"listType === 'picture-card' ? '' : 'margin-top: 0.5rem'\"\n          />\n        </div>\n\n        <label :class=\"nsUpload.be('list', 'item-status-label')\">\n          <el-icon\n            v-if=\"listType === 'text'\"\n            :class=\"[nsIcon.m('upload-success'), nsIcon.m('circle-check')]\"\n          >\n            <circle-check />\n          </el-icon>\n          <el-icon\n            v-else-if=\"['picture-card', 'picture'].includes(listType)\"\n            :class=\"[nsIcon.m('upload-success'), nsIcon.m('check')]\"\n          >\n            <Check />\n          </el-icon>\n        </label>\n        <el-icon\n          v-if=\"!disabled\"\n          :class=\"nsIcon.m('close')\"\n          @click=\"handleRemove(file)\"\n        >\n          <Close />\n        </el-icon>\n        <!-- Due to close btn only appears when li gets focused disappears after li gets blurred, thus keyboard navigation can never reach close btn-->\n        <!-- This is a bug which needs to be fixed -->\n        <!-- TODO: Fix the incorrect navigation interaction -->\n        <i v-if=\"!disabled\" :class=\"nsIcon.m('close-tip')\">{{\n          t('el.upload.deleteTip')\n        }}</i>\n        <span\n          v-if=\"listType === 'picture-card'\"\n          :class=\"nsUpload.be('list', 'item-actions')\"\n        >\n          <span\n            :class=\"nsUpload.be('list', 'item-preview')\"\n            @click=\"handlePreview(file)\"\n          >\n            <el-icon :class=\"nsIcon.m('zoom-in')\"><zoom-in /></el-icon>\n          </span>\n          <span\n            v-if=\"!disabled\"\n            :class=\"nsUpload.be('list', 'item-delete')\"\n            @click=\"handleRemove(file)\"\n          >\n            <el-icon :class=\"nsIcon.m('delete')\">\n              <Delete />\n            </el-icon>\n          </span>\n        </span>\n      </slot>\n    </li>\n    <slot name=\"append\" />\n  </transition-group>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, ref } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport {\n  Check,\n  CircleCheck,\n  Close,\n  Delete,\n  Document,\n  ZoomIn,\n} from '@element-plus/icons-vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport ElProgress from '@element-plus/components/progress'\nimport { useFormDisabled } from '@element-plus/components/form'\n\nimport { uploadListEmits, uploadListProps } from './upload-list'\nimport type { UploadFile } from './upload'\n\ndefineOptions({\n  name: 'ElUploadList',\n})\n\nconst props = defineProps(uploadListProps)\nconst emit = defineEmits(uploadListEmits)\n\nconst { t } = useLocale()\nconst nsUpload = useNamespace('upload')\nconst nsIcon = useNamespace('icon')\nconst nsList = useNamespace('list')\nconst disabled = useFormDisabled()\n\nconst focusing = ref(false)\n\nconst containerKls = computed(() => [\n  nsUpload.b('list'),\n  nsUpload.bm('list', props.listType),\n  nsUpload.is('disabled', props.disabled),\n])\n\nconst handleRemove = (file: UploadFile) => {\n  emit('remove', file)\n}\n</script>\n", "import { buildProps, isArray } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type UploadDragger from './upload-dragger.vue'\n\nexport const uploadDraggerProps = buildProps({\n  disabled: {\n    type: Boolean,\n    default: false,\n  },\n} as const)\nexport type UploadDraggerProps = ExtractPropTypes<typeof uploadDraggerProps>\n\nexport const uploadDraggerEmits = {\n  file: (file: File[]) => isArray(file),\n}\nexport type UploadDraggerEmits = typeof uploadDraggerEmits\n\nexport type UploadDraggerInstance = InstanceType<typeof UploadDragger>\n", "<template>\n  <div\n    :class=\"[ns.b('dragger'), ns.is('dragover', dragover)]\"\n    @drop.prevent=\"onDrop\"\n    @dragover.prevent=\"onDragover\"\n    @dragleave.prevent=\"dragover = false\"\n  >\n    <slot />\n  </div>\n</template>\n<script lang=\"ts\" setup>\nimport { inject, ref } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport { throwError } from '@element-plus/utils/error'\nimport { uploadContextKey } from './constants'\nimport { uploadDraggerEmits, uploadDraggerProps } from './upload-dragger'\n\nconst COMPONENT_NAME = 'ElUploadDrag'\n\ndefineOptions({\n  name: COMPONENT_NAME,\n})\n\ndefineProps(uploadDraggerProps)\nconst emit = defineEmits(uploadDraggerEmits)\n\nconst uploaderContext = inject(uploadContextKey)\nif (!uploaderContext) {\n  throwError(\n    COMPONENT_NAME,\n    'usage: <el-upload><el-upload-dragger /></el-upload>'\n  )\n}\n\nconst ns = useNamespace('upload')\nconst dragover = ref(false)\nconst disabled = useFormDisabled()\n\nconst onDrop = (e: DragEvent) => {\n  if (disabled.value) return\n  dragover.value = false\n\n  e.stopPropagation()\n\n  const files = Array.from(e.dataTransfer!.files)\n  emit('file', files)\n}\n\nconst onDragover = () => {\n  if (!disabled.value) dragover.value = true\n}\n</script>\n", "import { NOOP, buildProps, definePropType } from '@element-plus/utils'\nimport { uploadBaseProps } from './upload'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type {\n  UploadFile,\n  UploadHooks,\n  UploadProgressEvent,\n  UploadRawFile,\n} from './upload'\nimport type UploadContent from './upload-content.vue'\nimport type { UploadAjaxError } from './ajax'\n\nexport const uploadContentProps = buildProps({\n  ...uploadBaseProps,\n\n  beforeUpload: {\n    type: definePropType<UploadHooks['beforeUpload']>(Function),\n    default: NOOP,\n  },\n  onRemove: {\n    type: definePropType<\n      (file: UploadFile | UploadRawFile, rawFile?: UploadRawFile) => void\n    >(Function),\n    default: NOOP,\n  },\n  onStart: {\n    type: definePropType<(rawFile: UploadRawFile) => void>(Function),\n    default: NOOP,\n  },\n  onSuccess: {\n    type: definePropType<(response: any, rawFile: UploadRawFile) => unknown>(\n      Function\n    ),\n    default: NOOP,\n  },\n  onProgress: {\n    type: definePropType<\n      (evt: UploadProgressEvent, rawFile: UploadRawFile) => void\n    >(Function),\n    default: NOOP,\n  },\n  onError: {\n    type: definePropType<\n      (err: UploadAjaxError, rawFile: UploadRawFile) => void\n    >(Function),\n    default: NOOP,\n  },\n  onExceed: {\n    type: definePropType<UploadHooks['onExceed']>(Function),\n    default: NOOP,\n  },\n} as const)\n\nexport type UploadContentProps = ExtractPropTypes<typeof uploadContentProps>\n\nexport type UploadContentInstance = InstanceType<typeof UploadContent>\n", "<template>\n  <div\n    :class=\"[\n      ns.b(),\n      ns.m(listType),\n      ns.is('drag', drag),\n      ns.is('disabled', disabled),\n    ]\"\n    :tabindex=\"disabled ? '-1' : '0'\"\n    @click=\"handleClick\"\n    @keydown.self.enter.space=\"handleKeydown\"\n  >\n    <template v-if=\"drag\">\n      <upload-dragger :disabled=\"disabled\" @file=\"uploadFiles\">\n        <slot />\n      </upload-dragger>\n    </template>\n    <template v-else>\n      <slot />\n    </template>\n    <input\n      ref=\"inputRef\"\n      :class=\"ns.e('input')\"\n      :name=\"name\"\n      :disabled=\"disabled\"\n      :multiple=\"multiple\"\n      :accept=\"accept\"\n      type=\"file\"\n      @change=\"handleChange\"\n      @click.stop\n    />\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { shallowRef } from 'vue'\nimport { cloneDeep, isEqual } from 'lodash-unified'\nimport { entriesOf, isFunction, isPlainObject } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport UploadDragger from './upload-dragger.vue'\nimport { uploadContentProps } from './upload-content'\nimport { genFileId } from './upload'\nimport type { UploadContentProps } from './upload-content'\n\nimport type {\n  UploadFile,\n  UploadHooks,\n  UploadRawFile,\n  UploadRequestOptions,\n} from './upload'\n\ndefineOptions({\n  name: 'ElUploadContent',\n  inheritAttrs: false,\n})\n\nconst props = defineProps(uploadContentProps)\nconst ns = useNamespace('upload')\nconst disabled = useFormDisabled()\n\nconst requests = shallowRef<Record<string, XMLHttpRequest | Promise<unknown>>>(\n  {}\n)\nconst inputRef = shallowRef<HTMLInputElement>()\n\nconst uploadFiles = (files: File[]) => {\n  if (files.length === 0) return\n\n  const { autoUpload, limit, fileList, multiple, onStart, onExceed } = props\n\n  if (limit && fileList.length + files.length > limit) {\n    onExceed(files, fileList)\n    return\n  }\n\n  if (!multiple) {\n    files = files.slice(0, 1)\n  }\n\n  for (const file of files) {\n    const rawFile = file as UploadRawFile\n    rawFile.uid = genFileId()\n    onStart(rawFile)\n    if (autoUpload) upload(rawFile)\n  }\n}\n\nconst upload = async (rawFile: UploadRawFile): Promise<void> => {\n  inputRef.value!.value = ''\n\n  if (!props.beforeUpload) {\n    return doUpload(rawFile)\n  }\n\n  let hookResult: Exclude<ReturnType<UploadHooks['beforeUpload']>, Promise<any>>\n  let beforeData: UploadContentProps['data'] = {}\n\n  try {\n    // origin data: Handle data changes after synchronization tasks are executed\n    const originData = props.data\n    const beforeUploadPromise = props.beforeUpload(rawFile)\n    beforeData = isPlainObject(props.data) ? cloneDeep(props.data) : props.data\n    hookResult = await beforeUploadPromise\n    if (isPlainObject(props.data) && isEqual(originData, beforeData)) {\n      beforeData = cloneDeep(props.data)\n    }\n  } catch {\n    hookResult = false\n  }\n\n  if (hookResult === false) {\n    props.onRemove(rawFile)\n    return\n  }\n\n  let file: File = rawFile\n  if (hookResult instanceof Blob) {\n    if (hookResult instanceof File) {\n      file = hookResult\n    } else {\n      file = new File([hookResult], rawFile.name, {\n        type: rawFile.type,\n      })\n    }\n  }\n\n  doUpload(\n    Object.assign(file, {\n      uid: rawFile.uid,\n    }),\n    beforeData\n  )\n}\n\nconst resolveData = async (\n  data: UploadContentProps['data'],\n  rawFile: UploadRawFile\n): Promise<Record<string, any>> => {\n  if (isFunction(data)) {\n    return data(rawFile)\n  }\n\n  return data\n}\n\nconst doUpload = async (\n  rawFile: UploadRawFile,\n  beforeData?: UploadContentProps['data']\n) => {\n  const {\n    headers,\n    data,\n    method,\n    withCredentials,\n    name: filename,\n    action,\n    onProgress,\n    onSuccess,\n    onError,\n    httpRequest,\n  } = props\n\n  try {\n    beforeData = await resolveData(beforeData ?? data, rawFile)\n  } catch {\n    props.onRemove(rawFile)\n    return\n  }\n\n  const { uid } = rawFile\n  const options: UploadRequestOptions = {\n    headers: headers || {},\n    withCredentials,\n    file: rawFile,\n    data: beforeData,\n    method,\n    filename,\n    action,\n    onProgress: (evt) => {\n      onProgress(evt, rawFile)\n    },\n    onSuccess: (res) => {\n      onSuccess(res, rawFile)\n      delete requests.value[uid]\n    },\n    onError: (err) => {\n      onError(err, rawFile)\n      delete requests.value[uid]\n    },\n  }\n  const request = httpRequest(options)\n  requests.value[uid] = request\n  if (request instanceof Promise) {\n    request.then(options.onSuccess, options.onError)\n  }\n}\n\nconst handleChange = (e: Event) => {\n  const files = (e.target as HTMLInputElement).files\n  if (!files) return\n  uploadFiles(Array.from(files))\n}\n\nconst handleClick = () => {\n  if (!disabled.value) {\n    inputRef.value!.value = ''\n    inputRef.value!.click()\n  }\n}\n\nconst handleKeydown = () => {\n  handleClick()\n}\n\nconst abort = (file?: UploadFile) => {\n  const _reqs = entriesOf(requests.value).filter(\n    file ? ([uid]) => String(file.uid) === uid : () => true\n  )\n  _reqs.forEach(([uid, req]) => {\n    if (req instanceof XMLHttpRequest) req.abort()\n    delete requests.value[uid]\n  })\n}\n\ndefineExpose({\n  abort,\n  upload,\n})\n</script>\n", "import { watch } from 'vue'\nimport { isNil } from 'lodash-unified'\nimport { useVModel } from '@vueuse/core'\nimport { debugWarn, throwError } from '@element-plus/utils'\nimport { genFileId } from './upload'\nimport type { ShallowRef } from 'vue'\nimport type {\n  UploadContentInstance,\n  UploadContentProps,\n} from './upload-content'\nimport type {\n  UploadFile,\n  UploadFiles,\n  UploadProps,\n  UploadRawFile,\n  UploadStatus,\n} from './upload'\n\nconst SCOPE = 'ElUpload'\n\nconst revokeFileObjectURL = (file: UploadFile) => {\n  if (file.url?.startsWith('blob:')) {\n    URL.revokeObjectURL(file.url)\n  }\n}\n\nexport const useHandlers = (\n  props: UploadProps,\n  uploadRef: ShallowRef<UploadContentInstance | undefined>\n) => {\n  const uploadFiles = useVModel(\n    props as Omit<UploadProps, 'fileList'> & { fileList: UploadFiles },\n    'fileList',\n    undefined,\n    { passive: true }\n  )\n\n  const getFile = (rawFile: UploadRawFile) =>\n    uploadFiles.value.find((file) => file.uid === rawFile.uid)\n\n  function abort(file: UploadFile) {\n    uploadRef.value?.abort(file)\n  }\n\n  function clearFiles(\n    /** @default ['ready', 'uploading', 'success', 'fail'] */\n    states: UploadStatus[] = ['ready', 'uploading', 'success', 'fail']\n  ) {\n    uploadFiles.value = uploadFiles.value.filter(\n      (row) => !states.includes(row.status)\n    )\n  }\n\n  function removeFile(file: UploadFile) {\n    uploadFiles.value = uploadFiles.value.filter(\n      (uploadFile) => uploadFile !== file\n    )\n  }\n\n  const handleError: UploadContentProps['onError'] = (err, rawFile) => {\n    const file = getFile(rawFile)\n    if (!file) return\n\n    console.error(err)\n    file.status = 'fail'\n    removeFile(file)\n    props.onError(err, file, uploadFiles.value)\n    props.onChange(file, uploadFiles.value)\n  }\n\n  const handleProgress: UploadContentProps['onProgress'] = (evt, rawFile) => {\n    const file = getFile(rawFile)\n    if (!file) return\n\n    props.onProgress(evt, file, uploadFiles.value)\n    file.status = 'uploading'\n    file.percentage = Math.round(evt.percent)\n  }\n\n  const handleSuccess: UploadContentProps['onSuccess'] = (\n    response,\n    rawFile\n  ) => {\n    const file = getFile(rawFile)\n    if (!file) return\n\n    file.status = 'success'\n    file.response = response\n    props.onSuccess(response, file, uploadFiles.value)\n    props.onChange(file, uploadFiles.value)\n  }\n\n  const handleStart: UploadContentProps['onStart'] = (file) => {\n    if (isNil(file.uid)) file.uid = genFileId()\n    const uploadFile: UploadFile = {\n      name: file.name,\n      percentage: 0,\n      status: 'ready',\n      size: file.size,\n      raw: file,\n      uid: file.uid,\n    }\n    if (props.listType === 'picture-card' || props.listType === 'picture') {\n      try {\n        uploadFile.url = URL.createObjectURL(file)\n      } catch (err: unknown) {\n        debugWarn(SCOPE, (err as Error).message)\n        props.onError(err as Error, uploadFile, uploadFiles.value)\n      }\n    }\n    uploadFiles.value = [...uploadFiles.value, uploadFile]\n    props.onChange(uploadFile, uploadFiles.value)\n  }\n\n  const handleRemove: UploadContentProps['onRemove'] = async (\n    file\n  ): Promise<void> => {\n    const uploadFile = file instanceof File ? getFile(file) : file\n    if (!uploadFile) throwError(SCOPE, 'file to be removed not found')\n\n    const doRemove = (file: UploadFile) => {\n      abort(file)\n      removeFile(file)\n      props.onRemove(file, uploadFiles.value)\n      revokeFileObjectURL(file)\n    }\n\n    if (props.beforeRemove) {\n      const before = await props.beforeRemove(uploadFile, uploadFiles.value)\n      if (before !== false) doRemove(uploadFile)\n    } else {\n      doRemove(uploadFile)\n    }\n  }\n\n  function submit() {\n    uploadFiles.value\n      .filter(({ status }) => status === 'ready')\n      .forEach(({ raw }) => raw && uploadRef.value?.upload(raw))\n  }\n\n  watch(\n    () => props.listType,\n    (val) => {\n      if (val !== 'picture-card' && val !== 'picture') {\n        return\n      }\n\n      uploadFiles.value = uploadFiles.value.map((file) => {\n        const { raw, url } = file\n        if (!url && raw) {\n          try {\n            file.url = URL.createObjectURL(raw)\n          } catch (err: unknown) {\n            props.onError(err as Error, file, uploadFiles.value)\n          }\n        }\n        return file\n      })\n    }\n  )\n\n  watch(\n    uploadFiles,\n    (files) => {\n      for (const file of files) {\n        file.uid ||= genFileId()\n        file.status ||= 'success'\n      }\n    },\n    { immediate: true, deep: true }\n  )\n\n  return {\n    /** @description two-way binding ref from props `fileList` */\n    uploadFiles,\n    abort,\n    clearFiles,\n    handleError,\n    handleProgress,\n    handleStart,\n    handleSuccess,\n    handleRemove,\n    submit,\n    revokeFileObjectURL,\n  }\n}\n", "<template>\n  <div>\n    <upload-list\n      v-if=\"isPictureCard && showFileList\"\n      :disabled=\"disabled\"\n      :list-type=\"listType\"\n      :files=\"uploadFiles\"\n      :crossorigin=\"crossorigin\"\n      :handle-preview=\"onPreview\"\n      @remove=\"handleRemove\"\n    >\n      <template v-if=\"$slots.file\" #default=\"{ file, index }\">\n        <slot name=\"file\" :file=\"file\" :index=\"index\" />\n      </template>\n      <template #append>\n        <upload-content ref=\"uploadRef\" v-bind=\"uploadContentProps\">\n          <slot v-if=\"$slots.trigger\" name=\"trigger\" />\n          <slot v-if=\"!$slots.trigger && $slots.default\" />\n        </upload-content>\n      </template>\n    </upload-list>\n\n    <upload-content\n      v-if=\"!isPictureCard || (isPictureCard && !showFileList)\"\n      ref=\"uploadRef\"\n      v-bind=\"uploadContentProps\"\n    >\n      <slot v-if=\"$slots.trigger\" name=\"trigger\" />\n      <slot v-if=\"!$slots.trigger && $slots.default\" />\n    </upload-content>\n\n    <slot v-if=\"$slots.trigger\" />\n    <slot name=\"tip\" />\n    <upload-list\n      v-if=\"!isPictureCard && showFileList\"\n      :disabled=\"disabled\"\n      :list-type=\"listType\"\n      :files=\"uploadFiles\"\n      :crossorigin=\"crossorigin\"\n      :handle-preview=\"onPreview\"\n      @remove=\"handleRemove\"\n    >\n      <template v-if=\"$slots.file\" #default=\"{ file, index }\">\n        <slot name=\"file\" :file=\"file\" :index=\"index\" />\n      </template>\n    </upload-list>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, onBeforeUnmount, provide, shallowRef, toRef } from 'vue'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport { uploadContextKey } from './constants'\nimport UploadList from './upload-list.vue'\nimport UploadContent from './upload-content.vue'\nimport { useHandlers } from './use-handlers'\nimport { uploadProps } from './upload'\n\nimport type {\n  UploadContentInstance,\n  UploadContentProps,\n} from './upload-content'\n\ndefineOptions({\n  name: 'ElUpload',\n})\n\nconst props = defineProps(uploadProps)\n\nconst disabled = useFormDisabled()\n\nconst uploadRef = shallowRef<UploadContentInstance>()\nconst {\n  abort,\n  submit,\n  clearFiles,\n  uploadFiles,\n  handleStart,\n  handleError,\n  handleRemove,\n  handleSuccess,\n  handleProgress,\n  revokeFileObjectURL,\n} = useHandlers(props, uploadRef)\n\nconst isPictureCard = computed(() => props.listType === 'picture-card')\n\nconst uploadContentProps = computed<UploadContentProps>(() => ({\n  ...props,\n  fileList: uploadFiles.value,\n  onStart: handleStart,\n  onProgress: handleProgress,\n  onSuccess: handleSuccess,\n  onError: handleError,\n  onRemove: handleRemove,\n}))\n\nonBeforeUnmount(() => {\n  uploadFiles.value.forEach(revokeFileObjectURL)\n})\n\nprovide(uploadContextKey, {\n  accept: toRef(props, 'accept'),\n})\n\ndefineExpose({\n  /** @description cancel upload request */\n  abort,\n  /** @description upload the file list manually */\n  submit,\n  /** @description clear the file list  */\n  clearFiles,\n  /** @description select the file manually */\n  handleStart,\n  /** @description remove the file manually */\n  handleRemove,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Upload from './src/upload.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElUpload: SFCWithInstall<typeof Upload> = withInstall(Upload)\nexport default ElUpload\n\nexport * from './src/upload'\nexport * from './src/upload-content'\nexport * from './src/upload-list'\nexport * from './src/upload-dragger'\nexport * from './src/constants'\n", "import { buildProps, definePropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Watermark from './watermark.vue'\n\nexport interface WatermarkFontType {\n  color?: string\n  fontSize?: number | string\n  fontWeight?: 'normal' | 'light' | 'weight' | number\n  fontStyle?: 'none' | 'normal' | 'italic' | 'oblique'\n  fontFamily?: string\n  textAlign?: 'start' | 'end' | 'left' | 'right' | 'center'\n  textBaseline?:\n    | 'top'\n    | 'hanging'\n    | 'middle'\n    | 'alphabetic'\n    | 'ideographic'\n    | 'bottom'\n}\n\nexport const watermarkProps = buildProps({\n  /**\n   * @description The z-index of the appended watermark element\n   */\n  zIndex: {\n    type: Number,\n    default: 9,\n  },\n  /**\n   * @description The rotation angle of the watermark\n   */\n  rotate: {\n    type: Number,\n    default: -22,\n  },\n  /**\n   * @description The width of the watermark\n   */\n  width: Number,\n  /**\n   * @description The height of the watermark\n   */\n  height: Number,\n  /**\n   * @description Image source, it is recommended to export 2x or 3x image, high priority (support base64 format)\n   */\n  image: String,\n  /**\n   * @description Watermark text content\n   */\n  content: {\n    type: definePropType<string | string[]>([String, Array]),\n    default: 'Element Plus',\n  },\n  /**\n   * @description Text style\n   */\n  font: {\n    type: definePropType<WatermarkFontType>(Object),\n  },\n  /**\n   * @description The spacing between watermarks\n   */\n  gap: {\n    type: definePropType<[number, number]>(Array),\n    default: () => [100, 100],\n  },\n  /**\n   * @description The offset of the watermark from the upper left corner of the container. The default is gap/2\n   */\n  offset: {\n    type: definePropType<[number, number]>(Array),\n  },\n} as const)\n\nexport type WatermarkProps = ExtractPropTypes<typeof watermarkProps>\nexport type WatermarkInstance = InstanceType<typeof Watermark>\n", "import type { CSSProperties } from 'vue'\n\n/** converting camel-cased strings to be lowercase and link it with Separato */\nexport function toLowercaseSeparator(key: string) {\n  return key.replace(/([A-Z])/g, '-$1').toLowerCase()\n}\n\nexport function getStyleStr(style: CSSProperties): string {\n  return Object.keys(style)\n    .map(\n      (key) =>\n        `${toLowercaseSeparator(key)}: ${style[key as keyof CSSProperties]};`\n    )\n    .join(' ')\n}\n\n/** Returns the ratio of the device's physical pixel resolution to the css pixel resolution */\nexport function getPixelRatio() {\n  return window.devicePixelRatio || 1\n}\n\n/** Whether to re-render the watermark */\nexport const reRendering = (\n  mutation: MutationRecord,\n  watermarkElement?: HTMLElement\n) => {\n  let flag = false\n  // Whether to delete the watermark node\n  if (mutation.removedNodes.length && watermarkElement) {\n    flag = Array.from(mutation.removedNodes).includes(watermarkElement)\n  }\n  // Whether the watermark dom property value has been modified\n  if (mutation.type === 'attributes' && mutation.target === watermarkElement) {\n    flag = true\n  }\n  return flag\n}\n", "import type { WatermarkProps } from './watermark'\n\nexport const FontGap = 3\n\nfunction prepareCanvas(\n  width: number,\n  height: number,\n  ratio = 1\n): [\n  ctx: CanvasRenderingContext2D,\n  canvas: HTMLCanvasElement,\n  realWidth: number,\n  realHeight: number\n] {\n  const canvas = document.createElement('canvas')\n  const ctx = canvas.getContext('2d')!\n  const realWidth = width * ratio\n  const realHeight = height * ratio\n  canvas.setAttribute('width', `${realWidth}px`)\n  canvas.setAttribute('height', `${realHeight}px`)\n  ctx.save()\n\n  return [ctx, canvas, realWidth, realHeight]\n}\n\n/**\n * Get the clips of text content.\n * This is a lazy hook function since SSR no need this\n */\nexport default function useClips() {\n  // Get single clips\n  function getClips(\n    content: NonNullable<WatermarkProps['content']> | HTMLImageElement,\n    rotate: number,\n    ratio: number,\n    width: number,\n    height: number,\n    font: Required<NonNullable<WatermarkProps['font']>>,\n    gapX: number,\n    gapY: number\n  ): [dataURL: string, finalWidth: number, finalHeight: number] {\n    // ================= Text / Image =================\n    const [ctx, canvas, contentWidth, contentHeight] = prepareCanvas(\n      width,\n      height,\n      ratio\n    )\n\n    if (content instanceof HTMLImageElement) {\n      // Image\n      ctx.drawImage(content, 0, 0, contentWidth, contentHeight)\n    } else {\n      // Text\n      const {\n        color,\n        fontSize,\n        fontStyle,\n        fontWeight,\n        fontFamily,\n        textAlign,\n        textBaseline,\n      } = font\n      const mergedFontSize = Number(fontSize) * ratio\n\n      ctx.font = `${fontStyle} normal ${fontWeight} ${mergedFontSize}px/${height}px ${fontFamily}`\n      ctx.fillStyle = color\n      ctx.textAlign = textAlign\n      ctx.textBaseline = textBaseline\n      const contents = Array.isArray(content) ? content : [content]\n      contents?.forEach((item, index) => {\n        ctx.fillText(\n          item ?? '',\n          contentWidth / 2,\n          index * (mergedFontSize + FontGap * ratio)\n        )\n      })\n    }\n\n    // ==================== Rotate ====================\n    const angle = (Math.PI / 180) * Number(rotate)\n    const maxSize = Math.max(width, height)\n    const [rCtx, rCanvas, realMaxSize] = prepareCanvas(maxSize, maxSize, ratio)\n\n    // Copy from `ctx` and rotate\n    rCtx.translate(realMaxSize / 2, realMaxSize / 2)\n    rCtx.rotate(angle)\n    if (contentWidth > 0 && contentHeight > 0) {\n      rCtx.drawImage(canvas, -contentWidth / 2, -contentHeight / 2)\n    }\n\n    // Get boundary of rotated text\n    function getRotatePos(x: number, y: number) {\n      const targetX = x * Math.cos(angle) - y * Math.sin(angle)\n      const targetY = x * Math.sin(angle) + y * Math.cos(angle)\n      return [targetX, targetY]\n    }\n\n    let left = 0\n    let right = 0\n    let top = 0\n    let bottom = 0\n\n    const halfWidth = contentWidth / 2\n    const halfHeight = contentHeight / 2\n    const points = [\n      [0 - halfWidth, 0 - halfHeight],\n      [0 + halfWidth, 0 - halfHeight],\n      [0 + halfWidth, 0 + halfHeight],\n      [0 - halfWidth, 0 + halfHeight],\n    ]\n    points.forEach(([x, y]) => {\n      const [targetX, targetY] = getRotatePos(x, y)\n      left = Math.min(left, targetX)\n      right = Math.max(right, targetX)\n      top = Math.min(top, targetY)\n      bottom = Math.max(bottom, targetY)\n    })\n\n    const cutLeft = left + realMaxSize / 2\n    const cutTop = top + realMaxSize / 2\n    const cutWidth = right - left\n    const cutHeight = bottom - top\n\n    // ================ Fill Alternate ================\n    const realGapX = gapX * ratio\n    const realGapY = gapY * ratio\n    const filledWidth = (cutWidth + realGapX) * 2\n    const filledHeight = cutHeight + realGapY\n\n    const [fCtx, fCanvas] = prepareCanvas(filledWidth, filledHeight)\n\n    function drawImg(targetX = 0, targetY = 0) {\n      fCtx.drawImage(\n        rCanvas,\n        cutLeft,\n        cutTop,\n        cutWidth,\n        cutHeight,\n        targetX,\n        targetY,\n        cutWidth,\n        cutHeight\n      )\n    }\n    drawImg()\n    drawImg(cutWidth + realGapX, -cutHeight / 2 - realGapY / 2)\n    drawImg(cutWidth + realGapX, +cutHeight / 2 + realGapY / 2)\n\n    return [fCanvas.toDataURL(), filledWidth / ratio, filledHeight / ratio]\n  }\n\n  return getClips\n}\n", "<template>\n  <div ref=\"containerRef\" :style=\"[style]\">\n    <slot />\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  onBeforeUnmount,\n  onMounted,\n  ref,\n  shallowRef,\n  watch,\n} from 'vue'\nimport { useMutationObserver } from '@vueuse/core'\nimport { watermarkProps } from './watermark'\nimport { getPixelRatio, getStyleStr, reRendering } from './utils'\nimport useClips, { FontGap } from './useClips'\nimport type { WatermarkProps } from './watermark'\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElWatermark',\n})\n\nconst style: CSSProperties = {\n  position: 'relative',\n}\n\nconst props = defineProps(watermarkProps)\nconst color = computed(() => props.font?.color ?? 'rgba(0,0,0,.15)')\nconst fontSize = computed(() => props.font?.fontSize ?? 16)\nconst fontWeight = computed(() => props.font?.fontWeight ?? 'normal')\nconst fontStyle = computed(() => props.font?.fontStyle ?? 'normal')\nconst fontFamily = computed(() => props.font?.fontFamily ?? 'sans-serif')\nconst textAlign = computed(() => props.font?.textAlign ?? 'center')\nconst textBaseline = computed(() => props.font?.textBaseline ?? 'hanging')\n\nconst gapX = computed(() => props.gap[0])\nconst gapY = computed(() => props.gap[1])\nconst gapXCenter = computed(() => gapX.value / 2)\nconst gapYCenter = computed(() => gapY.value / 2)\nconst offsetLeft = computed(() => props.offset?.[0] ?? gapXCenter.value)\nconst offsetTop = computed(() => props.offset?.[1] ?? gapYCenter.value)\n\nconst getMarkStyle = () => {\n  const markStyle: CSSProperties = {\n    zIndex: props.zIndex,\n    position: 'absolute',\n    left: 0,\n    top: 0,\n    width: '100%',\n    height: '100%',\n    pointerEvents: 'none',\n    backgroundRepeat: 'repeat',\n  }\n\n  /** Calculate the style of the offset */\n  let positionLeft = offsetLeft.value - gapXCenter.value\n  let positionTop = offsetTop.value - gapYCenter.value\n  if (positionLeft > 0) {\n    markStyle.left = `${positionLeft}px`\n    markStyle.width = `calc(100% - ${positionLeft}px)`\n    positionLeft = 0\n  }\n  if (positionTop > 0) {\n    markStyle.top = `${positionTop}px`\n    markStyle.height = `calc(100% - ${positionTop}px)`\n    positionTop = 0\n  }\n  markStyle.backgroundPosition = `${positionLeft}px ${positionTop}px`\n\n  return markStyle\n}\n\nconst containerRef = shallowRef<HTMLDivElement | null>(null)\nconst watermarkRef = shallowRef<HTMLDivElement>()\nconst stopObservation = ref(false)\n\nconst destroyWatermark = () => {\n  if (watermarkRef.value) {\n    watermarkRef.value.remove()\n    watermarkRef.value = undefined\n  }\n}\nconst appendWatermark = (base64Url: string, markWidth: number) => {\n  if (containerRef.value && watermarkRef.value) {\n    stopObservation.value = true\n    watermarkRef.value.setAttribute(\n      'style',\n      getStyleStr({\n        ...getMarkStyle(),\n        backgroundImage: `url('${base64Url}')`,\n        backgroundSize: `${Math.floor(markWidth)}px`,\n      })\n    )\n    containerRef.value?.append(watermarkRef.value)\n    // Delayed execution\n    setTimeout(() => {\n      stopObservation.value = false\n    })\n  }\n}\n\n/**\n * Get the width and height of the watermark. The default values are as follows\n * Image: [120, 64]; Content: It's calculated by content;\n */\nconst getMarkSize = (ctx: CanvasRenderingContext2D) => {\n  let defaultWidth = 120\n  let defaultHeight = 64\n  const image = props.image\n  const content = props.content\n  const width = props.width\n  const height = props.height\n  if (!image && ctx.measureText) {\n    ctx.font = `${Number(fontSize.value)}px ${fontFamily.value}`\n    const contents = Array.isArray(content) ? content : [content]\n    const sizes = contents.map((item) => {\n      const metrics = ctx.measureText(item!)\n\n      return [\n        metrics.width,\n        // Using `actualBoundingBoxAscent` to be compatible with lower version browsers (eg: Firefox < 116)\n        metrics.fontBoundingBoxAscent !== undefined\n          ? metrics.fontBoundingBoxAscent + metrics.fontBoundingBoxDescent\n          : metrics.actualBoundingBoxAscent + metrics.actualBoundingBoxDescent,\n      ]\n    })\n    defaultWidth = Math.ceil(Math.max(...sizes.map((size) => size[0])))\n    defaultHeight =\n      Math.ceil(Math.max(...sizes.map((size) => size[1]))) * contents.length +\n      (contents.length - 1) * FontGap\n  }\n  return [width ?? defaultWidth, height ?? defaultHeight] as const\n}\n\nconst getClips = useClips()\n\nconst renderWatermark = () => {\n  const canvas = document.createElement('canvas')\n  const ctx = canvas.getContext('2d')\n  const image = props.image\n  const content = props.content\n  const rotate = props.rotate\n\n  if (ctx) {\n    if (!watermarkRef.value) {\n      watermarkRef.value = document.createElement('div')\n    }\n\n    const ratio = getPixelRatio()\n    const [markWidth, markHeight] = getMarkSize(ctx)\n\n    const drawCanvas = (\n      drawContent?: NonNullable<WatermarkProps['content']> | HTMLImageElement\n    ) => {\n      const [textClips, clipWidth] = getClips(\n        drawContent || '',\n        rotate,\n        ratio,\n        markWidth,\n        markHeight,\n        {\n          color: color.value,\n          fontSize: fontSize.value,\n          fontStyle: fontStyle.value,\n          fontWeight: fontWeight.value,\n          fontFamily: fontFamily.value,\n          textAlign: textAlign.value,\n          textBaseline: textBaseline.value,\n        },\n        gapX.value,\n        gapY.value\n      )\n\n      appendWatermark(textClips, clipWidth)\n    }\n\n    if (image) {\n      const img = new Image()\n      img.onload = () => {\n        drawCanvas(img)\n      }\n      img.onerror = () => {\n        drawCanvas(content)\n      }\n      img.crossOrigin = 'anonymous'\n      img.referrerPolicy = 'no-referrer'\n      img.src = image\n    } else {\n      drawCanvas(content)\n    }\n  }\n}\n\nonMounted(() => {\n  renderWatermark()\n})\n\nwatch(\n  () => props,\n  () => {\n    renderWatermark()\n  },\n  {\n    deep: true,\n    flush: 'post',\n  }\n)\n\nonBeforeUnmount(() => {\n  destroyWatermark()\n})\n\nconst onMutate = (mutations: MutationRecord[]) => {\n  if (stopObservation.value) {\n    return\n  }\n  mutations.forEach((mutation) => {\n    if (reRendering(mutation, watermarkRef.value)) {\n      destroyWatermark()\n      renderWatermark()\n    }\n  })\n}\n\nuseMutationObserver(containerRef, onMutate, {\n  attributes: true,\n  subtree: true,\n  childList: true,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Watermark from './src/watermark.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElWatermark: SFCWithInstall<typeof Watermark> =\n  withInstall(Watermark)\nexport default ElWatermark\n\nexport * from './src/watermark'\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type { PosInfo } from './types'\n\nexport const maskProps = buildProps({\n  /**\n   * @description mask's zIndex\n   */\n  zIndex: {\n    type: Number,\n    default: 1001,\n  },\n  /**\n   * @description whether to show the mask\n   */\n  visible: Boolean,\n  /**\n   * @description mask's fill\n   */\n  fill: {\n    type: String,\n    default: 'rgba(0,0,0,0.5)',\n  },\n  /***\n   * @description mask's transparent space position\n   */\n  pos: {\n    type: definePropType<PosInfo | null>(Object),\n  },\n  /**\n   * @description whether the target element can be clickable, when using mask\n   */\n  targetAreaClickable: {\n    type: Boolean,\n    default: true,\n  },\n})\n\nexport type MaskProps = ExtractPropTypes<typeof maskProps>\n", "import {\n  computed,\n  onBeforeUnmount,\n  onMounted,\n  ref,\n  unref,\n  watch,\n  watchEffect,\n} from 'vue'\nimport {\n  arrow,\n  autoUpdate,\n  computePosition,\n  detectOverflow,\n  flip,\n  offset as offsetMiddelware,\n  shift,\n} from '@floating-ui/dom'\nimport {\n  isArray,\n  isClient,\n  isFunction,\n  isString,\n  keysOf,\n} from '@element-plus/utils'\n\nimport type {\n  CSSProperties,\n  Component,\n  InjectionKey,\n  Ref,\n  SetupContext,\n} from 'vue'\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\nimport type { PosInfo, TourGap, TourMask } from './types'\nimport type {\n  ComputePositionReturn,\n  Middleware,\n  Placement,\n  Strategy,\n  VirtualElement,\n} from '@floating-ui/dom'\nimport type { TourStepProps } from './step'\n\nexport const useTarget = (\n  target: Ref<\n    string | HTMLElement | (() => HTMLElement | null) | null | undefined\n  >,\n  open: Ref<boolean>,\n  gap: Ref<TourGap>,\n  mergedMask: Ref<TourMask>,\n  scrollIntoViewOptions: Ref<boolean | ScrollIntoViewOptions>\n) => {\n  const posInfo: Ref<PosInfo | null> = ref(null)\n\n  const getTargetEl = () => {\n    let targetEl: HTMLElement | null | undefined\n    if (isString(target.value)) {\n      targetEl = document.querySelector<HTMLElement>(target.value)\n    } else if (isFunction(target.value)) {\n      targetEl = target.value()\n    } else {\n      targetEl = target.value\n    }\n    return targetEl\n  }\n\n  const updatePosInfo = () => {\n    const targetEl = getTargetEl()\n    if (!targetEl || !open.value) {\n      posInfo.value = null\n      return\n    }\n    if (!isInViewPort(targetEl) && open.value) {\n      targetEl.scrollIntoView(scrollIntoViewOptions.value)\n    }\n    const { left, top, width, height } = targetEl.getBoundingClientRect()\n    posInfo.value = {\n      left,\n      top,\n      width,\n      height,\n      radius: 0,\n    }\n  }\n\n  onMounted(() => {\n    watch(\n      [open, target],\n      () => {\n        updatePosInfo()\n      },\n      {\n        immediate: true,\n      }\n    )\n    window.addEventListener('resize', updatePosInfo)\n  })\n\n  onBeforeUnmount(() => {\n    window.removeEventListener('resize', updatePosInfo)\n  })\n\n  const getGapOffset = (index: number) =>\n    (isArray(gap.value.offset) ? gap.value.offset[index] : gap.value.offset) ??\n    6\n\n  const mergedPosInfo = computed(() => {\n    if (!posInfo.value) return posInfo.value\n\n    const gapOffsetX = getGapOffset(0)\n    const gapOffsetY = getGapOffset(1)\n    const gapRadius = gap.value?.radius || 2\n\n    return {\n      left: posInfo.value.left - gapOffsetX,\n      top: posInfo.value.top - gapOffsetY,\n      width: posInfo.value.width + gapOffsetX * 2,\n      height: posInfo.value.height + gapOffsetY * 2,\n      radius: gapRadius,\n    }\n  })\n\n  const triggerTarget = computed(() => {\n    const targetEl = getTargetEl()\n    if (!mergedMask.value || !targetEl || !window.DOMRect) {\n      return targetEl || undefined\n    }\n\n    return {\n      getBoundingClientRect() {\n        return window.DOMRect.fromRect({\n          width: mergedPosInfo.value?.width || 0,\n          height: mergedPosInfo.value?.height || 0,\n          x: mergedPosInfo.value?.left || 0,\n          y: mergedPosInfo.value?.top || 0,\n        })\n      },\n    }\n  })\n\n  return {\n    mergedPosInfo,\n    triggerTarget,\n  }\n}\n\nexport interface TourContext {\n  currentStep: Ref<TourStepProps | undefined>\n  current: Ref<number>\n  total: Ref<number>\n  showClose: Ref<boolean>\n  closeIcon: Ref<string | Component>\n  mergedType: Ref<'default' | 'primary' | undefined>\n  ns: UseNamespaceReturn\n  slots: SetupContext['slots']\n  updateModelValue(modelValue: boolean): void\n  onClose(): void\n  onFinish(): void\n  onChange(): void\n}\n\nexport const tourKey: InjectionKey<TourContext> = Symbol('ElTour')\n\nfunction isInViewPort(element: HTMLElement) {\n  const viewWidth = window.innerWidth || document.documentElement.clientWidth\n  const viewHeight = window.innerHeight || document.documentElement.clientHeight\n  const { top, right, bottom, left } = element.getBoundingClientRect()\n\n  return top >= 0 && left >= 0 && right <= viewWidth && bottom <= viewHeight\n}\n\nexport const useFloating = (\n  referenceRef: Ref<HTMLElement | VirtualElement | null>,\n  contentRef: Ref<HTMLElement | null>,\n  arrowRef: Ref<HTMLElement | null>,\n  placement: Ref<Placement | undefined>,\n  strategy: Ref<Strategy>,\n  offset: Ref<number>,\n  zIndex: Ref<number>,\n  showArrow: Ref<boolean>\n) => {\n  const x = ref<number>()\n  const y = ref<number>()\n  const middlewareData = ref<ComputePositionReturn['middlewareData']>({})\n\n  const states = {\n    x,\n    y,\n    placement,\n    strategy,\n    middlewareData,\n  } as const\n\n  const middleware = computed(() => {\n    const _middleware: Middleware[] = [\n      offsetMiddelware(unref(offset)),\n      flip(),\n      shift(),\n      overflowMiddleware(),\n    ]\n\n    if (unref(showArrow) && unref(arrowRef)) {\n      _middleware.push(\n        arrow({\n          element: unref(arrowRef)!,\n        })\n      )\n    }\n    return _middleware\n  })\n\n  const update = async () => {\n    if (!isClient) return\n\n    const referenceEl = unref(referenceRef)\n    const contentEl = unref(contentRef)\n    if (!referenceEl || !contentEl) return\n\n    const data = await computePosition(referenceEl, contentEl, {\n      placement: unref(placement),\n      strategy: unref(strategy),\n      middleware: unref(middleware),\n    })\n\n    keysOf(states).forEach((key) => {\n      states[key].value = data[key]\n    })\n  }\n\n  const contentStyle = computed<CSSProperties>(() => {\n    if (!unref(referenceRef)) {\n      return {\n        position: 'fixed',\n        top: '50%',\n        left: '50%',\n        transform: 'translate3d(-50%, -50%, 0)',\n        maxWidth: '100vw',\n        zIndex: unref(zIndex),\n      }\n    }\n\n    const { overflow } = unref(middlewareData)\n\n    return {\n      position: unref(strategy),\n      zIndex: unref(zIndex),\n      top: unref(y) != null ? `${unref(y)}px` : '',\n      left: unref(x) != null ? `${unref(x)}px` : '',\n      maxWidth: overflow?.maxWidth ? `${overflow?.maxWidth}px` : '',\n    }\n  })\n\n  const arrowStyle = computed<CSSProperties>(() => {\n    if (!unref(showArrow)) return {}\n\n    const { arrow } = unref(middlewareData)\n    return {\n      left: arrow?.x != null ? `${arrow?.x}px` : '',\n      top: arrow?.y != null ? `${arrow?.y}px` : '',\n    }\n  })\n\n  let cleanup: any\n  onMounted(() => {\n    const referenceEl = unref(referenceRef)\n    const contentEl = unref(contentRef)\n    if (referenceEl && contentEl) {\n      cleanup = autoUpdate(referenceEl, contentEl, update)\n    }\n\n    watchEffect(() => {\n      update()\n    })\n  })\n\n  onBeforeUnmount(() => {\n    cleanup && cleanup()\n  })\n\n  return {\n    update,\n    contentStyle,\n    arrowStyle,\n  }\n}\n\nconst overflowMiddleware = (): Middleware => {\n  return {\n    name: 'overflow',\n    async fn(state) {\n      const overflow = await detectOverflow(state)\n      let overWidth = 0\n      if (overflow.left > 0) overWidth = overflow.left\n      if (overflow.right > 0) overWidth = overflow.right\n      const floatingWidth = state.rects.floating.width\n      return {\n        data: {\n          maxWidth: floatingWidth - overWidth,\n        },\n      }\n    },\n  }\n}\n", "<template>\n  <div\n    v-if=\"visible\"\n    :class=\"ns.e('mask')\"\n    :style=\"({\n    position: 'fixed',\n    left: 0,\n    right: 0,\n    top: 0,\n    bottom: 0,\n    zIndex,\n    pointerEvents: pos && targetAreaClickable ? 'none' : 'auto',\n  } as any)\"\n    v-bind=\"$attrs\"\n  >\n    <svg\n      :style=\"{\n        width: '100%',\n        height: '100%',\n      }\"\n    >\n      <path :class=\"ns.e('hollow')\" :style=\"pathStyle\" :d=\"path\" />\n    </svg>\n  </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, inject, toRef } from 'vue'\nimport { useLockscreen } from '@element-plus/hooks'\nimport { maskProps } from './mask'\nimport { tourKey } from './helper'\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElTourMask',\n  inheritAttrs: false,\n})\n\nconst props = defineProps(maskProps)\n\nconst { ns } = inject(tourKey)!\nconst radius = computed(() => props.pos?.radius ?? 2)\nconst roundInfo = computed(() => {\n  const v = radius.value\n  const baseInfo = `a${v},${v} 0 0 1`\n  return {\n    topRight: `${baseInfo} ${v},${v}`,\n    bottomRight: `${baseInfo} ${-v},${v}`,\n    bottomLeft: `${baseInfo} ${-v},${-v}`,\n    topLeft: `${baseInfo} ${v},${-v}`,\n  }\n})\n\nconst path = computed(() => {\n  const width = window.innerWidth\n  const height = window.innerHeight\n  const info = roundInfo.value\n  const _path = `M${width},0 L0,0 L0,${height} L${width},${height} L${width},0 Z`\n  const _radius = radius.value\n  return props.pos\n    ? `${_path} M${props.pos.left + _radius},${props.pos.top} h${\n        props.pos.width - _radius * 2\n      } ${info.topRight} v${props.pos.height - _radius * 2} ${\n        info.bottomRight\n      } h${-props.pos.width + _radius * 2} ${info.bottomLeft} v${\n        -props.pos.height + _radius * 2\n      } ${info.topLeft} z`\n    : _path\n})\n\nconst pathStyle = computed<CSSProperties>(() => {\n  return {\n    fill: props.fill,\n    pointerEvents: 'auto',\n    cursor: 'auto',\n  }\n})\n\nuseLockscreen(toRef(props, 'visible'), {\n  ns,\n})\n</script>\n", "import { buildProps, definePropType } from '@element-plus/utils'\nimport type { ExtractPropTypes } from 'vue'\nimport type { Placement, Strategy, VirtualElement } from '@floating-ui/dom'\n\nexport const tourStrategies = ['absolute', 'fixed'] as const\n\nexport const tourPlacements = [\n  'top-start',\n  'top-end',\n  'top',\n  'bottom-start',\n  'bottom-end',\n  'bottom',\n  'left-start',\n  'left-end',\n  'left',\n  'right-start',\n  'right-end',\n  'right',\n] as const\n\nexport const tourContentProps = buildProps({\n  /**\n   * @description position of the guide card relative to the target element\n   */\n  placement: {\n    type: definePropType<Placement>(String),\n    values: tourPlacements,\n    default: 'bottom',\n  },\n  /**\n   * @description the reference dom\n   */\n  reference: {\n    type: definePropType<HTMLElement | VirtualElement | null>(Object),\n    default: null,\n  },\n  /**\n   * @description position strategy of the content\n   */\n  strategy: {\n    type: definePropType<Strategy>(String),\n    values: tourStrategies,\n    default: 'absolute',\n  },\n  /**\n   * @description offset of the arrow\n   */\n  offset: {\n    type: Number,\n    default: 10,\n  },\n  /**\n   * @description @description whether to show the arrow\n   */\n  showArrow: Boolean,\n  /**\n   * @description content's zIndex\n   */\n  zIndex: {\n    type: Number,\n    default: 2001,\n  },\n})\n\nexport type TourContentProps = ExtractPropTypes<typeof tourContentProps>\n\nexport const tourContentEmits = {\n  close: () => true,\n}\nexport type TourContentEmits = typeof tourContentEmits\n", "<template>\n  <div\n    ref=\"contentRef\"\n    :style=\"contentStyle\"\n    :class=\"ns.e('content')\"\n    :data-side=\"side\"\n    tabindex=\"-1\"\n  >\n    <el-focus-trap\n      loop\n      trapped\n      focus-start-el=\"container\"\n      :focus-trap-el=\"contentRef || undefined\"\n      @release-requested=\"onCloseRequested\"\n      @focusout-prevented=\"onFocusoutPrevented\"\n    >\n      <slot />\n    </el-focus-trap>\n    <span\n      v-if=\"showArrow\"\n      ref=\"arrowRef\"\n      :style=\"arrowStyle\"\n      :class=\"ns.e('arrow')\"\n    />\n  </div>\n</template>\n<script setup lang=\"ts\">\nimport { computed, inject, ref, toRef, watch } from 'vue'\nimport ElFocusTrap from '@element-plus/components/focus-trap'\nimport { tourContentEmits, tourContentProps } from './content'\nimport { tourKey, useFloating } from './helper'\n\ndefineOptions({\n  name: 'ElTourContent',\n})\n\nconst props = defineProps(tourContentProps)\nconst emit = defineEmits(tourContentEmits)\n\nconst placement = ref(props.placement)\nconst strategy = ref(props.strategy)\nconst contentRef = ref<HTMLElement | null>(null)\nconst arrowRef = ref<HTMLElement | null>(null)\n\nwatch(\n  () => props.placement,\n  () => {\n    placement.value = props.placement\n  }\n)\n\nconst { contentStyle, arrowStyle } = useFloating(\n  toRef(props, 'reference'),\n  contentRef,\n  arrowRef,\n  placement,\n  strategy,\n  toRef(props, 'offset'),\n  toRef(props, 'zIndex'),\n  toRef(props, 'showArrow')\n)\n\nconst side = computed(() => {\n  return placement.value.split('-')[0]\n})\n\nconst { ns } = inject(tourKey)!\n\nconst onCloseRequested = () => {\n  emit('close')\n}\n\nconst onFocusoutPrevented = (event: CustomEvent) => {\n  if (event.detail.focusReason === 'pointer') {\n    event.preventDefault()\n  }\n}\n</script>\n", "import { defineComponent } from 'vue'\nimport { flattedChildren, isArray } from '@element-plus/utils'\nimport type { FlattenVNodes } from '@element-plus/utils'\nimport type { Component, VNode } from 'vue'\n\nexport default defineComponent({\n  name: 'ElTourSteps',\n  props: {\n    current: {\n      type: Number,\n      default: 0,\n    },\n  },\n  emits: ['update-total'],\n  setup(props, { slots, emit }) {\n    let cacheTotal = 0\n\n    return () => {\n      const children = slots.default?.()!\n      const result: VNode[] = []\n      let total = 0\n\n      function filterSteps(children?: FlattenVNodes) {\n        if (!isArray(children)) return\n        ;(children as VNode[]).forEach((item) => {\n          const name = ((item?.type || {}) as Component)?.name\n\n          if (name === 'ElTourStep') {\n            result.push(item)\n            total += 1\n          }\n        })\n      }\n\n      if (children.length) {\n        filterSteps(flattedChildren(children![0]?.children))\n      }\n\n      if (cacheTotal !== total) {\n        cacheTotal = total\n        emit('update-total', total)\n      }\n\n      if (result.length) {\n        return result[props.current]\n      }\n      return null\n    }\n  },\n})\n", "import {\n  buildProps,\n  definePropType,\n  iconPropType,\n  isBoolean,\n  isNumber,\n} from '@element-plus/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { tourContentProps } from './content'\nimport type { CSSProperties, ExtractPropTypes } from 'vue'\nimport type Tour from './tour.vue'\nimport type { TourGap, TourMask } from './types'\n\nexport const tourProps = buildProps({\n  /**\n   * @description open tour\n   */\n  modelValue: Boolean,\n  /**\n   * @description what is the current step\n   */\n  current: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description whether to show the arrow\n   */\n  showArrow: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether to show a close button\n   */\n  showClose: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description custom close icon\n   */\n  closeIcon: {\n    type: iconPropType,\n  },\n  /**\n   * @description position of the guide card relative to the target element\n   */\n  placement: tourContentProps.placement,\n  /**\n   * @description custom style for content\n   */\n  contentStyle: {\n    type: definePropType<CSSProperties>([Object]),\n  },\n  /**\n   * @description whether to enable masking, change mask style and fill color by pass custom props\n   */\n  mask: {\n    type: definePropType<TourMask>([Boolean, Object]),\n    default: true,\n  },\n  /**\n   * @description transparent gap between mask and target\n   */\n  gap: {\n    type: definePropType<TourGap>(Object),\n    default: () => ({\n      offset: 6,\n      radius: 2,\n    }),\n  },\n  /**\n   * @description tour's zIndex\n   */\n  zIndex: {\n    type: Number,\n  },\n  /**\n   * @description support pass custom scrollIntoView options\n   */\n  scrollIntoViewOptions: {\n    type: definePropType<boolean | ScrollIntoViewOptions>([Boolean, Object]),\n    default: () => ({\n      block: 'center',\n    }),\n  },\n  /**\n   * @description type, affects the background color and text color\n   */\n  type: {\n    type: definePropType<'default' | 'primary'>(String),\n  },\n  /**\n   * @description which element the TourContent appends to\n   */\n  appendTo: {\n    type: definePropType<string | HTMLElement>([String, Object]),\n    default: 'body',\n  },\n  /**\n   * @description whether the Tour can be closed by pressing ESC\n   */\n  closeOnPressEscape: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description whether the target element can be clickable, when using mask\n   */\n  targetAreaClickable: {\n    type: Boolean,\n    default: true,\n  },\n})\n\nexport type TourProps = ExtractPropTypes<typeof tourProps>\nexport type TourInstance = InstanceType<typeof Tour>\n\nexport const tourEmits = {\n  [UPDATE_MODEL_EVENT]: (value: boolean) => isBoolean(value),\n  ['update:current']: (current: number) => isNumber(current),\n  close: (current: number) => isNumber(current),\n  finish: () => true,\n  change: (current: number) => isNumber(current),\n}\nexport type TourEmits = typeof tourEmits\n", "<template>\n  <el-teleport :to=\"appendTo\">\n    <div :class=\"kls\" v-bind=\"$attrs\">\n      <el-tour-mask\n        :visible=\"mergedShowMask\"\n        :fill=\"mergedMaskStyle?.color\"\n        :style=\"mergedMaskStyle?.style\"\n        :pos=\"pos\"\n        :z-index=\"mergedZIndex\"\n        :target-area-clickable=\"targetAreaClickable\"\n      />\n      <el-tour-content\n        v-if=\"modelValue\"\n        :key=\"current\"\n        :reference=\"triggerTarget\"\n        :placement=\"mergedPlacement\"\n        :show-arrow=\"mergedShowArrow\"\n        :z-index=\"mergedZIndex\"\n        :style=\"mergedContentStyle\"\n        @close=\"onEscClose\"\n      >\n        <el-tour-steps :current=\"current\" @update-total=\"onUpdateTotal\">\n          <slot />\n        </el-tour-steps>\n      </el-tour-content>\n    </div>\n  </el-teleport>\n  <!-- just for IDE -->\n  <slot v-if=\"false\" name=\"indicators\" :current=\"current + 1\" :total=\"total\" />\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, provide, ref, toRef, useSlots, watch } from 'vue'\nimport { useVModel } from '@vueuse/core'\nimport { useNamespace, useZIndex } from '@element-plus/hooks'\nimport { isBoolean } from '@element-plus/utils'\nimport ElTeleport from '@element-plus/components/teleport'\nimport ElTourMask from './mask.vue'\nimport ElTourContent from './content.vue'\nimport ElTourSteps from './steps'\nimport { tourEmits, tourProps } from './tour'\nimport { tourKey, useTarget } from './helper'\nimport type { TourStepProps } from './step'\n\ndefineOptions({\n  name: 'ElTour',\n})\n\nconst props = defineProps(tourProps)\nconst emit = defineEmits(tourEmits)\n\nconst ns = useNamespace('tour')\nconst total = ref(0)\nconst currentStep = ref<TourStepProps>()\n\nconst current = useVModel(props, 'current', emit, {\n  passive: true,\n})\n\nconst currentTarget = computed(() => currentStep.value?.target)\n\nconst kls = computed(() => [\n  ns.b(),\n  mergedType.value === 'primary' ? ns.m('primary') : '',\n])\n\nconst mergedPlacement = computed(\n  () => currentStep.value?.placement || props.placement\n)\n\nconst mergedContentStyle = computed(\n  () => currentStep.value?.contentStyle ?? props.contentStyle\n)\n\nconst mergedMask = computed(() => currentStep.value?.mask ?? props.mask)\nconst mergedShowMask = computed(() => !!mergedMask.value && props.modelValue)\nconst mergedMaskStyle = computed(() =>\n  isBoolean(mergedMask.value) ? undefined : mergedMask.value\n)\n\nconst mergedShowArrow = computed(\n  () =>\n    !!currentTarget.value && (currentStep.value?.showArrow ?? props.showArrow)\n)\n\nconst mergedScrollIntoViewOptions = computed(\n  () => currentStep.value?.scrollIntoViewOptions ?? props.scrollIntoViewOptions\n)\nconst mergedType = computed(() => currentStep.value?.type ?? props.type)\n\nconst { nextZIndex } = useZIndex()\nconst nowZIndex = nextZIndex()\nconst mergedZIndex = computed(() => props.zIndex ?? nowZIndex)\n\nconst { mergedPosInfo: pos, triggerTarget } = useTarget(\n  currentTarget,\n  toRef(props, 'modelValue'),\n  toRef(props, 'gap'),\n  mergedMask,\n  mergedScrollIntoViewOptions\n)\n\nwatch(\n  () => props.modelValue,\n  (val) => {\n    if (!val) {\n      current.value = 0\n    }\n  }\n)\n\nconst onEscClose = () => {\n  if (props.closeOnPressEscape) {\n    emit('update:modelValue', false)\n    emit('close', current.value)\n  }\n}\n\nconst onUpdateTotal = (val: number) => {\n  total.value = val\n}\n\nconst slots = useSlots()\n\nprovide(tourKey, {\n  currentStep,\n  current,\n  total,\n  showClose: toRef(props, 'showClose'),\n  closeIcon: toRef(props, 'closeIcon') as any,\n  mergedType: mergedType as any,\n  ns,\n  slots,\n  updateModelValue(modelValue) {\n    emit('update:modelValue', modelValue)\n  },\n  onClose() {\n    emit('close', current.value)\n  },\n  onFinish() {\n    emit('finish')\n  },\n  onChange() {\n    emit('change', current.value)\n  },\n})\n</script>\n", "import { buildProps, definePropType, iconPropType } from '@element-plus/utils'\nimport { tourContentProps } from './content'\nimport type { CSSProperties, ExtractPropTypes } from 'vue'\nimport type { TourBtnProps, TourMask } from './types'\n\nexport const tourStepProps = buildProps({\n  /**\n   * @description get the element the guide card points to. empty makes it show in center of screen\n   */\n  target: {\n    type: definePropType<\n      string | HTMLElement | (() => HTMLElement | null) | null\n    >([String, Object, Function]),\n  },\n  /**\n   * @description the title of the tour content\n   */\n  title: String,\n  /**\n   * @description description\n   */\n  description: String,\n  /**\n   * @description whether to show a close button\n   */\n  showClose: {\n    type: Boolean,\n    default: undefined,\n  },\n  /**\n   * @description custom close icon, default is Close\n   */\n  closeIcon: {\n    type: iconPropType,\n  },\n  /**\n   * @description whether to show the arrow\n   */\n  showArrow: {\n    type: Boolean,\n    default: undefined,\n  },\n  /**\n   * @description position of the guide card relative to the target element\n   */\n  placement: tourContentProps.placement,\n  /**\n   * @description whether to enable masking, change mask style and fill color by pass custom props\n   */\n  mask: {\n    type: definePropType<TourMask>([Boolean, Object]),\n    default: undefined,\n  },\n  /**\n   * @description custom style for content\n   */\n  contentStyle: {\n    type: definePropType<CSSProperties>([Object]),\n  },\n  /**\n   * @description properties of the previous button\n   */\n  prevButtonProps: {\n    type: definePropType<TourBtnProps>(Object),\n  },\n  /**\n   * @description properties of the Next button\n   */\n  nextButtonProps: {\n    type: definePropType<TourBtnProps>(Object),\n  },\n  /**\n   * @description support pass custom scrollIntoView options\n   */\n  scrollIntoViewOptions: {\n    type: definePropType<boolean | ScrollIntoViewOptions>([Boolean, Object]),\n    default: undefined,\n  },\n  /**\n   * @description type, affects the background color and text color\n   */\n  type: {\n    type: definePropType<'default' | 'primary'>(String),\n  },\n})\n\nexport type TourStepProps = ExtractPropTypes<typeof tourStepProps>\n\nexport const tourStepEmits = {\n  close: () => true,\n}\nexport type TourStepEmits = typeof tourStepEmits\n", "<template>\n  <button\n    v-if=\"mergedShowClose\"\n    aria-label=\"Close\"\n    :class=\"ns.e('closebtn')\"\n    type=\"button\"\n    @click=\"onClose\"\n  >\n    <el-icon :class=\"ns.e('close')\">\n      <component :is=\"mergedCloseIcon\" />\n    </el-icon>\n  </button>\n  <header :class=\"[ns.e('header'), { 'show-close': showClose }]\">\n    <slot name=\"header\">\n      <span role=\"heading\" :class=\"ns.e('title')\">\n        {{ title }}\n      </span>\n    </slot>\n  </header>\n  <div :class=\"ns.e('body')\">\n    <slot>\n      <span>{{ description }}</span>\n    </slot>\n  </div>\n  <footer :class=\"ns.e('footer')\">\n    <div :class=\"ns.b('indicators')\">\n      <component\n        :is=\"tourSlots.indicators\"\n        v-if=\"tourSlots.indicators\"\n        :current=\"current\"\n        :total=\"total\"\n      />\n      <template v-else>\n        <span\n          v-for=\"(item, index) in total\"\n          :key=\"item\"\n          :class=\"[ns.b('indicator'), index === current ? 'is-active' : '']\"\n        />\n      </template>\n    </div>\n    <div :class=\"ns.b('buttons')\">\n      <el-button\n        v-if=\"current > 0\"\n        size=\"small\"\n        :type=\"mergedType\"\n        v-bind=\"filterButtonProps(prevButtonProps)\"\n        @click=\"onPrev\"\n      >\n        {{ prevButtonProps?.children ?? t('el.tour.previous') }}\n      </el-button>\n      <el-button\n        v-if=\"current <= total - 1\"\n        size=\"small\"\n        :type=\"mergedType === 'primary' ? 'default' : 'primary'\"\n        v-bind=\"filterButtonProps(nextButtonProps)\"\n        @click=\"onNext\"\n      >\n        {{\n          nextButtonProps?.children ??\n          (current === total - 1 ? t('el.tour.finish') : t('el.tour.next'))\n        }}\n      </el-button>\n    </div>\n  </footer>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, inject, watch } from 'vue'\nimport { omit } from 'lodash-unified'\nimport { ElButton } from '@element-plus/components/button'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { CloseComponents } from '@element-plus/utils'\nimport { useLocale } from '@element-plus/hooks'\nimport { tourStepEmits, tourStepProps } from './step'\nimport { tourKey } from './helper'\n\nimport type { TourBtnProps } from './types'\n\ndefineOptions({\n  name: 'ElTourStep',\n})\n\nconst props = defineProps(tourStepProps)\nconst emit = defineEmits(tourStepEmits)\n\nconst { Close } = CloseComponents\n\nconst { t } = useLocale()\n\nconst {\n  currentStep,\n  current,\n  total,\n  showClose,\n  closeIcon,\n  mergedType,\n  ns,\n  slots: tourSlots,\n  updateModelValue,\n  onClose: tourOnClose,\n  onFinish: tourOnFinish,\n  onChange,\n} = inject(tourKey)!\n\nwatch(\n  props,\n  (val) => {\n    currentStep.value = val\n  },\n  {\n    immediate: true,\n  }\n)\n\nconst mergedShowClose = computed(() => props.showClose ?? showClose.value)\nconst mergedCloseIcon = computed(\n  () => props.closeIcon ?? closeIcon.value ?? Close\n)\n\nconst filterButtonProps = (btnProps?: TourBtnProps) => {\n  if (!btnProps) return\n  return omit(btnProps, ['children', 'onClick'])\n}\n\nconst onPrev = () => {\n  current.value -= 1\n  if (props.prevButtonProps?.onClick) {\n    props.prevButtonProps?.onClick()\n  }\n  onChange()\n}\n\nconst onNext = () => {\n  if (current.value >= total.value - 1) {\n    onFinish()\n  } else {\n    current.value += 1\n  }\n  if (props.nextButtonProps?.onClick) {\n    props.nextButtonProps.onClick()\n  }\n  onChange()\n}\n\nconst onFinish = () => {\n  onClose()\n  tourOnFinish()\n}\n\nconst onClose = () => {\n  updateModelValue(false)\n  tourOnClose()\n  emit('close')\n}\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Tour from './src/tour.vue'\nimport TourStep from './src/step.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElTour: SFCWithInstall<typeof Tour> & {\n  TourStep: typeof TourStep\n} = withInstall(Tour, {\n  TourStep,\n})\nexport const ElTourStep: SFCWithInstall<typeof TourStep> =\n  withNoopInstall(TourStep)\nexport default ElTour\n\nexport * from './src/tour'\nexport * from './src/step'\nexport * from './src/content'\nexport type { TourMask, TourGap, TourBtnProps } from './src/types'\n", "import {\n  buildProps,\n  definePropType,\n  isString,\n  isUndefined,\n} from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Anchor from './anchor.vue'\n\nexport const anchorProps = buildProps({\n  /**\n   * @description scroll container\n   */\n  container: {\n    type: definePropType<string | HTMLElement | Window | null>([\n      String,\n      Object,\n    ]),\n  },\n  /**\n   * @description Set the offset of the anchor scroll\n   */\n  offset: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description The offset of the element starting to trigger the anchor\n   */\n  bound: {\n    type: Number,\n    default: 15,\n  },\n  /**\n   * @description Set the scroll duration of the container when the anchor is clicked, in milliseconds\n   */\n  duration: {\n    type: Number,\n    default: 300,\n  },\n  /**\n   * @description Whether to show the marker\n   */\n  marker: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description Set Anchor type\n   */\n  type: {\n    type: definePropType<'default' | 'underline'>(String),\n    default: 'default',\n  },\n  /**\n   * @description Set Anchor direction\n   */\n  direction: {\n    type: definePropType<'vertical' | 'horizontal'>(String),\n    default: 'vertical',\n  },\n})\n\nexport type AnchorProps = ExtractPropTypes<typeof anchorProps>\nexport type AnchorInstance = InstanceType<typeof Anchor>\n\nexport const anchorEmits = {\n  change: (href: string) => isString(href),\n  click: (e: MouseEvent, href?: string) =>\n    e instanceof MouseEvent && (isString(href) || isUndefined(href)),\n}\nexport type AnchorEmits = typeof anchorEmits\n", "import type { InjectionKey, Ref } from 'vue'\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\n\nexport interface AnchorLinkState {\n  el: HTMLElement\n  href: string\n}\n\nexport interface AnchorContext {\n  ns: UseNamespaceReturn\n  direction: string\n  currentAnchor: Ref<string>\n  addLink(state: AnchorLinkState): void\n  removeLink(href: string): void\n  handleClick(e: MouseEvent, href?: string): void\n}\n\nexport const anchorKey: InjectionKey<AnchorContext> = Symbol('anchor')\n", "<template>\n  <div ref=\"anchorRef\" :class=\"cls\">\n    <div\n      v-if=\"marker\"\n      ref=\"markerRef\"\n      :class=\"ns.e('marker')\"\n      :style=\"markerStyle\"\n    />\n    <div :class=\"ns.e('list')\">\n      <slot />\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, onMounted, provide, ref, watch } from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport { useNamespace } from '@element-plus/hooks'\nimport {\n  animateScrollTo,\n  getElement,\n  getOffsetTopDistance,\n  getScrollElement,\n  getScrollTop,\n  isUndefined,\n  isWindow,\n  throttleByRaf,\n} from '@element-plus/utils'\nimport { anchorEmits, anchorProps } from './anchor'\nimport { anchorKey } from './constants'\n\nimport type { AnchorLinkState } from './constants'\n\ndefineOptions({\n  name: 'ElAnchor',\n})\n\nconst props = defineProps(anchorProps)\nconst emit = defineEmits(anchorEmits)\n\nconst currentAnchor = ref('')\nconst anchorRef = ref<HTMLElement | null>(null)\nconst markerRef = ref<HTMLElement | null>(null)\nconst containerEl = ref<HTMLElement | Window>()\n\nconst links: Record<string, HTMLElement> = {}\nlet isScrolling = false\nlet currentScrollTop = 0\n\nconst ns = useNamespace('anchor')\n\nconst cls = computed(() => [\n  ns.b(),\n  props.type === 'underline' ? ns.m('underline') : '',\n  ns.m(props.direction),\n])\n\nconst addLink = (state: AnchorLinkState) => {\n  links[state.href] = state.el\n}\n\nconst removeLink = (href: string) => {\n  delete links[href]\n}\n\nconst setCurrentAnchor = (href: string) => {\n  const activeHref = currentAnchor.value\n  if (activeHref !== href) {\n    currentAnchor.value = href\n    emit('change', href)\n  }\n}\n\nlet clearAnimate: (() => void) | null = null\n\nconst scrollToAnchor = (href: string) => {\n  if (!containerEl.value) return\n  const target = getElement(href)\n  if (!target) return\n  if (clearAnimate) clearAnimate()\n  isScrolling = true\n  const scrollEle = getScrollElement(target, containerEl.value)\n  const distance = getOffsetTopDistance(target, scrollEle)\n  const max = scrollEle.scrollHeight - scrollEle.clientHeight\n  const to = Math.min(distance - props.offset, max)\n  clearAnimate = animateScrollTo(\n    containerEl.value,\n    currentScrollTop,\n    to,\n    props.duration,\n    () => {\n      // make sure it is executed after throttleByRaf's handleScroll\n      setTimeout(() => {\n        isScrolling = false\n      }, 20)\n    }\n  )\n}\n\nconst scrollTo = (href?: string) => {\n  if (href) {\n    setCurrentAnchor(href)\n    scrollToAnchor(href)\n  }\n}\n\nconst handleClick = (e: MouseEvent, href?: string) => {\n  emit('click', e, href)\n  scrollTo(href)\n}\n\nconst handleScroll = throttleByRaf(() => {\n  if (containerEl.value) {\n    currentScrollTop = getScrollTop(containerEl.value)\n  }\n  const currentHref = getCurrentHref()\n  if (isScrolling || isUndefined(currentHref)) return\n  setCurrentAnchor(currentHref)\n})\n\nconst getCurrentHref = () => {\n  if (!containerEl.value) return\n  const scrollTop = getScrollTop(containerEl.value)\n  const anchorTopList: { top: number; href: string }[] = []\n\n  for (const href of Object.keys(links)) {\n    const target = getElement(href)\n    if (!target) continue\n    const scrollEle = getScrollElement(target, containerEl.value)\n    const distance = getOffsetTopDistance(target, scrollEle)\n    anchorTopList.push({\n      top: distance - props.offset - props.bound,\n      href,\n    })\n  }\n  anchorTopList.sort((prev, next) => prev.top - next.top)\n\n  for (let i = 0; i < anchorTopList.length; i++) {\n    const item = anchorTopList[i]\n    const next = anchorTopList[i + 1]\n\n    if (i === 0 && scrollTop === 0) {\n      return ''\n    }\n    if (item.top <= scrollTop && (!next || next.top > scrollTop)) {\n      return item.href\n    }\n  }\n}\n\nconst getContainer = () => {\n  const el = getElement(props.container)\n  if (!el || isWindow(el)) {\n    containerEl.value = window\n  } else {\n    containerEl.value = el\n  }\n}\n\nuseEventListener(containerEl, 'scroll', handleScroll)\n\nconst markerStyle = computed(() => {\n  if (!anchorRef.value || !markerRef.value || !currentAnchor.value) return {}\n  const currentLinkEl = links[currentAnchor.value]\n  if (!currentLinkEl) return {}\n  const anchorRect = anchorRef.value.getBoundingClientRect()\n  const markerRect = markerRef.value.getBoundingClientRect()\n  const linkRect = currentLinkEl.getBoundingClientRect()\n\n  if (props.direction === 'horizontal') {\n    const left = linkRect.left - anchorRect.left\n    return {\n      left: `${left}px`,\n      width: `${linkRect.width}px`,\n      opacity: 1,\n    }\n  } else {\n    const top =\n      linkRect.top - anchorRect.top + (linkRect.height - markerRect.height) / 2\n    return {\n      top: `${top}px`,\n      opacity: 1,\n    }\n  }\n})\n\nonMounted(() => {\n  getContainer()\n  const hash = decodeURIComponent(window.location.hash)\n  const target = getElement(hash)\n  if (target) {\n    scrollTo(hash)\n  } else {\n    handleScroll()\n  }\n})\n\nwatch(\n  () => props.container,\n  () => {\n    getContainer()\n  }\n)\n\nprovide(anchorKey, {\n  ns,\n  direction: props.direction,\n  currentAnchor,\n  addLink,\n  removeLink,\n  handleClick,\n})\n\ndefineExpose({\n  scrollTo,\n})\n</script>\n", "import { buildProps } from '@element-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\n\nexport const anchorLinkProps = buildProps({\n  /**\n   * @description the text content of the anchor link\n   */\n  title: String,\n  /**\n   * @description The address of the anchor link\n   */\n  href: String,\n})\n\nexport type AnchorLinkProps = ExtractPropTypes<typeof anchorLinkProps>\n", "<template>\n  <div :class=\"ns.e('item')\">\n    <a ref=\"linkRef\" :class=\"cls\" :href=\"href\" @click=\"handleClick\">\n      <slot>{{ title }}</slot>\n    </a>\n    <div\n      v-if=\"$slots['sub-link'] && direction === 'vertical'\"\n      :class=\"ns.e('list')\"\n    >\n      <slot name=\"sub-link\" />\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n  computed,\n  inject,\n  nextTick,\n  onBeforeUnmount,\n  onMounted,\n  ref,\n  watch,\n} from 'vue'\nimport { anchorLinkProps } from './anchor-link'\nimport { anchorKey } from './constants'\n\ndefineOptions({\n  name: 'ElAnchorLink',\n})\n\nconst props = defineProps(anchorLinkProps)\n\nconst linkRef = ref<HTMLElement | null>(null)\n\nconst {\n  ns,\n  direction,\n  currentAnchor,\n  addLink,\n  removeLink,\n  handleClick: contextHandleClick,\n} = inject(anchorKey)!\n\nconst cls = computed(() => [\n  ns.e('link'),\n  ns.is('active', currentAnchor.value === props.href),\n])\n\nconst handleClick = (e: MouseEvent) => {\n  contextHandleClick(e, props.href)\n}\n\nwatch(\n  () => props.href,\n  (val, oldVal) => {\n    nextTick(() => {\n      if (oldVal) removeLink(oldVal)\n      if (val) {\n        addLink({\n          href: val,\n          el: linkRef.value!,\n        })\n      }\n    })\n  }\n)\n\nonMounted(() => {\n  const { href } = props\n  if (href) {\n    addLink({\n      href,\n      el: linkRef.value!,\n    })\n  }\n})\n\nonBeforeUnmount(() => {\n  const { href } = props\n  if (href) {\n    removeLink(href)\n  }\n})\n</script>\n", "import { withInstall, withNoopInstall } from '@element-plus/utils'\nimport Anchor from './src/anchor.vue'\nimport AnchorLink from './src/anchor-link.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElAnchor: SFCWithInstall<typeof Anchor> & {\n  AnchorLink: typeof AnchorLink\n} = withInstall(Anchor, {\n  AnchorLink,\n})\nexport const ElAnchorLink: SFCWithInstall<typeof AnchorLink> =\n  withNoopInstall(AnchorLink)\nexport default ElAnchor\n\nexport * from './src/anchor'\n", "import {\n  buildProps,\n  definePropType,\n  isBoolean,\n  isNumber,\n  isString,\n} from '@element-plus/utils'\nimport { useAriaProps, useSizeProp } from '@element-plus/hooks'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\n\nimport type { Option } from './types'\nimport type { ExtractPropTypes } from 'vue'\nimport type Segmented from './segmented.vue'\n\nexport const segmentedProps = buildProps({\n  /**\n   * @description options of segmented\n   */\n  options: {\n    type: definePropType<Option[]>(Array),\n    default: () => [],\n  },\n  /**\n   * @description binding value\n   */\n  modelValue: {\n    type: [String, Number, Boolean],\n    default: undefined,\n  },\n  /**\n   * @description fit width of parent content\n   */\n  block: Boolean,\n  /**\n   * @description size of component\n   */\n  size: useSizeProp,\n  /**\n   * @description whether segmented is disabled\n   */\n  disabled: Boolean,\n  /**\n   * @description whether to trigger form validation\n   */\n  validateEvent: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description native input id\n   */\n  id: String,\n  /**\n   * @description native `name` attribute\n   */\n  name: String,\n  ...useAriaProps(['ariaLabel']),\n})\n\nexport type SegmentedProps = ExtractPropTypes<typeof segmentedProps>\n\nexport const segmentedEmits = {\n  [UPDATE_MODEL_EVENT]: (val: any) =>\n    isString(val) || isNumber(val) || isBoolean(val),\n  [CHANGE_EVENT]: (val: any) =>\n    isString(val) || isNumber(val) || isBoolean(val),\n}\nexport type SegmentedEmits = typeof segmentedEmits\n\nexport type SegmentedInstance = InstanceType<typeof Segmented>\n", "<template>\n  <div\n    :id=\"inputId\"\n    ref=\"segmentedRef\"\n    :class=\"segmentedCls\"\n    role=\"radiogroup\"\n    :aria-label=\"!isLabeledByFormItem ? ariaLabel || 'segmented' : undefined\"\n    :aria-labelledby=\"isLabeledByFormItem ? formItem!.labelId : undefined\"\n  >\n    <div :class=\"ns.e('group')\">\n      <div :style=\"selectedStyle\" :class=\"selectedCls\" />\n      <label\n        v-for=\"(item, index) in options\"\n        :key=\"index\"\n        :class=\"getItemCls(item)\"\n      >\n        <input\n          :class=\"ns.e('item-input')\"\n          type=\"radio\"\n          :name=\"name\"\n          :disabled=\"getDisabled(item)\"\n          :checked=\"getSelected(item)\"\n          @change=\"handleChange(item)\"\n        />\n        <div :class=\"ns.e('item-label')\">\n          <slot :item=\"item\">{{ getLabel(item) }}</slot>\n        </div>\n      </label>\n    </div>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, reactive, ref, watch } from 'vue'\nimport { useActiveElement, useResizeObserver } from '@vueuse/core'\nimport { useId, useNamespace } from '@element-plus/hooks'\nimport {\n  useFormDisabled,\n  useFormItem,\n  useFormItemInputId,\n  useFormSize,\n} from '@element-plus/components/form'\nimport { debugWarn, isObject } from '@element-plus/utils'\nimport { CHANGE_EVENT, UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { segmentedEmits, segmentedProps } from './segmented'\nimport type { Option } from './types'\n\ndefineOptions({\n  name: 'ElSegmented',\n})\n\nconst props = defineProps(segmentedProps)\nconst emit = defineEmits(segmentedEmits)\n\nconst ns = useNamespace('segmented')\nconst segmentedId = useId()\nconst segmentedSize = useFormSize()\nconst _disabled = useFormDisabled()\nconst { formItem } = useFormItem()\nconst { inputId, isLabeledByFormItem } = useFormItemInputId(props, {\n  formItemContext: formItem,\n})\n\nconst segmentedRef = ref<HTMLElement | null>(null)\nconst activeElement = useActiveElement()\n\nconst state = reactive({\n  isInit: false,\n  width: 0,\n  translateX: 0,\n  focusVisible: false,\n})\n\nconst handleChange = (item: Option) => {\n  const value = getValue(item)\n  emit(UPDATE_MODEL_EVENT, value)\n  emit(CHANGE_EVENT, value)\n}\n\nconst getValue = (item: Option) => {\n  return isObject(item) ? item.value : item\n}\n\nconst getLabel = (item: Option) => {\n  return isObject(item) ? item.label : item\n}\n\nconst getDisabled = (item: Option | undefined) => {\n  return !!(_disabled.value || (isObject(item) ? item.disabled : false))\n}\n\nconst getSelected = (item: Option) => {\n  return props.modelValue === getValue(item)\n}\n\nconst getOption = (value: any) => {\n  return props.options.find((item) => getValue(item) === value)\n}\n\nconst getItemCls = (item: Option) => {\n  return [\n    ns.e('item'),\n    ns.is('selected', getSelected(item)),\n    ns.is('disabled', getDisabled(item)),\n  ]\n}\n\nconst updateSelect = () => {\n  if (!segmentedRef.value) return\n  const selectedItem = segmentedRef.value.querySelector(\n    '.is-selected'\n  ) as HTMLElement\n  const selectedItemInput = segmentedRef.value.querySelector(\n    '.is-selected input'\n  ) as HTMLElement\n  if (!selectedItem || !selectedItemInput) {\n    state.width = 0\n    state.translateX = 0\n    state.focusVisible = false\n    return\n  }\n  const rect = selectedItem.getBoundingClientRect()\n  state.isInit = true\n  state.width = rect.width\n  state.translateX = selectedItem.offsetLeft\n  try {\n    // This will failed in test\n    state.focusVisible = selectedItemInput.matches(':focus-visible')\n  } catch {}\n}\n\nconst segmentedCls = computed(() => [\n  ns.b(),\n  ns.m(segmentedSize.value),\n  ns.is('block', props.block),\n])\n\nconst selectedStyle = computed(() => ({\n  width: `${state.width}px`,\n  transform: `translateX(${state.translateX}px)`,\n  display: state.isInit ? 'block' : 'none',\n}))\n\nconst selectedCls = computed(() => [\n  ns.e('item-selected'),\n  ns.is('disabled', getDisabled(getOption(props.modelValue))),\n  ns.is('focus-visible', state.focusVisible),\n])\n\nconst name = computed(() => {\n  return props.name || segmentedId.value\n})\n\nuseResizeObserver(segmentedRef, updateSelect)\n\nwatch(activeElement, updateSelect)\n\nwatch(\n  () => props.modelValue,\n  () => {\n    updateSelect()\n    if (props.validateEvent) {\n      formItem?.validate?.('change').catch((err) => debugWarn(err))\n    }\n  },\n  {\n    flush: 'post',\n  }\n)\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Segmented from './src/segmented.vue'\n\nexport const ElSegmented = withInstall(Segmented)\nexport default ElSegmented\n\nexport * from './src/segmented'\n", "import { ensureArray, isFirefox } from '@element-plus/utils'\n\nimport type { MentionCtx, MentionOption } from './types'\n\nexport const filterOption = (\n  pattern: string,\n  option: MentionOption\n): boolean => {\n  const lowerCase = pattern.toLowerCase()\n  const label = option.label || option.value\n  return label.toLowerCase().includes(lowerCase)\n}\n\nexport const getMentionCtx = (\n  inputEl: HTMLInputElement | HTMLTextAreaElement,\n  prefix: string | string[],\n  split: string\n) => {\n  const { selectionEnd } = inputEl\n  if (selectionEnd === null) return\n  const inputValue = inputEl.value\n  const prefixArray = ensureArray(prefix)\n  let splitIndex = -1\n  let mentionCtx: MentionCtx | undefined\n  for (let i = selectionEnd - 1; i >= 0; --i) {\n    const char = inputValue[i]\n    if (char === split || char === '\\n' || char === '\\r') {\n      splitIndex = i\n      continue\n    }\n    if (prefixArray.includes(char)) {\n      const end = splitIndex === -1 ? selectionEnd : splitIndex\n      const pattern = inputValue.slice(i + 1, end)\n      mentionCtx = {\n        pattern,\n        start: i + 1,\n        end,\n        prefix: char,\n        prefixIndex: i,\n        splitIndex,\n        selectionEnd,\n      }\n      break\n    }\n  }\n  return mentionCtx\n}\n\n/**\n * fork from textarea-caret-position\n * https://github.com/component/textarea-caret-position\n * The MIT License (MIT)\n * Copyright (c) 2015 Jonathan Ong me@jongleberry.com\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\nexport const getCursorPosition = (\n  element: HTMLInputElement | HTMLTextAreaElement,\n  options = {\n    debug: false,\n    useSelectionEnd: false,\n  }\n) => {\n  const selectionStart =\n    element.selectionStart !== null ? element.selectionStart : 0\n  const selectionEnd = element.selectionEnd !== null ? element.selectionEnd : 0\n  const position = options.useSelectionEnd ? selectionEnd : selectionStart\n  // We'll copy the properties below into the mirror div.\n  // Note that some browsers, such as Firefox, do not concatenate properties\n  // into their shorthand (e.g. padding-top, padding-bottom etc. -> padding),\n  // so we have to list every single property explicitly.\n  const properties: string[] = [\n    'direction', // RTL support\n    'boxSizing',\n    'width', // on Chrome and IE, exclude the scrollbar, so the mirror div wraps exactly as the textarea does\n    'height',\n    'overflowX',\n    'overflowY', // copy the scrollbar for IE\n    'borderTopWidth',\n    'borderRightWidth',\n    'borderBottomWidth',\n    'borderLeftWidth',\n    'borderStyle',\n    'paddingTop',\n    'paddingRight',\n    'paddingBottom',\n    'paddingLeft',\n    // https://developer.mozilla.org/en-US/docs/Web/CSS/font\n    'fontStyle',\n    'fontVariant',\n    'fontWeight',\n    'fontStretch',\n    'fontSize',\n    'fontSizeAdjust',\n    'lineHeight',\n    'fontFamily',\n    'textAlign',\n    'textTransform',\n    'textIndent',\n    'textDecoration', // might not make a difference, but better be safe\n    'letterSpacing',\n    'wordSpacing',\n    'tabSize',\n    'MozTabSize',\n  ]\n\n  if (options.debug) {\n    const el = document.querySelector(\n      '#input-textarea-caret-position-mirror-div'\n    )\n    if (el?.parentNode) el.parentNode.removeChild(el)\n  }\n\n  // The mirror div will replicate the textareas style\n  const div = document.createElement('div')\n  div.id = 'input-textarea-caret-position-mirror-div'\n  document.body.appendChild(div)\n\n  const style = div.style\n  const computed = window.getComputedStyle(element)\n\n  const isInput = element.nodeName === 'INPUT'\n\n  // Default textarea styles\n  style.whiteSpace = isInput ? 'nowrap' : 'pre-wrap'\n  if (!isInput) style.wordWrap = 'break-word' // only for textarea-s\n\n  // Position off-screen\n  style.position = 'absolute' // required to return coordinates properly\n  if (!options.debug) style.visibility = 'hidden' // not 'display: none' because we want rendering\n\n  // Transfer the element's properties to the div\n  properties.forEach((prop) => {\n    if (isInput && prop === 'lineHeight') {\n      // Special case for <input>s because text is rendered centered and line height may be != height\n      if (computed.boxSizing === 'border-box') {\n        const height = Number.parseInt(computed.height as string)\n        const outerHeight =\n          Number.parseInt(computed.paddingTop as string) +\n          Number.parseInt(computed.paddingBottom as string) +\n          Number.parseInt(computed.borderTopWidth as string) +\n          Number.parseInt(computed.borderBottomWidth as string)\n        const targetHeight =\n          outerHeight + Number.parseInt(computed.lineHeight as string)\n        if (height > targetHeight) {\n          style.lineHeight = `${height - outerHeight}px`\n        } else if (height === targetHeight) {\n          style.lineHeight = computed.lineHeight\n        } else {\n          style.lineHeight = '0'\n        }\n      } else {\n        style.lineHeight = computed.height\n      }\n    } else {\n      style[prop as any] = computed[prop as any]\n    }\n  })\n\n  if (isFirefox()) {\n    // Firefox lies about the overflow property for textareas: https://bugzilla.mozilla.org/show_bug.cgi?id=984275\n    if (element.scrollHeight > Number.parseInt(computed.height as string)) {\n      style.overflowY = 'scroll'\n    }\n  } else {\n    style.overflow = 'hidden' // for Chrome to not render a scrollbar; IE keeps overflowY = 'scroll'\n  }\n\n  div.textContent = element.value.slice(0, Math.max(0, position))\n  // The second special handling for input type=\"text\" vs textarea:\n  // spaces need to be replaced with non-breaking spaces - http://stackoverflow.com/a/13402035/1269037\n  if (isInput && div.textContent) {\n    div.textContent = div.textContent.replace(/\\s/g, '\\u00A0')\n  }\n\n  const span = document.createElement('span')\n  // Wrapping must be replicated *exactly*, including when a long word gets\n  // onto the next line, with whitespace at the end of the line before (#7).\n  // The  *only* reliable way to do that is to copy the *entire* rest of the\n  // textareas content into the <span> created at the caret position.\n  // For inputs, just '.' would be enough, but no need to bother.\n  span.textContent = element.value.slice(Math.max(0, position)) || '.' // || because a completely empty faux span doesn't render at all\n  span.style.position = 'relative'\n  span.style.left = `${-element.scrollLeft}px`\n  span.style.top = `${-element.scrollTop}px`\n  div.appendChild(span)\n\n  const relativePosition = {\n    top: span.offsetTop + Number.parseInt(computed.borderTopWidth as string),\n    left: span.offsetLeft + Number.parseInt(computed.borderLeftWidth as string),\n    // We don't use line-height since it may be too large for position. Eg. 34px\n    // for input\n    height: Number.parseInt(computed.fontSize as string) * 1.5,\n  }\n\n  if (options.debug) {\n    span.style.backgroundColor = '#aaa'\n  } else {\n    document.body.removeChild(div)\n  }\n\n  if (relativePosition.left >= element.clientWidth) {\n    relativePosition.left = element.clientWidth\n  }\n  return relativePosition\n}\n", "import {\n  buildProps,\n  definePropType,\n  isFunction,\n  isString,\n} from '@element-plus/utils'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { inputProps } from '@element-plus/components/input'\nimport { filterOption } from './helper'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type Mention from './mention.vue'\nimport type { MentionOption } from './types'\nimport type { Options } from '@element-plus/components/popper'\n\nexport const mentionProps = buildProps({\n  ...inputProps,\n  /**\n   * @description mention options list\n   */\n  options: {\n    type: definePropType<MentionOption[]>(Array),\n    default: () => [],\n  },\n  /**\n   * @description prefix character to trigger mentions. The string length must be exactly 1.\n   */\n  prefix: {\n    type: definePropType<string | string[]>([String, Array]),\n    default: '@',\n    validator: (val: string | string[]) => {\n      if (isString(val)) return val.length === 1\n      return val.every((v) => isString(v) && v.length === 1)\n    },\n  },\n  /**\n   * @description character to split mentions. The string length must be exactly 1.\n   */\n  split: {\n    type: String,\n    default: ' ',\n    validator: (val: string) => val.length === 1,\n  },\n  /**\n   * @description customize filter option logic.\n   */\n  filterOption: {\n    type: definePropType<false | typeof filterOption>([Boolean, Function]),\n    default: () => filterOption,\n    validator: (val) => {\n      if (val === false) return true\n      return isFunction(val)\n    },\n  },\n  /**\n   * @description set popup placement\n   */\n  placement: {\n    type: definePropType<'bottom' | 'top'>(String),\n    default: 'bottom',\n  },\n  /**\n   * @description whether the dropdown panel has an arrow\n   */\n  showArrow: Boolean,\n  /**\n   * @description offset of the dropdown panel\n   */\n  offset: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description when backspace is pressed to delete, whether the mention content is deleted as a whole\n   */\n  whole: Boolean,\n  /**\n   * @description when backspace is pressed to delete, check if the mention is a whole\n   */\n  checkIsWhole: {\n    type: definePropType<(pattern: string, prefix: string) => boolean>(\n      Function\n    ),\n  },\n  /**\n   * @description input value\n   */\n  modelValue: String,\n  /**\n   * @description whether the dropdown panel of mentions is in a loading state.\n   */\n  loading: Boolean,\n  /**\n   * @description custom class name for dropdown panel\n   */\n  popperClass: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n   */\n  popperOptions: {\n    type: definePropType<Partial<Options>>(Object),\n    default: () => ({} as Partial<Options>),\n  },\n})\n\nexport const mentionEmits = {\n  [UPDATE_MODEL_EVENT]: (value: string) => isString(value),\n  search: (pattern: string, prefix: string) =>\n    isString(pattern) && isString(prefix),\n  select: (option: MentionOption, prefix: string) =>\n    isString(option.value) && isString(prefix),\n  focus: (evt: FocusEvent) => evt instanceof FocusEvent,\n  blur: (evt: FocusEvent) => evt instanceof FocusEvent,\n}\n\nexport type MentionEmits = typeof mentionEmits\nexport type MentionProps = ExtractPropTypes<typeof mentionProps>\nexport type MentionInstance = InstanceType<typeof Mention>\n\nexport type { MentionOption } from './types'\n", "import { buildProps, definePropType, isString } from '@element-plus/utils'\n\nimport type { MentionOption } from './types'\n\nexport const mentionDropdownProps = buildProps({\n  options: {\n    type: definePropType<MentionOption[]>(Array),\n    default: () => [],\n  },\n  loading: Boolean,\n  disabled: Boolean,\n  contentId: String,\n  ariaLabel: String,\n})\n\nexport const mentionDropdownEmits = {\n  select: (option: MentionOption) => isString(option.value),\n}\n", "<template>\n  <div ref=\"dropdownRef\" :class=\"ns.b('dropdown')\">\n    <div v-if=\"$slots.header\" :class=\"ns.be('dropdown', 'header')\">\n      <slot name=\"header\" />\n    </div>\n    <el-scrollbar\n      v-show=\"options.length > 0 && !loading\"\n      :id=\"contentId\"\n      ref=\"scrollbarRef\"\n      tag=\"ul\"\n      :wrap-class=\"ns.be('dropdown', 'wrap')\"\n      :view-class=\"ns.be('dropdown', 'list')\"\n      role=\"listbox\"\n      :aria-label=\"ariaLabel\"\n      aria-orientation=\"vertical\"\n    >\n      <li\n        v-for=\"(item, index) in options\"\n        :id=\"`${contentId}-${index}`\"\n        ref=\"optionRefs\"\n        :key=\"item.value\"\n        :class=\"optionkls(item, index)\"\n        role=\"option\"\n        :aria-disabled=\"item.disabled || disabled || undefined\"\n        :aria-selected=\"hoveringIndex === index\"\n        @mouseenter=\"handleMouseEnter(index)\"\n        @click.stop=\"handleSelect(item)\"\n      >\n        <slot name=\"label\" :item=\"item\" :index=\"index\">\n          <span>{{ item.label ?? item.value }}</span>\n        </slot>\n      </li>\n    </el-scrollbar>\n    <div v-if=\"loading\" :class=\"ns.be('dropdown', 'loading')\">\n      <slot name=\"loading\"> {{ t('el.mention.loading') }} </slot>\n    </div>\n    <div v-if=\"$slots.footer\" :class=\"ns.be('dropdown', 'footer')\">\n      <slot name=\"footer\" />\n    </div>\n  </div>\n</template>\n<script setup lang=\"ts\">\nimport { computed, nextTick, ref, watch } from 'vue'\nimport { useLocale, useNamespace } from '@element-plus/hooks'\nimport { scrollIntoView } from '@element-plus/utils'\nimport ElScrollbar from '@element-plus/components/scrollbar'\nimport { mentionDropdownEmits, mentionDropdownProps } from './mention-dropdown'\n\nimport type { MentionOption } from './types'\n\ndefineOptions({\n  name: 'ElMentionDropdown',\n})\n\nconst props = defineProps(mentionDropdownProps)\nconst emit = defineEmits(mentionDropdownEmits)\n\nconst ns = useNamespace('mention')\nconst { t } = useLocale()\nconst hoveringIndex = ref(-1)\n\nconst scrollbarRef = ref<InstanceType<typeof ElScrollbar>>()\nconst optionRefs = ref<HTMLElement[]>()\nconst dropdownRef = ref<HTMLElement>()\n\nconst optionkls = (item: MentionOption, index: number) => [\n  ns.be('dropdown', 'item'),\n  ns.is('hovering', hoveringIndex.value === index),\n  ns.is('disabled', item.disabled || props.disabled),\n]\n\nconst handleSelect = (item: MentionOption) => {\n  if (item.disabled || props.disabled) return\n  emit('select', item)\n}\n\nconst handleMouseEnter = (index: number) => {\n  hoveringIndex.value = index\n}\n\nconst filteredAllDisabled = computed(\n  () => props.disabled || props.options.every((item) => item.disabled)\n)\n\nconst hoverOption = computed(() => props.options[hoveringIndex.value])\n\nconst selectHoverOption = () => {\n  if (!hoverOption.value) return\n  emit('select', hoverOption.value)\n}\n\nconst navigateOptions = (direction: 'next' | 'prev') => {\n  const { options } = props\n  if (options.length === 0 || filteredAllDisabled.value) return\n\n  if (direction === 'next') {\n    hoveringIndex.value++\n    if (hoveringIndex.value === options.length) {\n      hoveringIndex.value = 0\n    }\n  } else if (direction === 'prev') {\n    hoveringIndex.value--\n    if (hoveringIndex.value < 0) {\n      hoveringIndex.value = options.length - 1\n    }\n  }\n  const option = options[hoveringIndex.value]\n  if (option.disabled) {\n    navigateOptions(direction)\n    return\n  }\n  nextTick(() => scrollToOption(option))\n}\n\nconst scrollToOption = (option: MentionOption) => {\n  const { options } = props\n\n  const index = options.findIndex((item) => item.value === option.value)\n  const target = optionRefs.value?.[index]\n\n  if (target) {\n    const menu = dropdownRef.value?.querySelector?.(\n      `.${ns.be('dropdown', 'wrap')}`\n    )\n    if (menu) {\n      scrollIntoView(menu as HTMLElement, target)\n    }\n  }\n  scrollbarRef.value?.handleScroll()\n}\n\nconst resetHoveringIndex = () => {\n  if (filteredAllDisabled.value || props.options.length === 0) {\n    hoveringIndex.value = -1\n  } else {\n    hoveringIndex.value = 0\n  }\n}\n\nwatch(() => props.options, resetHoveringIndex, {\n  immediate: true,\n})\n\ndefineExpose({\n  hoveringIndex,\n  navigateOptions,\n  selectHoverOption,\n  hoverOption,\n})\n</script>\n", "<template>\n  <div ref=\"wrapperRef\" :class=\"ns.b()\">\n    <el-input\n      v-bind=\"mergeProps(passInputProps, $attrs)\"\n      ref=\"elInputRef\"\n      :model-value=\"modelValue\"\n      :disabled=\"disabled\"\n      :role=\"dropdownVisible ? 'combobox' : undefined\"\n      :aria-activedescendant=\"dropdownVisible ? hoveringId || '' : undefined\"\n      :aria-controls=\"dropdownVisible ? contentId : undefined\"\n      :aria-expanded=\"dropdownVisible || undefined\"\n      :aria-label=\"ariaLabel\"\n      :aria-autocomplete=\"dropdownVisible ? 'none' : undefined\"\n      :aria-haspopup=\"dropdownVisible ? 'listbox' : undefined\"\n      @input=\"handleInputChange\"\n      @keydown=\"handleInputKeyDown\"\n      @mousedown=\"handleInputMouseDown\"\n    >\n      <template v-for=\"(_, name) in $slots\" #[name]=\"slotProps\">\n        <slot :name=\"name\" v-bind=\"slotProps\" />\n      </template>\n    </el-input>\n    <el-tooltip\n      ref=\"tooltipRef\"\n      :visible=\"dropdownVisible\"\n      :popper-class=\"[ns.e('popper'), popperClass]\"\n      :popper-options=\"popperOptions\"\n      :placement=\"computedPlacement\"\n      :fallback-placements=\"computedFallbackPlacements\"\n      effect=\"light\"\n      pure\n      :offset=\"offset\"\n      :show-arrow=\"showArrow\"\n    >\n      <template #default>\n        <div :style=\"cursorStyle\" />\n      </template>\n      <template #content>\n        <el-mention-dropdown\n          ref=\"dropdownRef\"\n          :options=\"filteredOptions\"\n          :disabled=\"disabled\"\n          :loading=\"loading\"\n          :content-id=\"contentId\"\n          :aria-label=\"ariaLabel\"\n          @select=\"handleSelect\"\n          @click.stop=\"elInputRef?.focus\"\n        >\n          <template v-for=\"(_, name) in $slots\" #[name]=\"slotProps\">\n            <slot :name=\"name\" v-bind=\"slotProps\" />\n          </template>\n        </el-mention-dropdown>\n      </template>\n    </el-tooltip>\n  </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, mergeProps, nextTick, ref } from 'vue'\nimport { pick } from 'lodash-unified'\nimport { useFocusController, useId, useNamespace } from '@element-plus/hooks'\nimport ElInput, { inputProps } from '@element-plus/components/input'\nimport ElTooltip from '@element-plus/components/tooltip'\nimport { UPDATE_MODEL_EVENT } from '@element-plus/constants'\nimport { useFormDisabled } from '@element-plus/components/form'\nimport { isFunction } from '@element-plus/utils'\nimport { mentionEmits, mentionProps } from './mention'\nimport { getCursorPosition, getMentionCtx } from './helper'\nimport ElMentionDropdown from './mention-dropdown.vue'\n\nimport type { Placement } from '@popperjs/core'\nimport type { CSSProperties } from 'vue'\nimport type { InputInstance } from '@element-plus/components/input'\nimport type { TooltipInstance } from '@element-plus/components/tooltip'\nimport type { MentionCtx, MentionOption } from './types'\n\ndefineOptions({\n  name: 'ElMention',\n})\n\nconst props = defineProps(mentionProps)\nconst emit = defineEmits(mentionEmits)\n\nconst passInputProps = computed(() => pick(props, Object.keys(inputProps)))\n\nconst ns = useNamespace('mention')\nconst disabled = useFormDisabled()\nconst contentId = useId()\n\nconst elInputRef = ref<InputInstance>()\nconst tooltipRef = ref<TooltipInstance>()\nconst dropdownRef = ref<InstanceType<typeof ElMentionDropdown>>()\n\nconst visible = ref(false)\nconst cursorStyle = ref<CSSProperties>()\nconst mentionCtx = ref<MentionCtx>()\n\nconst computedPlacement = computed<Placement>(() =>\n  props.showArrow ? props.placement : `${props.placement}-start`\n)\n\nconst computedFallbackPlacements = computed<Placement[]>(() =>\n  props.showArrow ? ['bottom', 'top'] : ['bottom-start', 'top-start']\n)\n\nconst filteredOptions = computed(() => {\n  const { filterOption, options } = props\n  if (!mentionCtx.value || !filterOption) return options\n  return options.filter((option) =>\n    filterOption(mentionCtx.value!.pattern, option)\n  )\n})\n\nconst dropdownVisible = computed(() => {\n  return visible.value && (!!filteredOptions.value.length || props.loading)\n})\n\nconst hoveringId = computed(() => {\n  return `${contentId.value}-${dropdownRef.value?.hoveringIndex}`\n})\n\nconst handleInputChange = (value: string) => {\n  emit('update:modelValue', value)\n  syncAfterCursorMove()\n}\n\nconst handleInputKeyDown = (e: KeyboardEvent | Event) => {\n  if (!('key' in e)) return\n  if (elInputRef.value?.isComposing) return\n  if (['ArrowLeft', 'ArrowRight'].includes(e.key)) {\n    syncAfterCursorMove()\n  } else if (['ArrowUp', 'ArrowDown'].includes(e.key)) {\n    if (!visible.value) return\n    e.preventDefault()\n    const direction = e.key === 'ArrowUp' ? 'prev' : 'next'\n    dropdownRef.value?.navigateOptions(direction)\n  } else if (['Enter'].includes(e.key)) {\n    if (!visible.value) return\n    e.preventDefault()\n    if (dropdownRef.value?.hoverOption) {\n      dropdownRef.value?.selectHoverOption()\n    } else {\n      visible.value = false\n    }\n  } else if (['Escape'].includes(e.key)) {\n    if (!visible.value) return\n    e.preventDefault()\n    visible.value = false\n  } else if (['Backspace'].includes(e.key)) {\n    if (props.whole && mentionCtx.value) {\n      const { splitIndex, selectionEnd, pattern, prefixIndex, prefix } =\n        mentionCtx.value\n      const inputEl = getInputEl()\n      if (!inputEl) return\n      const inputValue = inputEl.value\n      const matchOption = props.options.find((item) => item.value === pattern)\n      const isWhole = isFunction(props.checkIsWhole)\n        ? props.checkIsWhole(pattern, prefix)\n        : matchOption\n      if (isWhole && splitIndex !== -1 && splitIndex + 1 === selectionEnd) {\n        e.preventDefault()\n        const newValue =\n          inputValue.slice(0, prefixIndex) + inputValue.slice(splitIndex + 1)\n        emit(UPDATE_MODEL_EVENT, newValue)\n\n        const newSelectionEnd = prefixIndex\n        nextTick(() => {\n          // input value is updated\n          inputEl.selectionStart = newSelectionEnd\n          inputEl.selectionEnd = newSelectionEnd\n          syncDropdownVisible()\n        })\n      }\n    }\n  }\n}\n\nconst { wrapperRef } = useFocusController(elInputRef, {\n  beforeFocus() {\n    return disabled.value\n  },\n  afterFocus() {\n    syncAfterCursorMove()\n  },\n  beforeBlur(event) {\n    return tooltipRef.value?.isFocusInsideContent(event)\n  },\n  afterBlur() {\n    visible.value = false\n  },\n})\n\nconst handleInputMouseDown = () => {\n  syncAfterCursorMove()\n}\n\nconst handleSelect = (item: MentionOption) => {\n  if (!mentionCtx.value) return\n  const inputEl = getInputEl()\n  if (!inputEl) return\n  const inputValue = inputEl.value\n  const { split } = props\n\n  const newEndPart = inputValue.slice(mentionCtx.value.end)\n  const alreadySeparated = newEndPart.startsWith(split)\n  const newMiddlePart = `${item.value}${alreadySeparated ? '' : split}`\n\n  const newValue =\n    inputValue.slice(0, mentionCtx.value.start) + newMiddlePart + newEndPart\n\n  emit(UPDATE_MODEL_EVENT, newValue)\n  emit('select', item, mentionCtx.value.prefix)\n\n  const newSelectionEnd =\n    mentionCtx.value.start + newMiddlePart.length + (alreadySeparated ? 1 : 0)\n\n  nextTick(() => {\n    // input value is updated\n    inputEl.selectionStart = newSelectionEnd\n    inputEl.selectionEnd = newSelectionEnd\n    inputEl.focus()\n    syncDropdownVisible()\n  })\n}\n\nconst getInputEl = () =>\n  props.type === 'textarea'\n    ? elInputRef.value?.textarea\n    : elInputRef.value?.input\n\nconst syncAfterCursorMove = () => {\n  // can't use nextTick(), get cursor position will be wrong\n  setTimeout(() => {\n    syncCursor()\n    syncDropdownVisible()\n    nextTick(() => tooltipRef.value?.updatePopper())\n  }, 0)\n}\n\nconst syncCursor = () => {\n  const inputEl = getInputEl()\n  if (!inputEl) return\n\n  const caretPosition = getCursorPosition(inputEl)\n  const inputRect = inputEl.getBoundingClientRect()\n  const elInputRect = elInputRef.value!.$el.getBoundingClientRect()\n\n  cursorStyle.value = {\n    position: 'absolute',\n    width: 0,\n    height: `${caretPosition.height}px`,\n    left: `${caretPosition.left + inputRect.left - elInputRect.left}px`,\n    top: `${caretPosition.top + inputRect.top - elInputRect.top}px`,\n  }\n}\n\nconst syncDropdownVisible = () => {\n  const inputEl = getInputEl()\n  if (document.activeElement !== inputEl) {\n    visible.value = false\n    return\n  }\n  const { prefix, split } = props\n  mentionCtx.value = getMentionCtx(inputEl, prefix, split)\n  if (mentionCtx.value && mentionCtx.value.splitIndex === -1) {\n    visible.value = true\n    emit('search', mentionCtx.value.pattern, mentionCtx.value.prefix)\n    return\n  }\n  visible.value = false\n}\n\ndefineExpose({\n  input: elInputRef,\n  tooltip: tooltipRef,\n})\n</script>\n", "import { withInstall } from '@element-plus/utils'\nimport Mention from './src/mention.vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nexport const ElMention: SFCWithInstall<typeof Mention> = withInstall(Mention)\nexport default ElMention\n\nexport * from './src/mention'\n", "import { ElAffix } from '@element-plus/components/affix'\nimport { ElAlert } from '@element-plus/components/alert'\nimport { ElAutocomplete } from '@element-plus/components/autocomplete'\nimport { ElAvatar } from '@element-plus/components/avatar'\nimport { ElBacktop } from '@element-plus/components/backtop'\nimport { ElBadge } from '@element-plus/components/badge'\nimport {\n  ElBreadcrumb,\n  ElBreadcrumbItem,\n} from '@element-plus/components/breadcrumb'\nimport { ElButton, ElButtonGroup } from '@element-plus/components/button'\nimport { ElCalendar } from '@element-plus/components/calendar'\nimport { ElCard } from '@element-plus/components/card'\nimport { ElCarousel, ElCarouselItem } from '@element-plus/components/carousel'\nimport { ElCascader } from '@element-plus/components/cascader'\nimport { ElCascaderPanel } from '@element-plus/components/cascader-panel'\nimport { ElCheckTag } from '@element-plus/components/check-tag'\nimport {\n  ElCheckbox,\n  ElCheckboxButton,\n  ElCheckboxGroup,\n} from '@element-plus/components/checkbox'\nimport { ElCol } from '@element-plus/components/col'\nimport { ElCollapse, ElCollapseItem } from '@element-plus/components/collapse'\nimport { ElCollapseTransition } from '@element-plus/components/collapse-transition'\nimport { ElColorPicker } from '@element-plus/components/color-picker'\nimport { ElConfigProvider } from '@element-plus/components/config-provider'\nimport {\n  ElAside,\n  ElContainer,\n  ElFooter,\n  ElHeader,\n  ElMain,\n} from '@element-plus/components/container'\nimport { ElDatePicker } from '@element-plus/components/date-picker'\nimport {\n  ElDescriptions,\n  ElDescriptionsItem,\n} from '@element-plus/components/descriptions'\nimport { ElDialog } from '@element-plus/components/dialog'\nimport { ElDivider } from '@element-plus/components/divider'\nimport { ElDrawer } from '@element-plus/components/drawer'\nimport {\n  ElDropdown,\n  ElDropdownItem,\n  ElDropdownMenu,\n} from '@element-plus/components/dropdown'\nimport { ElEmpty } from '@element-plus/components/empty'\nimport { ElForm, ElFormItem } from '@element-plus/components/form'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { ElImage } from '@element-plus/components/image'\nimport { ElImageViewer } from '@element-plus/components/image-viewer'\nimport { ElInput } from '@element-plus/components/input'\nimport { ElInputNumber } from '@element-plus/components/input-number'\nimport { ElLink } from '@element-plus/components/link'\nimport {\n  ElMenu,\n  ElMenuItem,\n  ElMenuItemGroup,\n  ElSubMenu,\n} from '@element-plus/components/menu'\nimport { ElPageHeader } from '@element-plus/components/page-header'\nimport { ElPagination } from '@element-plus/components/pagination'\nimport { ElPopconfirm } from '@element-plus/components/popconfirm'\nimport { ElPopover } from '@element-plus/components/popover'\nimport { ElPopper } from '@element-plus/components/popper'\nimport { ElProgress } from '@element-plus/components/progress'\nimport {\n  ElRadio,\n  ElRadioButton,\n  ElRadioGroup,\n} from '@element-plus/components/radio'\nimport { ElRate } from '@element-plus/components/rate'\nimport { ElResult } from '@element-plus/components/result'\nimport { ElRow } from '@element-plus/components/row'\nimport { ElScrollbar } from '@element-plus/components/scrollbar'\nimport {\n  ElOption,\n  ElOptionGroup,\n  ElSelect,\n} from '@element-plus/components/select'\nimport { ElSelectV2 } from '@element-plus/components/select-v2'\nimport { ElSkeleton, ElSkeletonItem } from '@element-plus/components/skeleton'\nimport { ElSlider } from '@element-plus/components/slider'\nimport { ElSpace } from '@element-plus/components/space'\nimport { ElStatistic } from '@element-plus/components/statistic'\nimport { ElCountdown } from '@element-plus/components/countdown'\nimport { ElStep, ElSteps } from '@element-plus/components/steps'\nimport { ElSwitch } from '@element-plus/components/switch'\nimport { ElTable, ElTableColumn } from '@element-plus/components/table'\nimport { ElAutoResizer, ElTableV2 } from '@element-plus/components/table-v2'\nimport { ElTabPane, ElTabs } from '@element-plus/components/tabs'\nimport { ElTag } from '@element-plus/components/tag'\nimport { ElText } from '@element-plus/components/text'\nimport { ElTimePicker } from '@element-plus/components/time-picker'\nimport { ElTimeSelect } from '@element-plus/components/time-select'\nimport { ElTimeline, ElTimelineItem } from '@element-plus/components/timeline'\nimport { ElTooltip } from '@element-plus/components/tooltip'\nimport { ElTooltipV2 } from '@element-plus/components/tooltip-v2'\nimport { ElTransfer } from '@element-plus/components/transfer'\nimport { ElTree } from '@element-plus/components/tree'\nimport { ElTreeSelect } from '@element-plus/components/tree-select'\nimport { ElTreeV2 } from '@element-plus/components/tree-v2'\nimport { ElUpload } from '@element-plus/components/upload'\nimport { ElWatermark } from '@element-plus/components/watermark'\nimport { ElTour, ElTourStep } from '@element-plus/components/tour'\nimport { ElAnchor, ElAnchorLink } from '@element-plus/components/anchor'\nimport { ElSegmented } from '@element-plus/components/segmented'\nimport { ElMention } from '@element-plus/components/mention'\n\nimport type { Plugin } from 'vue'\n\nexport default [\n  ElAffix,\n  ElAlert,\n  ElAutocomplete,\n  ElAutoResizer,\n  ElAvatar,\n  ElBacktop,\n  ElBadge,\n  ElBreadcrumb,\n  ElBreadcrumbItem,\n  ElButton,\n  ElButtonGroup,\n  ElCalendar,\n  ElCard,\n  ElCarousel,\n  ElCarouselItem,\n  ElCascader,\n  ElCascaderPanel,\n  ElCheckTag,\n  ElCheckbox,\n  ElCheckboxButton,\n  ElCheckboxGroup,\n  ElCol,\n  ElCollapse,\n  ElCollapseItem,\n  ElCollapseTransition,\n  ElColorPicker,\n  ElConfigProvider,\n  ElContainer,\n  ElAside,\n  ElFooter,\n  ElHeader,\n  ElMain,\n  ElDatePicker,\n  ElDescriptions,\n  ElDescriptionsItem,\n  ElDialog,\n  ElDivider,\n  ElDrawer,\n  ElDropdown,\n  ElDropdownItem,\n  ElDropdownMenu,\n  ElEmpty,\n  ElForm,\n  ElFormItem,\n  ElIcon,\n  ElImage,\n  ElImageViewer,\n  ElInput,\n  ElInputNumber,\n  ElLink,\n  ElMenu,\n  ElMenuItem,\n  ElMenuItemGroup,\n  ElSubMenu,\n  ElPageHeader,\n  ElPagination,\n  ElPopconfirm,\n  ElPopover,\n  ElPopper,\n  ElProgress,\n  ElRadio,\n  ElRadioButton,\n  ElRadioGroup,\n  ElRate,\n  ElResult,\n  ElRow,\n  ElScrollbar,\n  ElSelect,\n  ElOption,\n  ElOptionGroup,\n  ElSelectV2,\n  ElSkeleton,\n  ElSkeletonItem,\n  ElSlider,\n  ElSpace,\n  ElStatistic,\n  ElCountdown,\n  ElSteps,\n  ElStep,\n  ElSwitch,\n  ElTable,\n  ElTableColumn,\n  ElTableV2,\n  ElTabs,\n  ElTabPane,\n  ElTag,\n  ElText,\n  ElTimePicker,\n  ElTimeSelect,\n  ElTimeline,\n  ElTimelineItem,\n  ElTooltip,\n  ElTooltipV2,\n  ElTransfer,\n  ElTree,\n  ElTreeSelect,\n  ElTreeV2,\n  ElUpload,\n  ElWatermark,\n  ElTour,\n  ElTourStep,\n  ElAnchor,\n  ElAnchorLink,\n  ElSegmented,\n  ElMention,\n] as Plugin[]\n", "// @ts-nocheck\nimport { nextTick } from 'vue'\nimport { throttle } from 'lodash-unified'\nimport {\n  getOffsetTopDistance,\n  getScrollContainer,\n  isFunction,\n  throwError,\n} from '@element-plus/utils'\n\nimport type { ComponentPublicInstance, ObjectDirective } from 'vue'\n\nexport const SCOPE = 'ElInfiniteScroll'\nexport const CHECK_INTERVAL = 50\nexport const DEFAULT_DELAY = 200\nexport const DEFAULT_DISTANCE = 0\n\nconst attributes = {\n  delay: {\n    type: Number,\n    default: DEFAULT_DELAY,\n  },\n  distance: {\n    type: Number,\n    default: DEFAULT_DISTANCE,\n  },\n  disabled: {\n    type: Boolean,\n    default: false,\n  },\n  immediate: {\n    type: Boolean,\n    default: true,\n  },\n}\n\ntype Attrs = typeof attributes\ntype ScrollOptions = { [K in keyof Attrs]: Attrs[K]['default'] }\ntype InfiniteScrollCallback = () => void\ntype InfiniteScrollEl = HTMLElement & {\n  [SCOPE]: {\n    container: HTMLElement | Window\n    containerEl: HTMLElement\n    instance: ComponentPublicInstance\n    delay: number // export for test\n    lastScrollTop: number\n    cb: InfiniteScrollCallback\n    onScroll: () => void\n    observer?: MutationObserver\n  }\n}\n\nconst getScrollOptions = (\n  el: HTMLElement,\n  instance: ComponentPublicInstance\n): ScrollOptions => {\n  return Object.entries(attributes).reduce((acm, [name, option]) => {\n    const { type, default: defaultValue } = option\n    const attrVal = el.getAttribute(`infinite-scroll-${name}`)\n    let value = instance[attrVal] ?? attrVal ?? defaultValue\n    value = value === 'false' ? false : value\n    value = type(value)\n    acm[name] = Number.isNaN(value) ? defaultValue : value\n    return acm\n  }, {} as ScrollOptions)\n}\n\nconst destroyObserver = (el: InfiniteScrollEl) => {\n  const { observer } = el[SCOPE]\n\n  if (observer) {\n    observer.disconnect()\n    delete el[SCOPE].observer\n  }\n}\n\nconst handleScroll = (el: InfiniteScrollEl, cb: InfiniteScrollCallback) => {\n  const { container, containerEl, instance, observer, lastScrollTop } =\n    el[SCOPE]\n  const { disabled, distance } = getScrollOptions(el, instance)\n  const { clientHeight, scrollHeight, scrollTop } = containerEl\n  const delta = scrollTop - lastScrollTop\n\n  el[SCOPE].lastScrollTop = scrollTop\n\n  // trigger only if full check has done and not disabled and scroll down\n  if (observer || disabled || delta < 0) return\n\n  let shouldTrigger = false\n\n  if (container === el) {\n    shouldTrigger = scrollHeight - (clientHeight + scrollTop) <= distance\n  } else {\n    // get the scrollHeight since el might be visible overflow\n    const { clientTop, scrollHeight: height } = el\n    const offsetTop = getOffsetTopDistance(el, containerEl)\n    shouldTrigger =\n      scrollTop + clientHeight >= offsetTop + clientTop + height - distance\n  }\n\n  if (shouldTrigger) {\n    cb.call(instance)\n  }\n}\n\nfunction checkFull(el: InfiniteScrollEl, cb: InfiniteScrollCallback) {\n  const { containerEl, instance } = el[SCOPE]\n  const { disabled } = getScrollOptions(el, instance)\n\n  if (disabled || containerEl.clientHeight === 0) return\n\n  if (containerEl.scrollHeight <= containerEl.clientHeight) {\n    cb.call(instance)\n  } else {\n    destroyObserver(el)\n  }\n}\n\nconst InfiniteScroll: ObjectDirective<\n  InfiniteScrollEl,\n  InfiniteScrollCallback\n> = {\n  async mounted(el, binding) {\n    const { instance, value: cb } = binding\n\n    if (!isFunction(cb)) {\n      throwError(SCOPE, \"'v-infinite-scroll' binding value must be a function\")\n    }\n\n    // ensure parentNode mounted\n    await nextTick()\n\n    const { delay, immediate } = getScrollOptions(el, instance)\n    const container = getScrollContainer(el, true)\n    const containerEl =\n      container === window\n        ? document.documentElement\n        : (container as HTMLElement)\n    const onScroll = throttle(handleScroll.bind(null, el, cb), delay)\n\n    if (!container) return\n\n    el[SCOPE] = {\n      instance,\n      container,\n      containerEl,\n      delay,\n      cb,\n      onScroll,\n      lastScrollTop: containerEl.scrollTop,\n    }\n\n    if (immediate) {\n      const observer = new MutationObserver(\n        throttle(checkFull.bind(null, el, cb), CHECK_INTERVAL)\n      )\n      el[SCOPE].observer = observer\n      observer.observe(el, { childList: true, subtree: true })\n      checkFull(el, cb)\n    }\n\n    container.addEventListener('scroll', onScroll)\n  },\n  unmounted(el) {\n    if (!el[SCOPE]) return\n    const { container, onScroll } = el[SCOPE]\n\n    container?.removeEventListener('scroll', onScroll)\n    destroyObserver(el)\n  },\n  async updated(el) {\n    if (!el[SCOPE]) {\n      await nextTick()\n    } else {\n      const { containerEl, cb, observer } = el[SCOPE]\n      if (containerEl.clientHeight && observer) {\n        checkFull(el, cb)\n      }\n    }\n  },\n}\n\nexport default InfiniteScroll\n", "import InfiniteScroll from './src'\n\nimport type { App } from 'vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nconst _InfiniteScroll = InfiniteScroll as SFCWithInstall<typeof InfiniteScroll>\n\n_InfiniteScroll.install = (app: App) => {\n  app.directive('InfiniteScroll', _InfiniteScroll)\n}\n\nexport default _InfiniteScroll\nexport const ElInfiniteScroll = _InfiniteScroll\n", "import {\n  Transition,\n  createApp,\n  createVNode,\n  defineComponent,\n  h,\n  reactive,\n  ref,\n  toRefs,\n  vShow,\n  withCtx,\n  withDirectives,\n} from 'vue'\nimport { removeClass } from '@element-plus/utils'\nimport { useGlobalComponentSettings } from '@element-plus/components/config-provider'\n\nimport type { UseNamespaceReturn } from '@element-plus/hooks'\nimport type { LoadingOptionsResolved } from './types'\n\nexport function createLoadingComponent(options: LoadingOptionsResolved) {\n  let afterLeaveTimer: ReturnType<typeof setTimeout>\n  // IMPORTANT NOTE: this is only a hacking way to expose the injections on an\n  // instance, DO NOT FOLLOW this pattern in your own code.\n  const afterLeaveFlag = ref(false)\n  const data = reactive({\n    ...options,\n    originalPosition: '',\n    originalOverflow: '',\n    visible: false,\n  })\n\n  function setText(text: string) {\n    data.text = text\n  }\n\n  function destroySelf() {\n    const target = data.parent\n    const ns = (vm as any).ns as UseNamespaceReturn\n    if (!target.vLoadingAddClassList) {\n      let loadingNumber: number | string | null =\n        target.getAttribute('loading-number')\n      loadingNumber = Number.parseInt(loadingNumber as any) - 1\n      if (!loadingNumber) {\n        removeClass(target, ns.bm('parent', 'relative'))\n        target.removeAttribute('loading-number')\n      } else {\n        target.setAttribute('loading-number', loadingNumber.toString())\n      }\n      removeClass(target, ns.bm('parent', 'hidden'))\n    }\n    removeElLoadingChild()\n    loadingInstance.unmount()\n  }\n  function removeElLoadingChild(): void {\n    vm.$el?.parentNode?.removeChild(vm.$el)\n  }\n  function close() {\n    if (options.beforeClose && !options.beforeClose()) return\n\n    afterLeaveFlag.value = true\n    clearTimeout(afterLeaveTimer)\n\n    afterLeaveTimer = setTimeout(handleAfterLeave, 400)\n    data.visible = false\n\n    options.closed?.()\n  }\n\n  function handleAfterLeave() {\n    if (!afterLeaveFlag.value) return\n    const target = data.parent\n    afterLeaveFlag.value = false\n    target.vLoadingAddClassList = undefined\n    destroySelf()\n  }\n\n  const elLoadingComponent = defineComponent({\n    name: 'ElLoading',\n    setup(_, { expose }) {\n      const { ns, zIndex } = useGlobalComponentSettings('loading')\n\n      expose({\n        ns,\n        zIndex,\n      })\n\n      return () => {\n        const svg = data.spinner || data.svg\n        const spinner = h(\n          'svg',\n          {\n            class: 'circular',\n            viewBox: data.svgViewBox ? data.svgViewBox : '0 0 50 50',\n            ...(svg ? { innerHTML: svg } : {}),\n          },\n          [\n            h('circle', {\n              class: 'path',\n              cx: '25',\n              cy: '25',\n              r: '20',\n              fill: 'none',\n            }),\n          ]\n        )\n\n        const spinnerText = data.text\n          ? h('p', { class: ns.b('text') }, [data.text])\n          : undefined\n\n        return h(\n          Transition,\n          {\n            name: ns.b('fade'),\n            onAfterLeave: handleAfterLeave,\n          },\n          {\n            default: withCtx(() => [\n              withDirectives(\n                createVNode(\n                  'div',\n                  {\n                    style: {\n                      backgroundColor: data.background || '',\n                    },\n                    class: [\n                      ns.b('mask'),\n                      data.customClass,\n                      data.fullscreen ? 'is-fullscreen' : '',\n                    ],\n                  },\n                  [\n                    h(\n                      'div',\n                      {\n                        class: ns.b('spinner'),\n                      },\n                      [spinner, spinnerText]\n                    ),\n                  ]\n                ),\n                [[vShow, data.visible]]\n              ),\n            ]),\n          }\n        )\n      }\n    },\n  })\n\n  const loadingInstance = createApp(elLoadingComponent)\n  const vm = loadingInstance.mount(document.createElement('div'))\n\n  return {\n    ...toRefs(data),\n    setText,\n    removeElLoadingChild,\n    close,\n    handleAfterLeave,\n    vm,\n    get $el(): HTMLElement {\n      return vm.$el\n    },\n  }\n}\n\nexport type LoadingInstance = ReturnType<typeof createLoadingComponent>\n", "// @ts-nocheck\nimport { nextTick } from 'vue'\nimport {\n  addClass,\n  getStyle,\n  isClient,\n  isString,\n  removeClass,\n} from '@element-plus/utils'\nimport { createLoadingComponent } from './loading'\n\nimport type { UseNamespaceReturn, UseZIndexReturn } from '@element-plus/hooks'\nimport type { LoadingInstance } from './loading'\nimport type { LoadingOptionsResolved } from '..'\nimport type { LoadingOptions } from './types'\nimport type { CSSProperties } from 'vue'\n\nlet fullscreenInstance: LoadingInstance | undefined = undefined\n\nexport const Loading = function (\n  options: LoadingOptions = {}\n): LoadingInstance {\n  if (!isClient) return undefined as any\n\n  const resolved = resolveOptions(options)\n\n  if (resolved.fullscreen && fullscreenInstance) {\n    return fullscreenInstance\n  }\n\n  const instance = createLoadingComponent({\n    ...resolved,\n    closed: () => {\n      resolved.closed?.()\n      if (resolved.fullscreen) fullscreenInstance = undefined\n    },\n  })\n\n  addStyle(resolved, resolved.parent, instance)\n  addClassList(resolved, resolved.parent, instance)\n\n  resolved.parent.vLoadingAddClassList = () =>\n    addClassList(resolved, resolved.parent, instance)\n\n  /**\n   * add loading-number to parent.\n   * because if a fullscreen loading is triggered when somewhere\n   * a v-loading.body was triggered before and it's parent is\n   * document.body which with a margin , the fullscreen loading's\n   * destroySelf function will remove 'el-loading-parent--relative',\n   * and then the position of v-loading.body will be error.\n   */\n  let loadingNumber: string | null =\n    resolved.parent.getAttribute('loading-number')\n  if (!loadingNumber) {\n    loadingNumber = '1'\n  } else {\n    loadingNumber = `${Number.parseInt(loadingNumber) + 1}`\n  }\n  resolved.parent.setAttribute('loading-number', loadingNumber)\n\n  resolved.parent.appendChild(instance.$el)\n\n  // after instance render, then modify visible to trigger transition\n  nextTick(() => (instance.visible.value = resolved.visible))\n\n  if (resolved.fullscreen) {\n    fullscreenInstance = instance\n  }\n  return instance\n}\n\nconst resolveOptions = (options: LoadingOptions): LoadingOptionsResolved => {\n  let target: HTMLElement\n  if (isString(options.target)) {\n    target =\n      document.querySelector<HTMLElement>(options.target) ?? document.body\n  } else {\n    target = options.target || document.body\n  }\n  return {\n    parent: target === document.body || options.body ? document.body : target,\n    background: options.background || '',\n    svg: options.svg || '',\n    svgViewBox: options.svgViewBox || '',\n    spinner: options.spinner || false,\n    text: options.text || '',\n    fullscreen: target === document.body && (options.fullscreen ?? true),\n    lock: options.lock ?? false,\n    customClass: options.customClass || '',\n    visible: options.visible ?? true,\n    beforeClose: options.beforeClose,\n    closed: options.closed,\n    target,\n  }\n}\n\nconst addStyle = async (\n  options: LoadingOptionsResolved,\n  parent: HTMLElement,\n  instance: LoadingInstance\n) => {\n  // Compatible with the instance data format of vue@3.2.12 and earlier versions #12351\n  const { nextZIndex } =\n    ((instance.vm as any).zIndex as UseZIndexReturn) ||\n    (instance.vm as any)._.exposed.zIndex\n\n  const maskStyle: CSSProperties = {}\n  if (options.fullscreen) {\n    instance.originalPosition.value = getStyle(document.body, 'position')\n    instance.originalOverflow.value = getStyle(document.body, 'overflow')\n    maskStyle.zIndex = nextZIndex()\n  } else if (options.parent === document.body) {\n    instance.originalPosition.value = getStyle(document.body, 'position')\n    /**\n     * await dom render when visible is true in init,\n     * because some component's height maybe 0.\n     * e.g. el-table.\n     */\n    await nextTick()\n    for (const property of ['top', 'left']) {\n      const scroll = property === 'top' ? 'scrollTop' : 'scrollLeft'\n      maskStyle[property] = `${\n        (options.target as HTMLElement).getBoundingClientRect()[property] +\n        document.body[scroll] +\n        document.documentElement[scroll] -\n        Number.parseInt(getStyle(document.body, `margin-${property}`), 10)\n      }px`\n    }\n    for (const property of ['height', 'width']) {\n      maskStyle[property] = `${\n        (options.target as HTMLElement).getBoundingClientRect()[property]\n      }px`\n    }\n  } else {\n    instance.originalPosition.value = getStyle(parent, 'position')\n  }\n  for (const [key, value] of Object.entries(maskStyle)) {\n    instance.$el.style[key] = value\n  }\n}\n\nconst addClassList = (\n  options: LoadingOptions,\n  parent: HTMLElement,\n  instance: LoadingInstance\n) => {\n  // Compatible with the instance data format of vue@3.2.12 and earlier versions #12351\n  const ns =\n    ((instance.vm as any).ns as UseNamespaceReturn) ||\n    (instance.vm as any)._.exposed.ns\n\n  if (\n    !['absolute', 'fixed', 'sticky'].includes(instance.originalPosition.value)\n  ) {\n    addClass(parent, ns.bm('parent', 'relative'))\n  } else {\n    removeClass(parent, ns.bm('parent', 'relative'))\n  }\n  if (options.fullscreen && options.lock) {\n    addClass(parent, ns.bm('parent', 'hidden'))\n  } else {\n    removeClass(parent, ns.bm('parent', 'hidden'))\n  }\n}\n", "// @ts-nocheck\nimport { isRef, ref } from 'vue'\nimport { hyphenate, isObject, isString } from '@element-plus/utils'\nimport { Loading } from './service'\nimport type { Directive, DirectiveBinding, UnwrapRef } from 'vue'\nimport type { LoadingOptions } from './types'\nimport type { LoadingInstance } from './loading'\n\nconst INSTANCE_KEY = Symbol('ElLoading')\n\nexport type LoadingBinding = boolean | UnwrapRef<LoadingOptions>\nexport interface ElementLoading extends HTMLElement {\n  [INSTANCE_KEY]?: {\n    instance: LoadingInstance\n    options: LoadingOptions\n  }\n}\n\nconst createInstance = (\n  el: ElementLoading,\n  binding: DirectiveBinding<LoadingBinding>\n) => {\n  const vm = binding.instance\n\n  const getBindingProp = <K extends keyof LoadingOptions>(\n    key: K\n  ): LoadingOptions[K] =>\n    isObject(binding.value) ? binding.value[key] : undefined\n\n  const resolveExpression = (key: any) => {\n    const data = (isString(key) && vm?.[key]) || key\n    if (data) return ref(data)\n    else return data\n  }\n\n  const getProp = <K extends keyof LoadingOptions>(name: K) =>\n    resolveExpression(\n      getBindingProp(name) ||\n        el.getAttribute(`element-loading-${hyphenate(name)}`)\n    )\n\n  const fullscreen =\n    getBindingProp('fullscreen') ?? binding.modifiers.fullscreen\n\n  const options: LoadingOptions = {\n    text: getProp('text'),\n    svg: getProp('svg'),\n    svgViewBox: getProp('svgViewBox'),\n    spinner: getProp('spinner'),\n    background: getProp('background'),\n    customClass: getProp('customClass'),\n    fullscreen,\n    target: getBindingProp('target') ?? (fullscreen ? undefined : el),\n    body: getBindingProp('body') ?? binding.modifiers.body,\n    lock: getBindingProp('lock') ?? binding.modifiers.lock,\n  }\n  el[INSTANCE_KEY] = {\n    options,\n    instance: Loading(options),\n  }\n}\n\nconst updateOptions = (\n  newOptions: UnwrapRef<LoadingOptions>,\n  originalOptions: LoadingOptions\n) => {\n  for (const key of Object.keys(originalOptions)) {\n    if (isRef(originalOptions[key]))\n      originalOptions[key].value = newOptions[key]\n  }\n}\n\nexport const vLoading: Directive<ElementLoading, LoadingBinding> = {\n  mounted(el, binding) {\n    if (binding.value) {\n      createInstance(el, binding)\n    }\n  },\n  updated(el, binding) {\n    const instance = el[INSTANCE_KEY]\n    if (binding.oldValue !== binding.value) {\n      if (binding.value && !binding.oldValue) {\n        createInstance(el, binding)\n      } else if (binding.value && binding.oldValue) {\n        if (isObject(binding.value))\n          updateOptions(binding.value, instance!.options)\n      } else {\n        instance?.instance.close()\n      }\n    }\n  },\n  unmounted(el) {\n    el[INSTANCE_KEY]?.instance.close()\n    el[INSTANCE_KEY] = null\n  },\n}\n", "import { Loading } from './src/service'\nimport { vLoading } from './src/directive'\n\nimport type { App } from 'vue'\n\n// installer and everything in all\nexport const ElLoading = {\n  install(app: App) {\n    app.directive('loading', vLoading)\n    app.config.globalProperties.$loading = Loading\n  },\n  directive: vLoading,\n  service: Loading,\n}\n\nexport default ElLoading\nexport { vLoading, vLoading as ElLoadingDirective, Loading as ElLoadingService }\n\nexport * from './src/types'\n", "import {\n  buildProps,\n  definePropType,\n  iconPropType,\n  isClient,\n  mutable,\n} from '@element-plus/utils'\nimport type { AppContext, ExtractPropTypes, VNode } from 'vue'\nimport type { Mutable } from '@element-plus/utils'\nimport type MessageConstructor from './message.vue'\n\nexport const messageTypes = ['success', 'info', 'warning', 'error'] as const\n\nexport type messageType = typeof messageTypes[number]\n\nexport interface MessageConfigContext {\n  max?: number\n  grouping?: boolean\n  duration?: number\n  offset?: number\n  showClose?: boolean\n}\n\nexport const messageDefaults = mutable({\n  customClass: '',\n  center: false,\n  dangerouslyUseHTMLString: false,\n  duration: 3000,\n  icon: undefined,\n  id: '',\n  message: '',\n  onClose: undefined,\n  showClose: false,\n  type: 'info',\n  plain: false,\n  offset: 16,\n  zIndex: 0,\n  grouping: false,\n  repeatNum: 1,\n  appendTo: isClient ? document.body : (undefined as never),\n} as const)\n\nexport const messageProps = buildProps({\n  /**\n   * @description custom class name for Message\n   */\n  customClass: {\n    type: String,\n    default: messageDefaults.customClass,\n  },\n  /**\n   * @description whether to center the text\n   */\n  center: {\n    type: Boolean,\n    default: messageDefaults.center,\n  },\n  /**\n   * @description whether `message` is treated as HTML string\n   */\n  dangerouslyUseHTMLString: {\n    type: Boolean,\n    default: messageDefaults.dangerouslyUseHTMLString,\n  },\n  /**\n   * @description display duration, millisecond. If set to 0, it will not turn off automatically\n   */\n  duration: {\n    type: Number,\n    default: messageDefaults.duration,\n  },\n  /**\n   * @description custom icon component, overrides `type`\n   */\n  icon: {\n    type: iconPropType,\n    default: messageDefaults.icon,\n  },\n  /**\n   * @description message dom id\n   */\n  id: {\n    type: String,\n    default: messageDefaults.id,\n  },\n  /**\n   * @description message text\n   */\n  message: {\n    type: definePropType<string | VNode | (() => VNode)>([\n      String,\n      Object,\n      Function,\n    ]),\n    default: messageDefaults.message,\n  },\n  /**\n   * @description callback function when closed with the message instance as the parameter\n   */\n  onClose: {\n    type: definePropType<() => void>(Function),\n    default: messageDefaults.onClose,\n  },\n  /**\n   * @description whether to show a close button\n   */\n  showClose: {\n    type: Boolean,\n    default: messageDefaults.showClose,\n  },\n  /**\n   * @description message type\n   */\n  type: {\n    type: String,\n    values: messageTypes,\n    default: messageDefaults.type,\n  },\n  /**\n   * @description whether message is plain\n   */\n  plain: {\n    type: Boolean,\n    default: messageDefaults.plain,\n  },\n  /**\n   * @description set the distance to the top of viewport\n   */\n  offset: {\n    type: Number,\n    default: messageDefaults.offset,\n  },\n  /**\n   * @description input box size\n   */\n  zIndex: {\n    type: Number,\n    default: messageDefaults.zIndex,\n  },\n  /**\n   * @description merge messages with the same content, type of VNode message is not supported\n   */\n  grouping: {\n    type: Boolean,\n    default: messageDefaults.grouping,\n  },\n  /**\n   * @description The number of repetitions, similar to badge, is used as the initial number when used with `grouping`\n   */\n  repeatNum: {\n    type: Number,\n    default: messageDefaults.repeatNum,\n  },\n} as const)\nexport type MessageProps = ExtractPropTypes<typeof messageProps>\n\nexport const messageEmits = {\n  destroy: () => true,\n}\nexport type MessageEmits = typeof messageEmits\n\nexport type MessageInstance = InstanceType<typeof MessageConstructor>\n\nexport type MessageOptions = Partial<\n  Mutable<\n    Omit<MessageProps, 'id'> & {\n      appendTo?: HTMLElement | string\n    }\n  >\n>\nexport type MessageParams = MessageOptions | MessageOptions['message']\nexport type MessageParamsNormalized = Omit<MessageProps, 'id'> & {\n  /**\n   * @description set the root element for the message, default to `document.body`\n   */\n  appendTo: HTMLElement\n}\nexport type MessageOptionsWithType = Omit<MessageOptions, 'type'>\nexport type MessageParamsWithType =\n  | MessageOptionsWithType\n  | MessageOptions['message']\n\nexport interface MessageHandler {\n  /**\n   * @description close the Message\n   */\n  close: () => void\n}\n\nexport type MessageFn = {\n  (options?: MessageParams, appContext?: null | AppContext): MessageHandler\n  closeAll(type?: messageType): void\n}\nexport type MessageTypedFn = (\n  options?: MessageParamsWithType,\n  appContext?: null | AppContext\n) => MessageHandler\n\nexport interface Message extends MessageFn {\n  success: MessageTypedFn\n  warning: MessageTypedFn\n  info: MessageTypedFn\n  error: MessageTypedFn\n}\n", "import { shallowReactive } from 'vue'\nimport type { ComponentInternalInstance, VNode } from 'vue'\nimport type { Mutable } from '@element-plus/utils'\nimport type { MessageHandler, MessageProps } from './message'\n\nexport type MessageContext = {\n  id: string\n  vnode: VNode\n  handler: MessageHandler\n  vm: ComponentInternalInstance\n  props: Mutable<MessageProps>\n}\n\nexport const instances: MessageContext[] = shallowReactive([])\n\nexport const getInstance = (id: string) => {\n  const idx = instances.findIndex((instance) => instance.id === id)\n  const current = instances[idx]\n  let prev: MessageContext | undefined\n  if (idx > 0) {\n    prev = instances[idx - 1]\n  }\n  return { current, prev }\n}\n\nexport const getLastOffset = (id: string): number => {\n  const { prev } = getInstance(id)\n  if (!prev) return 0\n  return prev.vm.exposed!.bottom.value\n}\n\nexport const getOffsetOrSpace = (id: string, offset: number) => {\n  const idx = instances.findIndex((instance) => instance.id === id)\n  return idx > 0 ? 16 : offset\n}\n", "<template>\n  <transition\n    :name=\"ns.b('fade')\"\n    @before-leave=\"onClose\"\n    @after-leave=\"$emit('destroy')\"\n  >\n    <div\n      v-show=\"visible\"\n      :id=\"id\"\n      ref=\"messageRef\"\n      :class=\"[\n        ns.b(),\n        { [ns.m(type)]: type },\n        ns.is('center', center),\n        ns.is('closable', showClose),\n        ns.is('plain', plain),\n        customClass,\n      ]\"\n      :style=\"customStyle\"\n      role=\"alert\"\n      @mouseenter=\"clearTimer\"\n      @mouseleave=\"startTimer\"\n    >\n      <el-badge\n        v-if=\"repeatNum > 1\"\n        :value=\"repeatNum\"\n        :type=\"badgeType\"\n        :class=\"ns.e('badge')\"\n      />\n      <el-icon v-if=\"iconComponent\" :class=\"[ns.e('icon'), typeClass]\">\n        <component :is=\"iconComponent\" />\n      </el-icon>\n      <slot>\n        <p v-if=\"!dangerouslyUseHTMLString\" :class=\"ns.e('content')\">\n          {{ message }}\n        </p>\n        <!-- Caution here, message could've been compromised, never use user's input as message -->\n        <p v-else :class=\"ns.e('content')\" v-html=\"message\" />\n      </slot>\n      <el-icon v-if=\"showClose\" :class=\"ns.e('closeBtn')\" @click.stop=\"close\">\n        <Close />\n      </el-icon>\n    </div>\n  </transition>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, onMounted, ref, watch } from 'vue'\nimport { useEventListener, useResizeObserver, useTimeoutFn } from '@vueuse/core'\nimport { TypeComponents, TypeComponentsMap } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport ElBadge from '@element-plus/components/badge'\nimport { useGlobalComponentSettings } from '@element-plus/components/config-provider'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { messageEmits, messageProps } from './message'\nimport { getLastOffset, getOffsetOrSpace } from './instance'\nimport type { BadgeProps } from '@element-plus/components/badge'\nimport type { CSSProperties } from 'vue'\n\nconst { Close } = TypeComponents\n\ndefineOptions({\n  name: 'ElMessage',\n})\n\nconst props = defineProps(messageProps)\ndefineEmits(messageEmits)\n\nconst { ns, zIndex } = useGlobalComponentSettings('message')\nconst { currentZIndex, nextZIndex } = zIndex\n\nconst messageRef = ref<HTMLDivElement>()\nconst visible = ref(false)\nconst height = ref(0)\n\nlet stopTimer: (() => void) | undefined = undefined\n\nconst badgeType = computed<BadgeProps['type']>(() =>\n  props.type ? (props.type === 'error' ? 'danger' : props.type) : 'info'\n)\nconst typeClass = computed(() => {\n  const type = props.type\n  return { [ns.bm('icon', type)]: type && TypeComponentsMap[type] }\n})\nconst iconComponent = computed(\n  () => props.icon || TypeComponentsMap[props.type] || ''\n)\n\nconst lastOffset = computed(() => getLastOffset(props.id))\nconst offset = computed(\n  () => getOffsetOrSpace(props.id, props.offset) + lastOffset.value\n)\nconst bottom = computed((): number => height.value + offset.value)\nconst customStyle = computed<CSSProperties>(() => ({\n  top: `${offset.value}px`,\n  zIndex: currentZIndex.value,\n}))\n\nfunction startTimer() {\n  if (props.duration === 0) return\n  ;({ stop: stopTimer } = useTimeoutFn(() => {\n    close()\n  }, props.duration))\n}\n\nfunction clearTimer() {\n  stopTimer?.()\n}\n\nfunction close() {\n  visible.value = false\n}\n\nfunction keydown({ code }: KeyboardEvent) {\n  if (code === EVENT_CODE.esc) {\n    // press esc to close the message\n    close()\n  }\n}\n\nonMounted(() => {\n  startTimer()\n  nextZIndex()\n  visible.value = true\n})\n\nwatch(\n  () => props.repeatNum,\n  () => {\n    clearTimer()\n    startTimer()\n  }\n)\n\nuseEventListener(document, 'keydown', keydown)\n\nuseResizeObserver(messageRef, () => {\n  height.value = messageRef.value!.getBoundingClientRect().height\n})\n\ndefineExpose({\n  visible,\n  bottom,\n  close,\n})\n</script>\n", "import { createVNode, render } from 'vue'\nimport {\n  debugWarn,\n  isBoolean,\n  isClient,\n  isElement,\n  isFunction,\n  isNumber,\n  isString,\n  isVNode,\n} from '@element-plus/utils'\nimport { messageConfig } from '@element-plus/components/config-provider'\nimport MessageConstructor from './message.vue'\nimport { messageDefaults, messageTypes } from './message'\nimport { instances } from './instance'\n\nimport type { MessageContext } from './instance'\nimport type { AppContext } from 'vue'\nimport type {\n  Message,\n  MessageFn,\n  MessageHandler,\n  MessageOptions,\n  MessageParams,\n  MessageParamsNormalized,\n  messageType,\n} from './message'\n\nlet seed = 1\n\n// TODO: Since Notify.ts is basically the same like this file. So we could do some encapsulation against them to reduce code duplication.\n\nconst normalizeOptions = (params?: MessageParams) => {\n  const options: MessageOptions =\n    !params || isString(params) || isVNode(params) || isFunction(params)\n      ? { message: params }\n      : params\n\n  const normalized = {\n    ...messageDefaults,\n    ...options,\n  }\n\n  if (!normalized.appendTo) {\n    normalized.appendTo = document.body\n  } else if (isString(normalized.appendTo)) {\n    let appendTo = document.querySelector<HTMLElement>(normalized.appendTo)\n\n    // should fallback to default value with a warning\n    if (!isElement(appendTo)) {\n      debugWarn(\n        'ElMessage',\n        'the appendTo option is not an HTMLElement. Falling back to document.body.'\n      )\n      appendTo = document.body\n    }\n\n    normalized.appendTo = appendTo\n  }\n\n  // When grouping is configured globally,\n  // if grouping is manually set when calling message individually and it is not equal to the default value,\n  // the global configuration cannot override the current setting. default => false\n  if (isBoolean(messageConfig.grouping) && !normalized.grouping) {\n    normalized.grouping = messageConfig.grouping\n  }\n  if (isNumber(messageConfig.duration) && normalized.duration === 3000) {\n    normalized.duration = messageConfig.duration\n  }\n  if (isNumber(messageConfig.offset) && normalized.offset === 16) {\n    normalized.offset = messageConfig.offset\n  }\n  if (isBoolean(messageConfig.showClose) && !normalized.showClose) {\n    normalized.showClose = messageConfig.showClose\n  }\n\n  return normalized as MessageParamsNormalized\n}\n\nconst closeMessage = (instance: MessageContext) => {\n  const idx = instances.indexOf(instance)\n  if (idx === -1) return\n\n  instances.splice(idx, 1)\n  const { handler } = instance\n  handler.close()\n}\n\nconst createMessage = (\n  { appendTo, ...options }: MessageParamsNormalized,\n  context?: AppContext | null\n): MessageContext => {\n  const id = `message_${seed++}`\n  const userOnClose = options.onClose\n\n  const container = document.createElement('div')\n\n  const props = {\n    ...options,\n    // now the zIndex will be used inside the message.vue component instead of here.\n    // zIndex: nextIndex() + options.zIndex\n    id,\n    onClose: () => {\n      userOnClose?.()\n      closeMessage(instance)\n    },\n\n    // clean message element preventing mem leak\n    onDestroy: () => {\n      // since the element is destroy, then the VNode should be collected by GC as well\n      // we do not want cause any mem leak because we have returned vm as a reference to users\n      // so that we manually set it to false.\n      render(null, container)\n    },\n  }\n  const vnode = createVNode(\n    MessageConstructor,\n    props,\n    isFunction(props.message) || isVNode(props.message)\n      ? {\n          default: isFunction(props.message)\n            ? props.message\n            : () => props.message,\n        }\n      : null\n  )\n  vnode.appContext = context || message._context\n\n  render(vnode, container)\n  // instances will remove this item when close function gets called. So we do not need to worry about it.\n  appendTo.appendChild(container.firstElementChild!)\n\n  const vm = vnode.component!\n\n  const handler: MessageHandler = {\n    // instead of calling the onClose function directly, setting this value so that we can have the full lifecycle\n    // for out component, so that all closing steps will not be skipped.\n    close: () => {\n      vm.exposed!.visible.value = false\n    },\n  }\n\n  const instance: MessageContext = {\n    id,\n    vnode,\n    vm,\n    handler,\n    props: (vnode.component as any).props,\n  }\n\n  return instance\n}\n\nconst message: MessageFn &\n  Partial<Message> & { _context: AppContext | null } = (\n  options = {},\n  context\n) => {\n  if (!isClient) return { close: () => undefined }\n\n  const normalized = normalizeOptions(options)\n\n  if (normalized.grouping && instances.length) {\n    const instance = instances.find(\n      ({ vnode: vm }) => vm.props?.message === normalized.message\n    )\n    if (instance) {\n      instance.props.repeatNum += 1\n      instance.props.type = normalized.type\n      return instance.handler\n    }\n  }\n\n  if (isNumber(messageConfig.max) && instances.length >= messageConfig.max) {\n    return { close: () => undefined }\n  }\n\n  const instance = createMessage(normalized, context)\n\n  instances.push(instance)\n  return instance.handler\n}\n\nmessageTypes.forEach((type) => {\n  message[type] = (options = {}, appContext) => {\n    const normalized = normalizeOptions(options)\n    return message({ ...normalized, type }, appContext)\n  }\n})\n\nexport function closeAll(type?: messageType): void {\n  for (const instance of instances) {\n    if (!type || type === instance.props.type) {\n      instance.handler.close()\n    }\n  }\n}\n\nmessage.closeAll = closeAll\nmessage._context = null\n\nexport default message as Message\n", "import { withInstallFunction } from '@element-plus/utils'\n\nimport Message from './src/method'\n\nexport const ElMessage = withInstallFunction(Message, '$message')\nexport default ElMessage\n\nexport * from './src/message'\n", "<template>\n  <transition name=\"fade-in-linear\" @after-leave=\"$emit('vanish')\">\n    <el-overlay\n      v-show=\"visible\"\n      :z-index=\"zIndex\"\n      :overlay-class=\"[ns.is('message-box'), modalClass]\"\n      :mask=\"modal\"\n    >\n      <div\n        role=\"dialog\"\n        :aria-label=\"title\"\n        aria-modal=\"true\"\n        :aria-describedby=\"!showInput ? contentId : undefined\"\n        :class=\"`${ns.namespace.value}-overlay-message-box`\"\n        @click=\"overlayEvent.onClick\"\n        @mousedown=\"overlayEvent.onMousedown\"\n        @mouseup=\"overlayEvent.onMouseup\"\n      >\n        <el-focus-trap\n          loop\n          :trapped=\"visible\"\n          :focus-trap-el=\"rootRef\"\n          :focus-start-el=\"focusStartRef\"\n          @release-requested=\"onCloseRequested\"\n        >\n          <div\n            ref=\"rootRef\"\n            :class=\"[\n              ns.b(),\n              customClass,\n              ns.is('draggable', draggable),\n              { [ns.m('center')]: center },\n            ]\"\n            :style=\"customStyle\"\n            tabindex=\"-1\"\n            @click.stop=\"\"\n          >\n            <div\n              v-if=\"title !== null && title !== undefined\"\n              ref=\"headerRef\"\n              :class=\"[ns.e('header'), { 'show-close': showClose }]\"\n            >\n              <div :class=\"ns.e('title')\">\n                <el-icon\n                  v-if=\"iconComponent && center\"\n                  :class=\"[ns.e('status'), typeClass]\"\n                >\n                  <component :is=\"iconComponent\" />\n                </el-icon>\n                <span>{{ title }}</span>\n              </div>\n              <button\n                v-if=\"showClose\"\n                type=\"button\"\n                :class=\"ns.e('headerbtn')\"\n                :aria-label=\"t('el.messagebox.close')\"\n                @click=\"\n                  handleAction(distinguishCancelAndClose ? 'close' : 'cancel')\n                \"\n                @keydown.prevent.enter=\"\n                  handleAction(distinguishCancelAndClose ? 'close' : 'cancel')\n                \"\n              >\n                <el-icon :class=\"ns.e('close')\">\n                  <close />\n                </el-icon>\n              </button>\n            </div>\n            <div :id=\"contentId\" :class=\"ns.e('content')\">\n              <div :class=\"ns.e('container')\">\n                <el-icon\n                  v-if=\"iconComponent && !center && hasMessage\"\n                  :class=\"[ns.e('status'), typeClass]\"\n                >\n                  <component :is=\"iconComponent\" />\n                </el-icon>\n                <div v-if=\"hasMessage\" :class=\"ns.e('message')\">\n                  <slot>\n                    <component\n                      :is=\"showInput ? 'label' : 'p'\"\n                      v-if=\"!dangerouslyUseHTMLString\"\n                      :for=\"showInput ? inputId : undefined\"\n                    >\n                      {{ !dangerouslyUseHTMLString ? message : '' }}\n                    </component>\n                    <component\n                      :is=\"showInput ? 'label' : 'p'\"\n                      v-else\n                      :for=\"showInput ? inputId : undefined\"\n                      v-html=\"message\"\n                    />\n                  </slot>\n                </div>\n              </div>\n              <div v-show=\"showInput\" :class=\"ns.e('input')\">\n                <el-input\n                  :id=\"inputId\"\n                  ref=\"inputRef\"\n                  v-model=\"inputValue\"\n                  :type=\"inputType\"\n                  :placeholder=\"inputPlaceholder\"\n                  :aria-invalid=\"validateError\"\n                  :class=\"{ invalid: validateError }\"\n                  @keydown.enter=\"handleInputEnter\"\n                />\n                <div\n                  :class=\"ns.e('errormsg')\"\n                  :style=\"{\n                    visibility: !!editorErrorMessage ? 'visible' : 'hidden',\n                  }\"\n                >\n                  {{ editorErrorMessage }}\n                </div>\n              </div>\n            </div>\n            <div :class=\"ns.e('btns')\">\n              <el-button\n                v-if=\"showCancelButton\"\n                :loading=\"cancelButtonLoading\"\n                :loading-icon=\"cancelButtonLoadingIcon\"\n                :class=\"[cancelButtonClass]\"\n                :round=\"roundButton\"\n                :size=\"btnSize\"\n                @click=\"handleAction('cancel')\"\n                @keydown.prevent.enter=\"handleAction('cancel')\"\n              >\n                {{ cancelButtonText || t('el.messagebox.cancel') }}\n              </el-button>\n              <el-button\n                v-show=\"showConfirmButton\"\n                ref=\"confirmRef\"\n                type=\"primary\"\n                :loading=\"confirmButtonLoading\"\n                :loading-icon=\"confirmButtonLoadingIcon\"\n                :class=\"[confirmButtonClasses]\"\n                :round=\"roundButton\"\n                :disabled=\"confirmButtonDisabled\"\n                :size=\"btnSize\"\n                @click=\"handleAction('confirm')\"\n                @keydown.prevent.enter=\"handleAction('confirm')\"\n              >\n                {{ confirmButtonText || t('el.messagebox.confirm') }}\n              </el-button>\n            </div>\n          </div>\n        </el-focus-trap>\n      </div>\n    </el-overlay>\n  </transition>\n</template>\n<script lang=\"ts\">\n// @ts-nocheck\nimport {\n  computed,\n  defineComponent,\n  markRaw,\n  nextTick,\n  onBeforeUnmount,\n  onMounted,\n  reactive,\n  ref,\n  toRefs,\n  watch,\n} from 'vue'\nimport ElButton from '@element-plus/components/button'\nimport { TrapFocus } from '@element-plus/directives'\nimport {\n  useDraggable,\n  useId,\n  useLockscreen,\n  useSameTarget,\n} from '@element-plus/hooks'\nimport ElInput from '@element-plus/components/input'\nimport { ElOverlay } from '@element-plus/components/overlay'\nimport {\n  TypeComponents,\n  TypeComponentsMap,\n  isValidComponentSize,\n} from '@element-plus/utils'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { Loading } from '@element-plus/icons-vue'\nimport ElFocusTrap from '@element-plus/components/focus-trap'\nimport { useGlobalComponentSettings } from '@element-plus/components/config-provider'\n\nimport type { ComponentPublicInstance, PropType } from 'vue'\nimport type { ComponentSize } from '@element-plus/constants'\nimport type {\n  Action,\n  MessageBoxState,\n  MessageBoxType,\n} from './message-box.type'\n\nexport default defineComponent({\n  name: 'ElMessageBox',\n  directives: {\n    TrapFocus,\n  },\n  components: {\n    ElButton,\n    ElFocusTrap,\n    ElInput,\n    ElOverlay,\n    ElIcon,\n    ...TypeComponents,\n  },\n  inheritAttrs: false,\n  props: {\n    buttonSize: {\n      type: String as PropType<ComponentSize>,\n      validator: isValidComponentSize,\n    },\n    modal: {\n      type: Boolean,\n      default: true,\n    },\n    lockScroll: {\n      type: Boolean,\n      default: true,\n    },\n    showClose: {\n      type: Boolean,\n      default: true,\n    },\n    closeOnClickModal: {\n      type: Boolean,\n      default: true,\n    },\n    closeOnPressEscape: {\n      type: Boolean,\n      default: true,\n    },\n    closeOnHashChange: {\n      type: Boolean,\n      default: true,\n    },\n    center: Boolean,\n    draggable: Boolean,\n    overflow: Boolean,\n    roundButton: {\n      default: false,\n      type: Boolean,\n    },\n    container: {\n      type: String, // default append to body\n      default: 'body',\n    },\n    boxType: {\n      type: String as PropType<MessageBoxType>,\n      default: '',\n    },\n  },\n  emits: ['vanish', 'action'],\n  setup(props, { emit }) {\n    // const popup = usePopup(props, doClose)\n    const {\n      locale,\n      zIndex,\n      ns,\n      size: btnSize,\n    } = useGlobalComponentSettings(\n      'message-box',\n      computed(() => props.buttonSize)\n    )\n\n    const { t } = locale\n    const { nextZIndex } = zIndex\n\n    const visible = ref(false)\n    // s represents state\n    const state = reactive<MessageBoxState>({\n      // autofocus element when open message-box\n      autofocus: true,\n      beforeClose: null,\n      callback: null,\n      cancelButtonText: '',\n      cancelButtonClass: '',\n      confirmButtonText: '',\n      confirmButtonClass: '',\n      customClass: '',\n      customStyle: {},\n      dangerouslyUseHTMLString: false,\n      distinguishCancelAndClose: false,\n      icon: '',\n      inputPattern: null,\n      inputPlaceholder: '',\n      inputType: 'text',\n      inputValue: null,\n      inputValidator: null,\n      inputErrorMessage: '',\n      message: null,\n      modalFade: true,\n      modalClass: '',\n      showCancelButton: false,\n      showConfirmButton: true,\n      type: '',\n      title: undefined,\n      showInput: false,\n      action: '' as Action,\n      confirmButtonLoading: false,\n      cancelButtonLoading: false,\n      confirmButtonLoadingIcon: markRaw(Loading),\n      cancelButtonLoadingIcon: markRaw(Loading),\n      confirmButtonDisabled: false,\n      editorErrorMessage: '',\n      // refer to: https://github.com/ElemeFE/element/commit/2999279ae34ef10c373ca795c87b020ed6753eed\n      // seemed ok for now without this state.\n      // isOnComposition: false, // temporary remove\n      validateError: false,\n      zIndex: nextZIndex(),\n    })\n\n    const typeClass = computed(() => {\n      const type = state.type\n      return { [ns.bm('icon', type)]: type && TypeComponentsMap[type] }\n    })\n\n    const contentId = useId()\n    const inputId = useId()\n\n    const iconComponent = computed(\n      () => state.icon || TypeComponentsMap[state.type] || ''\n    )\n    const hasMessage = computed(() => !!state.message)\n    const rootRef = ref<HTMLElement>()\n    const headerRef = ref<HTMLElement>()\n    const focusStartRef = ref<HTMLElement>()\n    const inputRef = ref<ComponentPublicInstance>()\n    const confirmRef = ref<ComponentPublicInstance>()\n\n    const confirmButtonClasses = computed(() => state.confirmButtonClass)\n\n    watch(\n      () => state.inputValue,\n      async (val) => {\n        await nextTick()\n        if (props.boxType === 'prompt' && val !== null) {\n          validate()\n        }\n      },\n      { immediate: true }\n    )\n\n    watch(\n      () => visible.value,\n      (val) => {\n        if (val) {\n          if (props.boxType !== 'prompt') {\n            if (state.autofocus) {\n              focusStartRef.value = confirmRef.value?.$el ?? rootRef.value\n            } else {\n              focusStartRef.value = rootRef.value\n            }\n          }\n          state.zIndex = nextZIndex()\n        }\n        if (props.boxType !== 'prompt') return\n        if (val) {\n          nextTick().then(() => {\n            if (inputRef.value && inputRef.value.$el) {\n              if (state.autofocus) {\n                focusStartRef.value = getInputElement() ?? rootRef.value\n              } else {\n                focusStartRef.value = rootRef.value\n              }\n            }\n          })\n        } else {\n          state.editorErrorMessage = ''\n          state.validateError = false\n        }\n      }\n    )\n\n    const draggable = computed(() => props.draggable)\n    const overflow = computed(() => props.overflow)\n    useDraggable(rootRef, headerRef, draggable, overflow)\n\n    onMounted(async () => {\n      await nextTick()\n      if (props.closeOnHashChange) {\n        window.addEventListener('hashchange', doClose)\n      }\n    })\n\n    onBeforeUnmount(() => {\n      if (props.closeOnHashChange) {\n        window.removeEventListener('hashchange', doClose)\n      }\n    })\n\n    function doClose() {\n      if (!visible.value) return\n      visible.value = false\n      nextTick(() => {\n        if (state.action) emit('action', state.action)\n      })\n    }\n\n    const handleWrapperClick = () => {\n      if (props.closeOnClickModal) {\n        handleAction(state.distinguishCancelAndClose ? 'close' : 'cancel')\n      }\n    }\n\n    const overlayEvent = useSameTarget(handleWrapperClick)\n\n    const handleInputEnter = (e: KeyboardEvent) => {\n      if (state.inputType !== 'textarea') {\n        e.preventDefault()\n        return handleAction('confirm')\n      }\n    }\n\n    const handleAction = (action: Action) => {\n      if (props.boxType === 'prompt' && action === 'confirm' && !validate()) {\n        return\n      }\n\n      state.action = action\n\n      if (state.beforeClose) {\n        state.beforeClose?.(action, state, doClose)\n      } else {\n        doClose()\n      }\n    }\n\n    const validate = () => {\n      if (props.boxType === 'prompt') {\n        const inputPattern = state.inputPattern\n        if (inputPattern && !inputPattern.test(state.inputValue || '')) {\n          state.editorErrorMessage =\n            state.inputErrorMessage || t('el.messagebox.error')\n          state.validateError = true\n          return false\n        }\n        const inputValidator = state.inputValidator\n        if (typeof inputValidator === 'function') {\n          const validateResult = inputValidator(state.inputValue)\n          if (validateResult === false) {\n            state.editorErrorMessage =\n              state.inputErrorMessage || t('el.messagebox.error')\n            state.validateError = true\n            return false\n          }\n          if (typeof validateResult === 'string') {\n            state.editorErrorMessage = validateResult\n            state.validateError = true\n            return false\n          }\n        }\n      }\n      state.editorErrorMessage = ''\n      state.validateError = false\n      return true\n    }\n\n    const getInputElement = () => {\n      const inputRefs = inputRef.value.$refs\n      return (inputRefs.input || inputRefs.textarea) as HTMLElement\n    }\n\n    const handleClose = () => {\n      handleAction('close')\n    }\n\n    // when close on press escape is disabled, pressing esc should not callout\n    // any other message box and close any other dialog-ish elements\n    // e.g. Dialog has a close on press esc feature, and when it closes, it calls\n    // props.beforeClose method to make a intermediate state by callout a message box\n    // for some verification or alerting. then if we allow global event liek this\n    // to dispatch, it could callout another message box.\n    const onCloseRequested = () => {\n      if (props.closeOnPressEscape) {\n        handleClose()\n      }\n    }\n\n    // locks the screen to prevent scroll\n    if (props.lockScroll) {\n      useLockscreen(visible)\n    }\n\n    return {\n      ...toRefs(state),\n      ns,\n      overlayEvent,\n      visible,\n      hasMessage,\n      typeClass,\n      contentId,\n      inputId,\n      btnSize,\n      iconComponent,\n      confirmButtonClasses,\n      rootRef,\n      focusStartRef,\n      headerRef,\n      inputRef,\n      confirmRef,\n      doClose, // for outside usage\n      handleClose, // for out side usage\n      onCloseRequested,\n      handleWrapperClick,\n      handleInputEnter,\n      handleAction,\n      t,\n    }\n  },\n})\n</script>\n", "import { createVNode, render } from 'vue'\nimport {\n  debugWarn,\n  hasOwn,\n  isClient,\n  isElement,\n  isFunction,\n  isObject,\n  isString,\n  isUndefined,\n  isVNode,\n} from '@element-plus/utils'\nimport MessageBoxConstructor from './index.vue'\n\nimport type { AppContext, ComponentPublicInstance, VNode } from 'vue'\nimport type {\n  Action,\n  Callback,\n  ElMessageBoxOptions,\n  ElMessageBoxShortcutMethod,\n  IElMessageBox,\n  MessageBoxData,\n  MessageBoxState,\n} from './message-box.type'\n\n// component default merge props & data\n\nconst messageInstance = new Map<\n  ComponentPublicInstance<{ doClose: () => void }>, // marking doClose as function\n  {\n    options: any\n    callback: Callback | undefined\n    resolve: (res: any) => void\n    reject: (reason?: any) => void\n  }\n>()\n\nconst getAppendToElement = (props: any): HTMLElement => {\n  let appendTo: HTMLElement | null = document.body\n  if (props.appendTo) {\n    if (isString(props.appendTo)) {\n      appendTo = document.querySelector<HTMLElement>(props.appendTo)\n    }\n    if (isElement(props.appendTo)) {\n      appendTo = props.appendTo\n    }\n\n    // should fallback to default value with a warning\n    if (!isElement(appendTo)) {\n      debugWarn(\n        'ElMessageBox',\n        'the appendTo option is not an HTMLElement. Falling back to document.body.'\n      )\n      appendTo = document.body\n    }\n  }\n  return appendTo\n}\n\nconst initInstance = (\n  props: any,\n  container: HTMLElement,\n  appContext: AppContext | null = null\n) => {\n  const vnode = createVNode(\n    MessageBoxConstructor,\n    props,\n    isFunction(props.message) || isVNode(props.message)\n      ? {\n          default: isFunction(props.message)\n            ? props.message\n            : () => props.message,\n        }\n      : null\n  )\n  vnode.appContext = appContext\n  render(vnode, container)\n  getAppendToElement(props).appendChild(container.firstElementChild!)\n  return vnode.component\n}\n\nconst genContainer = () => {\n  return document.createElement('div')\n}\n\nconst showMessage = (options: any, appContext?: AppContext | null) => {\n  const container = genContainer()\n  // Adding destruct method.\n  // when transition leaves emitting `vanish` evt. so that we can do the clean job.\n  options.onVanish = () => {\n    // not sure if this causes mem leak, need proof to verify that.\n    // maybe calling out like 1000 msg-box then close them all.\n    render(null, container)\n    messageInstance.delete(vm) // Remove vm to avoid mem leak.\n    // here we were suppose to call document.body.removeChild(container.firstElementChild)\n    // but render(null, container) did that job for us. so that we do not call that directly\n  }\n\n  options.onAction = (action: Action) => {\n    const currentMsg = messageInstance.get(vm)!\n    let resolve: Action | { value: string; action: Action }\n    if (options.showInput) {\n      resolve = { value: vm.inputValue, action }\n    } else {\n      resolve = action\n    }\n    if (options.callback) {\n      options.callback(resolve, instance.proxy)\n    } else {\n      if (action === 'cancel' || action === 'close') {\n        if (options.distinguishCancelAndClose && action !== 'cancel') {\n          currentMsg.reject('close')\n        } else {\n          currentMsg.reject('cancel')\n        }\n      } else {\n        currentMsg.resolve(resolve)\n      }\n    }\n  }\n\n  const instance = initInstance(options, container, appContext)!\n\n  // This is how we use message box programmably.\n  // Maybe consider releasing a template version?\n  // get component instance like v2.\n  const vm = instance.proxy as ComponentPublicInstance<\n    {\n      visible: boolean\n      doClose: () => void\n    } & MessageBoxState\n  >\n\n  for (const prop in options) {\n    if (hasOwn(options, prop) && !hasOwn(vm.$props, prop)) {\n      vm[prop as keyof ComponentPublicInstance] = options[prop]\n    }\n  }\n\n  // change visibility after everything is settled\n  vm.visible = true\n  return vm\n}\n\nasync function MessageBox(\n  options: ElMessageBoxOptions,\n  appContext?: AppContext | null\n): Promise<MessageBoxData>\nfunction MessageBox(\n  options: ElMessageBoxOptions | string | VNode,\n  appContext: AppContext | null = null\n): Promise<{ value: string; action: Action } | Action> {\n  if (!isClient) return Promise.reject()\n  let callback: Callback | undefined\n  if (isString(options) || isVNode(options)) {\n    options = {\n      message: options,\n    }\n  } else {\n    callback = options.callback\n  }\n\n  return new Promise((resolve, reject) => {\n    const vm = showMessage(\n      options,\n      appContext ?? (MessageBox as IElMessageBox)._context\n    )\n    // collect this vm in order to handle upcoming events.\n    messageInstance.set(vm, {\n      options,\n      callback,\n      resolve,\n      reject,\n    })\n  })\n}\n\nconst MESSAGE_BOX_VARIANTS = ['alert', 'confirm', 'prompt'] as const\nconst MESSAGE_BOX_DEFAULT_OPTS: Record<\n  typeof MESSAGE_BOX_VARIANTS[number],\n  Partial<ElMessageBoxOptions>\n> = {\n  alert: { closeOnPressEscape: false, closeOnClickModal: false },\n  confirm: { showCancelButton: true },\n  prompt: { showCancelButton: true, showInput: true },\n}\n\nMESSAGE_BOX_VARIANTS.forEach((boxType) => {\n  ;(MessageBox as IElMessageBox)[boxType] = messageBoxFactory(\n    boxType\n  ) as ElMessageBoxShortcutMethod\n})\n\nfunction messageBoxFactory(boxType: typeof MESSAGE_BOX_VARIANTS[number]) {\n  return (\n    message: string | VNode,\n    title: string | ElMessageBoxOptions,\n    options?: ElMessageBoxOptions,\n    appContext?: AppContext | null\n  ) => {\n    let titleOrOpts = ''\n    if (isObject(title)) {\n      options = title as ElMessageBoxOptions\n      titleOrOpts = ''\n    } else if (isUndefined(title)) {\n      titleOrOpts = ''\n    } else {\n      titleOrOpts = title as string\n    }\n\n    return MessageBox(\n      Object.assign(\n        {\n          title: titleOrOpts,\n          message,\n          type: '',\n          ...MESSAGE_BOX_DEFAULT_OPTS[boxType],\n        },\n        options,\n        {\n          boxType,\n        }\n      ),\n      appContext\n    )\n  }\n}\n\nMessageBox.close = () => {\n  // instance.setupInstall.doClose()\n  // instance.setupInstall.state.visible = false\n\n  messageInstance.forEach((_, vm) => {\n    vm.doClose()\n  })\n\n  messageInstance.clear()\n}\n;(MessageBox as IElMessageBox)._context = null\n\nexport default MessageBox as IElMessageBox\n", "import MessageBox from './src/messageBox'\n\nimport type { App } from 'vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nconst _MessageBox = MessageBox as SFCWithInstall<typeof MessageBox>\n\n_MessageBox.install = (app: App) => {\n  _MessageBox._context = app._context\n  app.config.globalProperties.$msgbox = _MessageBox\n  app.config.globalProperties.$messageBox = _MessageBox\n  app.config.globalProperties.$alert = _MessageBox.alert\n  app.config.globalProperties.$confirm = _MessageBox.confirm\n  app.config.globalProperties.$prompt = _MessageBox.prompt\n}\n\nexport default _MessageBox\nexport const ElMessageBox = _MessageBox\n\nexport * from './src/message-box.type'\n", "import { buildProps, definePropType, iconPropType } from '@element-plus/utils'\n\nimport type { ExtractPropTypes, VNode } from 'vue'\nimport type Notification from './notification.vue'\n\nexport const notificationTypes = [\n  'success',\n  'info',\n  'warning',\n  'error',\n] as const\n\nexport const notificationProps = buildProps({\n  /**\n   * @description custom class name for Notification\n   */\n  customClass: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description whether `message` is treated as HTML string\n   */\n  dangerouslyUseHTMLString: Boolean,\n  /**\n   * @description duration before close. It will not automatically close if set 0\n   */\n  duration: {\n    type: Number,\n    default: 4500,\n  },\n  /**\n   * @description custom icon component. It will be overridden by `type`\n   */\n  icon: {\n    type: iconPropType,\n  },\n  /**\n   * @description notification dom id\n   */\n  id: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description description text\n   */\n  message: {\n    type: definePropType<string | VNode>([String, Object]),\n    default: '',\n  },\n  /**\n   * @description offset from the top edge of the screen. Every Notification instance of the same moment should have the same offset\n   */\n  offset: {\n    type: Number,\n    default: 0,\n  },\n  /**\n   * @description callback function when notification clicked\n   */\n  onClick: {\n    type: definePropType<() => void>(Function),\n    default: () => undefined,\n  },\n  /**\n   * @description callback function when closed\n   */\n  onClose: {\n    type: definePropType<() => void>(Function),\n    required: true,\n  },\n  /**\n   * @description custom position\n   */\n  position: {\n    type: String,\n    values: ['top-right', 'top-left', 'bottom-right', 'bottom-left'],\n    default: 'top-right',\n  },\n  /**\n   * @description whether to show a close button\n   */\n  showClose: {\n    type: Boolean,\n    default: true,\n  },\n  /**\n   * @description title\n   */\n  title: {\n    type: String,\n    default: '',\n  },\n  /**\n   * @description notification type\n   */\n  type: {\n    type: String,\n    values: [...notificationTypes, ''],\n    default: '',\n  },\n  /**\n   * @description initial zIndex\n   */\n  zIndex: Number,\n} as const)\nexport type NotificationProps = ExtractPropTypes<typeof notificationProps>\n\nexport const notificationEmits = {\n  destroy: () => true,\n}\nexport type NotificationEmits = typeof notificationEmits\n\nexport type NotificationInstance = InstanceType<typeof Notification>\n\nexport type NotificationOptions = Omit<NotificationProps, 'id'> & {\n  /**\n   * @description set the root element for the notification, default to `document.body`\n   */\n  appendTo?: HTMLElement | string\n}\nexport type NotificationOptionsTyped = Omit<NotificationOptions, 'type'>\n\nexport interface NotificationHandle {\n  close: () => void\n}\n\nexport type NotificationParams = Partial<NotificationOptions> | string | VNode\nexport type NotificationParamsTyped =\n  | Partial<NotificationOptionsTyped>\n  | string\n  | VNode\n\nexport type NotifyFn = ((\n  options?: NotificationParams\n) => NotificationHandle) & { closeAll: () => void }\n\nexport type NotifyTypedFn = (\n  options?: NotificationParamsTyped\n) => NotificationHandle\n\nexport interface Notify extends NotifyFn {\n  success: NotifyTypedFn\n  warning: NotifyTypedFn\n  error: NotifyTypedFn\n  info: NotifyTypedFn\n}\n\nexport interface NotificationQueueItem {\n  vm: VNode\n}\n\nexport type NotificationQueue = NotificationQueueItem[]\n", "<template>\n  <transition\n    :name=\"ns.b('fade')\"\n    @before-leave=\"onClose\"\n    @after-leave=\"$emit('destroy')\"\n  >\n    <div\n      v-show=\"visible\"\n      :id=\"id\"\n      :class=\"[ns.b(), customClass, horizontalClass]\"\n      :style=\"positionStyle\"\n      role=\"alert\"\n      @mouseenter=\"clearTimer\"\n      @mouseleave=\"startTimer\"\n      @click=\"onClick\"\n    >\n      <el-icon v-if=\"iconComponent\" :class=\"[ns.e('icon'), typeClass]\">\n        <component :is=\"iconComponent\" />\n      </el-icon>\n      <div :class=\"ns.e('group')\">\n        <h2 :class=\"ns.e('title')\" v-text=\"title\" />\n        <div\n          v-show=\"message\"\n          :class=\"ns.e('content')\"\n          :style=\"!!title ? undefined : { margin: 0 }\"\n        >\n          <slot>\n            <p v-if=\"!dangerouslyUseHTMLString\">{{ message }}</p>\n            <!-- Caution here, message could've been compromised, never use user's input as message -->\n            <p v-else v-html=\"message\" />\n          </slot>\n        </div>\n        <el-icon v-if=\"showClose\" :class=\"ns.e('closeBtn')\" @click.stop=\"close\">\n          <Close />\n        </el-icon>\n      </div>\n    </div>\n  </transition>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, onMounted, ref } from 'vue'\nimport { useEventListener, useTimeoutFn } from '@vueuse/core'\nimport { CloseComponents, TypeComponentsMap } from '@element-plus/utils'\nimport { EVENT_CODE } from '@element-plus/constants'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { useGlobalComponentSettings } from '@element-plus/components/config-provider'\nimport { notificationEmits, notificationProps } from './notification'\n\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n  name: 'ElNotification',\n})\n\nconst props = defineProps(notificationProps)\ndefineEmits(notificationEmits)\n\nconst { ns, zIndex } = useGlobalComponentSettings('notification')\nconst { nextZIndex, currentZIndex } = zIndex\n\nconst { Close } = CloseComponents\n\nconst visible = ref(false)\nlet timer: (() => void) | undefined = undefined\n\nconst typeClass = computed(() => {\n  const type = props.type\n  return type && TypeComponentsMap[props.type] ? ns.m(type) : ''\n})\n\nconst iconComponent = computed(() => {\n  if (!props.type) return props.icon\n  return TypeComponentsMap[props.type] || props.icon\n})\n\nconst horizontalClass = computed(() =>\n  props.position.endsWith('right') ? 'right' : 'left'\n)\n\nconst verticalProperty = computed(() =>\n  props.position.startsWith('top') ? 'top' : 'bottom'\n)\n\nconst positionStyle = computed<CSSProperties>(() => {\n  return {\n    [verticalProperty.value]: `${props.offset}px`,\n    zIndex: props.zIndex ?? currentZIndex.value,\n  }\n})\n\nfunction startTimer() {\n  if (props.duration > 0) {\n    ;({ stop: timer } = useTimeoutFn(() => {\n      if (visible.value) close()\n    }, props.duration))\n  }\n}\n\nfunction clearTimer() {\n  timer?.()\n}\n\nfunction close() {\n  visible.value = false\n}\n\nfunction onKeydown({ code }: KeyboardEvent) {\n  if (code === EVENT_CODE.delete || code === EVENT_CODE.backspace) {\n    clearTimer() // press delete/backspace clear timer\n  } else if (code === EVENT_CODE.esc) {\n    // press esc to close the notification\n    if (visible.value) {\n      close()\n    }\n  } else {\n    startTimer() // resume timer\n  }\n}\n\n// lifecycle\nonMounted(() => {\n  startTimer()\n  nextZIndex()\n  visible.value = true\n})\n\nuseEventListener(document, 'keydown', onKeydown)\n\ndefineExpose({\n  visible,\n  /** @description close notification */\n  close,\n})\n</script>\n", "import { createVNode, render } from 'vue'\nimport {\n  debugWarn,\n  isClient,\n  isElement,\n  isString,\n  isVNode,\n} from '@element-plus/utils'\nimport NotificationConstructor from './notification.vue'\nimport { notificationTypes } from './notification'\n\nimport type { AppContext, Ref, VNode } from 'vue'\nimport type {\n  NotificationOptions,\n  NotificationProps,\n  NotificationQueue,\n  Notify,\n  NotifyFn,\n} from './notification'\n\n// This should be a queue but considering there were `non-autoclosable` notifications.\nconst notifications: Record<\n  NotificationOptions['position'],\n  NotificationQueue\n> = {\n  'top-left': [],\n  'top-right': [],\n  'bottom-left': [],\n  'bottom-right': [],\n}\n\n// the gap size between each notification\nconst GAP_SIZE = 16\nlet seed = 1\n\nconst notify: NotifyFn & Partial<Notify> & { _context: AppContext | null } =\n  function (options = {}, context: AppContext | null = null) {\n    if (!isClient) return { close: () => undefined }\n\n    if (typeof options === 'string' || isVNode(options)) {\n      options = { message: options }\n    }\n\n    const position = options.position || 'top-right'\n\n    let verticalOffset = options.offset || 0\n    notifications[position].forEach(({ vm }) => {\n      verticalOffset += (vm.el?.offsetHeight || 0) + GAP_SIZE\n    })\n    verticalOffset += GAP_SIZE\n\n    const id = `notification_${seed++}`\n    const userOnClose = options.onClose\n    const props: Partial<NotificationProps> = {\n      ...options,\n      offset: verticalOffset,\n      id,\n      onClose: () => {\n        close(id, position, userOnClose)\n      },\n    }\n\n    let appendTo: HTMLElement | null = document.body\n    if (isElement(options.appendTo)) {\n      appendTo = options.appendTo\n    } else if (isString(options.appendTo)) {\n      appendTo = document.querySelector(options.appendTo)\n    }\n\n    // should fallback to default value with a warning\n    if (!isElement(appendTo)) {\n      debugWarn(\n        'ElNotification',\n        'the appendTo option is not an HTMLElement. Falling back to document.body.'\n      )\n      appendTo = document.body\n    }\n\n    const container = document.createElement('div')\n\n    const vm = createVNode(\n      NotificationConstructor,\n      props,\n      isVNode(props.message)\n        ? {\n            default: () => props.message,\n          }\n        : null\n    )\n    vm.appContext = context ?? notify._context\n\n    // clean notification element preventing mem leak\n    vm.props!.onDestroy = () => {\n      render(null, container)\n    }\n\n    // instances will remove this item when close function gets called. So we do not need to worry about it.\n    render(vm, container)\n    notifications[position].push({ vm })\n    appendTo.appendChild(container.firstElementChild!)\n\n    return {\n      // instead of calling the onClose function directly, setting this value so that we can have the full lifecycle\n      // for out component, so that all closing steps will not be skipped.\n      close: () => {\n        ;(vm.component!.exposed as { visible: Ref<boolean> }).visible.value =\n          false\n      },\n    }\n  }\nnotificationTypes.forEach((type) => {\n  notify[type] = (options = {}) => {\n    if (typeof options === 'string' || isVNode(options)) {\n      options = {\n        message: options,\n      }\n    }\n    return notify({\n      ...options,\n      type,\n    })\n  }\n})\n\n/**\n * This function gets called when user click `x` button or press `esc` or the time reached its limitation.\n * Emitted by transition@before-leave event so that we can fetch the current notification.offsetHeight, if this was called\n * by @after-leave the DOM element will be removed from the page thus we can no longer fetch the offsetHeight.\n * @param {String} id notification id to be closed\n * @param {Position} position the positioning strategy\n * @param {Function} userOnClose the callback called when close passed by user\n */\nexport function close(\n  id: string,\n  position: NotificationOptions['position'],\n  userOnClose?: (vm: VNode) => void\n): void {\n  // maybe we can store the index when inserting the vm to notification list.\n  const orientedNotifications = notifications[position]\n  const idx = orientedNotifications.findIndex(\n    ({ vm }) => vm.component?.props.id === id\n  )\n  if (idx === -1) return\n  const { vm } = orientedNotifications[idx]\n  if (!vm) return\n  // calling user's on close function before notification gets removed from DOM.\n  userOnClose?.(vm)\n\n  // note that this is called @before-leave, that's why we were able to fetch this property.\n  const removedHeight = vm.el!.offsetHeight\n  const verticalPos = position.split('-')[0]\n  orientedNotifications.splice(idx, 1)\n  const len = orientedNotifications.length\n  if (len < 1) return\n  // starting from the removing item.\n  for (let i = idx; i < len; i++) {\n    // new position equals the current offsetTop minus removed height plus 16px(the gap size between each item)\n    const { el, component } = orientedNotifications[i].vm\n    const pos =\n      Number.parseInt(el!.style[verticalPos], 10) - removedHeight - GAP_SIZE\n    component!.props.offset = pos\n  }\n}\n\nexport function closeAll(): void {\n  // loop through all directions, close them at once.\n  for (const orientedNotifications of Object.values(notifications)) {\n    orientedNotifications.forEach(({ vm }) => {\n      // same as the previous close method, we'd like to make sure lifecycle gets handle properly.\n      ;(vm.component!.exposed as { visible: Ref<boolean> }).visible.value =\n        false\n    })\n  }\n}\n\nnotify.closeAll = closeAll\nnotify._context = null\n\nexport default notify as Notify\n", "import { withInstallFunction } from '@element-plus/utils'\n\nimport Notify from './src/notify'\n\nexport const ElNotification = withInstallFunction(Notify, '$notify')\nexport default ElNotification\n\nexport * from './src/notification'\n", "import { ElInfiniteScroll } from '@element-plus/components/infinite-scroll'\nimport { ElLoading } from '@element-plus/components/loading'\nimport { ElMessage } from '@element-plus/components/message'\nimport { ElMessageBox } from '@element-plus/components/message-box'\nimport { ElNotification } from '@element-plus/components/notification'\nimport { ElPopoverDirective } from '@element-plus/components/popover'\n\nimport type { Plugin } from 'vue'\n\nexport default [\n  ElInfiniteScroll,\n  ElLoading,\n  ElMessage,\n  ElMessageBox,\n  ElNotification,\n  ElPopoverDirective,\n] as Plugin[]\n", "import { makeInstaller } from './make-installer'\nimport Components from './component'\nimport Plugins from './plugin'\n\nexport default makeInstaller([...Components, ...Plugins])\n", "import installer from './defaults'\nexport * from '@element-plus/components'\nexport * from '@element-plus/constants'\nexport * from '@element-plus/directives'\nexport * from '@element-plus/hooks'\nexport * from './make-installer'\n\nexport const install = installer.install\nexport const version = installer.version\nexport default installer\n\nexport { default as dayjs } from 'dayjs'\n"],
  "mappings": "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BAAA;AAChC,kBAAA,QAA2B;QACvB,UAAA;QACF,OAAA;QACA,QAAA,GAAA,cAAA,MAAA;QACF,MAAA,GAAA,cAAA,OAAA,UAAA,OAAA,YAAA,IAAA;QACM,KAAA,GAAE,cAAkB,MAAA,UAAA,MAAA,YAAA,GAAA;MAC1B;IACA;AACE,UAAA,sBAAgB,MAAA;AAChB,YAAA,UAAA,WAA0B;AAC1B,UAAA,SAAA,kBAAA,SAAA;AACF,gBAAA,QAAA;AACA;MAAgB;AAGL,YAAA,EAAA,QAAA,OAAAG,OAAA,IAAAL;AACX,iBAAO,QAAA,cAAA,SAAA,QAAAK,MAAA;AACP,UAAS,WAAA,SAAA,WAAA,MAAA,eAAA,IAAA;AACV,gBAAA,QAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACjRW,IAAC,YAAY,YAAY,OAAO;;;AC2G5C,IAAA,aAAe;EACb;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACAC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACF;;;AC/MY,IAACC,UAAQ;AACT,IAAC,iBAAiB;AAClB,IAAC,gBAAgB;AACjB,IAAC,mBAAmB;AAChC,IAAM,aAAa;EACjB,OAAO;IACL,MAAM;IACN,SAAS;EACb;EACE,UAAU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",
  "names": ["exports", "module", "s", "u", "a", "o", "c", "f", "h", "d", "l", "M", "t", "e", "n", "m", "r", "v", "i", "D", "p", "S", "_", "w", "O", "b", "$", "y", "g", "exports", "module", "o", "s", "e", "a", "t", "f", "n", "h", "u", "r", "i", "d", "c", "l", "m", "M", "Y", "p", "v", "D", "exports", "module", "o", "n", "u", "e", "t", "r", "i", "a", "s", "f", "d", "exports", "module", "e", "t", "r", "s", "a", "exports", "module", "f", "i", "n", "s", "a", "o", "e", "exports", "module", "e", "t", "exports", "module", "e", "t", "exports", "module", "e", "t", "exports", "module", "e", "i", "computed", "a", "b", "fn", "_a", "result", "isFunction", "isString", "filter", "fn", "reject", "filter", "invoke", "reject", "fn", "v", "update", "get", "isFunction", "set", "result", "v2", "fn", "fn", "fn", "isVue2", "_a", "target", "isString", "fn", "register", "window", "target2", "_a", "window", "document", "update", "target", "window", "_a", "document", "target", "_a", "window", "left", "right", "x", "update", "target", "_a", "window", "a", "b", "props", "_a", "clone", "isVue2", "isFunction", "getValue", "v", "window", "window", "update", "offset", "parent", "b", "c", "d", "Symbol", "result", "objectProto", "nativeObjectToString", "symToStringTag", "array", "iteratee", "result", "isArray", "result", "result", "string", "string", "isObject", "type", "NAN", "INFINITY", "result", "identity", "isFunction", "uid", "funcProto", "objectProto", "funcToString", "hasOwnProperty", "pattern", "object", "object", "object", "result", "result", "fn", "result", "nativeMax", "result", "offset", "array", "result", "noop", "objectProto", "hasOwnProperty", "result", "array", "array", "result", "objectProto", "hasOwnProperty", "string", "array", "iteratee", "array", "array", "array", "array", "WRAP_BIND_FLAG", "WRAP_BIND_FLAG", "WRAP_BIND_KEY_FLAG", "WRAP_CURRY_FLAG", "WRAP_PARTIAL_FLAG", "WRAP_PARTIAL_RIGHT_FLAG", "ary", "result", "object", "type", "array", "array", "result", "WRAP_BIND_FLAG", "WRAP_BIND_KEY_FLAG", "WRAP_CURRY_FLAG", "WRAP_CURRY_RIGHT_FLAG", "WRAP_ARY_FLAG", "WRAP_FLIP_FLAG", "ary", "fn", "fn", "WRAP_BIND_FLAG", "fn", "PLACEHOLDER", "WRAP_BIND_FLAG", "WRAP_BIND_KEY_FLAG", "WRAP_CURRY_BOUND_FLAG", "WRAP_CURRY_FLAG", "WRAP_ARY_FLAG", "WRAP_REARG_FLAG", "nativeMin", "FUNC_ERROR_TEXT", "WRAP_BIND_FLAG", "WRAP_BIND_KEY_FLAG", "WRAP_CURRY_FLAG", "WRAP_CURRY_RIGHT_FLAG", "WRAP_PARTIAL_FLAG", "WRAP_PARTIAL_RIGHT_FLAG", "nativeMax", "ary", "result", "WRAP_ARY_FLAG", "object", "objectProto", "hasOwnProperty", "object", "props", "object", "nativeMax", "transform", "array", "MAX_SAFE_INTEGER", "object", "type", "object", "objectProto", "iteratee", "result", "objectProto", "hasOwnProperty", "argsTag", "funcTag", "freeExports", "freeModule", "moduleExports", "types", "objectProto", "hasOwnProperty", "result", "transform", "objectProto", "hasOwnProperty", "object", "result", "keys", "object", "objectProto", "hasOwnProperty", "object", "object", "result", "objectProto", "hasOwnProperty", "object", "result", "object", "object", "object", "object", "object", "type", "result", "objectProto", "hasOwnProperty", "result", "objectProto", "hasOwnProperty", "HASH_UNDEFINED", "array", "Map", "type", "map", "result", "size", "FUNC_ERROR_TEXT", "cache", "result", "result", "cache", "string", "result", "number", "object", "INFINITY", "result", "object", "object", "result", "object", "result", "array", "values", "offset", "array", "result", "array", "objectTag", "funcProto", "objectProto", "funcToString", "hasOwnProperty", "isPlainObject", "errorTag", "FUNC_ERROR_TEXT", "result", "WRAP_BIND_FLAG", "WRAP_PARTIAL_FLAG", "object", "WRAP_BIND_FLAG", "WRAP_BIND_KEY_FLAG", "WRAP_PARTIAL_FLAG", "object", "array", "end", "result", "array", "end", "string", "string", "rsAstralRange", "rsComboMarksRange", "reComboHalfMarksRange", "rsComboSymbolsRange", "rsComboRange", "rsVarRange", "rsZWJ", "string", "string", "string", "capitalize", "string", "array", "iteratee", "object", "rsComboMarksRange", "reComboHalfMarksRange", "rsComboSymbolsRange", "rsComboRange", "rsCombo", "string", "string", "string", "rsAstralRange", "rsComboMarksRange", "reComboHalfMarksRange", "rsComboSymbolsRange", "rsComboRange", "rsVarRange", "rsCombo", "rsFitz", "rsModifier", "rsNonAstral", "rsRegional", "rsSurrPair", "rsZWJ", "reOptMod", "rsOptVar", "rsOptJoin", "rsSeq", "string", "string", "pattern", "rsApos", "string", "result", "nativeMin", "number", "result", "nativeMax", "array", "size", "result", "number", "clamp", "number", "result", "object", "object", "freeExports", "freeModule", "moduleExports", "Buffer", "result", "array", "result", "objectProto", "propertyIsEnumerable", "object", "object", "nativeGetSymbols", "object", "result", "object", "object", "result", "object", "object", "Promise", "Set", "mapTag", "objectTag", "setTag", "weakMapTag", "dataViewTag", "result", "objectProto", "hasOwnProperty", "array", "result", "Uint8Array", "result", "regexp", "result", "symbolProto", "boolTag", "dateTag", "mapTag", "numberTag", "regexpTag", "setTag", "stringTag", "symbolTag", "arrayBufferTag", "dataViewTag", "float32Tag", "float64Tag", "int8Tag", "int16Tag", "int32Tag", "uint8Tag", "uint8ClampedTag", "uint16Tag", "uint32Tag", "object", "object", "mapTag", "setTag", "argsTag", "arrayTag", "boolTag", "dateTag", "errorTag", "funcTag", "genTag", "mapTag", "numberTag", "objectTag", "regexpTag", "setTag", "stringTag", "symbolTag", "weakMapTag", "arrayBufferTag", "dataViewTag", "float32Tag", "float64Tag", "int8Tag", "int16Tag", "int32Tag", "uint8Tag", "uint8ClampedTag", "uint16Tag", "uint32Tag", "object", "result", "key", "props", "CLONE_SYMBOLS_FLAG", "CLONE_DEEP_FLAG", "CLONE_SYMBOLS_FLAG", "CLONE_DEEP_FLAG", "CLONE_SYMBOLS_FLAG", "CLONE_SYMBOLS_FLAG", "array", "result", "array", "HASH_UNDEFINED", "values", "array", "cache", "array", "result", "othValue", "map", "result", "set", "result", "COMPARE_PARTIAL_FLAG", "COMPARE_UNORDERED_FLAG", "boolTag", "dateTag", "errorTag", "mapTag", "numberTag", "regexpTag", "setTag", "stringTag", "symbolTag", "arrayBufferTag", "dataViewTag", "symbolProto", "symbolValueOf", "object", "result", "COMPARE_PARTIAL_FLAG", "objectProto", "hasOwnProperty", "object", "result", "COMPARE_PARTIAL_FLAG", "argsTag", "arrayTag", "objectTag", "objectProto", "hasOwnProperty", "object", "COMPARE_PARTIAL_FLAG", "COMPARE_UNORDERED_FLAG", "object", "result", "object", "result", "object", "object", "object", "object", "result", "object", "COMPARE_PARTIAL_FLAG", "COMPARE_UNORDERED_FLAG", "object", "object", "object", "FUNC_ERROR_TEXT", "object", "props", "props", "object", "CLONE_DEEP_FLAG", "object", "array", "iteratee", "object", "iteratee", "props", "object", "iteratee", "iteratee", "iteratee", "collection", "iteratee", "objectProto", "hasOwnProperty", "result", "result", "WRAP_CURRY_FLAG", "result", "WRAP_CURRY_RIGHT_FLAG", "result", "FUNC_ERROR_TEXT", "nativeMax", "nativeMin", "result", "objectProto", "hasOwnProperty", "object", "props", "object", "object", "object", "object", "object", "object", "FUNC_ERROR_TEXT", "array", "LARGE_ARRAY_SIZE", "array", "values", "iteratee", "includes", "result", "computed", "array", "values", "array", "array", "values", "iteratee", "array", "values", "array", "array", "array", "array", "array", "iteratee", "array", "iteratee", "object", "iteratee", "iteratee", "string", "target", "end", "object", "props", "set", "result", "mapTag", "setTag", "object", "string", "reRegExpChar", "string", "array", "result", "collection", "MAX_ARRAY_LENGTH", "array", "end", "array", "end", "result", "collection", "iteratee", "nativeMax", "array", "result", "collection", "object", "nativeMax", "nativeMin", "array", "object", "array", "iteratee", "result", "collection", "iteratee", "iteratee", "INFINITY", "iteratee", "iteratee", "INFINITY", "array", "array", "WRAP_FLIP_FLAG", "FUNC_ERROR_TEXT", "WRAP_CURRY_FLAG", "WRAP_PARTIAL_FLAG", "WRAP_ARY_FLAG", "WRAP_REARG_FLAG", "index", "result", "object", "iteratee", "object", "iteratee", "object", "iteratee", "object", "iteratee", "result", "object", "props", "object", "object", "objectProto", "hasOwnProperty", "result", "objectProto", "hasOwnProperty", "object", "object", "nativeMax", "nativeMin", "number", "end", "number", "end", "stringTag", "isString", "object", "props", "object", "nativeMax", "nativeMax", "array", "array", "nativeMin", "iteratee", "includes", "result", "array", "computed", "cache", "iteratee", "object", "iteratee", "object", "iteratee", "objectProto", "nativeObjectToString", "result", "objectProto", "hasOwnProperty", "nativeObjectToString", "result", "object", "object", "result", "arrayBufferTag", "boolTag", "dateTag", "isDate", "mapTag", "setTag", "objectProto", "hasOwnProperty", "result", "nativeIsFinite", "object", "object", "numberTag", "isNumber", "isNaN", "regexpTag", "MAX_SAFE_INTEGER", "weakMapTag", "CLONE_DEEP_FLAG", "arrayProto", "array", "result", "result", "array", "nativeMax", "nativeMin", "array", "result", "object", "iteratee", "result", "object", "iteratee", "result", "CLONE_DEEP_FLAG", "CLONE_DEEP_FLAG", "array", "iteratee", "computed", "result", "array", "array", "iteratee", "array", "iteratee", "result", "NAN", "array", "iteratee", "array", "array", "iteratee", "object", "object", "object", "array", "array", "iteratee", "object", "props", "chain", "result", "FUNC_ERROR_TEXT", "result", "mapTag", "setTag", "array", "array", "object", "CLONE_DEEP_FLAG", "CLONE_FLAT_FLAG", "CLONE_SYMBOLS_FLAG", "object", "result", "object", "object", "result", "object", "props", "object", "array", "object", "result", "iteratee", "result", "collection", "object", "iteratee", "nativeMin", "MAX_SAFE_INTEGER", "string", "result", "rsAstralRange", "rsComboMarksRange", "reComboHalfMarksRange", "rsComboSymbolsRange", "rsComboRange", "rsVarRange", "rsAstral", "rsCombo", "rsFitz", "rsModifier", "rsNonAstral", "rsRegional", "rsSurrPair", "rsZWJ", "reOptMod", "rsOptVar", "rsOptJoin", "rsSeq", "rsSymbol", "reUnicode", "string", "result", "string", "nativeCeil", "result", "nativeCeil", "nativeFloor", "string", "string", "string", "reTrimStart", "parseInt", "string", "WRAP_PARTIAL_FLAG", "WRAP_PARTIAL_RIGHT_FLAG", "result", "object", "object", "result", "parent", "clone", "object", "array", "arrayProto", "splice", "array", "values", "iteratee", "indexOf", "computed", "array", "values", "array", "values", "iteratee", "array", "values", "arrayProto", "splice", "array", "array", "result", "nativeFloor", "nativeMin", "nativeRandom", "nativeCeil", "nativeMax", "end", "result", "end", "WRAP_REARG_FLAG", "iteratee", "collection", "iteratee", "array", "iteratee", "iteratee", "array", "result", "string", "string", "FUNC_ERROR_TEXT", "object", "arrayProto", "array", "array", "array", "size", "array", "array", "set", "object", "object", "array", "mapTag", "setTag", "array", "end", "result", "result", "collection", "MAX_ARRAY_LENGTH", "nativeFloor", "nativeMin", "array", "iteratee", "computed", "MAX_ARRAY_LENGTH", "array", "computed", "array", "array", "iteratee", "array", "array", "array", "iteratee", "array", "array", "iteratee", "result", "computed", "array", "array", "iteratee", "MAX_ARRAY_LENGTH", "string", "FUNC_ERROR_TEXT", "nativeMax", "array", "result", "string", "target", "array", "array", "iteratee", "array", "array", "array", "array", "array", "objectProto", "hasOwnProperty", "object", "objectProto", "hasOwnProperty", "string", "offset", "result", "FUNC_ERROR_TEXT", "MAX_SAFE_INTEGER", "MAX_ARRAY_LENGTH", "nativeMin", "iteratee", "result", "result", "MAX_SAFE_INTEGER", "object", "iteratee", "string", "end", "string", "end", "reTrimStart", "string", "reFlags", "string", "end", "result", "string", "INFINITY", "values", "LARGE_ARRAY_SIZE", "array", "iteratee", "includes", "result", "set", "computed", "iteratee", "array", "array", "iteratee", "array", "object", "nativeMax", "array", "array", "iteratee", "result", "object", "object", "object", "result", "object", "array", "values", "object", "array", "iteratee", "result", "array", "iteratee", "props", "values", "result", "props", "values", "props", "values", "iteratee", "result", "result", "nativeMax", "nativeMin", "end", "size", "nativeMin", "array", "end", "result", "iteratee", "type", "computed", "WRAP_BIND_KEY_FLAG", "LAZY_FILTER_FLAG", "MAX_ARRAY_LENGTH", "arrayProto", "objectProto", "hasOwnProperty", "symIterator", "nativeMax", "nativeMin", "mixin", "object", "props", "result", "type", "iteratee", "end", "value", "isUndefined", "isBoolean", "isNumber", "isEmpty", "isElement", "fn", "string", "capitalize", "toCapitalize", "m", "message", "_a", "computed", "isNumber", "s", "parent", "_a", "timestamp", "target", "target", "values", "required", "type", "props", "fn", "component", "ref", "SCOPE", "SCOPE", "type", "props", "result", "_a", "castArray", "throttle", "useAttrs", "_a", "version", "ref", "type", "draggable", "transform", "_a", "_", "_a", "b", "m", "be", "object", "scrollBarWidth", "updateEventKeyRaw", "props", "hide", "isBoolean", "_a", "o", "a", "s", "f", "c", "at", "u", "m", "v", "l", "h", "p", "x", "d", "b", "w", "O", "A", "D", "S", "lt", "M", "T", "_", "Y", "gt", "F", "_a", "attributes", "throttle", "fn", "delay", "close", "isNumber", "initial", "isNumber", "min", "max", "round", "floor", "v", "clamp", "end", "bt", "direction", "platform", "x", "fn", "min", "max", "offset", "clamp", "flip", "platform", "placements", "sides", "side", "d", "a", "b", "placement", "overflow", "platform", "x", "y", "min", "max", "clamp", "isElement", "getComputedStyle", "result", "getComputedStyle", "round", "isElement", "x", "left", "max", "cache", "result", "min", "window", "root", "floor", "update", "shift", "flip", "arrow", "computePosition", "cache", "x", "update", "computePosition", "arrowCore", "_a", "uid", "p", "target", "_a", "isElement", "_a", "SCOPE", "props", "isEmptyValue", "_a", "zIndex", "size", "global", "a", "b", "keys", "props", "version", "install", "c", "version", "isNumber", "isBoolean", "props", "target", "target", "root", "transform", "offset", "props", "update", "target2", "difference", "handleScroll", "_a", "size", "props", "isUndefined", "props", "close", "size", "globalConfig", "props", "_a", "message", "isBoolean", "SCOPE", "max", "props", "ensureArray", "COMPONENT_NAME", "inline", "props", "props2", "result", "_a", "formatRegExp", "warning", "process", "env", "window", "document", "type", "errors", "console", "warn", "ASYNC_VALIDATOR_NO_WARNING", "every", "e", "convertFieldsError", "length", "fields", "forEach", "error", "field", "push", "format", "template", "args", "i", "len", "apply", "str", "replace", "x", "String", "Number", "JSON", "stringify", "_", "isNativeStringType", "isEmptyValue", "value", "undefined", "Array", "isArray", "asyncParallelArray", "arr", "func", "callback", "results", "total", "arrLength", "count", "a", "asyncSerialArray", "index", "next", "original", "flattenObjArr", "objArr", "ret", "Object", "keys", "k", "AsyncValidationError", "Error", "asyncMap", "option", "source", "first", "pending", "Promise", "resolve", "reject", "flattenArr", "firstFields", "objArrKeys", "objArrLength", "key", "indexOf", "isErrorObj", "obj", "message", "getValue", "path", "v", "complementError", "rule", "oe", "fieldValue", "fullFields", "fullField", "deepMerge", "target", "s", "hasOwnProperty", "required", "options", "messages", "whitespace", "test", "urlReg", "word", "b", "includeBoundaries", "v4", "v6seg", "v6", "trim", "v46Exact", "RegExp", "v4exact", "v6exact", "ip", "exact", "protocol", "auth", "ipv4", "ipv6", "host", "domain", "tld", "port", "regex", "pattern", "email", "hex", "types", "integer", "number", "parseInt", "array", "regexp", "date", "getTime", "getMonth", "getYear", "isNaN", "object", "method", "match", "url", "getUrlRegex", "custom", "ruleType", "range", "min", "max", "spRegexp", "val", "num", "ENUM", "enumerable", "join", "lastIndex", "mismatch", "_pattern", "enumRule", "string", "validate", "rules", "boolean", "floatFn", "dateObject", "Date", "any", "float", "enumValidator", "newMessages", "parse", "invalid", "clone", "cloned", "Schema", "descriptor", "_messages", "defaultMessages", "define", "name", "item", "source_", "o", "oc", "complete", "add", "concat", "series", "z", "r", "transform", "validator", "getValidationMethod", "getType", "errorFields", "data", "doIt", "deep", "defaultField", "addFullField", "schema", "cb", "errorList", "suppressWarning", "filledErrors", "map", "fieldsSchema", "paredFieldsSchema", "fieldSchema", "fieldSchemaList", "bind", "errs", "finalErrors", "res", "asyncValidator", "suppressValidatorError", "setTimeout", "then", "validators", "messageIndex", "splice", "register", "COMPONENT_NAME", "defineComponent", "name", "props", "isAutoWidth", "Boolean", "updateAll", "slots", "formContext", "inject", "throwError", "ns", "useNamespace", "el", "ref", "computedWidth", "getLabelWidth", "_a", "width", "window", "getComputedStyle", "value", "firstElementChild", "Math", "ceil", "Number", "parseFloat", "nextTick", "action", "onMounted", "updateLabelWidthFn", "onBeforeUnmount", "onUpdated", "watch", "registerLabelWidth", "useResizeObserver", "computed", "hasLabel", "style", "autoLabelWidth", "marginWidth", "max", "parseInt", "labelPosition", "formItemContext", "marginPosition", "_createVNode", "be", "_Fragment", "props", "isBoolean", "required", "rules", "ensureArray", "_a", "_a", "result", "isNumber", "useRawAttrs", "props", "useAttrs", "_a", "IconView", "IconHide", "type", "size", "COMPONENT_NAME", "props", "_a", "offset", "handleScroll", "wrap", "update", "props", "isNumber", "COMPONENT_NAME", "props", "handleScroll", "_a", "isNumber", "update", "props", "props", "NAME", "OnlyChild", "defineComponent", "name", "slots", "attrs", "_a", "forwardRefInjection", "inject", "FORWARD_REF_INJECTION_KEY", "forwardRefDirective", "useForwardRefDirective", "setForwardRef", "NOOP", "_a2", "defaultSlot", "debugWarn", "firstLegitNode", "findFirstLegitChild", "node", "children", "child", "isObject", "Fragment", "_createVNode", "s", "props", "isElement", "_a", "obtainAllFocusableElements", "last", "remove", "_a", "_sfc_main", "props", "focusReason", "last", "target", "obtainAllFocusableElements", "_renderSlot", "props", "offset", "props", "_a", "offset", "update", "attributes", "props", "attributes", "isNumber", "props", "_a", "props", "attributes", "update", "isElement", "type", "props", "_sfc_main", "Teleport", "Teleport", "props", "_a", "_a", "hide", "props", "isBoolean", "COMPONENT_NAME", "useAttrs", "useRawAttrs", "readonly", "props", "getData", "result", "_a", "close", "isNumber", "size", "props", "isNumber", "props", "componentName", "handleScroll", "_a", "COMPONENT_NAME", "props", "props", "isNumber", "_a", "props", "props", "props", "globalConfig", "_a", "max", "a", "c", "b", "max", "min", "h", "s", "l", "d", "p", "q", "v", "f", "hex", "a", "d", "h", "a", "s", "v", "l", "format", "TinyColor", "_a", "R", "G", "B", "s", "h", "v", "l", "b", "x", "hex", "format", "p", "result", "props", "props", "props", "format", "a", "b", "date", "isEmpty", "dayjs", "total", "method", "_a", "props", "end", "date", "result", "_", "_a", "d", "isValidValue", "target", "values", "date", "result", "type", "method", "props", "handlers", "isElement", "delay", "_a", "N", "E", "U", "h", "X", "I", "P", "fn", "props", "type", "range", "left", "right", "now", "total", "handleScroll", "props", "isUndefined", "isValidValue", "dayjs", "result", "end", "left", "right", "up", "down", "date", "getDefaultValue", "end", "result", "props", "date", "isValidValue", "_", "dayjs", "offset", "left", "right", "up", "down", "d", "getDefaultValue", "dayjs", "extend", "customParseFormat", "defineComponent", "name", "install", "props", "isRange", "type", "default", "setup", "commonPicker", "modelUpdater", "value", "_a", "provide", "expose", "handleFocusInput", "_createVNode", "Picker", "_mergeProps", "handleOpen", "format", "handleClose", "date", "_", "props", "dayjs", "localeData", "now", "end", "_", "type", "date", "now", "props", "type", "date", "end", "props", "componentName", "now", "dayjs", "date", "result", "_", "type", "range", "COMPONENT_NAME", "date", "props", "isNumber", "props", "componentName", "root", "_a", "arrow", "COMPONENT_NAME", "root", "props", "props", "translate", "_a", "isUndefined", "uid", "translate", "props", "transform", "isNumber", "isBoolean", "_a", "max", "min", "isUndefined", "props", "_a", "target", "props", "isUndefined", "_a", "props", "isBoolean", "o", "_a", "props", "_a", "props", "props", "_a", "props", "isNumber", "isBoolean", "props", "size", "size", "props", "size", "props", "props", "_sfc_main", "props", "_a", "isLeaf", "uid", "_resolveComponent", "_openBlock", "_normalizeClass", "_createCommentVNode", "_createBlock", "_withModifiers", "_createElementVNode", "_createVNode", "_createElementBlock", "_Fragment", "_sfc_main", "props", "isEmpty", "left", "_createBlock", "_normalizeClass", "_a", "_openBlock", "_createElementBlock", "_Fragment", "_renderList", "_createVNode", "_withCtx", "_createTextVNode", "_toDisplayString", "_renderSlot", "parent", "Node", "root", "isEmpty", "isLeaf", "isUndefined", "capitalize", "c", "p", "Node", "props", "_sfc_main", "props", "isEmpty", "Node", "parent", "_a", "values", "castArray", "target", "_sfc_render", "_resolveComponent", "_openBlock", "_createElementBlock", "_normalizeClass", "_Fragment", "_renderList", "_createBlock", "type", "round", "props", "_", "isBoolean", "COMPONENT_NAME", "props", "_a", "readonly", "genTag", "rest", "target", "isBoolean", "props", "props", "size", "props", "isNumber", "isNumber", "props", "ensureArray", "props", "on", "props", "_a", "props", "_a", "props", "_a", "target", "left", "b", "update", "COMPONENT_NAME", "props", "update", "_sfc_main", "props", "update", "target", "left", "_createElementBlock", "_normalizeClass", "_createElementVNode", "_normalizeStyle", "isOnePointZero", "isPercentage", "bound01", "max", "b", "hex", "v", "min", "h", "d", "s", "f", "p", "q", "format", "_sfc_main", "props", "c", "_createElementBlock", "_normalizeClass", "_createElementVNode", "_openBlock", "_Fragment", "_renderList", "_normalizeStyle", "_sfc_main", "props", "update", "left", "_createElementBlock", "_normalizeClass", "_normalizeStyle", "_createElementVNode", "props", "_a", "b", "hide", "props", "props", "props", "props", "isValidRange", "range", "left", "right", "dayjs", "unit", "d", "now", "date", "type", "props", "_", "castArray", "offset", "d", "end", "dayjs", "_a", "date", "column", "target", "defineComponent", "name", "props", "basicCellProps", "ns", "slots", "inject", "ROOT_PICKER_INJECTION_KEY", "cell", "_createVNode", "_a", "props", "props", "_", "_a", "now", "dayjs", "castArray", "date", "target", "column", "d", "dayjs", "props", "_a", "now", "castArray", "d", "date", "target", "column", "_", "dayjs", "date", "props", "type", "result", "getDefaultValue", "now", "isValidValue", "parseDate", "_a", "up", "down", "left", "right", "home", "end", "pageUp", "pageDown", "map", "dayjs", "props", "unit", "isValidRange", "end", "format", "dayjs", "props", "isValidValue", "date", "isValidRange", "close", "type", "_", "format", "dayjs", "unit", "props", "close", "_", "isValidRange", "dayjs", "props", "close", "isValidRange", "format", "getDefaultValue", "left", "right", "unit", "_", "isValidValue", "date", "type", "dayjs", "extend", "localeData", "advancedFormat", "customParseFormat", "weekOfYear", "weekYear", "dayOfYear", "isSameOrAfter", "isSameOrBefore", "defineComponent", "name", "install", "props", "datePickerProps", "emits", "expose", "emit", "slots", "provide", "pickerNs", "commonPicker", "focus", "_a", "handleOpen", "handleClose", "onModelValueUpdated", "val", "format", "DEFAULT_FORMATS_DATEPICKER", "getPanel", "_createVNode", "_a", "direction", "_a2", "props", "_a", "DescriptionsItem", "props", "props", "draggable", "isBoolean", "props", "_a", "zIndex", "close", "hide", "_a2", "zIndex", "props", "draggable", "_a", "props", "zIndex", "props", "isHorizontal", "DO_defineComponent", "_renderSlot", "DO_defineComponent", "_renderSlot", "COLLECTION_INJECTION_KEY", "COLLECTION_ITEM_INJECTION_KEY", "ElCollection", "a", "b", "ElCollectionItem", "_", "array", "_", "_sfc_main", "props", "_a", "ROVING_FOCUS_COLLECTION_INJECTION_KEY", "_a2", "target", "_sfc_main", "ElFocusGroupCollection", "_createBlock", "_withCtx", "_createVNode", "_renderSlot", "_sfc_main", "ElRovingFocusCollectionItem", "props", "ROVING_FOCUS_COLLECTION_INJECTION_KEY", "target", "_createBlock", "_renderSlot", "ElCollection", "ElCollectionItem", "COLLECTION_INJECTION_KEY", "COLLECTION_ITEM_INJECTION_KEY", "ElButtonGroup", "_sfc_main", "ElDropdownCollection", "ElOnlyChild", "props", "ensureArray", "_a", "_resolveComponent", "_openBlock", "_createElementBlock", "_normalizeClass", "_createVNode", "_createSlots", "_withCtx", "_renderSlot", "_createBlock", "_mergeProps", "_sfc_main", "_", "DROPDOWN_COLLECTION_ITEM_INJECTION_KEY", "ROVING_FOCUS_ITEM_COLLECTION_INJECTION_KEY", "_openBlock", "_createElementBlock", "_mergeProps", "_createCommentVNode", "_createElementVNode", "_withModifiers", "_createBlock", "_withCtx", "_resolveDynamicComponent", "_renderSlot", "_sfc_main", "ElDropdownCollectionItem", "props", "_a", "target", "_resolveComponent", "_openBlock", "_createBlock", "_withCtx", "_createVNode", "_mergeProps", "_sfc_main", "props", "size", "DROPDOWN_COLLECTION_INJECTION_KEY", "ROVING_FOCUS_COLLECTION_INJECTION_KEY", "_a", "target", "_openBlock", "_createElementBlock", "_normalizeClass", "_normalizeStyle", "_withModifiers", "_renderSlot", "props", "isNumber", "props", "transform", "zIndex", "_a", "hide", "_a2", "isNumber", "useRawAttrs", "useAttrs", "props", "_a", "isElement", "Image", "isNumber", "props", "isNumber", "isUndefined", "update", "max", "min", "_a", "props", "parent", "_sfc_main", "_openBlock", "_createBlock", "_Transition", "_mergeProps", "_withCtx", "_renderSlot", "parent", "props", "props", "COMPONENT_NAME", "SubMenu", "props", "_a", "_a2", "Menu", "props", "close", "_a", "debounce", "fn", "Menubar", "ElSubMenu", "vClickoutside", "COMPONENT_NAME", "_sfc_main", "props", "_createElementBlock", "_normalizeClass", "_createBlock", "_withCtx", "_renderSlot", "_createElementVNode", "_Fragment", "COMPONENT_NAME", "_sfc_main", "_createElementBlock", "_normalizeClass", "_createElementVNode", "_Fragment", "_createTextVNode", "_toDisplayString", "_renderSlot", "Menu", "MenuItem", "SubMenu", "props", "props", "props", "ensureArray", "_a", "target", "regexp", "_sfc_main", "props", "_createElementBlock", "_normalizeClass", "_withModifiers", "_renderSlot", "_createElementVNode", "_sfc_main", "_a", "_openBlock", "_createElementBlock", "_normalizeClass", "_normalizeStyle", "_renderSlot", "_createCommentVNode", "props", "_a", "isEmptyValue", "debounce", "updateOptions", "isUndefined", "ensureArray", "isNumber", "result", "isNull", "isUndefined2", "lodashDebounce", "it", "target", "direction", "_", "_a", "_a2", "COMPONENT_NAME", "_sfc_main", "ElOption", "props", "_createElementBlock", "_normalizeClass", "_toHandlerKey", "_createVNode", "_withCtx", "_a", "_createElementVNode", "_withModifiers", "_openBlock", "_renderSlot", "_createCommentVNode", "_Fragment", "_renderList", "_normalizeStyle", "_createBlock", "_withDirectives", "_withKeys", "_vModelText", "_toDisplayString", "_vShow", "_sfc_main", "props", "_a", "flattedChildren", "ensureArray", "_sfc_render", "_withDirectives", "_openBlock", "_createElementBlock", "_normalizeClass", "_createElementVNode", "_toDisplayString", "props", "_a", "_a", "props", "array", "offset", "target", "v", "isNumber", "props", "_a", "handleCurrentChange", "addClass", "c", "_a", "props", "isBoolean", "props", "_a", "hide", "props", "offset", "a", "b", "_a", "isNumber", "map", "a", "b", "props", "result", "target", "props", "isEqual", "cache", "props", "_", "layout", "offset", "offset2", "isRTL", "renderThumbStyle", "size", "layout", "translate", "props", "GAP", "renderThumbStyle", "attachEvents", "isDragging", "offset", "v", "getOffset", "getEstimatedTotalSize", "props", "isNumber", "total", "cache", "size", "offset", "_a", "direction", "itemSize", "layout", "window", "initScrollOffset", "end", "Container", "Scrollbar", "buildList", "itemSize", "total", "layout", "size", "offset", "SCOPE", "props", "itemSize", "offset", "size", "total", "estimatedItemSize", "_", "layout", "cache", "_a", "x", "getEstimatedTotalHeight", "getEstimatedTotalWidth", "props", "cache", "isNumber", "_a", "isRTL", "onUpdated", "offset", "x", "scrollBarWidth", "direction", "left", "Scrollbar", "column", "Container", "SCOPE", "_", "scrollBarWidth", "left", "isNumber", "max", "min", "floor", "SCOPE", "getItemFromCache", "props", "type", "offset", "size", "bs", "es", "total", "findItem", "cache", "column", "scrollBarWidth", "_a", "isUndefined", "isNumber", "_sfc_main", "_createElementBlock", "_normalizeClass", "_normalizeStyle", "_toDisplayString", "useOption", "props", "props", "getValue", "SelectProps", "isNumber", "_sfc_main", "props", "useOption", "_createElementBlock", "_normalizeStyle", "_normalizeClass", "_withModifiers", "_renderSlot", "_createElementVNode", "_toDisplayString", "props", "loading", "Boolean", "data", "type", "Array", "required", "hoveringIndex", "Number", "width", "ElSelectMenu", "defineComponent", "name", "slots", "expose", "select", "ns", "getLabel", "getValue", "getDisabled", "cachedHeights", "listRef", "size", "computed", "watch", "_a", "tooltipRef", "value", "isSized", "isUndefined", "estimatedOptionHeight", "listProps", "itemSize", "itemHeight", "estimatedSize", "target", "contains", "valueKey", "isObject", "arr", "isEqual", "item", "selected", "get", "isItemSelected", "modelValue", "isItemDisabled", "multipleLimit", "isItemHovering", "resetScrollTop", "list", "Item", "style", "_createVNode", "_mergeProps", "onSelect", "onHover", "sized", "default", "onKeyboardSelect", "onForward", "onBackward", "onEscOrTab", "onKeydown", "code", "up", "enter", "EVENT_CODE", "e", "props", "getValue", "it", "MINIMUM_INPUT_WIDTH", "useSelect", "props", "getValue", "isEmptyValue", "_a", "debounce", "o", "regexp", "updateOptions", "lodashDebounce", "update", "it", "direction", "v", "_sfc_main", "ElSelectMenu", "SelectProps", "props", "useSelect", "_createElementBlock", "_normalizeClass", "_createVNode", "_withCtx", "_createElementVNode", "_withModifiers", "_renderSlot", "_createCommentVNode", "_openBlock", "_Fragment", "_renderList", "_normalizeStyle", "_createTextVNode", "_toDisplayString", "_createBlock", "_withKeys", "_vModelText", "_withDirectives", "_resolveDynamicComponent", "_createSlots", "Select", "props", "isNumber", "props", "props", "a", "b", "props", "_a", "props", "min", "max", "getClientXY", "props", "result", "_", "props", "_a", "isNumber", "props", "props", "props", "props", "props", "size", "wrap", "fill", "h", "v", "isNumber", "isNumber", "props", "Item", "_a", "direction", "formatter", "props", "isNumber", "integer", "isNumber", "timeUnits", "isNumber", "timestamp", "format", "unit", "props", "formatter", "timestamp", "isNumber", "props", "parent", "props", "_a", "isNumber", "isBoolean", "isNumber", "COMPONENT_NAME", "props", "_a", "isBoolean", "result", "_a", "orderBy", "array", "reverse", "sortBy", "a", "b", "column", "matches", "rowKey", "arrayMap", "defaults", "type", "isBoolean", "root", "isNil", "parent", "props", "after", "columns", "offset", "direction", "getOffset", "rowKey", "rowKey", "rowKey", "keys", "parent", "_a", "orderBy", "columns", "result", "column", "_a", "rowKey", "_a2", "isUndefined", "treeProps", "rowKey2", "columns2", "values", "keys", "type", "array", "column", "_a", "parent", "column2", "values", "props", "keys", "columns", "column", "_a", "ElCheckboxGroup", "_sfc_main", "props", "parent", "_a", "filter", "_resolveComponent", "_resolveDirective", "_openBlock", "_createBlock", "_withCtx", "_createElementBlock", "_createElementVNode", "_normalizeClass", "_createVNode", "_Fragment", "_renderList", "_toDisplayString", "_withDirectives", "root", "layout", "_a", "column", "props", "parent", "column", "isElement", "target", "_a", "props", "parent", "column", "_a", "columns", "result", "column", "parent", "props", "props", "parent", "column", "a", "b", "props", "parent", "_a", "column", "range", "left", "right", "props", "parent", "column", "offset", "fn", "result", "columns", "props", "parent", "type", "rowKey", "columns", "column", "parent2", "defaultProps", "defaultProps", "props", "parent", "_a", "_a2", "useStyle", "props", "columns", "columns2", "column", "props", "columns", "useStyle", "column", "values", "useUtils", "useStyle", "props", "layout", "isHidden", "rowKey", "column", "_a", "fn", "_a", "defaultProps", "props", "columns", "column", "offset", "isNumber", "left", "_sfc_main", "defaultProps", "props", "layout", "isEmpty", "useUtils", "isHidden", "useStyle", "_a", "columns", "_resolveComponent", "_resolveDirective", "_openBlock", "_createElementBlock", "_normalizeClass", "_normalizeStyle", "_renderSlot", "_withDirectives", "_createElementVNode", "_createVNode", "_createCommentVNode", "_withCtx", "_createBlock", "_createTextVNode", "_vShow", "type", "column", "_a", "property", "props", "useWatcher", "useRender", "props", "parent", "column", "type", "_a", "v", "columns", "props2", "defaultProps", "defaultProps", "props", "parent2", "useWatcher", "useRender", "parent", "type", "isUndefined", "defaults", "column", "_a", "TableColumn", "ElTableColumn", "column", "_a", "props", "columns", "column", "_a", "sortBy", "useScrollbar", "props", "_a", "props", "isNumber", "_a", "rowKey", "props", "rowKey", "array", "x", "expandColumnKey", "sum2", "sum", "props", "useStyles", "props", "total", "isNumber", "column", "sum", "_a", "props", "left", "right", "_a", "props", "columns", "useScrollbar", "useStyles", "rowKey", "slots", "_a", "cellData", "style", "props", "displayText", "toString", "defaultSlot", "renderSlot", "_createVNode", "class", "TableV2Cell", "displayName", "slots", "renderSlot", "props", "column", "title", "_a", "HeaderCell", "inheritAttrs", "TableV2HeaderRow", "defineComponent", "name", "props", "tableV2HeaderRowProps", "slots", "columns", "columnsStyles", "headerIndex", "style", "column", "Cells", "map", "columnIndex", "header", "cells", "node", "COMPONENT_NAME", "TableV2Header", "defineComponent", "name", "props", "tableV2HeaderProps", "slots", "expose", "ns", "headerRef", "ref", "width", "height", "computed", "ensureArray", "headerHeights", "scrollToLeft", "nextTick", "headerEl", "left", "renderFixedRows", "rowHeight", "fixedHeaderData", "style", "_a", "class", "columns", "rowData", "rowIndex", "renderDynamicRows", "unref", "headerIndex", "_createVNode", "headerStyle", "useTableRow", "isScrolling", "inject", "TableV2InjectionKey", "measured", "rowRef", "isNumber", "props", "doMeasure", "columns", "onRowHeightChange", "rowKey", "rowIndex", "style", "height", "$rowRef", "getBoundingClientRect", "value", "nextTick", "firstColumn", "placeholderSign", "rowData", "onRowHover", "handlers", "rowEventHandlers", "eventHandlers", "Object", "forEach", "eventName", "isFunction", "handler", "event", "name", "hovered", "onExpand", "onRowExpand", "onMounted", "COMPONENT_NAME", "TableV2Row", "attrs", "measurable", "expose", "column", "expandColumnKey", "ColumnCells", "expandable", "slots", "depth", "unref", "cells", "isArray", "node", "_createVNode", "_mergeProps", "SortIcon", "sortOrder", "_createVNode", "props", "ExpandIcon", "expanded", "expandable", "onExpand", "style", "size", "onClick", "props", "_createVNode", "_mergeProps", "COMPONENT_NAME", "useTableGrid", "props", "headerRef", "ref", "bodyRef", "data", "rowHeight", "estimatedRowHeight", "sum", "headerHeight", "gridHeight", "height", "Math", "max", "unref", "hasHeader", "itemKey", "rowIndex", "rowCacheStart", "_a", "rowCacheEnd", "rowVisibleEnd", "isObject", "header$", "scrollToLeft", "scrollLeft", "scrollTop", "top", "scrollToTop", "forceUpdate", "fixedRowHeight", "scrollToRow", "TableGrid", "name", "expose", "ns", "inject", "onItemRendered", "resetAfterRowIndex", "scrollTo", "columns", "isNumber", "_createVNode", "cache", "fixedData", "useIsScrolling", "scrollbarAlwaysOn", "scrollbarEndGap", "scrollbarStartGap", "style", "bodyWidth", "headerWidth", "width", "onScroll", "isDynamicRowEnabled", "Grid", "Header", "MainTable", "slots", "rest", "props", "mainTableRef", "LeftTable", "slots", "leftTableRef", "rest", "_createVNode", "Table", "_mergeProps", "LeftTable", "slots", "rightTableRef", "rest", "_createVNode", "Table", "_mergeProps", "RowRenderer", "slots", "columns", "columnsStyles", "depthMap", "expandColumnKey", "expandedRowKeys", "estimatedRowHeight", "hasFixedColumns", "rowData", "rowIndex", "style", "isScrolling", "rowProps", "rowClass", "rowKey", "rowEventHandlers", "ns", "props", "onRowExpanded", "_rowKey", "depth", "canExpand", "Boolean", "isFixedRow", "kls", "e", "is", "class", "handlerMosueEnter", "onRowHover", "hovered", "event", "handlerMouseLeave", "_isSlot", "CellRenderer", "column", "columns", "columnIndex", "depth", "expandIconProps", "isScrolling", "rowData", "rowIndex", "style", "expandedRowKeys", "ns", "cellProps", "indentSize", "rowKey", "slots", "cellRenderer", "dataKey", "dataGetter", "cellData", "class", "_createVNode", "TableCell", "expandColumnKey", "columnCellRenderer", "Cell", "kls", "_mergeProps", "expanded", "includes", "iconStyle", "IconOrPlaceholder", "HeaderRenderer", "columns", "columnsStyles", "headerIndex", "style", "headerProps", "ns", "slots", "kls", "extraProps", "class", "_createVNode", "HeaderRow", "_isSlot", "enforceUnit", "HeaderCellRenderer", "slots", "column", "ns", "props", "onColumnSorted", "_createVNode", "cellStyle", "headerClass", "sortable", "class", "Cell", "sortBy", "headerCellProps", "sorting", "sortOrder", "_mergeProps", "cellKls", "slots", "_a", "_createVNode", "props", "class", "style", "default", "slots", "_createVNode", "renderSlot", "props", "class", "Footer", "slots", "_a", "_createVNode", "props", "class", "style", "default", "Empty", "Overlay", "s", "_isVNode", "COMPONENT_NAME", "TableV2", "name", "props", "expose", "columnsStyles", "fixedColumnsOnLeft", "fixedColumnsOnRight", "mainColumns", "mainTableHeight", "fixedTableHeight", "leftTableWidth", "rightTableWidth", "data", "depthMap", "expandedRowKeys", "hasFixedColumns", "mainTableRef", "leftTableRef", "rightTableRef", "isDynamic", "isResetting", "isScrolling", "bodyWidth", "emptyStyle", "rootStyle", "headerWidth", "footerHeight", "showEmpty", "scrollTo", "scrollToLeft", "scrollToTop", "scrollToRow", "getRowHeight", "onColumnSorted", "onRowExpanded", "onRowsRendered", "onScroll", "onVerticalScroll", "useTable", "cache", "expandColumnKey", "sortBy", "rowKey", "rowProps", "cellProps", "estimatedRowHeight", "fixedData", "headerHeight", "headerClass", "headerProps", "headerCellProps", "sortState", "rowHeight", "rowClass", "rowEventHandlers", "scrollbarAlwaysOn", "indentSize", "iconSize", "useIsScrolling", "width", "class", "columns", "height", "scrollbarStartGap", "scrollbarEndGap", "vScrollbarSize", "ns", "unref", "props2", "_createVNode", "Cell", "_mergeProps", "_isSlot", "onRowHeightChange", "Header", "HeaderCell", "_columnsStyles", "row", "cell", "Footer", "header", "slots", "AutoResizer", "defineComponent", "name", "props", "autoResizerProps", "slots", "ns", "height", "width", "sizer", "useAutoResize", "_a", "_createVNode", "b", "style", "default", "value", "COMPONENT_NAME", "offset", "props", "_a", "capitalize", "update", "tabNavProps", "buildProps", "panes", "type", "definePropType", "Array", "default", "mutable", "currentName", "String", "Number", "editable", "Boolean", "values", "stretch", "tabNavEmits", "tabClick", "tab", "tabName", "ev", "Event", "tabRemove", "COMPONENT_NAME", "TabNav", "defineComponent", "name", "props", "emits", "expose", "emit", "ns", "useNamespace", "visibility", "useDocumentVisibility", "focused", "useWindowFocus", "navScroll$", "ref", "nav$", "el$", "tabBarRef", "scrollable", "navOffset", "isFocus", "focusable", "sizeName", "computed", "includes", "rootTabs", "tabPosition", "navStyle", "dir", "value", "transform", "scrollPrev", "containerSize", "capitalize", "currentOffset", "newOffset", "scrollNext", "activeTab", "navScroll", "navScrollBounding", "maxOffset", "isHorizontal", "offsetWidth", "activeTabBounding", "right", "top", "bottom", "max", "update", "_a", "navSize", "prev", "changeTab", "left", "up", "down", "tabList", "currentIndex", "nextIndex", "preventScroll", "setFocus", "watch", "_createVNode", "setTimeout", "useResizeObserver", "onUpdated", "removeFocus", "uid", "e", "pane", "index", "disabled", "btnClose", "delete", "backspace", "tabLabelContent", "tabsProps", "buildProps", "type", "values", "default", "closable", "addable", "modelValue", "isNumber", "editable", "tabPosition", "props", "_a", "beforeLeave", "definePropType", "stretch", "Boolean", "isUndefined", "isPaneName", "name", "ev", "tabChange", "tabRemove", "defineComponent", "emits", "expose", "ns", "useNamespace", "children", "addChild", "removeChild", "getCurrentInstance", "nav$", "ref", "currentName", "setCurrentName", "value", "_a2", "trigger", "emit", "handleTabClick", "render", "pane", "handleTabAdd", "_createVNode", "watch", "scrollToActiveTab", "panes", "unregisterPane", "TabNavRenderer", "newButton", "COMPONENT_NAME", "props", "_a", "props", "isUndefined", "Text", "values", "formatTime", "dayjs", "customParseFormat", "ElOption", "props", "formatTime", "end", "result", "_a", "_", "props", "props", "_a", "isNumber", "props", "props", "props", "x", "update", "zIndex", "arrow", "forwardRefProps", "buildProps", "setRef", "type", "definePropType", "Function", "required", "onlyChild", "Boolean", "props", "slots", "fragmentRef", "composeRefs", "_a", "_createVNode", "_Fragment", "props", "type", "props", "direction", "props", "props", "v", "props", "o", "props", "direction", "props", "isEmpty", "props", "_a", "parent", "props", "Node", "isLeaf", "target", "ref", "array", "defaultProps", "reject", "Node", "a", "b", "cache", "keys", "_a", "array", "_sfc_main", "props", "props", "props", "_a", "_sfc_main", "NodeContent", "Node", "props", "getNodeKey", "getNodeKeyUtil", "_createElementBlock", "_normalizeClass", "_withModifiers", "_createElementVNode", "_normalizeStyle", "_openBlock", "_createBlock", "_resolveDynamicComponent", "_createCommentVNode", "_createVNode", "_withCtx", "_Fragment", "_renderList", "_vShow", "_a", "_sfc_main", "props", "root", "isEmpty", "filter", "getNodeKey", "getNodeKeyUtil", "parent", "keys", "remove", "_createElementBlock", "_normalizeClass", "_openBlock", "_Fragment", "_renderList", "_createBlock", "_renderSlot", "_a", "_createElementVNode", "_createCommentVNode", "_withDirectives", "useSelect", "props", "_a", "result", "props", "result", "isValidValue", "parent", "find", "useTree", "props", "_a", "array", "parent", "isValidValue", "_a2", "isEmpty", "h", "TreeSelectOption", "regexp", "props", "_a", "_sfc_main", "props", "useSelect", "treeProps", "useTree", "itemSize", "useCheck", "props", "keys", "props", "_a", "filter", "useTree", "props", "setData", "useCheck", "_a", "parent", "filter", "keys", "handleCurrentChange", "offset", "props", "_a", "props", "props", "filter", "setData", "useTree", "SCOPE", "message", "method", "url", "props", "COMPONENT_NAME", "props", "method", "uid", "SCOPE", "_a", "props", "before", "url", "revokeFileObjectURL", "props", "uploadContentProps", "x", "left", "right", "_a", "props", "size", "target", "left", "_a", "right", "useFloating", "offset", "zIndex", "x", "offsetMiddelware", "flip", "shift", "arrow", "update", "computePosition", "arrow2", "_a", "props", "v", "props", "useFloating", "props", "_a", "result", "total", "_a2", "isBoolean", "isNumber", "total", "props", "_a", "isBoolean", "total", "props", "_a", "isUndefined", "props", "target", "max", "handleScroll", "isUndefined", "left", "direction", "props", "isNumber", "isBoolean", "props", "getValue", "_a", "pattern", "lowerCase", "split", "ensureArray", "end", "computed", "v", "pattern", "props", "direction", "_a", "target", "props", "filterOption", "_a", "direction", "pattern", "split", "ElTableColumn", "SCOPE", "_a", "type", "delay", "target", "_a", "close", "_", "zIndex", "_a", "target", "parent", "property", "_a", "getProp", "offset", "zIndex", "props", "type", "offset", "close", "isElement", "isBoolean", "isNumber", "props", "_a", "type", "Message", "_sfc_main", "props", "zIndex", "type", "_a", "_a2", "draggable", "_resolveComponent", "_openBlock", "_createBlock", "_Transition", "_withCtx", "_withDirectives", "_createVNode", "_createElementVNode", "_normalizeClass", "_normalizeStyle", "_withModifiers", "_createCommentVNode", "_toDisplayString", "_createElementBlock", "_withKeys", "_renderSlot", "_resolveDynamicComponent", "_createTextVNode", "_vShow", "props", "isElement", "reject", "message", "isUndefined", "_", "zIndex", "type", "props", "_a", "close", "seed", "_a", "props", "isElement", "type", "component", "closeAll", "Notify", "version"]
}