{"version":3,"file":"Picker-4061cdf2.js","sources":["../../../node_modules/framesync/dist/es/on-next-frame.js","../../../node_modules/framesync/dist/es/create-render-step.js","../../../node_modules/framesync/dist/es/index.js","../../../node_modules/lodash-es/toFinite.js","../../../node_modules/lodash-es/toInteger.js","../../../node_modules/lodash-es/noop.js","../../../node_modules/lodash-es/_baseFindIndex.js","../../../node_modules/lodash-es/_baseIsNaN.js","../../../node_modules/lodash-es/_strictIndexOf.js","../../../node_modules/lodash-es/_baseIndexOf.js","../../../node_modules/lodash-es/_arrayIncludes.js","../../../node_modules/lodash-es/_isFlattenable.js","../../../node_modules/lodash-es/_baseFlatten.js","../../../node_modules/lodash-es/flatten.js","../../../node_modules/lodash-es/_flatRest.js","../../../node_modules/lodash-es/_arrayReduce.js","../../../node_modules/lodash-es/_baseIsMatch.js","../../../node_modules/lodash-es/_isStrictComparable.js","../../../node_modules/lodash-es/_getMatchData.js","../../../node_modules/lodash-es/_matchesStrictComparable.js","../../../node_modules/lodash-es/_baseMatches.js","../../../node_modules/lodash-es/_baseHasIn.js","../../../node_modules/lodash-es/_hasPath.js","../../../node_modules/lodash-es/hasIn.js","../../../node_modules/lodash-es/_baseMatchesProperty.js","../../../node_modules/lodash-es/_baseProperty.js","../../../node_modules/lodash-es/_basePropertyDeep.js","../../../node_modules/lodash-es/property.js","../../../node_modules/lodash-es/_baseIteratee.js","../../../node_modules/lodash-es/_baseForOwn.js","../../../node_modules/lodash-es/_createBaseEach.js","../../../node_modules/lodash-es/_baseEach.js","../../../node_modules/lodash-es/_arrayIncludesWith.js","../../../node_modules/lodash-es/_castFunction.js","../../../node_modules/lodash-es/_baseHas.js","../../../node_modules/lodash-es/has.js","../../../node_modules/lodash-es/isString.js","../../../node_modules/lodash-es/isEmpty.js","../../../node_modules/lodash-es/_customOmitClone.js","../../../node_modules/lodash-es/omit.js","../../../node_modules/lodash-es/_basePickBy.js","../../../node_modules/lodash-es/_basePick.js","../../../node_modules/lodash-es/pick.js","../../../node_modules/lodash-es/_baseReduce.js","../../../node_modules/lodash-es/reduce.js","../../../node_modules/lodash-es/times.js","../../../node_modules/lodash-es/toPath.js","../../../node_modules/lodash-es/_createSet.js","../../../node_modules/lodash-es/_baseUniq.js","../../../node_modules/lodash-es/union.js","../../src/components/editor/dialog/DialogAttributeBadge.tsx","../../src/utils/date.ts","../../src/components/TextField.tsx","../../src/components/styles/previews/GeneratedPreview.tsx","../../../node_modules/react-use-memo-with-comparator/dist/react-use-memo-with-comparator.esm.js","../../src/components/styles/previews/GeneratedPreviewExternal.tsx","../../src/components/styles/previews/index.tsx","../../src/components/styles/fields/FileField.tsx","../../src/components/editor/dialog/DialogAttributesStatic.tsx","../../src/components/PickerWizard.tsx","../../src/components/DatasourceBadge.tsx","../../src/components/DataItem.tsx","../../src/components/picker/PickerDatasourcesSource.tsx","../../src/components/datasources/DatasourceTreeLeafWrapper.tsx","../../src/components/datasources/DatasourceTree.tsx","../../../node_modules/jsonpath-plus/dist/index-browser-esm.js","../../src/components/datasources/DatasourceTreeLeafContent.tsx","../../src/components/picker/PickerDatasourcesPath.tsx","../../src/components/styles/fields/NumberField.tsx","../../src/components/picker/PickerDatasourcesItems.tsx","../../src/components/editor/dialog/DialogAttributesMapping.tsx","../../src/components/editor/dialog/DialogAttributes.tsx","../../src/components/styles/fields/SwitchGroupField.tsx","../../src/components/editor/dialog/DialogAttributesFallback.tsx","../../src/components/editor/dialog/DialogStyleBadge.tsx","../../src/components/editor/dialog/DialogStyleElementBadge.tsx","../../src/components/styles/fields/SizeField.tsx","../../src/components/editor/dialog/DialogStyleDimensions.tsx","../../src/components/editor/dialog/DialogStyleGrid.tsx","../../src/svg/Horizontally-Center.svg","../../src/svg/Horizontally-Distribute.svg","../../src/svg/Horizontally-Justify.svg","../../src/svg/Horizontally-Left.svg","../../src/svg/Horizontally-Right.svg","../../src/svg/Horizontally-Stretch.svg","../../src/svg/Vertical-Space-Between.svg","../../src/svg/Vertically-Bottom.svg","../../src/svg/Vertically-Center.svg","../../src/svg/Vertically-Stretch.svg","../../src/svg/Vertically-Top.svg","../../src/components/editor/dialog/DialogStyleLayout.tsx","../../src/components/styles/fields/AlignmentField.tsx","../../src/components/editor/dialog/DialogStyleMediaSizing.tsx","../../src/components/editor/dialog/DialogStyleSpacing.tsx","../../src/components/editor/dialog/DialogStyleTextAlignment.tsx","../../src/components/editor/dialog/Dialog.tsx","../../../node_modules/jsonpointer/jsonpointer.js","../../../node_modules/lodash/_listCacheClear.js","../../../node_modules/lodash/eq.js","../../../node_modules/lodash/_assocIndexOf.js","../../../node_modules/lodash/_listCacheDelete.js","../../../node_modules/lodash/_listCacheGet.js","../../../node_modules/lodash/_listCacheHas.js","../../../node_modules/lodash/_listCacheSet.js","../../../node_modules/lodash/_ListCache.js","../../../node_modules/lodash/_stackClear.js","../../../node_modules/lodash/_stackDelete.js","../../../node_modules/lodash/_stackGet.js","../../../node_modules/lodash/_stackHas.js","../../../node_modules/lodash/_freeGlobal.js","../../../node_modules/lodash/_root.js","../../../node_modules/lodash/_Symbol.js","../../../node_modules/lodash/_getRawTag.js","../../../node_modules/lodash/_objectToString.js","../../../node_modules/lodash/_baseGetTag.js","../../../node_modules/lodash/isObject.js","../../../node_modules/lodash/isFunction.js","../../../node_modules/lodash/_coreJsData.js","../../../node_modules/lodash/_isMasked.js","../../../node_modules/lodash/_toSource.js","../../../node_modules/lodash/_baseIsNative.js","../../../node_modules/lodash/_getValue.js","../../../node_modules/lodash/_getNative.js","../../../node_modules/lodash/_Map.js","../../../node_modules/lodash/_nativeCreate.js","../../../node_modules/lodash/_hashClear.js","../../../node_modules/lodash/_hashDelete.js","../../../node_modules/lodash/_hashGet.js","../../../node_modules/lodash/_hashHas.js","../../../node_modules/lodash/_hashSet.js","../../../node_modules/lodash/_Hash.js","../../../node_modules/lodash/_mapCacheClear.js","../../../node_modules/lodash/_isKeyable.js","../../../node_modules/lodash/_getMapData.js","../../../node_modules/lodash/_mapCacheDelete.js","../../../node_modules/lodash/_mapCacheGet.js","../../../node_modules/lodash/_mapCacheHas.js","../../../node_modules/lodash/_mapCacheSet.js","../../../node_modules/lodash/_MapCache.js","../../../node_modules/lodash/_stackSet.js","../../../node_modules/lodash/_Stack.js","../../../node_modules/lodash/_arrayEach.js","../../../node_modules/lodash/_defineProperty.js","../../../node_modules/lodash/_baseAssignValue.js","../../../node_modules/lodash/_assignValue.js","../../../node_modules/lodash/_copyObject.js","../../../node_modules/lodash/_baseTimes.js","../../../node_modules/lodash/isObjectLike.js","../../../node_modules/lodash/_baseIsArguments.js","../../../node_modules/lodash/isArguments.js","../../../node_modules/lodash/isArray.js","../../../node_modules/lodash/stubFalse.js","../../../node_modules/lodash/isBuffer.js","../../../node_modules/lodash/_isIndex.js","../../../node_modules/lodash/isLength.js","../../../node_modules/lodash/_baseIsTypedArray.js","../../../node_modules/lodash/_baseUnary.js","../../../node_modules/lodash/_nodeUtil.js","../../../node_modules/lodash/isTypedArray.js","../../../node_modules/lodash/_arrayLikeKeys.js","../../../node_modules/lodash/_isPrototype.js","../../../node_modules/lodash/_overArg.js","../../../node_modules/lodash/_nativeKeys.js","../../../node_modules/lodash/_baseKeys.js","../../../node_modules/lodash/isArrayLike.js","../../../node_modules/lodash/keys.js","../../../node_modules/lodash/_baseAssign.js","../../../node_modules/lodash/_nativeKeysIn.js","../../../node_modules/lodash/_baseKeysIn.js","../../../node_modules/lodash/keysIn.js","../../../node_modules/lodash/_baseAssignIn.js","../../../node_modules/lodash/_cloneBuffer.js","../../../node_modules/lodash/_copyArray.js","../../../node_modules/lodash/_arrayFilter.js","../../../node_modules/lodash/stubArray.js","../../../node_modules/lodash/_getSymbols.js","../../../node_modules/lodash/_copySymbols.js","../../../node_modules/lodash/_arrayPush.js","../../../node_modules/lodash/_getPrototype.js","../../../node_modules/lodash/_getSymbolsIn.js","../../../node_modules/lodash/_copySymbolsIn.js","../../../node_modules/lodash/_baseGetAllKeys.js","../../../node_modules/lodash/_getAllKeys.js","../../../node_modules/lodash/_getAllKeysIn.js","../../../node_modules/lodash/_DataView.js","../../../node_modules/lodash/_Promise.js","../../../node_modules/lodash/_Set.js","../../../node_modules/lodash/_WeakMap.js","../../../node_modules/lodash/_getTag.js","../../../node_modules/lodash/_initCloneArray.js","../../../node_modules/lodash/_Uint8Array.js","../../../node_modules/lodash/_cloneArrayBuffer.js","../../../node_modules/lodash/_cloneDataView.js","../../../node_modules/lodash/_cloneRegExp.js","../../../node_modules/lodash/_cloneSymbol.js","../../../node_modules/lodash/_cloneTypedArray.js","../../../node_modules/lodash/_initCloneByTag.js","../../../node_modules/lodash/_baseCreate.js","../../../node_modules/lodash/_initCloneObject.js","../../../node_modules/lodash/_baseIsMap.js","../../../node_modules/lodash/isMap.js","../../../node_modules/lodash/_baseIsSet.js","../../../node_modules/lodash/isSet.js","../../../node_modules/lodash/_baseClone.js","../../../node_modules/lodash/cloneDeep.js","../../../node_modules/lodash/_setCacheAdd.js","../../../node_modules/lodash/_setCacheHas.js","../../../node_modules/lodash/_SetCache.js","../../../node_modules/lodash/_arraySome.js","../../../node_modules/lodash/_cacheHas.js","../../../node_modules/lodash/_equalArrays.js","../../../node_modules/lodash/_mapToArray.js","../../../node_modules/lodash/_setToArray.js","../../../node_modules/lodash/_equalByTag.js","../../../node_modules/lodash/_equalObjects.js","../../../node_modules/lodash/_baseIsEqualDeep.js","../../../node_modules/lodash/_baseIsEqual.js","../../../node_modules/lodash/isEqual.js","../../../node_modules/lodash/_isFlattenable.js","../../../node_modules/lodash/_baseFlatten.js","../../../node_modules/lodash/_arrayMap.js","../../../node_modules/lodash/isSymbol.js","../../../node_modules/lodash/_isKey.js","../../../node_modules/lodash/memoize.js","../../../node_modules/lodash/_memoizeCapped.js","../../../node_modules/lodash/_stringToPath.js","../../../node_modules/lodash/_baseToString.js","../../../node_modules/lodash/toString.js","../../../node_modules/lodash/_castPath.js","../../../node_modules/lodash/_toKey.js","../../../node_modules/lodash/_baseGet.js","../../../node_modules/lodash/_baseIsMatch.js","../../../node_modules/lodash/_isStrictComparable.js","../../../node_modules/lodash/_getMatchData.js","../../../node_modules/lodash/_matchesStrictComparable.js","../../../node_modules/lodash/_baseMatches.js","../../../node_modules/lodash/get.js","../../../node_modules/lodash/_baseHasIn.js","../../../node_modules/lodash/_hasPath.js","../../../node_modules/lodash/hasIn.js","../../../node_modules/lodash/_baseMatchesProperty.js","../../../node_modules/lodash/identity.js","../../../node_modules/lodash/_baseProperty.js","../../../node_modules/lodash/_basePropertyDeep.js","../../../node_modules/lodash/property.js","../../../node_modules/lodash/_baseIteratee.js","../../../node_modules/lodash/_createBaseFor.js","../../../node_modules/lodash/_baseFor.js","../../../node_modules/lodash/_baseForOwn.js","../../../node_modules/lodash/_createBaseEach.js","../../../node_modules/lodash/_baseEach.js","../../../node_modules/lodash/_baseMap.js","../../../node_modules/lodash/_baseSortBy.js","../../../node_modules/lodash/_compareAscending.js","../../../node_modules/lodash/_compareMultiple.js","../../../node_modules/lodash/_baseOrderBy.js","../../../node_modules/lodash/_apply.js","../../../node_modules/lodash/_overRest.js","../../../node_modules/lodash/constant.js","../../../node_modules/lodash/_baseSetToString.js","../../../node_modules/lodash/_shortOut.js","../../../node_modules/lodash/_setToString.js","../../../node_modules/lodash/_baseRest.js","../../../node_modules/lodash/_isIterateeCall.js","../../../node_modules/lodash/sortBy.js","../../../node_modules/lodash/_baseFindIndex.js","../../../node_modules/lodash/_baseIsNaN.js","../../../node_modules/lodash/_strictIndexOf.js","../../../node_modules/lodash/_baseIndexOf.js","../../../node_modules/lodash/_arrayIncludes.js","../../../node_modules/lodash/_arrayIncludesWith.js","../../../node_modules/lodash/noop.js","../../../node_modules/lodash/_createSet.js","../../../node_modules/lodash/_baseUniq.js","../../../node_modules/lodash/uniq.js","../../../node_modules/lodash/uniqWith.js","../../../node_modules/lodash/defaults.js","../../../node_modules/lodash/_baseIntersection.js","../../../node_modules/lodash/isArrayLikeObject.js","../../../node_modules/lodash/_castArrayLikeObject.js","../../../node_modules/lodash/last.js","../../../node_modules/lodash/intersectionWith.js","../../../node_modules/lodash/isPlainObject.js","../../../node_modules/lodash/isBoolean.js","../../../node_modules/json-schema-compare/src/index.js","../../../node_modules/validate.io-array/lib/index.js","../../../node_modules/validate.io-number/lib/index.js","../../../node_modules/validate.io-integer/lib/index.js","../../../node_modules/validate.io-integer-array/lib/index.js","../../../node_modules/validate.io-function/lib/index.js","../../../node_modules/compute-gcd/lib/index.js","../../../node_modules/compute-lcm/lib/index.js","../../../node_modules/lodash/_assignMergeValue.js","../../../node_modules/lodash/_safeGet.js","../../../node_modules/lodash/toPlainObject.js","../../../node_modules/lodash/_baseMergeDeep.js","../../../node_modules/lodash/_baseMerge.js","../../../node_modules/lodash/_customDefaultsMerge.js","../../../node_modules/lodash/_createAssigner.js","../../../node_modules/lodash/mergeWith.js","../../../node_modules/lodash/defaultsDeep.js","../../../node_modules/lodash/flatten.js","../../../node_modules/lodash/flattenDeep.js","../../../node_modules/lodash/intersection.js","../../../node_modules/lodash/_baseIndexOfWith.js","../../../node_modules/lodash/_basePullAll.js","../../../node_modules/lodash/pullAll.js","../../../node_modules/lodash/_castFunction.js","../../../node_modules/lodash/forEach.js","../../../node_modules/lodash/_baseDifference.js","../../../node_modules/lodash/without.js","../../../node_modules/json-schema-merge-allof/src/common.js","../../../node_modules/json-schema-merge-allof/src/complex-resolvers/properties.js","../../../node_modules/json-schema-merge-allof/src/complex-resolvers/items.js","../../../node_modules/json-schema-merge-allof/src/index.js","../../../node_modules/@rjsf/utils/node_modules/react-is/cjs/react-is.development.js","../../../node_modules/@rjsf/utils/node_modules/react-is/index.js","../../../node_modules/@rjsf/utils/dist/utils.esm.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/codegen/code.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/codegen/scope.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/codegen/index.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/util.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/names.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/errors.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/validate/boolSchema.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/rules.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/validate/applicability.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/validate/dataType.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/validate/defaults.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/code.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/validate/keyword.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/validate/subschema.js","../../../node_modules/fast-deep-equal/index.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/json-schema-traverse/index.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/resolve.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/validate/index.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/runtime/validation_error.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/ref_error.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/compile/index.js","../../../node_modules/uri-js/dist/es5/uri.all.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/runtime/uri.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/core.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/core/id.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/core/ref.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/core/index.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/validation/limitNumber.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/validation/multipleOf.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/runtime/ucs2length.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/validation/limitLength.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/validation/pattern.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/validation/limitProperties.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/validation/required.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/validation/limitItems.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/runtime/equal.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/validation/uniqueItems.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/validation/const.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/validation/enum.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/validation/index.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/additionalItems.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/items.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/prefixItems.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/items2020.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/contains.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/dependencies.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/propertyNames.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/additionalProperties.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/properties.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/patternProperties.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/not.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/anyOf.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/oneOf.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/allOf.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/if.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/thenElse.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/applicator/index.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/format/format.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/format/index.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/metadata.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/draft7.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/discriminator/types.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/vocabularies/discriminator/index.js","../../../node_modules/@rjsf/validator-ajv8/node_modules/ajv/dist/ajv.js","../../../node_modules/ajv-formats/dist/formats.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/codegen/code.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/codegen/scope.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/codegen/index.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/util.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/names.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/errors.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/validate/boolSchema.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/rules.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/validate/applicability.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/validate/dataType.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/validate/defaults.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/code.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/validate/keyword.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/validate/subschema.js","../../../node_modules/ajv-formats/node_modules/json-schema-traverse/index.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/resolve.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/validate/index.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/runtime/validation_error.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/ref_error.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/compile/index.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/runtime/uri.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/core.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/core/id.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/core/ref.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/core/index.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/validation/limitNumber.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/validation/multipleOf.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/runtime/ucs2length.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/validation/limitLength.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/validation/pattern.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/validation/limitProperties.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/validation/required.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/validation/limitItems.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/runtime/equal.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/validation/uniqueItems.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/validation/const.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/validation/enum.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/validation/index.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/additionalItems.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/items.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/prefixItems.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/items2020.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/contains.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/dependencies.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/propertyNames.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/additionalProperties.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/properties.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/patternProperties.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/not.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/anyOf.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/oneOf.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/allOf.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/if.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/thenElse.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/applicator/index.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/format/format.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/format/index.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/metadata.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/draft7.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/discriminator/types.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/vocabularies/discriminator/index.js","../../../node_modules/ajv-formats/node_modules/ajv/dist/ajv.js","../../../node_modules/ajv-formats/dist/limit.js","../../../node_modules/ajv-formats/dist/index.js","../../../node_modules/@rjsf/validator-ajv8/dist/validator-ajv8.esm.js","../../../node_modules/nanoid/index.browser.js","../../../node_modules/markdown-to-jsx/dist/index.modern.js","../../../node_modules/@rjsf/core/dist/core.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/react-use-safe-layout-effect/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/color-mode/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/styled-system/dist/index.esm.js","../../../node_modules/@chakra-ui/react-utils/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/utils/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/system/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/react-context/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/react-use-merge-refs/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/shared-utils/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/icon/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/react-use-callback-ref/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/react-use-controllable-state/dist/index.esm.js","../../../node_modules/@chakra-ui/alert/node_modules/@chakra-ui/react-context/dist/index.esm.js","../../../node_modules/@chakra-ui/alert/node_modules/@chakra-ui/shared-utils/dist/index.esm.js","../../../node_modules/@chakra-ui/alert/node_modules/@chakra-ui/icon/dist/index.esm.js","../../../node_modules/@chakra-ui/alert/dist/index.esm.js","../../../node_modules/@chakra-ui/button/node_modules/@chakra-ui/react-use-merge-refs/dist/index.esm.js","../../../node_modules/@chakra-ui/button/node_modules/@chakra-ui/react-context/dist/index.esm.js","../../../node_modules/@chakra-ui/button/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/form-control/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/react-use-update-effect/dist/index.esm.js","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/visually-hidden/dist/index.esm.js","../../../node_modules/@zag-js/focus-visible/dist/index.mjs","../../../node_modules/@chakra-ui/react/node_modules/@chakra-ui/checkbox/dist/index.esm.js","../../../node_modules/@chakra-ui/counter/node_modules/@chakra-ui/react-use-callback-ref/dist/index.esm.js","../../../node_modules/@chakra-ui/counter/node_modules/@chakra-ui/number-utils/dist/index.esm.js","../../../node_modules/@chakra-ui/counter/dist/index.esm.js","../../../node_modules/@chakra-ui/react-use-event-listener/node_modules/@chakra-ui/react-use-callback-ref/dist/index.esm.js","../../../node_modules/@chakra-ui/react-use-event-listener/dist/index.esm.js","../../../node_modules/@chakra-ui/input/node_modules/@chakra-ui/react-context/dist/index.esm.js","../../../node_modules/@chakra-ui/input/node_modules/@chakra-ui/react-use-merge-refs/dist/index.esm.js","../../../node_modules/@chakra-ui/input/node_modules/@chakra-ui/shared-utils/dist/index.esm.js","../../../node_modules/@chakra-ui/input/node_modules/@chakra-ui/icon/dist/index.esm.js","../../../node_modules/@chakra-ui/input/node_modules/@chakra-ui/form-control/dist/index.esm.js","../../../node_modules/@chakra-ui/input/node_modules/@chakra-ui/react-children-utils/dist/index.esm.js","../../../node_modules/@chakra-ui/input/node_modules/@chakra-ui/object-utils/dist/index.esm.js","../../../node_modules/@chakra-ui/input/dist/index.esm.js","../../../node_modules/@chakra-ui/number-input/node_modules/@chakra-ui/react-context/dist/index.esm.js","../../../node_modules/@chakra-ui/number-input/node_modules/@chakra-ui/react-use-merge-refs/dist/index.esm.js","../../../node_modules/@chakra-ui/number-input/node_modules/@chakra-ui/shared-utils/dist/index.esm.js","../../../node_modules/@chakra-ui/number-input/node_modules/@chakra-ui/icon/dist/index.esm.js","../../../node_modules/@chakra-ui/number-input/node_modules/@chakra-ui/form-control/dist/index.esm.js","../../../node_modules/@chakra-ui/number-input/node_modules/@chakra-ui/react-use-update-effect/dist/index.esm.js","../../../node_modules/@chakra-ui/number-input/node_modules/@chakra-ui/react-use-safe-layout-effect/dist/index.esm.js","../../../node_modules/@chakra-ui/number-input/node_modules/@chakra-ui/react-use-callback-ref/dist/index.esm.js","../../../node_modules/@chakra-ui/react-use-interval/node_modules/@chakra-ui/react-use-callback-ref/dist/index.esm.js","../../../node_modules/@chakra-ui/react-use-interval/dist/index.esm.js","../../../node_modules/@chakra-ui/number-input/dist/index.esm.js","../../../node_modules/@chakra-ui/radio/node_modules/@chakra-ui/react-context/dist/index.esm.js","../../../node_modules/@chakra-ui/radio/node_modules/@chakra-ui/react-use-merge-refs/dist/index.esm.js","../../../node_modules/@chakra-ui/radio/node_modules/@chakra-ui/shared-utils/dist/index.esm.js","../../../node_modules/@chakra-ui/radio/node_modules/@chakra-ui/icon/dist/index.esm.js","../../../node_modules/@chakra-ui/radio/node_modules/@chakra-ui/form-control/dist/index.esm.js","../../../node_modules/@chakra-ui/radio/dist/index.esm.js","../../../node_modules/@chakra-ui/slider/node_modules/@chakra-ui/react-context/dist/index.esm.js","../../../node_modules/@chakra-ui/react-use-pan-event/node_modules/@chakra-ui/event-utils/dist/index.esm.js","../../../node_modules/@chakra-ui/react-use-latest-ref/dist/index.esm.js","../../../node_modules/@chakra-ui/react-use-pan-event/dist/index.esm.js","../../../node_modules/@chakra-ui/slider/node_modules/@chakra-ui/react-use-callback-ref/dist/index.esm.js","../../../node_modules/@chakra-ui/slider/node_modules/@chakra-ui/react-use-controllable-state/dist/index.esm.js","../../../node_modules/@chakra-ui/slider/node_modules/@chakra-ui/react-use-update-effect/dist/index.esm.js","../../../node_modules/@chakra-ui/slider/node_modules/@chakra-ui/react-use-merge-refs/dist/index.esm.js","../../../node_modules/@chakra-ui/slider/node_modules/@chakra-ui/number-utils/dist/index.esm.js","../../../node_modules/@zag-js/element-size/dist/index.mjs","../../../node_modules/@chakra-ui/react-use-size/dist/index.esm.js","../../../node_modules/@chakra-ui/slider/dist/index.esm.js","../../../node_modules/@chakra-ui/textarea/node_modules/@chakra-ui/react-context/dist/index.esm.js","../../../node_modules/@chakra-ui/textarea/node_modules/@chakra-ui/react-use-merge-refs/dist/index.esm.js","../../../node_modules/@chakra-ui/textarea/node_modules/@chakra-ui/shared-utils/dist/index.esm.js","../../../node_modules/@chakra-ui/textarea/node_modules/@chakra-ui/icon/dist/index.esm.js","../../../node_modules/@chakra-ui/textarea/node_modules/@chakra-ui/form-control/dist/index.esm.js","../../../node_modules/@chakra-ui/textarea/dist/index.esm.js","../../../node_modules/@chakra-ui/icons/dist/chunk-CJVMJGVA.mjs","../../../node_modules/@chakra-ui/icons/dist/chunk-BAUXAC2P.mjs","../../../node_modules/@chakra-ui/icons/dist/chunk-HFJCK6H7.mjs","../../../node_modules/@chakra-ui/icons/dist/chunk-VJ54TX72.mjs","../../../node_modules/@chakra-ui/icons/dist/chunk-MPWSHGS7.mjs","../../../node_modules/@chakra-ui/icons/dist/chunk-22DG7YNS.mjs","../../../node_modules/@rjsf/chakra-ui/dist/chakra-ui.esm.js","../../src/components/SchemaForm.tsx","../../src/components/editor/dialog/DialogAttributesExternalSchema.tsx","../../src/components/editor/dialog/DialogMenu.tsx","../../src/components/editor/dialog/DialogMenuAttrbutes.tsx","../../src/components/ComponentVersionThumbnailWrapper.tsx","../../src/components/ComponentVersionThumbnail.tsx","../../src/components/picker/PickerWrapper.tsx","../../src/components/picker/PickerLibraryCreateWebComponent.tsx","../../src/components/picker/PickerLibrary.tsx","../../src/components/editor/dialog/DialogMenuComponent.tsx","../../src/components/editor/dialog/DialogMenuDatasources.tsx","../../src/components/editor/dialog/DialogMenuTheme.tsx","../../src/components/picker/PickerContext.tsx","../../src/contexts/EntityContext.ts","../../src/components/entities/EntityActionsMenu.tsx","../../src/components/entities/EntityActions.tsx","../../src/contexts/EntitiesContext.ts","../../src/components/entities/EntityModal.tsx","../../src/components/entities/EntityBlock.tsx","../../src/components/entities/EntityOverlay.tsx","../../src/hooks/useOnClickOutside.ts","../../src/components/entities/EntityCollection.tsx","../../src/components/entities/EntityBlockOpen.tsx","../../src/components/entities/EntityProvider.tsx","../../src/utils/string.ts","../../src/components/datasources/DatasourceFetchButton.tsx","../../src/components/datasources/DatasourceConflictDefinition.tsx","../../src/components/datasources/DatasourceGeneratorSelect.tsx","../../src/components/datasources/DatasourceStatus.tsx","../../src/components/datasources/DatasourceTreeRoot.tsx","../../src/components/datasources/DatasourceName.tsx","../../src/components/datasources/DatasourceDescription.tsx","../../src/components/datasources/DatasourceSample.tsx","../../src/components/datasources/DatasourceDetails.tsx","../../src/components/datasources/DatasourceHttpSegmentTable.tsx","../../src/components/datasources/DatasourceQuery.tsx","../../src/components/datasources/DatasourceVariables.tsx","../../src/components/datasources/DatasourceHttpSegmentFlex.tsx","../../src/components/datasources/DatasourceHttpSegment.tsx","../../src/components/datasources/DatasourceMethod.tsx","../../src/components/datasources/DatasourceEndpoint.tsx","../../src/components/datasources/Datasource.tsx","../../src/components/entities/EntitiesAlert.tsx","../../src/components/entities/EntitiesProvider.tsx","../../src/components/picker/PickerDatasourcesFetchUpdates.tsx","../../src/components/picker/PickerDatasources.tsx","../../src/components/styles/sidebar.ts","../../src/components/picker/PickerStylePreview.tsx","../../src/components/EmptyContent.tsx","../../src/components/FlexGrid.tsx","../../src/components/styles/StyleCSSReference.tsx","../../src/components/styles/fieldsets/DetailsFieldset.tsx","../../src/utils/font.ts","../../src/components/styles/FontVariants.tsx","../../src/hooks/useCodemirror.ts","../../src/components/styles/fieldsets/OverrideFieldset.tsx","../../src/components/styles/fieldsets/FontFieldset.tsx","../../src/components/styles/style/StyleFontSummary.tsx","../../src/components/styles/style/StyleTheme.tsx","../../src/components/picker/PickerThemesCombo.tsx","../../src/components/picker/PickerStylePreviewSelect.tsx","../../src/components/styles/fields/OpacityField.tsx","../../../node_modules/tinycolor2/tinycolor.js","../../src/components/styles/fieldsets/ColorsFieldset.tsx","../../src/components/styles/fields/ColorField.tsx","../../src/components/styles/fieldsets/DecorationBorderFieldset.tsx","../../src/components/styles/fieldsets/DecorationBorderRadiusFieldset.tsx","../../src/components/styles/fieldsets/DecorationBoxShadowFieldset.tsx","../../src/components/styles/fieldsets/FillColorFieldset.tsx","../../src/components/styles/fieldsets/FillEffectsFieldset.tsx","../../src/components/styles/fieldsets/PaletteTextFieldset.tsx","../../src/components/styles/fieldsets/SpacingFieldset.tsx","../../src/components/styles/fieldsets/TypographySizeSettingFieldset.tsx","../../src/components/styles/fieldsets/TypographySizeFieldset.tsx","../../src/components/styles/fieldsets/TypographyTypeFieldset.tsx","../../src/components/styles/fieldsets/GraphicFieldset.tsx","../../src/components/styles/fieldsets/BreakpointFieldset.tsx","../../src/components/styles/fieldsets/index.tsx","../../src/components/picker/PickerElementFloatingFooter.tsx","../../src/components/picker/PickerElementAspectCustom.tsx","../../src/components/picker/PickerElementAspect.tsx","../../src/components/picker/PickerElement.tsx","../../src/components/picker/PickerLibraryComponent.tsx","../../src/components/picker/PickerThemesCollectionCombos.tsx","../../src/components/picker/PickerThemesCollections.tsx","../../src/components/picker/PickerThemes.tsx","../../src/components/picker/PickerResponsiveBundlesBreakpoint.tsx","../../src/components/picker/PickerResponsiveBundles.tsx","../../src/components/picker/PickerOverview.tsx","../../src/components/picker/Picker.tsx"],"sourcesContent":["var defaultTimestep = (1 / 60) * 1000;\nvar getCurrentTime = typeof performance !== \"undefined\"\n ? function () { return performance.now(); }\n : function () { return Date.now(); };\nvar onNextFrame = typeof window !== \"undefined\"\n ? function (callback) {\n return window.requestAnimationFrame(callback);\n }\n : function (callback) {\n return setTimeout(function () { return callback(getCurrentTime()); }, defaultTimestep);\n };\n\nexport { defaultTimestep, onNextFrame };\n","function createRenderStep(runNextFrame) {\n var toRun = [];\n var toRunNextFrame = [];\n var numToRun = 0;\n var isProcessing = false;\n var toKeepAlive = new WeakSet();\n var step = {\n schedule: function (callback, keepAlive, immediate) {\n if (keepAlive === void 0) { keepAlive = false; }\n if (immediate === void 0) { immediate = false; }\n var addToCurrentFrame = immediate && isProcessing;\n var buffer = addToCurrentFrame ? toRun : toRunNextFrame;\n if (keepAlive)\n toKeepAlive.add(callback);\n if (buffer.indexOf(callback) === -1) {\n buffer.push(callback);\n if (addToCurrentFrame && isProcessing)\n numToRun = toRun.length;\n }\n return callback;\n },\n cancel: function (callback) {\n var index = toRunNextFrame.indexOf(callback);\n if (index !== -1)\n toRunNextFrame.splice(index, 1);\n toKeepAlive.delete(callback);\n },\n process: function (frameData) {\n var _a;\n isProcessing = true;\n _a = [toRunNextFrame, toRun], toRun = _a[0], toRunNextFrame = _a[1];\n toRunNextFrame.length = 0;\n numToRun = toRun.length;\n if (numToRun) {\n for (var i = 0; i < numToRun; i++) {\n var callback = toRun[i];\n callback(frameData);\n if (toKeepAlive.has(callback)) {\n step.schedule(callback);\n runNextFrame();\n }\n }\n }\n isProcessing = false;\n },\n };\n return step;\n}\n\nexport { createRenderStep };\n","import { onNextFrame, defaultTimestep } from './on-next-frame.js';\nimport { createRenderStep } from './create-render-step.js';\n\nvar maxElapsed = 40;\nvar useDefaultElapsed = true;\nvar runNextFrame = false;\nvar isProcessing = false;\nvar frame = {\n delta: 0,\n timestamp: 0\n};\nvar stepsOrder = [\"read\", \"update\", \"preRender\", \"render\", \"postRender\"];\nvar steps = /*#__PURE__*/stepsOrder.reduce(function (acc, key) {\n acc[key] = createRenderStep(function () {\n return runNextFrame = true;\n });\n return acc;\n}, {});\nvar sync = /*#__PURE__*/stepsOrder.reduce(function (acc, key) {\n var step = steps[key];\n acc[key] = function (process, keepAlive, immediate) {\n if (keepAlive === void 0) {\n keepAlive = false;\n }\n if (immediate === void 0) {\n immediate = false;\n }\n if (!runNextFrame) startLoop();\n return step.schedule(process, keepAlive, immediate);\n };\n return acc;\n}, {});\nvar cancelSync = /*#__PURE__*/stepsOrder.reduce(function (acc, key) {\n acc[key] = steps[key].cancel;\n return acc;\n}, {});\nvar flushSync = /*#__PURE__*/stepsOrder.reduce(function (acc, key) {\n acc[key] = function () {\n return steps[key].process(frame);\n };\n return acc;\n}, {});\nvar processStep = function (stepId) {\n return steps[stepId].process(frame);\n};\nvar processFrame = function (timestamp) {\n runNextFrame = false;\n frame.delta = useDefaultElapsed ? defaultTimestep : Math.max(Math.min(timestamp - frame.timestamp, maxElapsed), 1);\n frame.timestamp = timestamp;\n isProcessing = true;\n stepsOrder.forEach(processStep);\n isProcessing = false;\n if (runNextFrame) {\n useDefaultElapsed = false;\n onNextFrame(processFrame);\n }\n};\nvar startLoop = function () {\n runNextFrame = true;\n useDefaultElapsed = true;\n if (!isProcessing) onNextFrame(processFrame);\n};\nvar getFrameData = function () {\n return frame;\n};\n\nexport default sync;\nexport { cancelSync, flushSync, getFrameData };\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","/**\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","/**\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 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","/**\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","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 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","/**\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 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","/** 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","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 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 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 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 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","/**\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","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","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 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 { Badge, Text } from '@chakra-ui/react'\nimport * as FEAAS from '@sitecore-feaas/clientside/headless'\nimport { DialogAttributeGeneric } from './Dialog.js'\n\nconst DialogAttributeBadge = ({ type, label, labels, value, jsonpath }: DialogAttributeGeneric) => {\n return (\n <>\n {jsonpath ? (\n <>\n {label == 'Visibility' && (\n \n if set:\n \n )}\n \n {FEAAS.DataPath.getLastPathBit(jsonpath)}\n \n \n ) : !jsonpath && value == '' ? (\n \n Empty {type == 'url' ? 'URL' : type == 'string' ? 'Text' : null}\n \n ) : !jsonpath && typeof value == 'boolean' ? (\n \n {value == true ? labels.static : labels.none}\n \n ) : !jsonpath && value != '' && typeof value !== 'boolean' ? (\n \n {value}\n \n ) : (\n \n {labels.none || 'None'}\n \n )}\n \n )\n}\n\nexport default DialogAttributeBadge\n","const monthNames = [\n 'January',\n 'February',\n 'March',\n 'April',\n 'May',\n 'June',\n 'July',\n 'August',\n 'September',\n 'October',\n 'November',\n 'December'\n]\n\nexport const formatDate = (date: Date) => {\n if (!date || typeof date.getDay !== 'function') return\n\n const year = date.getFullYear()\n const month = monthNames[date.getMonth()]\n const day = date.getDate()\n\n return `${month} ${day}, ${year}`\n}\n","import { useEffect, useRef, useState } from 'react'\nimport FormError from './FormError.js'\nimport { Input, InputGroup, InputRightAddon, Text } from '@chakra-ui/react'\n\nconst TextField = ({\n value,\n error,\n onBlur = () => {},\n disabled,\n ariaLabel,\n placeholder,\n caption,\n forceShowErrors,\n withAddon,\n onChange,\n type = 'text'\n}: {\n value: any\n error?: string\n onBlur?: any\n disabled?: boolean\n ariaLabel?: string\n placeholder?: string\n caption?: string\n forceShowErrors?: boolean\n withAddon?: string\n onChange: (value: string) => void\n type?: string\n}) => {\n const [isDirty, setIsDirty] = useState(false)\n\n const showErrors = error && (isDirty || forceShowErrors)\n\n const onFieldChange = ({ target }: { target: HTMLInputElement }) => {\n setIsDirty(true)\n\n onChange(target.value)\n }\n\n return (\n <>\n \n \n\n {withAddon && }\n \n\n {caption && (\n \n {caption}\n \n )}\n\n {showErrors && }\n \n )\n}\n\nexport default TextField\n","import { CSS, Style, mergeDeep } from '@sitecore-feaas/sdk'\nimport { useMemo } from 'react'\nimport { useLibrary } from '../../../hooks/useData.js'\n\ninterface Props {\n rule: Style.Rule\n rules: Style.Rule[]\n customRules?: Record\n children: any\n}\n\nexport function GeneratedPreview({ rule, children, customRules, rules }: Props) {\n const id = useMemo(() => 'preview-' + String(Math.floor(Math.random() * 1000000000)), [])\n\n var ruleProp: any[]\n\n if (rule.type == 'font') {\n if (rule.props.variants) {\n ruleProp = CSS.produceFontVariantProps({\n id: rule.details.id,\n ...rule.props.variants[0]\n })\n }\n } else if ((rule.type == 'block' && rule.details.collectionId == 'section') || rule.type == 'theme') {\n var extraStyles = [\n Style.Rule({\n type: 'layout',\n details: {\n id: 'preview-layout',\n slug: 'preview-layout'\n },\n props: {\n columnCount: 2,\n justifyContent: 'flex-top' as any\n }\n }),\n Style.Rule({\n type: 'spacing',\n details: {\n id: 'preview-spacing'\n },\n props: {\n rowGap: 20,\n columnGap: 20,\n paddingTop: 20,\n paddingLeft: 20,\n paddingBottom: 20,\n paddingRight: 20\n }\n })\n ]\n rule = mergeDeep(rule, {\n props: {\n layoutIds: ['preview-layout'],\n spacingIds: ['preview-spacing'],\n blocks:\n rule.type == 'theme'\n ? rule.props.blocks.map((b) => ({ ...b, spacingId: 'preview-spacing', layoutId: 'preview-layout' }))\n : null\n }\n })\n ruleProp = [\n ...CSS.produceProps(rule.type, rule.props),\n ['rule', '.-section', ...CSS.produceProps('layout', extraStyles[0].props)],\n [\n 'rule',\n ':not(div):not(a) + *',\n ['property', '---self--paragraph-spacing', 'var(---typography--paragraph-spacing)']\n ]\n ]\n } else {\n ruleProp = CSS.produceProps(rule.type, rule.props)\n }\n if (!ruleProp) return children\n const cssText = CSS.stringify(\n [\n [\n 'rule',\n [`:wrapper(#${id}) + *`],\n\n ['rule', '.target.target', ...ruleProp] // reoslve `&` to `.target`,\n ]\n ],\n {\n rules: (rules as Style.Rule[]).concat(extraStyles || []),\n customStyles: customRules,\n bundle: true\n }\n )\n return (\n <>\n \n {children}\n \n )\n}\n","import { useMemo, useRef } from 'react';\n\nfunction useMemoizedDeps(deps, comparator) {\n var memoizedDeps = useRef(deps);\n\n if (!comparator(deps, memoizedDeps.current)) {\n memoizedDeps.current = deps;\n }\n\n return memoizedDeps.current;\n}\n\nfunction useMemoWithComparator(callback, deps, comparator) {\n var memoizedDeps = useMemoizedDeps(deps, comparator);\n return useMemo(callback, memoizedDeps);\n}\n\nexport { useMemoWithComparator };\n//# sourceMappingURL=react-use-memo-with-comparator.esm.js.map\n","import { CSS, Style, mergeDeep } from '@sitecore-feaas/sdk'\nimport { useMemo } from 'react'\n\ninterface Props {\n rules: Style.Rule[]\n rule: Style.Rule\n customRules?: Record\n children: any\n isCompact?: boolean\n}\n\nexport function GeneratedPreviewExternal({ rules, rule, children, customRules, isCompact }: Props) {\n const id = useMemo(() => 'preview-' + String(Math.floor(Math.random() * 1000000000)), [])\n\n const compactOverrides = [\n ['property', 'font-size', '14px'], // override font-size so that everything looks uniform\n ['property', 'padding', '0'],\n ['property', 'box-shadow', 'none']\n ]\n\n var ruleProp = [\n ...CSS.produceProps(rule.type, rule.props),\n ...(rule.details.override ? CSS.parse(rule.details.override) : []),\n ...(isCompact ? compactOverrides : [])\n ]\n\n if (rule.type == 'font') {\n if (rule.props.variants) {\n ruleProp = CSS.produceFontVariantProps({\n id: rule.details.id,\n ...rule.props.variants[0]\n })\n }\n } else if ((rule.type == 'block' && rule.details.collectionId == 'section') || rule.type == 'theme') {\n var extraStyles = [\n Style.Rule({\n type: 'layout',\n details: {\n id: 'preview-layout',\n slug: 'preview-layout'\n },\n props: {\n columnCount: 2,\n justifyContent: 'flex-top' as any\n }\n }),\n Style.Rule({\n type: 'spacing',\n details: {\n id: 'preview-spacing'\n },\n props: {\n rowGap: 20,\n columnGap: 20,\n paddingTop: 20,\n paddingLeft: 20,\n paddingBottom: 20,\n paddingRight: 20\n }\n })\n ]\n rule = mergeDeep(rule, {\n props: {\n layoutIds: ['preview-layout'],\n spacingIds: ['preview-spacing'],\n blocks:\n rule.type == 'theme'\n ? rule.props.blocks.map((b) => ({ ...b, spacingId: 'preview-spacing', layoutId: 'preview-layout' }))\n : null\n }\n })\n ruleProp = [\n ...ruleProp,\n ['rule', '.-section', ...CSS.produceProps('layout', extraStyles[0].props)],\n [\n 'rule',\n ':not(div):not(a) + *',\n ['property', '---self--paragraph-spacing', 'var(---typography--paragraph-spacing)']\n ]\n ]\n }\n if (!ruleProp) return children\n const cssText = CSS.stringify(\n [\n [\n 'rule',\n [`:wrapper(#${id}) + *`],\n ['rule', '.target.target', ...ruleProp] // reoslve `&` to `.target`,\n ]\n ],\n {\n rules: (rules as Style.Rule[]).concat(extraStyles || []),\n customRules,\n bundle: true\n }\n )\n return (\n <>\n \n {children}\n \n )\n}\n","import { Badge, Box, Flex, HStack, SimpleGrid, Text, VStack } from '@chakra-ui/react'\nimport { CSS, Style } from '@sitecore-feaas/sdk'\nimport { GeneratedPreview } from './GeneratedPreview.js'\nimport { css } from '@emotion/react'\nimport { useMemoWithComparator } from 'react-use-memo-with-comparator'\nimport { isDeepEquals } from '@sitecore-feaas/sdk'\nimport { GeneratedPreviewExternal } from './GeneratedPreviewExternal.js'\nimport { singularize } from 'inflection'\n\nexport const checkerboard = css`\n background-image: linear-gradient(45deg, var(--chakra-colors-blackAlpha-100) 25%, transparent 25%),\n linear-gradient(-45deg, var(--chakra-colors-blackAlpha-100) 25%, transparent 25%),\n linear-gradient(45deg, transparent 75%, var(--chakra-colors-blackAlpha-100) 75%),\n linear-gradient(-45deg, transparent 75%, var(--chakra-colors-blackAlpha-100) 75%);\n background-size: 16px 16px;\n background-position: 0 0, 0 8px, 8px -8px, -8px 0px;\n`\n\nconst SpacingStyle = css`\n grid-template-areas:\n '. . t . . '\n '. c c c . '\n 'l c c c r '\n '. c c c . '\n '. . b . . ';\n grid-template-columns: auto 0px 1fr 0px auto;\n grid-template-rows: auto 0px 1fr 0px auto;\n height: 100px;\n\n .value {\n > span {\n position: absolute;\n color: var(--chakra-colors-primary-500);\n font-size: var(--chakra-fontSizes-sm);\n font-weight: var(--chakra-fontWeights-extrabold);\n }\n\n display: flex;\n justify-content: center;\n align-items: center;\n position: relative;\n z-index: 0;\n\n &.left,\n &.right {\n min-width: 32px;\n flex-direction: column;\n\n > span {\n top: 50%;\n transform: translateY(calc(-100% - 4px));\n }\n }\n\n &.top,\n &.bottom,\n &.vgap {\n min-height: 24px;\n\n > span {\n left: 50%;\n transform: translateX(calc(-100% - 6px));\n }\n }\n\n &.left {\n grid-area: l;\n }\n\n &.right {\n grid-area: r;\n }\n\n &.bottom {\n grid-area: b;\n }\n\n &.top {\n grid-area: t;\n }\n\n &.vgap {\n min-height: 0;\n flex: 1;\n }\n\n &.hgap {\n min-height: 18px;\n min-width: 18px;\n\n > span {\n left: 50%;\n transform: translateX(calc(-100% - 13px));\n }\n }\n }\n\n .column {\n flex-basis: 50%;\n align-self: stretch;\n align-items: stretch;\n }\n\n .row {\n background: var(--chakra-colors-blackAlpha-200);\n margin: 0;\n flex-basis: 18px;\n border-radius: 4px;\n }\n\n .center {\n grid-area: c;\n border-radius: 4px;\n outline: 1px solid var(--chakra-colors-primary-500);\n align-items: start;\n }\n\n .arrow {\n position: relative;\n background-color: var(--chakra-colors-primary-500);\n\n &:before,\n &:after {\n content: '';\n position: absolute;\n width: 4px;\n height: 4px;\n display: block;\n border-style: solid;\n border-color: var(--chakra-colors-primary-500);\n rotate: 45deg;\n }\n\n &.up-down {\n width: 1px;\n height: 70%;\n margin-left: 6px;\n margin-right: 6px;\n\n &:before {\n left: -2px;\n border-width: 1px 0px 0px 1px;\n }\n &:after {\n bottom: 0px;\n left: -2px;\n border-width: 0px 1px 1px 0px;\n }\n }\n\n &.left-right {\n width: 80%;\n height: 1px;\n margin-top: 6px;\n margin-bottom: 6px;\n\n &:before {\n top: -2px;\n border-width: 0px 0px 1px 1px;\n }\n &:after {\n top: -2px;\n right: 0;\n border-width: 1px 1px 0px 0px;\n }\n }\n }\n`\n\nfunction Thumbnail({\n maxWidth = 512,\n hasCheckerboard = false,\n children,\n isCompact,\n ...props\n}: {\n maxWidth?: number\n hasCheckerboard?: boolean\n children?: any\n isCompact?: boolean\n [key: string]: any\n}) {\n return (\n \n {children}\n \n )\n}\n\ninterface PreviewProps {\n rule: T\n customRules?: Record\n variant?: string\n rules: Style.Rule[]\n isCompact?: boolean\n [prop: string]: any\n}\n\nconst previewTypes: Partial JSX.Element>> = {\n block: ({\n rule: {\n details: { collectionId }\n },\n rules,\n customRules,\n isCompact,\n ...box\n }) =>\n isCompact ? (\n \n \n \n ) : collectionId === 'section' ? (\n \n \n \n ) : (\n \n \n \n ),\n typography: ({\n rule: {\n details: { title, exampleContent }\n },\n rules,\n customRules: customRules,\n isCompact,\n ...box\n }: PreviewProps) =>\n isCompact ? (\n \n Ag\n \n ) : (\n \n \n The quick brown fox\n \n \n ),\n inline: ({\n rule: {\n details: { title, exampleContent, collectionId }\n },\n rules = [],\n customRules,\n isCompact,\n ...box\n }: PreviewProps) =>\n isCompact ? (\n \n \n {collectionId === 'link' ? (\n \n Link\n \n ) : (\n Style.Set.findById(rules, collectionId)?.details.title[0] || 'I'\n )}\n \n \n ) : (\n \n \n {exampleContent ||\n (collectionId == 'link'\n ? 'Link'\n : singularize(Style.Set.findById(rules, collectionId)?.details.title || 'Inline element'))}\n \n \n ),\n text: ({\n rule: {\n details: { title, exampleContent }\n },\n rules,\n customRules,\n isCompact,\n ...box\n }: PreviewProps>) =>\n isCompact ? (\n \n \n Ag\n \n \n ) : (\n \n \n The quick brown fox\n \n \n ),\n decoration: ({ isCompact }) =>\n isCompact ? (\n \n \n \n ) : (\n \n \n \n ),\n fill: ({ isCompact }) =>\n isCompact ? (\n \n \n \n ) : (\n \n \n \n ),\n font: ({\n rule: {\n details: { title, exampleContent }\n },\n isCompact\n }: PreviewProps) => (\n \n {title || 'Example text'}\n \n ),\n breakpoint: ({\n rule: {\n details: { title, exampleContent },\n props\n }\n }: PreviewProps>) => {\n const { minWidth, maxWidth } = props\n return (\n \n \n \n \n\n \n \n {minWidth}px - {isFinite(maxWidth) ? `${maxWidth}px` : '∞'}\n \n \n \n )\n },\n graphic: ({\n rule: {\n details: { title, exampleContent },\n props\n }\n }: PreviewProps) => {\n //@ts-ignore\n const { url } = props\n return (\n \n \n \n )\n },\n theme: ({\n variant,\n rule: {\n details: { title, exampleContent },\n props\n }\n }: PreviewProps) => {\n return (\n \n \n \n \n \n B\n \n \n Title\n \n \n \n \n )\n },\n color: ({\n rule: {\n details: { title, exampleContent },\n props\n }\n }: PreviewProps>) => {\n const bg = Style.rgbaToString(props)\n\n return (\n \n \n \n )\n },\n palette: ({ rule: { props }, rules, isCompact }: PreviewProps>) => {\n const color = Style.Set.findById<'color'>(rules, props.textColor.id)\n const bg = Style.rgbaToString(color?.props)\n return isCompact ? (\n \n \n \n ) : (\n \n \n \n )\n },\n fontVariant: ({\n rule: {\n details: { title, exampleContent }\n }\n }: PreviewProps) => (\n \n {exampleContent || 'Example text'}\n \n ),\n spacing: ({ rule: { props } }: PreviewProps>) => {\n return (\n \n \n \n {Style.stringifyLength(props.paddingTop).replace('px', '')}\n \n \n \n {Style.stringifyLength(props.paddingBottom).replace('px', '')}\n \n \n \n {Style.stringifyLength(props.paddingLeft).replace('px', '')}\n \n \n \n {Style.stringifyLength(props.paddingRight).replace('px', '')}\n \n \n \n \n \n \n \n {Style.stringifyLength(props.columnGap).replace('px', '')}\n \n \n \n \n \n {Style.stringifyLength(props.rowGap).replace('px', '')}\n \n \n \n \n \n \n \n )\n }\n}\n\nexport default function Preview({ rule, rules, customRules, ...props }: PreviewProps) {\n const PreviewType = previewTypes[rule.type]\n if (!PreviewType) return null\n const Generated = rules ? GeneratedPreviewExternal : GeneratedPreview\n const isCompact = props.variant === 'compact'\n return (\n \n \n \n )\n}\n\nexport function PreviewFontsStylesheet({ styles }: { styles: Style.Rule[] }) {\n const usedFonts = Style.Set.filterByType(styles, 'font')\n\n const cssText = useMemoWithComparator(\n () => {\n return CSS.stringify(usedFonts.map((font) => CSS.produceStyle(font), { styles: styles }))\n },\n [usedFonts],\n isDeepEquals\n )\n return \n}\n","import { Box, Button, HStack, Text, VStack } from '@chakra-ui/react'\nimport { FunctionComponent, ReactElement, useEffect, useRef, useState } from 'react'\nimport { formatDate } from '../../../utils/date.js'\nimport FieldsetField from '../../FieldsetField.js'\nimport TextField from '../../TextField.js'\nimport { SDKContext } from '../../providers/SDKProvider.js'\nimport { checkerboard } from '../previews/index.js'\nimport { useSDK } from '../../../hooks/useData.js'\n\ninterface Props {\n onChange: (value: string) => void\n onUpload: (filelist: FileList) => void\n value: string\n label?: string\n disabled?: boolean\n}\n\nconst FileField: FunctionComponent = (props: Props): ReactElement => {\n const { onChange, value, label = 'Alignment', disabled, onUpload } = props\n\n const [date, setDate] = useState(null)\n const previewRef = useRef()\n const sdk = useSDK()\n const [state, setState] = useState()\n const ref = useRef>(null)\n useEffect(() => {\n if (!value) return\n clearTimeout(ref.current)\n ref.current = setTimeout(() => {\n setState(null)\n sdk\n .proxy(value, { method: 'GET' })\n .then((response) => {\n const c = new Date(response.headers.get('Created-At') || 'Nothing')\n if (isFinite(Number(c))) {\n setDate(c)\n } else {\n const m = new Date(response.headers.get('Last-Modified') || 'Nothing')\n if (isFinite(Number(m))) {\n setDate(m)\n } else {\n setDate(null)\n }\n }\n })\n .catch(() => {\n setDate(null)\n })\n }, 300)\n }, [value])\n\n return (\n \n \n \n \n \n \n \n {value?.split('/').pop().split('?')[0]}\n \n \n {state ?? formatDate(date)}\n \n \n\n \n \n \n \n \n \n )\n}\n\nexport default FileField\n","import { DialogAttributeGeneric } from './Dialog.js'\nimport { useSDK } from '../../../hooks/useData.js'\nimport { Box, Input, Textarea } from '@chakra-ui/react'\nimport FieldsetField from '../../FieldsetField.js'\nimport { ChangeEvent } from 'react'\nimport FileField from '../../styles/fields/FileField.js'\n\nconst DialogAttributesStatic = ({ type, value, onChange }: DialogAttributeGeneric) => {\n const sdk = useSDK()\n\n return (\n type != 'boolean' &&\n type != 'custom' && (\n \n {type == 'string' && (\n \n ) => onChange(e.target.value)}\n />\n \n )}\n {type == 'url' && (\n \n ) => {\n onChange(e.target.value)\n }}\n />\n \n )}\n {type == 'object' && (\n \n ) => onChange(e.target.value)}\n />\n \n )}\n {type == 'html' && (\n \n ) => onChange(e.target.value)}\n />\n \n )}\n {type == 'image' && (\n {\n const file = files[0]\n var extension = file.name.split('.').pop()\n if (!extension.match(/(jpg|jpeg|png|gif|svg)/)) {\n extension = 'png'\n }\n sdk.uploadBlob('images', sdk.nanoid(32) + '.' + extension, files[0]).then(({ url }) => {\n onChange(url)\n })\n }}\n />\n )}\n \n )\n )\n}\n\nexport default DialogAttributesStatic\n","import {\n Box,\n Button,\n HStack,\n Icon,\n Spacer,\n Step,\n StepIcon,\n StepIndicator,\n StepNumber,\n Stepper,\n StepSeparator,\n StepStatus,\n StepTitle,\n Text,\n useSteps,\n VStack\n} from '@chakra-ui/react'\nimport { css } from '@emotion/react'\nimport { mdiArrowLeft, mdiArrowRight } from '@mdi/js'\nimport React, { FC, ReactElement } from 'react'\n\nexport type WizardStep = {\n title: string\n}\n\nconst PickerWizard = ({\n defaultStep,\n steps,\n extraButton,\n onComplete,\n children\n}: {\n defaultStep: number\n steps: WizardStep[]\n extraButton?: FC\n onComplete?: () => void\n children: ReactElement[]\n}) => {\n const { activeStep, goToNext, goToPrevious, setActiveStep } = useSteps({\n index: defaultStep,\n count: steps.length\n })\n const filteredChildren = children.filter((c) => !!c)\n return (\n <>\n \n {steps.length > 1 && (\n \n {steps.map((step, index) => (\n \n {/* @ts-ignore */}\n setActiveStep(index)}>\n \n   \n } incomplete={} active={} />\n \n {step.title}\n \n \n \n\n \n \n ))}\n \n )}\n {filteredChildren[activeStep]}\n \n\n {/* Footer */}\n {(steps.length > 1 || extraButton) && (\n \n {extraButton && extraButton({ activeStep })}\n \n {activeStep > 0 && (\n \n )}\n {activeStep < steps.length - 1 ? (\n \n ) : onComplete ? (\n \n ) : null}\n \n \n )}\n \n )\n}\n\nexport default PickerWizard\n","import { mdiCodeBraces, mdiDatabaseOutline } from '@mdi/js'\nimport { Tag, TagLeftIcon, Text, Image, TagProps, HStack, Tooltip } from '@chakra-ui/react'\nimport { DatasourceModel } from '@sitecore-feaas/sdk'\n\nexport const DatasourceB = {\n display: 'inline-flex'\n}\n\nexport const Img = {\n height: '18px'\n}\n\nconst DatasourceBadge = ({\n datasources,\n className,\n ...props\n}: {\n datasources: Partial>[]\n className?: string\n} & TagProps) => {\n const isXmTemplate = (type: string) => type === 'xmTemplate'\n const isCH1 = (type: string) => type === 'contentHubOne'\n const isCustom = (type: string) => type == 'internal'\n const isExternal = (type: string) => type == 'external'\n\n const isSingleDatasource = datasources.length === 1\n const firstDatasource = datasources?.[0]\n const firstDatasourceType = datasources?.[0]?.type\n const isFirstDatasourceCustom = isCustom(firstDatasourceType)\n const isFirstDatasourceExternal = isExternal(firstDatasourceType)\n\n const extended = datasources?.some((d) => d?.isExtended?.()) && (\n \n \n (Extended)\n \n \n )\n return (\n <>\n \n {datasources.length > 1 && (\n \n \n \n \n Multiple data sources\n \n )}\n\n {isSingleDatasource && isFirstDatasourceCustom && (\n \n \n \n \n \n Custom endpoint\n {extended}\n \n \n )}\n\n {isSingleDatasource && isXmTemplate(firstDatasourceType) && (\n \n \n \n XM Cloud\n {extended}\n \n \n )}\n\n {isSingleDatasource && isCH1(firstDatasourceType) && (\n \n \n \n Content Hub One\n {extended}\n \n \n )}\n\n {isSingleDatasource && isFirstDatasourceExternal && (\n \n \n \n \n \n External\n {extended}\n \n \n )}\n \n \n )\n}\n\nexport default DatasourceBadge\n","import {\n Badge,\n Button,\n ButtonProps,\n Checkbox,\n HStack,\n Icon,\n IconButton,\n Img,\n StackProps,\n Text,\n Tooltip,\n VStack\n} from '@chakra-ui/react'\nimport { mdiLink } from '@mdi/js'\nimport { createObjectSummary, findContentfulObject, findObjectValue, getColorForValue } from '@sitecore-feaas/sdk'\nimport * as inflection from 'inflection'\nimport React from 'react'\n\nconst DataItem = >({\n data,\n limit = 7,\n variant,\n nameOnly,\n isSelected,\n onSelect,\n isDisabled,\n byocProps,\n ...props\n}: {\n data: T\n nameOnly?: boolean\n variant?: string\n limit?: number\n isSelected?: boolean\n isDisabled?: boolean\n onSelect?: (selected: boolean) => void\n byocProps?: Record\n} & ButtonProps &\n StackProps) => {\n const object = findContentfulObject(data || {})\n const { summary, keyMap } = createObjectSummary(object || {})\n const texts = [keyMap.title, keyMap.description, keyMap.date, ...keyMap.extras, ...keyMap.unknown]\n const textLimit = limit - (summary.image ? 2 : 0) - (summary.status || summary.number || summary.category ? 1 : 0)\n function sanitize(text: string) {\n return String(text ?? '')\n .replace(/<[^>]+>/g, ' ')\n .replace(/\\s>/g, ' ')\n .trim()\n }\n return (\n \n {nameOnly ? (\n <>\n \n \n {inflection.titleize('name')}\n \n \n {sanitize(summary.title)}\n \n \n \n ) : (\n <>\n {summary.image || summary.status || summary.number || summary.category || !isDisabled ? (\n \n {summary.image && (\n \n \n \n )}\n \n {summary.icon && (\n \n \n \n )}\n {summary.status && (\n \n \n {sanitize(summary.status)}\n \n \n )}\n {summary.number && (\n \n \n {sanitize(summary.number)}\n \n \n )}\n {summary.category && (\n \n \n {sanitize(summary.category)}\n \n \n )}\n \n {!isDisabled && (\n {\n isSelected ? onSelect(false) : onSelect(true)\n }}\n />\n )}\n {summary.url && (\n \n \n \n \n }\n />\n \n )}\n \n \n \n ) : null}\n {texts\n .filter((prop) => object[prop] != null && findObjectValue(object, prop, null))\n .slice(0, textLimit)\n .map((prop, index) => {\n return (\n \n \n {inflection.titleize(prop)}\n \n \n {sanitize(findObjectValue(object, prop, null))}\n \n \n )\n })}\n \n )}\n \n )\n}\n\nexport default DataItem\n","import {\n Accordion,\n AccordionButton,\n AccordionIcon,\n AccordionItem,\n AccordionPanel,\n Badge,\n Box,\n Card,\n CardBody,\n HStack,\n Icon,\n Tag,\n Text,\n VStack\n} from '@chakra-ui/react'\nimport { css } from '@emotion/react'\nimport DatasourceBadge from '../DatasourceBadge.js'\nimport { mdiCheckCircle, mdiCircleOutline } from '@mdi/js'\nimport React from 'react'\nimport { DatasourceModel } from '@sitecore-feaas/sdk'\nimport DataItem from '../DataItem.js'\n\nconst PickerDatasourcesSource = ({\n datasources,\n datasource,\n onDatasourceChange,\n byocProps\n}: {\n datasources: DatasourceModel[]\n datasource: DatasourceModel\n onDatasourceChange: (datasource: DatasourceModel) => void\n byocProps?: Record\n}) => {\n return (\n <>\n {datasources.map((d) => {\n const isSelected = datasource?.id === d.id\n const byocMatchingValues = byocProps && Object.keys(d.sample).filter((key) => byocProps.includes(key))?.length\n\n return (\n onDatasourceChange(d)}\n variant={'outline'}\n width={'100%'}\n css={css`\n ${isSelected && 'outline: 1px solid var(--chakra-colors-primary-600);'}\n &:hover {\n cursor: pointer;\n background: var(--chakra-colors-blackAlpha-100);\n outline: 1px solid var(--chakra-colors-blackAlpha-400);\n }\n `}\n >\n \n \n \n \n \n {byocProps && (\n \n \n {byocMatchingValues} matching value{byocMatchingValues === 1 ? '' : 's'}\n \n \n )}\n \n {isSelected ? (\n \n \n \n \n \n ) : (\n \n \n \n \n \n )}\n \n \n {d.name}\n \n \n \n \n \n Sample\n \n \n \n\n \n \n \n \n \n \n \n \n )\n })}\n \n )\n}\n\nexport default PickerDatasourcesSource\n","import { Badge, BadgeProps, Box, HStack, Icon, Tooltip } from '@chakra-ui/react'\nimport { mdiCached, mdiClose } from '@mdi/js'\nimport { BranchParams } from './DatasourceTree.js'\nimport { ReactNode } from 'react'\nimport { css } from '@emotion/react'\n\nexport type LeafStatus = 'new' | 'removed' | 'changed' | 'unchanged'\n\nexport interface DataLeafProps extends Pick {\n children?: ReactNode\n warning: string\n error: string\n onClick: (...args: any[]) => any\n onClear: (...args: any[]) => any\n}\n\nconst DatasourceTreeLeafWrapper = ({\n children,\n warning,\n action,\n isVerbose,\n error,\n onClick,\n onClear\n}: DataLeafProps) => {\n const badgeProps: BadgeProps = {\n borderRadius: 'lg',\n margin: '1',\n variant: 'datapath'\n }\n const buttonBadgeProps: BadgeProps = {\n ...badgeProps,\n cursor: 'pointer',\n as: 'button',\n onClick\n }\n if (error) {\n if (!isVerbose) return\n return (\n \n \n {children}\n \n \n )\n }\n\n if (action == 'trimming') {\n return (\n \n {children}\n \n )\n } else if (action == 'repeating') {\n return (\n \n {children}{' '}\n \n )\n } else if (action == 'mapping' || action == 'scoping') {\n if (warning) {\n return (\n \n \n {children}\n \n \n )\n } else {\n return (\n \n {children}\n \n )\n }\n } else if (action == 'repeating-mapping') {\n return (\n \n \n {children}\n \n \n )\n } else if (action == 'nesting') {\n return (\n \n \n {children}{' '}\n \n \n )\n } else if (action == 'indicating') {\n return (\n <>\n \n \n {children}\n {\n e.stopPropagation()\n onClear()\n }}\n >\n \n \n \n \n \n )\n } else if (action == 'rooting') {\n return (\n \n {children}\n \n )\n } else {\n return (\n \n \n {children}\n \n \n )\n }\n}\n\nexport default DatasourceTreeLeafWrapper\n","import React, { useState } from 'react'\nimport { isDate, Optional } from '@sitecore-feaas/sdk'\nimport { List } from '@chakra-ui/react'\nimport DatasourceTreeLeafWrapper, { DataLeafProps } from './DatasourceTreeLeafWrapper.js'\nimport { default as styled } from '@emotion/styled'\n\nconst Item = (styled as any).li`\n &[data-action='rooting'][data-action='rooting'] > ul {\n border-left-color: var(--chakra-colors-green-300);\n }\n`\n\nexport type ConfigureAction =\n | 'mapping'\n | 'trimming'\n | 'scoping'\n | 'rooting'\n | 'repeating'\n | 'nesting'\n | 'repeating-mapping'\n | 'indicating'\n\nexport interface BranchParams {\n datasourceName?: string\n prefix: string\n bits: string[]\n path: string | null\n label?: string\n intent: ConfigureAction\n action: ConfigureAction | 'reporting' | null\n isVerbose: boolean\n scopes: string[]\n validator?: (value: any) => string\n onConfigure: (value: string | null) => void\n data: any\n renderLeafTree?: (\n props: DataLeafProps,\n collapsedLeaves: string[],\n onCollapsedLeavesChange: (leaves: string[]) => void\n ) => JSX.Element\n collapsedLeaves?: string[]\n onCollapsedLeavesChange?: (leaves: string[]) => void\n isValid?: boolean\n}\n\nexport default function DatasourceTree({\n datasourceName,\n validator = null,\n prefix = '$',\n label,\n path = undefined,\n intent,\n isVerbose,\n scopes = [],\n onConfigure = undefined,\n data,\n renderLeafTree\n}: Optional<\n Pick<\n BranchParams,\n | 'validator'\n | 'prefix'\n | 'label'\n | 'path'\n | 'intent'\n | 'isVerbose'\n | 'scopes'\n | 'onConfigure'\n | 'data'\n | 'renderLeafTree'\n | 'datasourceName'\n >,\n 'scopes' | 'prefix' | 'validator' | 'path'\n>) {\n const [collapsedLeaves, setCollapsedLeaves] = useState([])\n return (\n \n {ConfigureDataBranch({\n datasourceName,\n validator,\n prefix,\n label: label || prefix,\n bits: [prefix],\n path,\n intent,\n action: null,\n isVerbose,\n scopes,\n onConfigure,\n data,\n collapsedLeaves,\n onCollapsedLeavesChange: setCollapsedLeaves,\n renderLeafTree\n })}\n \n )\n}\n\nfunction walk(callback: (data: any, prop: string) => any, data: any, key: string) {\n if (data != null && Array.isArray(data)) {\n for (var prop of data) {\n callback(data[prop], prop)\n walk(callback, data[prop], prop)\n }\n } else if (data != null && typeof data == 'object') {\n for (var prop1 in data) {\n callback(data[prop1], prop1)\n walk(callback, data[prop1], prop1)\n }\n } else {\n callback(data, key)\n }\n}\n\nfunction isPrimitive(value: any) {\n return (\n !(value != null && (Array.isArray(value) || typeof value == 'object')) ||\n (value?.type == 'doc' && Array.isArray(value.content))\n )\n}\n\n// check if paths equal, or if left path is qualifying the right with array expression ([], .*)\nfunction matchPath(left: string, right: string) {\n return left.startsWith(right) && left.substring(right.length).match(/^(|\\.\\*|\\[[^]+\\])$/)\n}\n\n// this following function is not great, but it handles all the cases\n// as long as this mess is contained in here, it works alright.\nfunction ConfigureDataBranch({\n datasourceName,\n validator,\n prefix,\n data,\n bits,\n path,\n label = prefix,\n intent,\n action,\n isVerbose,\n scopes = [],\n onConfigure,\n renderLeafTree,\n collapsedLeaves,\n onCollapsedLeavesChange\n}: BranchParams): JSX.Element {\n var currentPath = bits.join('.')\n var descendIntent = intent\n\n if (!action && scopes.find((scope) => matchPath(scope, currentPath))) {\n action = 'nesting'\n }\n if (path && matchPath(path, bits.join('.'))) {\n action = intent == 'trimming' ? 'rooting' : 'indicating'\n // descendIntent = false\n }\n if (typeof data == 'object' && data != null && !isPrimitive(data) && !isDate(data)) {\n if (!action && intent == 'trimming' && !isPrimitive(data)) {\n action = 'trimming'\n }\n if (!action && intent == 'scoping' && !isPrimitive(data)) {\n action = 'scoping'\n }\n var entries = Object.entries(data)\n if (entries.length > 0 && Array.isArray(data)) {\n bits = bits.concat('*')\n if (intent == 'repeating' && !action) {\n action = 'repeating'\n }\n if (!isPrimitive(entries[0][1])) {\n entries = Object.entries(entries[0][1])\n } else {\n descendIntent = null\n }\n // go deeper quicker by skipping objects with a single key and going into arrays direcly\n } else if (entries.length == 1 && intent != 'trimming' && intent != 'scoping') {\n return ConfigureDataBranch({\n datasourceName,\n prefix: (bits.length == 1 ? '' : prefix + '.') + entries[0][0],\n validator,\n path,\n data: entries[0][1],\n bits: bits.concat(entries[0][0]),\n intent,\n action,\n isVerbose,\n onConfigure,\n scopes,\n renderLeafTree,\n collapsedLeaves,\n onCollapsedLeavesChange\n })\n }\n }\n\n // This was to prevent from showing nodes that don't contain arrays when repeating.\n // It has been commented out since UI has changed\n // if (intent == 'repeating') {\n // // always show array children, just disabled\n // var hasArrays = action == 'repeating' || action == 'nesting'\n // walk(\n // (value: any) => {\n // if (Array.isArray(value)) hasArrays = true\n // },\n // data,\n // ''\n // )\n //\n // if (!hasArrays && action != 'repeating' && action != 'nesting' && action != 'indicating') {\n // if (isPrimitive(data)) {\n // var error = 'Only collections can be used for repeating'\n // } else {\n // var error = 'Does not contain collections for repeating'\n // }\n // }\n //\n // if (!hasArrays || action == 'repeating') descendIntent = null\n // }\n if (intent == 'scoping' && action != 'scoping') {\n if (Array.isArray(data)) currentPath += '.*' // ugh lol\n if (action == 'indicating') {\n descendIntent = null\n } else if (Array.isArray(data)) {\n descendIntent = null\n if (action != 'nesting') {\n if (scopes.length) {\n error = 'This collection is not in the current scope'\n } else {\n error = 'Use repeating on this collection to map its values'\n }\n } else {\n action = 'scoping'\n }\n }\n }\n if (intent == 'mapping' && (!action || action == 'nesting')) {\n if (action == 'nesting' && isPrimitive(Object.entries(data)[0][1])) {\n action = 'repeating-mapping'\n descendIntent = null\n currentPath += '.*' // ugh lol\n } else if (isPrimitive(data)) {\n var warning = validator ? validator(data) : null\n action = 'mapping'\n } else {\n if (Array.isArray(data) && action != 'nesting') {\n if (scopes.length) {\n descendIntent = null\n error = 'This collection is not in the current scope'\n } else {\n // error = 'Use repeating on this collection to map its values'\n }\n }\n var hasPrimitives = true\n walk(\n (value) => {\n if (isPrimitive(value)) hasPrimitives = true\n },\n data,\n ''\n )\n\n if (!hasPrimitives) {\n var error = 'Does not contain primitive value'\n }\n }\n }\n\n const DataLeaf = (props: DataLeafProps) => {\n return renderLeafTree ? (\n renderLeafTree(props, collapsedLeaves, onCollapsedLeavesChange)\n ) : (\n {label}\n )\n }\n\n return (\n \n onConfigure(currentPath)}\n warning={warning}\n onClear={() => onConfigure(null)}\n label={label == '$' ? datasourceName : label}\n action={action}\n error={error}\n isVerbose={isVerbose}\n path={currentPath}\n />\n\n {entries && descendIntent && entries.length > 0 && (\n \n {entries.map(([key, value]) =>\n ConfigureDataBranch({\n datasourceName,\n prefix: key,\n validator,\n path,\n data: value,\n bits: bits.concat(key),\n intent,\n action: null,\n isVerbose,\n scopes,\n onConfigure,\n renderLeafTree,\n collapsedLeaves,\n onCollapsedLeavesChange\n })\n )}\n \n )}\n \n )\n}\n","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n _typeof = function (obj) {\n return typeof obj;\n };\n } else {\n _typeof = function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n }\n\n return _typeof(obj);\n}\n\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n if (superClass) _setPrototypeOf(subClass, superClass);\n}\n\nfunction _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}\n\nfunction _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n\n return _setPrototypeOf(o, p);\n}\n\nfunction _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}\n\nfunction _construct(Parent, args, Class) {\n if (_isNativeReflectConstruct()) {\n _construct = Reflect.construct;\n } else {\n _construct = function _construct(Parent, args, Class) {\n var a = [null];\n a.push.apply(a, args);\n var Constructor = Function.bind.apply(Parent, a);\n var instance = new Constructor();\n if (Class) _setPrototypeOf(instance, Class.prototype);\n return instance;\n };\n }\n\n return _construct.apply(null, arguments);\n}\n\nfunction _isNativeFunction(fn) {\n return Function.toString.call(fn).indexOf(\"[native code]\") !== -1;\n}\n\nfunction _wrapNativeSuper(Class) {\n var _cache = typeof Map === \"function\" ? new Map() : undefined;\n\n _wrapNativeSuper = function _wrapNativeSuper(Class) {\n if (Class === null || !_isNativeFunction(Class)) return Class;\n\n if (typeof Class !== \"function\") {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n if (typeof _cache !== \"undefined\") {\n if (_cache.has(Class)) return _cache.get(Class);\n\n _cache.set(Class, Wrapper);\n }\n\n function Wrapper() {\n return _construct(Class, arguments, _getPrototypeOf(this).constructor);\n }\n\n Wrapper.prototype = Object.create(Class.prototype, {\n constructor: {\n value: Wrapper,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n return _setPrototypeOf(Wrapper, Class);\n };\n\n return _wrapNativeSuper(Class);\n}\n\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\nfunction _possibleConstructorReturn(self, call) {\n if (call && (typeof call === \"object\" || typeof call === \"function\")) {\n return call;\n }\n\n return _assertThisInitialized(self);\n}\n\nfunction _createSuper(Derived) {\n var hasNativeReflectConstruct = _isNativeReflectConstruct();\n\n return function _createSuperInternal() {\n var Super = _getPrototypeOf(Derived),\n result;\n\n if (hasNativeReflectConstruct) {\n var NewTarget = _getPrototypeOf(this).constructor;\n\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n\n return _possibleConstructorReturn(this, result);\n };\n}\n\nfunction _toConsumableArray(arr) {\n return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();\n}\n\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return _arrayLikeToArray(arr);\n}\n\nfunction _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\n\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n}\n\nfunction _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n\n return arr2;\n}\n\nfunction _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nfunction _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n\n if (!it) {\n if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n\n var F = function () {};\n\n return {\n s: F,\n n: function () {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function (e) {\n throw e;\n },\n f: F\n };\n }\n\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n\n var normalCompletion = true,\n didErr = false,\n err;\n return {\n s: function () {\n it = it.call(o);\n },\n n: function () {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function (e) {\n didErr = true;\n err = e;\n },\n f: function () {\n try {\n if (!normalCompletion && it.return != null) it.return();\n } finally {\n if (didErr) throw err;\n }\n }\n };\n}\n\nvar hasOwnProp = Object.prototype.hasOwnProperty;\n/**\n* @typedef {null|boolean|number|string|PlainObject|GenericArray} JSONObject\n*/\n\n/**\n * Copies array and then pushes item into it.\n * @param {GenericArray} arr Array to copy and into which to push\n * @param {any} item Array item to add (to end)\n * @returns {GenericArray} Copy of the original array\n */\n\nfunction push(arr, item) {\n arr = arr.slice();\n arr.push(item);\n return arr;\n}\n/**\n * Copies array and then unshifts item into it.\n * @param {any} item Array item to add (to beginning)\n * @param {GenericArray} arr Array to copy and into which to unshift\n * @returns {GenericArray} Copy of the original array\n */\n\n\nfunction unshift(item, arr) {\n arr = arr.slice();\n arr.unshift(item);\n return arr;\n}\n/**\n * Caught when JSONPath is used without `new` but rethrown if with `new`\n * @extends Error\n */\n\n\nvar NewError = /*#__PURE__*/function (_Error) {\n _inherits(NewError, _Error);\n\n var _super = _createSuper(NewError);\n\n /**\n * @param {any} value The evaluated scalar value\n */\n function NewError(value) {\n var _this;\n\n _classCallCheck(this, NewError);\n\n _this = _super.call(this, 'JSONPath should not be called with \"new\" (it prevents return ' + 'of (unwrapped) scalar values)');\n _this.avoidNew = true;\n _this.value = value;\n _this.name = 'NewError';\n return _this;\n }\n\n return NewError;\n}( /*#__PURE__*/_wrapNativeSuper(Error));\n/**\n* @typedef {PlainObject} ReturnObject\n* @property {string} path\n* @property {JSONObject} value\n* @property {PlainObject|GenericArray} parent\n* @property {string} parentProperty\n*/\n\n/**\n* @callback JSONPathCallback\n* @param {string|PlainObject} preferredOutput\n* @param {\"value\"|\"property\"} type\n* @param {ReturnObject} fullRetObj\n* @returns {void}\n*/\n\n/**\n* @callback OtherTypeCallback\n* @param {JSONObject} val\n* @param {string} path\n* @param {PlainObject|GenericArray} parent\n* @param {string} parentPropName\n* @returns {boolean}\n*/\n\n/* eslint-disable max-len -- Can make multiline type after https://github.com/syavorsky/comment-parser/issues/109 */\n\n/**\n * @typedef {PlainObject} JSONPathOptions\n * @property {JSON} json\n * @property {string|string[]} path\n * @property {\"value\"|\"path\"|\"pointer\"|\"parent\"|\"parentProperty\"|\"all\"} [resultType=\"value\"]\n * @property {boolean} [flatten=false]\n * @property {boolean} [wrap=true]\n * @property {PlainObject} [sandbox={}]\n * @property {boolean} [preventEval=false]\n * @property {PlainObject|GenericArray|null} [parent=null]\n * @property {string|null} [parentProperty=null]\n * @property {JSONPathCallback} [callback]\n * @property {OtherTypeCallback} [otherTypeCallback] Defaults to\n * function which throws on encountering `@other`\n * @property {boolean} [autostart=true]\n */\n\n/* eslint-enable max-len -- Can make multiline type after https://github.com/syavorsky/comment-parser/issues/109 */\n\n/**\n * @param {string|JSONPathOptions} opts If a string, will be treated as `expr`\n * @param {string} [expr] JSON path to evaluate\n * @param {JSON} [obj] JSON object to evaluate against\n * @param {JSONPathCallback} [callback] Passed 3 arguments: 1) desired payload\n * per `resultType`, 2) `\"value\"|\"property\"`, 3) Full returned object with\n * all payloads\n * @param {OtherTypeCallback} [otherTypeCallback] If `@other()` is at the end\n * of one's query, this will be invoked with the value of the item, its\n * path, its parent, and its parent's property name, and it should return\n * a boolean indicating whether the supplied value belongs to the \"other\"\n * type or not (or it may handle transformations and return `false`).\n * @returns {JSONPath}\n * @class\n */\n\n\nfunction JSONPath(opts, expr, obj, callback, otherTypeCallback) {\n // eslint-disable-next-line no-restricted-syntax\n if (!(this instanceof JSONPath)) {\n try {\n return new JSONPath(opts, expr, obj, callback, otherTypeCallback);\n } catch (e) {\n if (!e.avoidNew) {\n throw e;\n }\n\n return e.value;\n }\n }\n\n if (typeof opts === 'string') {\n otherTypeCallback = callback;\n callback = obj;\n obj = expr;\n expr = opts;\n opts = null;\n }\n\n var optObj = opts && _typeof(opts) === 'object';\n opts = opts || {};\n this.json = opts.json || obj;\n this.path = opts.path || expr;\n this.resultType = opts.resultType || 'value';\n this.flatten = opts.flatten || false;\n this.wrap = hasOwnProp.call(opts, 'wrap') ? opts.wrap : true;\n this.sandbox = opts.sandbox || {};\n this.preventEval = opts.preventEval || false;\n this.parent = opts.parent || null;\n this.parentProperty = opts.parentProperty || null;\n this.callback = opts.callback || callback || null;\n\n this.otherTypeCallback = opts.otherTypeCallback || otherTypeCallback || function () {\n throw new TypeError('You must supply an otherTypeCallback callback option ' + 'with the @other() operator.');\n };\n\n if (opts.autostart !== false) {\n var args = {\n path: optObj ? opts.path : expr\n };\n\n if (!optObj) {\n args.json = obj;\n } else if ('json' in opts) {\n args.json = opts.json;\n }\n\n var ret = this.evaluate(args);\n\n if (!ret || _typeof(ret) !== 'object') {\n throw new NewError(ret);\n }\n\n return ret;\n }\n} // PUBLIC METHODS\n\n\nJSONPath.prototype.evaluate = function (expr, json, callback, otherTypeCallback) {\n var _this2 = this;\n\n var currParent = this.parent,\n currParentProperty = this.parentProperty;\n var flatten = this.flatten,\n wrap = this.wrap;\n this.currResultType = this.resultType;\n this.currPreventEval = this.preventEval;\n this.currSandbox = this.sandbox;\n callback = callback || this.callback;\n this.currOtherTypeCallback = otherTypeCallback || this.otherTypeCallback;\n json = json || this.json;\n expr = expr || this.path;\n\n if (expr && _typeof(expr) === 'object' && !Array.isArray(expr)) {\n if (!expr.path && expr.path !== '') {\n throw new TypeError('You must supply a \"path\" property when providing an object ' + 'argument to JSONPath.evaluate().');\n }\n\n if (!hasOwnProp.call(expr, 'json')) {\n throw new TypeError('You must supply a \"json\" property when providing an object ' + 'argument to JSONPath.evaluate().');\n }\n\n var _expr = expr;\n json = _expr.json;\n flatten = hasOwnProp.call(expr, 'flatten') ? expr.flatten : flatten;\n this.currResultType = hasOwnProp.call(expr, 'resultType') ? expr.resultType : this.currResultType;\n this.currSandbox = hasOwnProp.call(expr, 'sandbox') ? expr.sandbox : this.currSandbox;\n wrap = hasOwnProp.call(expr, 'wrap') ? expr.wrap : wrap;\n this.currPreventEval = hasOwnProp.call(expr, 'preventEval') ? expr.preventEval : this.currPreventEval;\n callback = hasOwnProp.call(expr, 'callback') ? expr.callback : callback;\n this.currOtherTypeCallback = hasOwnProp.call(expr, 'otherTypeCallback') ? expr.otherTypeCallback : this.currOtherTypeCallback;\n currParent = hasOwnProp.call(expr, 'parent') ? expr.parent : currParent;\n currParentProperty = hasOwnProp.call(expr, 'parentProperty') ? expr.parentProperty : currParentProperty;\n expr = expr.path;\n }\n\n currParent = currParent || null;\n currParentProperty = currParentProperty || null;\n\n if (Array.isArray(expr)) {\n expr = JSONPath.toPathString(expr);\n }\n\n if (!expr && expr !== '' || !json) {\n return undefined;\n }\n\n var exprList = JSONPath.toPathArray(expr);\n\n if (exprList[0] === '$' && exprList.length > 1) {\n exprList.shift();\n }\n\n this._hasParentSelector = null;\n\n var result = this._trace(exprList, json, ['$'], currParent, currParentProperty, callback).filter(function (ea) {\n return ea && !ea.isParentSelector;\n });\n\n if (!result.length) {\n return wrap ? [] : undefined;\n }\n\n if (!wrap && result.length === 1 && !result[0].hasArrExpr) {\n return this._getPreferredOutput(result[0]);\n }\n\n return result.reduce(function (rslt, ea) {\n var valOrPath = _this2._getPreferredOutput(ea);\n\n if (flatten && Array.isArray(valOrPath)) {\n rslt = rslt.concat(valOrPath);\n } else {\n rslt.push(valOrPath);\n }\n\n return rslt;\n }, []);\n}; // PRIVATE METHODS\n\n\nJSONPath.prototype._getPreferredOutput = function (ea) {\n var resultType = this.currResultType;\n\n switch (resultType) {\n case 'all':\n {\n var path = Array.isArray(ea.path) ? ea.path : JSONPath.toPathArray(ea.path);\n ea.pointer = JSONPath.toPointer(path);\n ea.path = typeof ea.path === 'string' ? ea.path : JSONPath.toPathString(ea.path);\n return ea;\n }\n\n case 'value':\n case 'parent':\n case 'parentProperty':\n return ea[resultType];\n\n case 'path':\n return JSONPath.toPathString(ea[resultType]);\n\n case 'pointer':\n return JSONPath.toPointer(ea.path);\n\n default:\n throw new TypeError('Unknown result type');\n }\n};\n\nJSONPath.prototype._handleCallback = function (fullRetObj, callback, type) {\n if (callback) {\n var preferredOutput = this._getPreferredOutput(fullRetObj);\n\n fullRetObj.path = typeof fullRetObj.path === 'string' ? fullRetObj.path : JSONPath.toPathString(fullRetObj.path); // eslint-disable-next-line node/callback-return\n\n callback(preferredOutput, type, fullRetObj);\n }\n};\n/**\n *\n * @param {string} expr\n * @param {JSONObject} val\n * @param {string} path\n * @param {PlainObject|GenericArray} parent\n * @param {string} parentPropName\n * @param {JSONPathCallback} callback\n * @param {boolean} hasArrExpr\n * @param {boolean} literalPriority\n * @returns {ReturnObject|ReturnObject[]}\n */\n\n\nJSONPath.prototype._trace = function (expr, val, path, parent, parentPropName, callback, hasArrExpr, literalPriority) {\n var _this3 = this;\n\n // No expr to follow? return path and value as the result of\n // this trace branch\n var retObj;\n\n if (!expr.length) {\n retObj = {\n path: path,\n value: val,\n parent: parent,\n parentProperty: parentPropName,\n hasArrExpr: hasArrExpr\n };\n\n this._handleCallback(retObj, callback, 'value');\n\n return retObj;\n }\n\n var loc = expr[0],\n x = expr.slice(1); // We need to gather the return value of recursive trace calls in order to\n // do the parent sel computation.\n\n var ret = [];\n /**\n *\n * @param {ReturnObject|ReturnObject[]} elems\n * @returns {void}\n */\n\n function addRet(elems) {\n if (Array.isArray(elems)) {\n // This was causing excessive stack size in Node (with or\n // without Babel) against our performance test:\n // `ret.push(...elems);`\n elems.forEach(function (t) {\n ret.push(t);\n });\n } else {\n ret.push(elems);\n }\n }\n\n if ((typeof loc !== 'string' || literalPriority) && val && hasOwnProp.call(val, loc)) {\n // simple case--directly follow property\n addRet(this._trace(x, val[loc], push(path, loc), val, loc, callback, hasArrExpr)); // eslint-disable-next-line unicorn/prefer-switch -- Part of larger `if`\n } else if (loc === '*') {\n // all child properties\n this._walk(loc, x, val, path, parent, parentPropName, callback, function (m, l, _x, v, p, par, pr, cb) {\n addRet(_this3._trace(unshift(m, _x), v, p, par, pr, cb, true, true));\n });\n } else if (loc === '..') {\n // all descendent parent properties\n // Check remaining expression with val's immediate children\n addRet(this._trace(x, val, path, parent, parentPropName, callback, hasArrExpr));\n\n this._walk(loc, x, val, path, parent, parentPropName, callback, function (m, l, _x, v, p, par, pr, cb) {\n // We don't join m and x here because we only want parents,\n // not scalar values\n if (_typeof(v[m]) === 'object') {\n // Keep going with recursive descent on val's\n // object children\n addRet(_this3._trace(unshift(l, _x), v[m], push(p, m), v, m, cb, true));\n }\n }); // The parent sel computation is handled in the frame above using the\n // ancestor object of val\n\n } else if (loc === '^') {\n // This is not a final endpoint, so we do not invoke the callback here\n this._hasParentSelector = true;\n return {\n path: path.slice(0, -1),\n expr: x,\n isParentSelector: true\n };\n } else if (loc === '~') {\n // property name\n retObj = {\n path: push(path, loc),\n value: parentPropName,\n parent: parent,\n parentProperty: null\n };\n\n this._handleCallback(retObj, callback, 'property');\n\n return retObj;\n } else if (loc === '$') {\n // root only\n addRet(this._trace(x, val, path, null, null, callback, hasArrExpr));\n } else if (/^(\\x2D?[0-9]*):(\\x2D?[0-9]*):?([0-9]*)$/.test(loc)) {\n // [start:end:step] Python slice syntax\n addRet(this._slice(loc, x, val, path, parent, parentPropName, callback));\n } else if (loc.indexOf('?(') === 0) {\n // [?(expr)] (filtering)\n if (this.currPreventEval) {\n throw new Error('Eval [?(expr)] prevented in JSONPath expression.');\n }\n\n this._walk(loc, x, val, path, parent, parentPropName, callback, function (m, l, _x, v, p, par, pr, cb) {\n if (_this3._eval(l.replace(/^\\?\\(((?:[\\0-\\t\\x0B\\f\\x0E-\\u2027\\u202A-\\uD7FF\\uE000-\\uFFFF]|[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF])*?)\\)$/, '$1'), v[m], m, p, par, pr)) {\n addRet(_this3._trace(unshift(m, _x), v, p, par, pr, cb, true));\n }\n });\n } else if (loc[0] === '(') {\n // [(expr)] (dynamic property/index)\n if (this.currPreventEval) {\n throw new Error('Eval [(expr)] prevented in JSONPath expression.');\n } // As this will resolve to a property name (but we don't know it\n // yet), property and parent information is relative to the\n // parent of the property to which this expression will resolve\n\n\n addRet(this._trace(unshift(this._eval(loc, val, path[path.length - 1], path.slice(0, -1), parent, parentPropName), x), val, path, parent, parentPropName, callback, hasArrExpr));\n } else if (loc[0] === '@') {\n // value type: @boolean(), etc.\n var addType = false;\n var valueType = loc.slice(1, -2);\n\n switch (valueType) {\n case 'scalar':\n if (!val || !['object', 'function'].includes(_typeof(val))) {\n addType = true;\n }\n\n break;\n\n case 'boolean':\n case 'string':\n case 'undefined':\n case 'function':\n // eslint-disable-next-line valid-typeof\n if (_typeof(val) === valueType) {\n addType = true;\n }\n\n break;\n\n case 'integer':\n if (Number.isFinite(val) && !(val % 1)) {\n addType = true;\n }\n\n break;\n\n case 'number':\n if (Number.isFinite(val)) {\n addType = true;\n }\n\n break;\n\n case 'nonFinite':\n if (typeof val === 'number' && !Number.isFinite(val)) {\n addType = true;\n }\n\n break;\n\n case 'object':\n // eslint-disable-next-line valid-typeof\n if (val && _typeof(val) === valueType) {\n addType = true;\n }\n\n break;\n\n case 'array':\n if (Array.isArray(val)) {\n addType = true;\n }\n\n break;\n\n case 'other':\n addType = this.currOtherTypeCallback(val, path, parent, parentPropName);\n break;\n\n case 'null':\n if (val === null) {\n addType = true;\n }\n\n break;\n\n /* c8 ignore next 2 */\n\n default:\n throw new TypeError('Unknown value type ' + valueType);\n }\n\n if (addType) {\n retObj = {\n path: path,\n value: val,\n parent: parent,\n parentProperty: parentPropName\n };\n\n this._handleCallback(retObj, callback, 'value');\n\n return retObj;\n } // `-escaped property\n\n } else if (loc[0] === '`' && val && hasOwnProp.call(val, loc.slice(1))) {\n var locProp = loc.slice(1);\n addRet(this._trace(x, val[locProp], push(path, locProp), val, locProp, callback, hasArrExpr, true));\n } else if (loc.includes(',')) {\n // [name1,name2,...]\n var parts = loc.split(',');\n\n var _iterator = _createForOfIteratorHelper(parts),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var part = _step.value;\n addRet(this._trace(unshift(part, x), val, path, parent, parentPropName, callback, true));\n } // simple case--directly follow property\n\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n } else if (!literalPriority && val && hasOwnProp.call(val, loc)) {\n addRet(this._trace(x, val[loc], push(path, loc), val, loc, callback, hasArrExpr, true));\n } // We check the resulting values for parent selections. For parent\n // selections we discard the value object and continue the trace with the\n // current val object\n\n\n if (this._hasParentSelector) {\n for (var t = 0; t < ret.length; t++) {\n var rett = ret[t];\n\n if (rett && rett.isParentSelector) {\n var tmp = this._trace(rett.expr, val, rett.path, parent, parentPropName, callback, hasArrExpr);\n\n if (Array.isArray(tmp)) {\n ret[t] = tmp[0];\n var tl = tmp.length;\n\n for (var tt = 1; tt < tl; tt++) {\n t++;\n ret.splice(t, 0, tmp[tt]);\n }\n } else {\n ret[t] = tmp;\n }\n }\n }\n }\n\n return ret;\n};\n\nJSONPath.prototype._walk = function (loc, expr, val, path, parent, parentPropName, callback, f) {\n if (Array.isArray(val)) {\n var n = val.length;\n\n for (var i = 0; i < n; i++) {\n f(i, loc, expr, val, path, parent, parentPropName, callback);\n }\n } else if (val && _typeof(val) === 'object') {\n Object.keys(val).forEach(function (m) {\n f(m, loc, expr, val, path, parent, parentPropName, callback);\n });\n }\n};\n\nJSONPath.prototype._slice = function (loc, expr, val, path, parent, parentPropName, callback) {\n if (!Array.isArray(val)) {\n return undefined;\n }\n\n var len = val.length,\n parts = loc.split(':'),\n step = parts[2] && Number.parseInt(parts[2]) || 1;\n var start = parts[0] && Number.parseInt(parts[0]) || 0,\n end = parts[1] && Number.parseInt(parts[1]) || len;\n start = start < 0 ? Math.max(0, start + len) : Math.min(len, start);\n end = end < 0 ? Math.max(0, end + len) : Math.min(len, end);\n var ret = [];\n\n for (var i = start; i < end; i += step) {\n var tmp = this._trace(unshift(i, expr), val, path, parent, parentPropName, callback, true); // Should only be possible to be an array here since first part of\n // ``unshift(i, expr)` passed in above would not be empty, nor `~`,\n // nor begin with `@` (as could return objects)\n // This was causing excessive stack size in Node (with or\n // without Babel) against our performance test: `ret.push(...tmp);`\n\n\n tmp.forEach(function (t) {\n ret.push(t);\n });\n }\n\n return ret;\n};\n\nJSONPath.prototype._eval = function (code, _v, _vname, path, parent, parentPropName) {\n if (code.includes('@parentProperty')) {\n this.currSandbox._$_parentProperty = parentPropName;\n code = code.replace(/@parentProperty/g, '_$_parentProperty');\n }\n\n if (code.includes('@parent')) {\n this.currSandbox._$_parent = parent;\n code = code.replace(/@parent/g, '_$_parent');\n }\n\n if (code.includes('@property')) {\n this.currSandbox._$_property = _vname;\n code = code.replace(/@property/g, '_$_property');\n }\n\n if (code.includes('@path')) {\n this.currSandbox._$_path = JSONPath.toPathString(path.concat([_vname]));\n code = code.replace(/@path/g, '_$_path');\n }\n\n if (code.includes('@root')) {\n this.currSandbox._$_root = this.json;\n code = code.replace(/@root/g, '_$_root');\n }\n\n if (/@([\\t-\\r \\)\\.\\[\\xA0\\u1680\\u2000-\\u200A\\u2028\\u2029\\u202F\\u205F\\u3000\\uFEFF])/.test(code)) {\n this.currSandbox._$_v = _v;\n code = code.replace(/@([\\t-\\r \\)\\.\\[\\xA0\\u1680\\u2000-\\u200A\\u2028\\u2029\\u202F\\u205F\\u3000\\uFEFF])/g, '_$_v$1');\n }\n\n try {\n return this.vm.runInNewContext(code, this.currSandbox);\n } catch (e) {\n // eslint-disable-next-line no-console\n console.log(e);\n throw new Error('jsonPath: ' + e.message + ': ' + code);\n }\n}; // PUBLIC CLASS PROPERTIES AND METHODS\n// Could store the cache object itself\n\n\nJSONPath.cache = {};\n/**\n * @param {string[]} pathArr Array to convert\n * @returns {string} The path string\n */\n\nJSONPath.toPathString = function (pathArr) {\n var x = pathArr,\n n = x.length;\n var p = '$';\n\n for (var i = 1; i < n; i++) {\n if (!/^(~|\\^|@(?:[\\0-\\t\\x0B\\f\\x0E-\\u2027\\u202A-\\uD7FF\\uE000-\\uFFFF]|[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF])*?\\(\\))$/.test(x[i])) {\n p += /^[\\*0-9]+$/.test(x[i]) ? '[' + x[i] + ']' : \"['\" + x[i] + \"']\";\n }\n }\n\n return p;\n};\n/**\n * @param {string} pointer JSON Path\n * @returns {string} JSON Pointer\n */\n\n\nJSONPath.toPointer = function (pointer) {\n var x = pointer,\n n = x.length;\n var p = '';\n\n for (var i = 1; i < n; i++) {\n if (!/^(~|\\^|@(?:[\\0-\\t\\x0B\\f\\x0E-\\u2027\\u202A-\\uD7FF\\uE000-\\uFFFF]|[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF])*?\\(\\))$/.test(x[i])) {\n p += '/' + x[i].toString().replace(/~/g, '~0').replace(/\\//g, '~1');\n }\n }\n\n return p;\n};\n/**\n * @param {string} expr Expression to convert\n * @returns {string[]}\n */\n\n\nJSONPath.toPathArray = function (expr) {\n var cache = JSONPath.cache;\n\n if (cache[expr]) {\n return cache[expr].concat();\n }\n\n var subx = [];\n var normalized = expr // Properties\n .replace(/@(?:null|boolean|number|string|integer|undefined|nonFinite|scalar|array|object|function|other)\\(\\)/g, ';$&;') // Parenthetical evaluations (filtering and otherwise), directly\n // within brackets or single quotes\n .replace(/['\\[](\\??\\((?:[\\0-\\t\\x0B\\f\\x0E-\\u2027\\u202A-\\uD7FF\\uE000-\\uFFFF]|[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF])*?\\))['\\]]/g, function ($0, $1) {\n return '[#' + (subx.push($1) - 1) + ']';\n }) // Escape periods and tildes within properties\n .replace(/\\[[\"']((?:(?!['\\]])[\\s\\S])*)[\"']\\]/g, function ($0, prop) {\n return \"['\" + prop.replace(/\\./g, '%@%').replace(/~/g, '%%@@%%') + \"']\";\n }) // Properties operator\n .replace(/~/g, ';~;') // Split by property boundaries\n .replace(/[\"']?\\.[\"']?(?!(?:(?!\\[)[\\s\\S])*\\])|\\[[\"']?/g, ';') // Reinsert periods within properties\n .replace(/%@%/g, '.') // Reinsert tildes within properties\n .replace(/%%@@%%/g, '~') // Parent\n .replace(/(?:;)?(\\^+)(?:;)?/g, function ($0, ups) {\n return ';' + ups.split('').join(';') + ';';\n }) // Descendents\n .replace(/;;;|;;/g, ';..;') // Remove trailing\n .replace(/;$|'?\\]|'$/g, '');\n var exprList = normalized.split(';').map(function (exp) {\n var match = exp.match(/#([0-9]+)/);\n return !match || !match[1] ? exp : subx[match[1]];\n });\n cache[expr] = exprList;\n return cache[expr].concat();\n};\n\n/**\n* @callback ConditionCallback\n* @param {any} item\n* @returns {boolean}\n*/\n\n/**\n * Copy items out of one array into another.\n * @param {GenericArray} source Array with items to copy\n * @param {GenericArray} target Array to which to copy\n * @param {ConditionCallback} conditionCb Callback passed the current item;\n * will move item if evaluates to `true`\n * @returns {void}\n */\n\nvar moveToAnotherArray = function moveToAnotherArray(source, target, conditionCb) {\n var il = source.length;\n\n for (var i = 0; i < il; i++) {\n var item = source[i];\n\n if (conditionCb(item)) {\n target.push(source.splice(i--, 1)[0]);\n }\n }\n};\n\nJSONPath.prototype.vm = {\n /**\n * @param {string} expr Expression to evaluate\n * @param {PlainObject} context Object whose items will be added\n * to evaluation\n * @returns {any} Result of evaluated code\n */\n runInNewContext: function runInNewContext(expr, context) {\n var keys = Object.keys(context);\n var funcs = [];\n moveToAnotherArray(keys, funcs, function (key) {\n return typeof context[key] === 'function';\n });\n var values = keys.map(function (vr, i) {\n return context[vr];\n });\n var funcString = funcs.reduce(function (s, func) {\n var fString = context[func].toString();\n\n if (!/function/.test(fString)) {\n fString = 'function ' + fString;\n }\n\n return 'var ' + func + '=' + fString + ';' + s;\n }, '');\n expr = funcString + expr; // Mitigate http://perfectionkills.com/global-eval-what-are-the-options/#new_function\n\n if (!/([\"'])use strict\\1/.test(expr) && !keys.includes('arguments')) {\n expr = 'var arguments = undefined;' + expr;\n } // Remove last semi so `return` will be inserted before\n // the previous one instead, allowing for the return\n // of a bare ending expression\n\n\n expr = expr.replace(/;[\\t-\\r \\xA0\\u1680\\u2000-\\u200A\\u2028\\u2029\\u202F\\u205F\\u3000\\uFEFF]*$/, ''); // Insert `return`\n\n var lastStatementEnd = expr.lastIndexOf(';');\n var code = lastStatementEnd > -1 ? expr.slice(0, lastStatementEnd + 1) + ' return ' + expr.slice(lastStatementEnd + 1) : ' return ' + expr; // eslint-disable-next-line no-new-func\n\n return _construct(Function, _toConsumableArray(keys).concat([code])).apply(void 0, _toConsumableArray(values));\n }\n};\n\nexport { JSONPath };\n","import { HStack, Icon, Text, Tooltip } from '@chakra-ui/react'\nimport {\n mdiCalendar,\n mdiChevronDown,\n mdiChevronUp,\n mdiCircleSmall,\n mdiFolderOpenOutline,\n mdiFolderOutline,\n mdiFolderRefreshOutline,\n mdiImageOutline,\n mdiLinkVariant,\n mdiLockOutline,\n mdiNumeric,\n mdiPaperclip,\n mdiText,\n mdiToggleSwitchOutline\n} from '@mdi/js'\nimport { JSONPath } from 'jsonpath-plus'\nimport { DatasourceModel, isObject } from '@sitecore-feaas/sdk'\nimport type { LeafStatus } from './DatasourceTreeLeafWrapper.js'\nimport type { ConfigureAction } from './DatasourceTree.js'\n\nconst IMAGE_EXTENSIONS = [\n '.jpeg',\n '.jpg',\n '.png',\n '.gif',\n '.bmp',\n '.tif',\n '.tiff',\n '.webp',\n '.webm',\n '.wbmp',\n '.svg',\n '.apng',\n '.ico',\n '.psd',\n '.ai',\n '.eps',\n '.heif',\n '.heic',\n 'data:image'\n]\nconst URL_PREFIXES = [\n 'http://',\n 'https://',\n 'ftp://',\n 'sftp://',\n 'file://',\n 'data:',\n 'ws://',\n 'wss://',\n 'ssh://',\n 'git://',\n 'steam://'\n]\n\nconst getIcon = (\n type: 'array' | 'empty' | 'object' | 'date' | 'string' | 'image' | 'url' | 'boolean' | 'number',\n action: ConfigureAction | 'reporting' | null\n) => {\n const ICONS = {\n date: mdiCalendar,\n array: mdiFolderOpenOutline,\n repeater: mdiFolderRefreshOutline,\n object: mdiFolderOutline,\n image: mdiImageOutline,\n url: mdiLinkVariant,\n number: mdiNumeric,\n string: mdiText,\n boolean: mdiToggleSwitchOutline,\n empty: mdiCircleSmall\n }\n\n if (type === 'array' && (action === 'repeating-mapping' || action === 'nesting')) return ICONS['repeater']\n else return ICONS[type]\n}\nconst DatasourceTreeLeafContent = ({\n path,\n datasource,\n label,\n collapsedLeaves,\n onCollapsedLeavesChange,\n leafStatus = 'unchanged',\n action\n}: {\n path: string\n datasource: DatasourceModel\n label: string\n collapsedLeaves: string[]\n onCollapsedLeavesChange: (path: string[]) => void\n leafStatus?: LeafStatus\n action: ConfigureAction | 'reporting' | null\n}) => {\n const value = JSONPath({\n path: path.replaceAll('*', '0').replaceAll('@', '`@'),\n json: datasource.sample,\n wrap: false\n })\n const type =\n value === ''\n ? 'empty'\n : Array.isArray(value)\n ? 'array'\n : isObject(value)\n ? 'object'\n : value instanceof Date\n ? 'date'\n : typeof value === 'string'\n ? IMAGE_EXTENSIONS.some((ext) => value.includes(ext))\n ? 'image'\n : URL_PREFIXES.some((prefix) => value.startsWith(prefix))\n ? 'url'\n : isNaN(+value) && Date.parse(value)\n ? 'date'\n : 'string'\n : typeof value === 'boolean'\n ? 'boolean'\n : !isNaN(value)\n ? 'number'\n : undefined\n\n const handleCollapseLeaf = (e: React.MouseEvent) => {\n e.stopPropagation()\n if (collapsedLeaves.includes(path)) onCollapsedLeavesChange(collapsedLeaves.filter((p) => p !== path))\n else onCollapsedLeavesChange([...collapsedLeaves, path])\n }\n\n return (\n \n \n {leafStatus !== 'removed' && (\n \n \n \n )}\n {path === '$' || path === '$.*' ? datasource.name : label}\n {((type === 'object' && Object.keys(value).length) || (type === 'array' && value.length)) && (\n handleCollapseLeaf(e)}>\n \n \n )}\n \n \n )\n}\n\nexport default DatasourceTreeLeafContent\n","import { DatasourceModel } from '@sitecore-feaas/sdk'\nimport { mdiInformationOutline } from '@mdi/js'\nimport { Box, FormControl, FormLabel, HStack, Icon, Input, Link, Switch, Tooltip } from '@chakra-ui/react'\nimport FieldsetField from '../FieldsetField.js'\nimport DatasourceTree from '../datasources/DatasourceTree.js'\nimport DatasourceTreeLeafWrapper from '../datasources/DatasourceTreeLeafWrapper.js'\nimport DatasourceTreeLeafContent from '../datasources/DatasourceTreeLeafContent.js'\nimport React, { ChangeEvent, useEffect, useState } from 'react'\nimport { DataPath, DataScope } from '@sitecore-feaas/clientside/headless'\nimport { DialogAttributeGeneric } from '../editor/dialog/Dialog.js'\nimport * as CK from '@sitecore-feaas/ckeditor5'\nimport { Text } from '@chakra-ui/react'\n\nconst PickerDatasourcesPath = ({\n context,\n type,\n datasource,\n textpath,\n jsonpath,\n onTextpathChange,\n onConfigure,\n onRepeatingChange\n}: {\n context: DialogAttributeGeneric['context']\n type: DialogAttributeGeneric['type']\n datasource: DatasourceModel\n textpath: string\n jsonpath: string\n onTextpathChange: (textpath: string) => void\n onConfigure: (value: string) => void\n onRepeatingChange: (repeating: 'no-limit' | 'limit' | 'range') => void\n}) => {\n if (!datasource) return <>Please select a datasource to be able to set its path\n\n const [showDetails, setShowDetails] = useState(false)\n\n const scopes = (context as CK.ModelElement)\n .getAncestors({ includeSelf: true })\n .reduce((scopes, el: CK.ModelElement) => {\n if (el.getAttribute('data-path-scope') == null) return scopes\n return [el.getAttribute('data-path-scope')].concat(scopes)\n }, [])\n const validate = (value: string) => {\n if (type == 'url' || type == 'image') {\n if (typeof value != 'string' || (!value.startsWith('/') && !value.includes('//'))) {\n return 'Value does not look like an URL'\n }\n }\n if (type == 'boolean') {\n if (typeof value != 'boolean' && typeof value != 'number') {\n return 'Value does not look like an boolean'\n }\n }\n }\n\n return (\n <>\n <>\n \n \n setShowDetails((v) => !v)}\n isChecked={showDetails}\n >\n \n \n \n JSONPath{' '}\n \n \n \n \n \n \n\n {showDetails && (\n ) => onTextpathChange(e.target.value)}\n onBlur={(e: ChangeEvent) => onConfigure(e.target.value)}\n placeholder='JSON Path'\n />\n )}\n\n \n {\n onRepeatingChange('no-limit')\n onConfigure(path)\n }}\n intent={type == 'array' ? 'repeating' : type == 'object' ? 'scoping' : 'mapping'}\n data={DataScope.queryObjectRaw(datasource.sample, datasource.settings.jsonpath)[0]}\n prefix={\n datasource?.id +\n (datasource.settings.jsonpath == '$' ? '' : '.' + datasource.settings.jsonpath.replace('$.', '') + '.$')\n }\n label={datasource.settings.jsonpath != '$' ? datasource.name : undefined}\n path={jsonpath}\n scopes={scopes}\n renderLeafTree={(props, collapsedLeaves, onCollapsedLeavesChange) => {\n const { path, label } = props\n const currentPath = path.replace(datasource.id, '$')\n const parentPath = currentPath.substring(0, currentPath.lastIndexOf('.'))\n\n // collapsed\n if (collapsedLeaves.some((p) => parentPath.includes(p))) return null\n\n // expanded\n return (\n <>\n \n {\n \n }\n \n \n )\n }}\n />\n \n \n \n )\n}\n\nexport default PickerDatasourcesPath\n","import React, { useEffect, useState } from 'react'\nimport {\n InputGroup,\n InputGroupProps,\n InputRightAddon,\n NumberDecrementStepper,\n NumberIncrementStepper,\n NumberInput,\n NumberInputField,\n NumberInputStepper\n} from '@chakra-ui/react'\n\nconst NumberField = ({\n value,\n min = 0,\n max = 100,\n step = 1,\n disabled,\n onChange,\n placeholder,\n withAddon,\n withStepper,\n ...props\n}: Omit & {\n value: number\n placeholder?: string\n min?: number\n max?: number\n step?: number\n disabled?: boolean\n onChange: (value: number) => void\n withAddon?: string\n withStepper?: boolean\n}) => {\n const [current, setCurrent] = useState(value)\n\n const isCurrentNotValidNumber = Number.isNaN(current)\n const isCurrentValidNumber = !isCurrentNotValidNumber\n const isCurrentEmptyString = current == ''\n const isCurrentNotEmptyString = !isCurrentEmptyString\n const isCurrentValid = isCurrentNotEmptyString && isCurrentValidNumber\n const isValueNotZero = value != 0\n const isValueZero = !isValueNotZero\n const isCurrentDash = current === '-'\n const currentIsEqualToValue = current == value\n const sx = !withStepper ? { div: { display: 'none' } } : {}\n\n const onUpdateCurrentFromValue = () => setCurrent(value)\n const onUpdateValueFromCurrent = () => onChange(current)\n\n const onResetCurrent = () => setCurrent(0)\n const onResetValue = () => onChange(0)\n\n useEffect(() => {\n if (isCurrentDash) return\n\n if (isCurrentEmptyString) {\n onResetValue()\n\n return\n }\n\n if (currentIsEqualToValue) return\n\n onUpdateValueFromCurrent()\n }, [current])\n\n useEffect(() => {\n if (currentIsEqualToValue) return\n\n // Why are we checking with \"isCurrentNotEmptyString\" here?\n if (isValueZero && isCurrentNotEmptyString) return\n\n onUpdateCurrentFromValue()\n }, [value])\n\n const onBlur = () => {\n if (isCurrentValid) return\n\n onResetCurrent()\n }\n\n const onInputChange = (valueAsString: string, valueAsNumber: number) => {\n const largerThanMax = valueAsNumber > max\n const lowerThanMin = valueAsNumber < min\n\n if (largerThanMax || lowerThanMin) return\n\n const isValueAsNumberNotValidNumber = Number.isNaN(valueAsNumber)\n\n const newCurrent = isValueAsNumberNotValidNumber ? valueAsString : valueAsNumber\n\n setCurrent(newCurrent)\n }\n\n return (\n \n \n \n \n \n \n \n \n\n {withAddon && }\n \n )\n}\n\nexport default NumberField\n","import FieldsetField from '../FieldsetField.js'\nimport ButtonGroupSwitch from '../ButtonGroupSwitch.js'\nimport {\n Text,\n Button,\n Flex,\n Icon,\n Input,\n Spacer,\n Switch,\n Tooltip,\n VStack,\n AlertTitle,\n AlertDescription,\n Alert\n} from '@chakra-ui/react'\nimport NumberField from '../styles/fields/NumberField.js'\nimport { mdiInformationOutline } from '@mdi/js'\nimport { DataPath, DataScope, DataSettings } from '@sitecore-feaas/clientside/headless'\nimport React, { ChangeEvent, useReducer, useState } from 'react'\nimport DataItem from '../DataItem.js'\nimport { DatasourceModel } from '@sitecore-feaas/sdk'\nimport isDataSettings = DataSettings.isDataSettings\nimport { PickerProps } from './Picker.js'\n\n/**\n * Keep in mind that this component is used both in Pages (where datasource path looks like $.[some-path].*) and Components Builder (where datasource path looks like {datasource.id}.[some-path].*\n * This function replaces the {datasource.id} with \"$\" so that in both cases the path looks like $.[some-path].*\n */\nconst getOriginalPath = (jsonpath: string, datasource: DatasourceModel) =>\n jsonpath.substring(0, datasource.id.length + 1) == datasource.id + '.' || jsonpath === datasource.id\n ? jsonpath.replace(datasource.id, '$')\n : jsonpath\n\nconst PickerDatasourcesItems = ({\n datasource,\n jsonpath,\n repeating,\n qualifier,\n variant,\n isBYOC,\n onRepeatingChange,\n onConfigure\n}: {\n datasource: DatasourceModel\n jsonpath: string\n repeating: 'no-limit' | 'limit' | 'range'\n qualifier: string\n isBYOC?: boolean\n variant?: PickerProps['variant']\n onRepeatingChange: (repeating: 'no-limit' | 'limit' | 'range') => void\n onConfigure: (value: any, attribute?: string) => void\n}) => {\n if (!datasource || !jsonpath) return <>Please select a datasource and a path to be able to view items\n\n const rawPath = qualifier ? jsonpath?.substring(0, jsonpath.length - qualifier.length) : jsonpath\n\n const root = DataScope.queryObjectRaw(datasource.sample, getOriginalPath(rawPath, datasource))[0] as any\n const isArray = Array.isArray(root)\n const isFetched = isDataSettings(datasource.settings) && datasource.settings?.url\n\n const [isInvalid, setIsInvalid] = useState(false)\n const [hideDetails, setHideDetails] = useState(false)\n const items =\n datasource && jsonpath\n ? (DataScope.queryObject(datasource.sample, getOriginalPath(rawPath, datasource)) as any[])\n : []\n const selectedItems =\n datasource && jsonpath\n ? DataScope.queryObject(datasource.sample, getOriginalPath(rawPath, datasource) + qualifier).map((item, index) =>\n items.findIndex((i) => i === item)\n )\n : []\n const [renderItemNumbersInput, rerenderItemNumbersInput] = useReducer((r) => r + 1, 0)\n\n function reconfigure(mode: typeof repeating) {\n setIsInvalid(false)\n if (!rawPath) onConfigure(null)\n else if (mode == 'no-limit') onConfigure(rawPath + '.*')\n else if (mode == 'limit') onConfigure(rawPath + '[0:10]')\n else if (mode == 'range') onConfigure(rawPath + '[0,1,2]')\n }\n\n // increment numbers by given numbers, exclude second value of ranges to ensure inclusivity\n function adjustNumbers(string: string, diff: number) {\n return string?.replace(/(.|^)(\\d+)/g, (m, b, n) => b + (b == ':' ? n : String(parseInt(n) + diff)))\n }\n\n function onQualifierChange(nextQualifier: string, isLimit = false) {\n const parsedLimit = isLimit ? DataPath.parseLimit(nextQualifier) : DataPath.parseRange(nextQualifier)\n setIsInvalid(parsedLimit == null)\n if (parsedLimit) onConfigure(rawPath + nextQualifier)\n }\n\n return (\n <>\n {isArray && (isFetched || variant != 'pages') ? (\n <>\n \n {\n reconfigure(value)\n onRepeatingChange(value)\n }}\n >\n \n \n \n \n \n {repeating == 'limit' && (\n \n {\n const nextQualifier = '[0:' + value + ']'\n onQualifierChange(nextQualifier, true)\n }}\n withStepper={true}\n />\n \n )}\n {repeating == 'range' && (\n \n Item numbers{' '}\n \n Examples:\n
\n 1   -- only first item\n
\n 1-3 -- First three items\n
\n 2,3 -- Second and third item\n \n }\n >\n \n \n \n \n \n }\n >\n {\n const nextQualifier =\n '[' + adjustNumbers(e.target.value.replace(/(\\d)\\s*-\\s*(\\d)/g, '$1:$2'), -1) + ']'\n onQualifierChange(nextQualifier)\n }}\n />\n \n )}\n \n \n ) => setHideDetails(e.target.checked)}\n isChecked={hideDetails}\n >\n \n \n \n ) : (\n !isBYOC && (\n \n \n {!isFetched ? (\n <>\n Configure fetching\n \n Data item picker allows limiting and choosing specific data items from fetched data source. To\n enable this, data source needs to be configured for data fetching (i.e. needs to have URL specified)\n \n \n ) : (\n <>\n Select an array\n \n Data item picker allows Pages users to configure sets of data items. To enable this, you must select\n an array in the data tree. If you need to, edit the data source to include an array in its data\n structure.\n \n \n )}\n \n \n )\n )}\n \n {items.map((item: any, index: number) => (\n {\n if (isFetched) onConfigure(jsonpath)\n }}\n onSelect={(selected) => {\n const nextSelectedItems = selected ? [...selectedItems, index] : selectedItems.filter((i) => i !== index)\n const nextQualifier = '[' + nextSelectedItems.join(',') + ']'\n onQualifierChange(nextQualifier)\n onRepeatingChange('range')\n rerenderItemNumbersInput()\n }}\n />\n ))}\n \n \n )\n}\n\nexport default PickerDatasourcesItems\n","import { DialogAttributeGeneric } from './Dialog.js'\nimport { useSDK } from '../../../hooks/useData.js'\nimport React, { useEffect, useState } from 'react'\nimport * as CK from '@sitecore-feaas/ckeditor5'\nimport { Box } from '@chakra-ui/react'\nimport { DatasourceModel } from '@sitecore-feaas/sdk'\nimport { DataPath } from '@sitecore-feaas/clientside/headless'\nimport PickerWizard from '../../PickerWizard.js'\nimport PickerDatasourcesSource from '../../picker/PickerDatasourcesSource.js'\nimport PickerDatasourcesPath from '../../picker/PickerDatasourcesPath.js'\nimport PickerDatasourcesItems from '../../picker/PickerDatasourcesItems.js'\nimport { PickerProps } from '../../picker/Picker.js'\nfunction getDefaultDatasource(model: CK.ModelElement, datasources: DatasourceModel[]) {\n function getDatasourceFromElement(model: CK.ModelElement) {\n for (const [name, value] of model.getAttributes()) {\n if (name.startsWith('data-path')) {\n const id = String(value).replace(/^\\$.?/, '').split(/\\.|\\[/)[0]\n\n const datasource = datasources.find((d) => d.id == id)\n\n return datasource\n }\n }\n }\n\n for (var m = model; m; m = m.parent as CK.ModelElement) {\n const datasource = getDatasourceFromElement(m)\n\n if (datasource) return datasource\n }\n\n function walkModel(element: CK.ModelElement, callback: (element: CK.ModelElement) => void) {\n callback(element)\n\n for (const child of element.getChildren()) {\n if (child.is('element')) {\n walkModel(child, callback)\n }\n }\n }\n\n var datasource\n for (const rootName of model.root.document.getRootNames()) {\n const root = model.root.document.getRoot(rootName)\n\n if (!datasource)\n walkModel(root as CK.ModelElement, (child) => {\n datasource ||= getDatasourceFromElement(child)\n })\n }\n\n return datasource\n}\n\nconst DialogAttributesMapping = ({\n context,\n jsonpath,\n type,\n onConfigure,\n label,\n onModeChange\n}: DialogAttributeGeneric) => {\n const [showWizard, setShowWizard] = useState(true)\n\n const datasources = useSDK('datasources')\n const qualifier = DataPath.getQualifier(jsonpath)\n const [repeating, setRepeating] = useState<'no-limit' | 'limit' | 'range'>(() => {\n return DataPath.parseLimit(qualifier) ? 'limit' : DataPath.parseRange(qualifier) ? 'range' : 'no-limit'\n })\n\n const [textpath, setTextpath] = useState(jsonpath)\n useEffect(() => {\n setTextpath(jsonpath)\n if (!jsonpath) setRepeating('no-limit')\n }, [jsonpath])\n\n const [datasource, setDatasource] = useState(() => getDefaultDatasource(context as CK.ModelElement, datasources))\n\n const steps =\n type === 'array'\n ? [\n {\n title: 'Source'\n },\n { title: 'Path' },\n { title: 'Items' }\n ]\n : [{ title: 'Source' }, { title: 'Path' }]\n\n if (!showWizard) return null\n\n return (\n \n onModeChange(null)}\n >\n \n \n \n \n \n )\n}\n\nexport default DialogAttributesMapping\n","import { Button } from '@chakra-ui/react'\nimport { useRef, useState } from 'react'\nimport ButtonGroupSwitch from '../../ButtonGroupSwitch.js'\nimport type { DialogAttributeGeneric } from './Dialog.js'\nimport DialogAttributesStatic from './DialogAttributesStatic.js'\nimport DialogAttributesMapping from './DialogAttributesMapping.js'\nexport const useDialogRemembering = (\n props: DialogAttributeGeneric\n): { props: DialogAttributeGeneric; values: Pick } => {\n const { value, jsonpath, onChange, onConfigure } = props\n const remembered = useRef({ value, jsonpath })\n\n const onRememberingChange = (value: any, attribute?: string) => {\n if (!attribute) remembered.current.value = value\n onChange(value, attribute)\n }\n const onRememberingConfiugre = (jsonpath: string, attribute?: string) => {\n remembered.current.jsonpath = jsonpath\n onConfigure(jsonpath, attribute)\n }\n return {\n values: remembered.current,\n props: {\n ...props,\n onChange: onRememberingChange,\n onConfigure: onRememberingConfiugre\n }\n }\n}\n\nconst DialogAttributes = (props: DialogAttributeGeneric) => {\n const { isNonNullable, above, below, type, value, jsonpath, labels, label, onChange, onConfigure } = props\n const getIndex = () => {\n if (jsonpath) return 2\n if (value != null) return 1\n if (!labels.none) {\n if (labels.static) return 1\n if (labels.mapped) return 2\n }\n return 0\n }\n\n const [index, setIndex] = useState(getIndex)\n\n const remembered = useDialogRemembering(props)\n\n const onIndexChange = (newIndex: number) => {\n if (newIndex == index) return\n if (isNonNullable && newIndex == 2) {\n onChange('')\n } else if (newIndex != 1) {\n if (value != null && label != 'Text') {\n onChange(null)\n }\n }\n if (newIndex != 2) {\n if (jsonpath != null) {\n onConfigure(null)\n }\n } else {\n onConfigure(remembered.values.jsonpath)\n }\n if (newIndex == 1 && (value == null || value == '')) {\n onChange(remembered.values.value ?? (type == 'boolean' ? null : ''))\n }\n setIndex(newIndex)\n }\n return (\n <>\n {above?.({ ...remembered.props, index, setIndex: onIndexChange })}\n {Object.values(labels).filter(Boolean).length > 1 && (\n \n {labels.none && }\n {labels.static && }\n {labels.mapped && }\n \n )}\n\n {index == 1 && }\n {index == 2 && }\n {below?.({ ...remembered.props, index, setIndex: onIndexChange })}\n \n )\n}\nexport default DialogAttributes\n","import { useState } from 'react'\nimport { Box, FormControl, FormLabel, Text } from '@chakra-ui/react'\nimport ButtonGroupSwitch from '../../ButtonGroupSwitch.js'\n\nfunction SwitchGroupField({\n value,\n label,\n required,\n onChange,\n error,\n children,\n mb,\n mt,\n my,\n ...more\n}: {\n value: T\n onChange: (value: T) => void\n label?: string\n required?: boolean\n error?: string\n onBlur?: any\n disabled?: boolean\n children: any[]\n [prop: string]: any\n}) {\n const [showErrors, setShowErrors] = useState(false)\n\n return (\n \n {label != null && (\n \n {label}\n\n {required && (\n \n *\n \n )}\n \n )}\n\n \n {children}\n \n\n {showErrors && (\n \n {error}\n \n )}\n \n )\n}\n\nexport default SwitchGroupField\n","import { Button } from '@chakra-ui/react'\nimport { useState } from 'react'\nimport SwitchGroupField from '../../styles/fields/SwitchGroupField.js'\nimport DialogAttributesStatic from './DialogAttributesStatic.js'\nimport type { DialogAttributeGeneric } from './Dialog.js'\n\nconst DialogAttributesFallback = (props: DialogAttributeGeneric) => {\n const { above, below, type, value, jsonpath, onChange } = props\n\n const getIndex = () => {\n if (jsonpath) return 1\n if (value != null) return 2\n return 0\n }\n const [index, setIndex] = useState(getIndex)\n\n const onIndexChange = (newIndex: number) => {\n if (newIndex == index) return\n if (newIndex == 0) {\n onChange(null)\n }\n if (newIndex == 1) {\n onChange(false)\n }\n if (newIndex == 2) {\n onChange(true)\n }\n setIndex(newIndex)\n }\n\n return (\n <>\n {above?.({ ...props, index, setIndex: onIndexChange })}\n \n \n \n \n \n {index == 2 && }\n {below?.({ ...props, index, setIndex: onIndexChange })}\n \n )\n}\nexport default DialogAttributesFallback\n","import { Style } from '@sitecore-feaas/sdk'\nimport { Badge } from '@chakra-ui/react'\nimport type { DialogStyleGeneric } from './Dialog.js'\n\nconst DialogStyleBadge = ({ id, rules, customRules, context, themeClassList }: DialogStyleGeneric) => {\n const type = id as Style.Type.Aspect\n const aspect = Style.Set.getContextElementAspect(rules, context, type, customRules)\n const combo = Style.isTypeElementAspect(type)\n ? Style.Set.getContextComboAspect(rules, context, type, themeClassList)\n : null\n let style = aspect || combo || Style.Rule({ type })\n const summary = Style.Props.summarize(type, style.props)\n return (\n \n {summary}\n \n )\n}\n\nexport default DialogStyleBadge\n","import { Style } from '@sitecore-feaas/sdk'\nimport { mdiAlertOutline, mdiInformationOutline } from '@mdi/js'\nimport { Badge, Icon, Tooltip, HStack, Text } from '@chakra-ui/react'\nimport type { DialogStyleGeneric } from './Dialog.js'\n\nconst BADGE_STYLES = {\n info: { colorScheme: 'teal', icon: mdiInformationOutline },\n warning: { colorScheme: 'orange', icon: mdiAlertOutline },\n default: { colorScheme: 'blackAlpha', icon: '' }\n}\n\nconst DialogStyleElementBadge = ({ rules, customRules, context, themeClassList }: DialogStyleGeneric) => {\n const element = Style.Set.getContextElement(rules, context)\n const definition = Style.Set.getContextDefinition(rules, context)\n const combo = Style.Set.getContextCombo(rules, context, themeClassList)\n const elementStyle = element || Style.Set.findById(rules, combo?.refId)\n const effectiveRules = Style.Set.join(rules, customRules)\n const assignedRules = Style.Set.getContextAssigned(effectiveRules, context)\n const assignedAspects = assignedRules.filter((style) =>\n Style.TypeDefinitions[definition.type].aspects.some((aspect) => style.type == aspect)\n ) as Style.Rule.ElementAspect[]\n\n const customizationType = element\n ? Style.Set.getElementCustomizationType(effectiveRules, element, assignedAspects)\n : Style.Set.getDefinitionCustomizationType(effectiveRules, definition, assignedAspects)\n const badgeText = elementStyle?.details.title || 'No styles'\n\n const label = element\n ? customizationType !== 'default'\n ? 'This element does not belong to the current theme'\n : 'This element does not use a theme style'\n : combo && !combo.isDefault\n ? customizationType === 'oneOff'\n ? 'This element has customised styles and will not follow theme updates'\n : 'This element uses a non-default theme style'\n : customizationType === 'oneOff'\n ? 'This element has customised styles and will not follow theme updates'\n : customizationType === 'allowed'\n ? 'This element uses a non-default theme style'\n : ''\n\n const { colorScheme, icon } =\n element || customizationType === 'oneOff'\n ? BADGE_STYLES.warning\n : (combo && !combo.isDefault) || customizationType === 'allowed'\n ? BADGE_STYLES.info\n : BADGE_STYLES.default\n return (\n \n \n \n {icon && (\n \n \n \n )}\n {badgeText}\n \n \n \n )\n}\n\nexport default DialogStyleElementBadge\n","import {\n Box,\n Flex,\n Icon,\n InputGroup,\n InputLeftElement,\n NumberDecrementStepper,\n NumberIncrementStepper,\n NumberInput,\n NumberInputField,\n NumberInputStepper\n} from '@chakra-ui/react'\nimport { Style } from '@sitecore-feaas/sdk'\nimport { Select } from '../../Select.js'\nimport { useEffect, useMemo, useState } from 'react'\nimport { Option } from '../../../types/index.js'\n\nconst defaultUnits = ['px', '%', 'em', 'rem']\n\n// SizeField has to be able to accept null for value\n// For things like typography optional font-size\nconst SizeField = ({\n icon,\n units = defaultUnits,\n placeholder,\n length,\n min = 0,\n max,\n allowEmpty,\n onChange,\n ariaLabel,\n allowDecimal,\n withStepper,\n size\n}: {\n icon?: string\n units?: any[]\n placeholder?: string\n length: Style.Length\n min?: number\n max?: number\n allowEmpty?: boolean\n ariaLabel?: string\n onChange: (length: Style.Length) => void\n allowDecimal?: boolean\n withStepper?: boolean\n size?: 'sm' | 'md' | 'lg'\n}) => {\n const [unit, setUnit] = useState(length?.unit || 'px')\n const [current, setCurrent] = useState(String(length?.value ?? ''))\n\n allowDecimal ??= unit == 'em' || unit == 'rem' || unit == '%'\n // Value is given as length from outside\n // Component stores current values in local state to allow intermediate malformed state of the length\n // When text input is blurred, it normalizes value back to usable state\n useEffect(() => {\n if (length?.value != (allowEmpty ? null : 0) || current != '') {\n setCurrent(String(length?.value ?? ''))\n }\n }, [length?.value])\n\n useEffect(() => {\n if (length) setUnit(length?.unit)\n }, [length?.unit])\n\n // using useEffect here can create a situation where changes de-sync with upstream\n // if typing too rapidly. This slows things down by commiting changes synchronously\n const onValueChange = (current: any, unit: Style.Length['unit']) => {\n var value = length?.value\n if (current == '' && allowEmpty) {\n value = null\n } else if (current == '') {\n value = 0\n } else if (current == '-') {\n value == 0\n } else {\n value = current\n }\n if (unit != null && value != null) {\n onChange(Style.Length({ unit, value }))\n } else if (length?.value != null) {\n onChange(null)\n }\n }\n\n const unitOptions = useMemo(\n () =>\n units.map((unit) => ({\n label: unit,\n value: unit\n })),\n units\n )\n return (\n \n \n {icon && (\n \n \n \n }\n />\n )}\n\n {\n // Clean up decimal part if not allowed (depends on unit setting)\n // Value is internally set string, and then parsed by Style.Length\n const nextValue = !allowDecimal ? valueAsString.replace(/\\..*/, '') : valueAsString\n setCurrent(nextValue)\n onValueChange(nextValue, unit)\n }}\n onBlur={() => {\n // Set value to 0, if it can't be empty or incorrect\n // Some inputs allow numeric value to be empty, leading to observed `null` length\n if (Number.isNaN(current) || (current.trim() == '' && !allowEmpty)) {\n setCurrent('0')\n }\n }}\n >\n \n {withStepper && (\n \n \n \n \n )}\n \n \n\n \n ) => {\n setUnit(option.value)\n onValueChange(current, option.value)\n }}\n />\n \n \n )\n}\n\nexport default SizeField\n","import { Box, Button, VStack } from '@chakra-ui/react'\nimport { Style, mergeDeep } from '@sitecore-feaas/sdk'\nimport { useState } from 'react'\nimport ButtonGroupSwitch from '../../ButtonGroupSwitch.js'\nimport FieldsetField from '../../FieldsetField.js'\nimport SizeField from '../../styles/fields/SizeField.js'\nimport type { DialogStyleProps } from './Dialog.js'\n\nexport default function DialogDimensions({ context, onChange, rules, customRules }: DialogStyleProps) {\n const style =\n Style.Set.getContextElementAspect(rules, context, 'dimensions', customRules) || Style.Rule({ type: 'dimensions' })\n\n const [index, setIndex] = useState(() => {\n return Style.stringifyLength(style.props.minHeight, null) == Style.stringifyLength(style.props.maxHeight, null) &&\n Style.stringifyLength(style.props.minWidth, null) == Style.stringifyLength(style.props.maxWidth, null)\n ? 0\n : 1\n })\n\n const definition = Style.Context.getDefinition(context)\n\n const onChangeIndex = (index: number) => {\n setIndex(index)\n\n if (index == 0) {\n setProperties({\n maxWidth: style.props.maxWidth,\n maxHeight: style.props.maxHeight\n })\n } else {\n setProperties({\n maxWidth: style.props.minWidth,\n maxHeight: style.props.minHeight\n })\n }\n }\n\n function setProperties(props: Partial) {\n onChange(\n mergeDeep(style, {\n props: props\n })\n )\n }\n\n return (\n <>\n \n \n \n \n \n \n\n {index == 0 && (\n \n \n {\n setProperties({\n minWidth: value,\n maxWidth: value\n })\n }}\n />\n \n\n {definition.id != 'section' && (\n \n {\n setProperties({\n minHeight: value,\n maxHeight: value\n })\n }}\n />\n \n )}\n \n )}\n\n {index == 1 && (\n \n \n {\n setProperties({\n minWidth: value\n })\n }}\n />\n \n\n {definition.id != 'section' && (\n \n {\n setProperties({\n minHeight: value\n })\n }}\n />\n \n )}\n\n \n {\n setProperties({\n maxWidth: value\n })\n }}\n />\n \n\n {definition.id != 'section' && (\n \n {\n setProperties({\n maxHeight: value\n })\n }}\n />\n \n )}\n \n )}\n \n )\n}\n","import { Box, Button, Divider, HStack, Icon, IconButton, Tooltip, VStack } from '@chakra-ui/react'\nimport { Style, cloneDeep, mergeDeep } from '@sitecore-feaas/sdk'\nimport { useMemo, useRef } from 'react'\nimport FieldsetField from '../../FieldsetField.js'\nimport NumberField from '../../styles/fields/NumberField.js'\nimport SizeField from '../../styles/fields/SizeField.js'\nimport { Grid } from '../chrome/ChromeGrid.js'\nimport type { DialogStyleProps } from './Dialog.js'\nimport { Select } from '../../Select.js'\nimport { mdiInformationOutline, mdiMinus, mdiPlus } from '@mdi/js'\nimport { Text } from '@chakra-ui/react'\n\nexport default function DialogStyleGrid({ onChange, context, customRules, rules }: DialogStyleProps) {\n const style = Style.Set.getContextElementAspect(rules, context, 'grid', customRules) || Style.Rule({ type: 'grid' })\n const grid = useMemo(() => new Grid(style).snapshot(), [context, style])\n\n function setProperties(props: Partial) {\n onChange(\n mergeDeep(style, {\n props: props\n })\n )\n }\n\n function setGrid(grid: Grid) {\n setProperties(grid.props)\n }\n\n const expandableRows = grid.getExpandableRows()\n\n const nextExpandableRowSuggestion = [grid.props.rows.length - 1, 0]\n .concat(grid.props.rows.map((r, i) => i))\n .find((index) => expandableRows.indexOf(index) == -1)\n\n const setRowExpandable = (index: number) => {\n grid.props.rows[index].max = null\n setGrid(grid)\n }\n const setRowStatic = (index: number) => {\n grid.props.rows[index].max = grid.props.rows[index].min\n setGrid(grid)\n }\n\n const debounce = useRef>>({ columns: null, rows: null })\n\n return (\n \n \n \n {\n clearTimeout(debounce.current.rows)\n debounce.current.rows = setTimeout(() => {\n setGrid(grid.setRowNumber(value))\n }, 600)\n }}\n withStepper={true}\n />\n \n \n {\n clearTimeout(debounce.current.columns)\n debounce.current.columns = setTimeout(() => {\n setGrid(grid.setColumnNumber(value))\n }, 600)\n }}\n withStepper={true}\n />\n \n \n \n {\n setGrid(\n grid.setRowHeight({\n value,\n unit: 'px'\n })\n )\n }}\n />\n \n \n \n Expandable rows{' '}\n \n \n \n \n \n \n {expandableRows.map((row, index) => {\n return (\n \n \n 1 && {\n name: 'Middle',\n value: Math.floor(grid.props.rows.length / 2),\n isDisabled: expandableRows.includes(Math.floor(grid.props.rows.length / 2))\n },\n grid.props.rows.length > 1 && {\n name: 'Last',\n value: grid.props.rows.length - 1,\n isDisabled: expandableRows.includes(grid.props.rows.length - 1)\n }\n ].filter(Boolean)\n },\n {\n label: 'Rows',\n options: grid.props.rows.map((row, index) => {\n return {\n name: String(index + 1),\n value: index,\n isDisabled: expandableRows.includes(index)\n }\n })\n }\n ]}\n getOptionLabel={(c) => c.name}\n getOptionValue={(c) => String(c.value)}\n onChange={(choice) => {\n setRowStatic(row)\n setRowExpandable(choice.value)\n }}\n placeholder='Select version to embed'\n />\n \n \n setRowStatic(row)}\n icon={\n \n \n \n }\n />\n \n \n )\n })}\n {nextExpandableRowSuggestion != null && (\n \n \n \n }\n onClick={() => setRowExpandable(nextExpandableRowSuggestion)}\n >\n Make a row expandable\n \n )}\n \n )\n}\n","export default \"__VITE_ASSET__ee4b5568__\"","export default \"__VITE_ASSET__e3d3fb75__\"","export default \"__VITE_ASSET__b4d0aa5b__\"","export default \"__VITE_ASSET__12b3fd8d__\"","export default \"__VITE_ASSET__b6cc9d99__\"","export default \"__VITE_ASSET__dd7bea6d__\"","export default \"__VITE_ASSET__dfbd1a39__\"","export default \"__VITE_ASSET__cc404f5c__\"","export default \"__VITE_ASSET__9f6568c6__\"","export default \"__VITE_ASSET__5f82daef__\"","export default \"__VITE_ASSET__b13e4720__\"","import { Box, Button, Divider, Flex, HStack, Icon, IconButton, Switch, Text, Tooltip, VStack } from '@chakra-ui/react'\nimport { css } from '@emotion/react'\nimport { mdiArrowLeftRight, mdiInformationOutline, mdiMinus, mdiPlus } from '@mdi/js'\nimport type * as CK from '@sitecore-feaas/ckeditor5'\nimport { Style, mergeDeep } from '@sitecore-feaas/sdk'\nimport * as React from 'react'\nimport { ReactComponent as HorizontallyCenterIcon } from '../../../svg/Horizontally-Center.svg'\nimport { ReactComponent as HorizontallyDistributeIcon } from '../../../svg/Horizontally-Distribute.svg'\nimport { ReactComponent as HorizontallyJustifyIcon } from '../../../svg/Horizontally-Justify.svg'\nimport { ReactComponent as HorizontallyLeftIcon } from '../../../svg/Horizontally-Left.svg'\nimport { ReactComponent as HorizontallyRightIcon } from '../../../svg/Horizontally-Right.svg'\nimport { ReactComponent as HorizontallyStretchIcon } from '../../../svg/Horizontally-Stretch.svg'\nimport { ReactComponent as VerticallyJustify } from '../../../svg/Vertical-Space-Between.svg'\nimport { ReactComponent as VerticallyBottomIcon } from '../../../svg/Vertically-Bottom.svg'\nimport { ReactComponent as VerticallyCenterIcon } from '../../../svg/Vertically-Center.svg'\nimport { ReactComponent as VerticallyStretchIcon } from '../../../svg/Vertically-Stretch.svg'\nimport { ReactComponent as VerticallyTopIcon } from '../../../svg/Vertically-Top.svg'\nimport ButtonGroupSwitch from '../../ButtonGroupSwitch.js'\nimport type { DialogStyleProps } from './Dialog.js'\n\ninterface Alignment {\n property: keyof Style.Rule<'layout'>['props']\n value: `${Style.Layout.AlignItems | Style.Layout.JustifyContent}`\n label: string\n IconComponent: React.FC & { title?: string }>\n}\n\nconst horizontalAlignmentRow: Alignment[] = [\n { property: 'justifyContent', value: 'flex-start', label: 'Left', IconComponent: HorizontallyLeftIcon },\n { property: 'justifyContent', value: 'center', label: 'Center', IconComponent: HorizontallyCenterIcon },\n { property: 'justifyContent', value: 'space-between', label: 'Justify', IconComponent: HorizontallyJustifyIcon },\n { property: 'justifyContent', value: 'space-evenly', label: 'Distribute', IconComponent: HorizontallyDistributeIcon },\n { property: 'justifyContent', value: 'stretch', label: 'Stretch', IconComponent: HorizontallyStretchIcon },\n { property: 'justifyContent', value: 'flex-end', label: 'Right', IconComponent: HorizontallyRightIcon }\n]\n\nconst verticalAlignmentRow: Alignment[] = [\n { property: 'alignItems', value: 'flex-start', label: 'Top', IconComponent: VerticallyTopIcon },\n { property: 'alignItems', value: 'center', label: 'Center', IconComponent: VerticallyCenterIcon },\n { property: 'alignItems', value: 'stretch', label: 'Stretch', IconComponent: VerticallyStretchIcon },\n { property: 'alignItems', value: 'flex-end', label: 'Bottom', IconComponent: VerticallyBottomIcon }\n]\n\nconst horizontalAlignmentColumn: Alignment[] = [\n { property: 'alignItems', value: 'flex-start', label: 'Left', IconComponent: HorizontallyLeftIcon },\n { property: 'alignItems', value: 'center', label: 'Center', IconComponent: HorizontallyCenterIcon },\n { property: 'alignItems', value: 'stretch', label: 'Stretch', IconComponent: HorizontallyStretchIcon },\n { property: 'alignItems', value: 'flex-end', label: 'Right', IconComponent: HorizontallyRightIcon }\n]\n\nconst verticalAlignmentColumn: Alignment[] = [\n { property: 'justifyContent', value: 'flex-start', label: 'Top', IconComponent: VerticallyTopIcon },\n { property: 'justifyContent', value: 'center', label: 'Center', IconComponent: VerticallyCenterIcon },\n { property: 'justifyContent', value: 'space-between', label: 'Justify', IconComponent: VerticallyJustify },\n { property: 'justifyContent', value: 'stretch', label: 'Stretch', IconComponent: VerticallyStretchIcon },\n { property: 'justifyContent', value: 'flex-end', label: 'Bottom', IconComponent: VerticallyBottomIcon }\n]\n\nfunction getDefaultOption(options: Alignment[]) {\n return (\n options.find((v) => v.value == 'stretch') ||\n options.find((v) => v.value == 'center') ||\n options.find((v) => v.value == 'space-between')\n )\n}\n\nconst boxesCss = css`\n .top {\n position: absolute;\n top: 4px;\n opacity: 0;\n left: 50%;\n transform: translateX(-50%);\n text-align: center;\n }\n .bottom {\n position: absolute;\n bottom: 4px;\n left: 50%;\n transform: translateX(-50%);\n text-align: center;\n }\n .box {\n position: relative;\n border-radius: 4px;\n flex-grow: 1;\n border: 1px dashed var(--chakra-colors-blackAlpha-800);\n height: 92px;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n &:hover {\n .top {\n opacity: 1;\n }\n }\n`\n\nexport default function DialogLayout({ customRules, rules, context, onChange }: DialogStyleProps) {\n const style =\n Style.Set.getContextElementAspect(rules, context, 'layout', customRules) || Style.Rule({ type: 'layout' })\n\n const verticalOptions = style.props.columnCount == 1 ? verticalAlignmentColumn : verticalAlignmentRow\n const horizontalOptions = style.props.columnCount == 1 ? horizontalAlignmentColumn : horizontalAlignmentRow\n\n const vertical = verticalOptions.find((v) => style.props[v.property] == v.value)\n const horizontal = horizontalOptions.find((h) => style.props[h.property] == h.value)\n\n function setLayoutProperty

['props']>(\n property: P,\n value: Style.Rule<'layout'>['props'][P]\n ) {\n var props: Partial = {\n [property]: value\n }\n if ((property as string) == 'columnCount') {\n props.weights = new Array(value as number).fill(1)\n\n // swap horizontal/vertical\n if (value == 1 || style.props.columnCount == 1) {\n const nextVerticalOptions = value == 1 ? verticalAlignmentColumn : verticalAlignmentRow\n const nextHorizontalOptions = value == 1 ? horizontalAlignmentColumn : horizontalAlignmentRow\n\n // going from 1 to X - force stretch layout\n // going from X to 1 - reset stretch to top\n const nextV =\n style.props.columnCount == 1\n ? nextVerticalOptions.find((v) => v.value == 'stretch')\n : value == 1 && vertical.value == 'stretch'\n ? nextVerticalOptions.find((v) => v.value == 'flex-start')\n : nextVerticalOptions.find((v) => v.value == vertical.value) || getDefaultOption(nextVerticalOptions)\n const nextH =\n style.props.columnCount == 1\n ? nextHorizontalOptions.find((v) => v.value == 'flex-start')\n : value == 1\n ? nextHorizontalOptions.find((v) => v.value == 'stretch')\n : nextHorizontalOptions.find((h) => h.value == horizontal.value) || getDefaultOption(nextHorizontalOptions)\n\n // @ts-ignore FIXME\n props[nextV.property] = nextV.value\n // @ts-ignore FIXME\n props[nextH.property] = nextH.value\n }\n }\n onChange(\n mergeDeep(style, {\n props: props\n })\n )\n }\n\n const weights = style.props.weights || [1]\n const sum = weights.reduce((s, v) => s + v, 0)\n const children = Array.from((context as CK.ModelElement).getChildren())\n const columns = weights.map((v, index) => {\n const child = children[index] as CK.ModelElement\n return child ? Style.Set.getContextElementAspect(rules, child, 'dimensions', customRules)?.props : null\n })\n const hasLimits = columns.some((c) => c?.maxWidth != null)\n const boxes = weights.map((v, index) => {\n const plus = hasLimits && style.props.columnCount != 1 && horizontal.value == 'stretch' ? '+' : ''\n const width = `${Math.floor((v / sum) * 100)}${plus}%`\n const minWidth = Style.stringifyLength(columns[index]?.minWidth, null)\n const maxWidth = Style.stringifyLength(columns[index]?.maxWidth, null)\n const isFixedWidth = minWidth == maxWidth && minWidth\n\n return (\n \n \n {isFixedWidth && minWidth ? minWidth : width}\n \n {!isFixedWidth && (minWidth || maxWidth) && (\n \n {minWidth && min: {minWidth}}\n {maxWidth && max: {maxWidth}}\n \n )}\n \n )\n })\n\n const divider = (\n \n )\n const spacer = (\n \n \n \n )\n\n return (\n <>\n {style.props.columnCount != null && (\n \n {boxes\n .map((box, index) => {\n return [\n // first\n index == 0 &&\n (horizontal.value == 'flex-start' ||\n horizontal.value == 'stretch' ||\n horizontal.value == 'space-between'\n ? divider\n : spacer),\n\n // between\n index != 0 &&\n (horizontal.value == 'space-between' || horizontal.value == 'space-evenly' ? spacer : divider),\n\n box,\n\n // last\n index == boxes.length - 1 &&\n (horizontal.value == 'flex-end' ||\n horizontal.value == 'stretch' ||\n horizontal.value == 'space-between'\n ? divider\n : spacer)\n ]\n })\n .filter(Boolean)\n .flat()}\n \n )}\n \n \n Number of columns\n \n {\n if (c == null) {\n setLayoutProperty('columnCount', null)\n } else {\n setLayoutProperty('columnCount', c + 1)\n }\n }}\n value={style.props.columnCount == null ? null : style.props.columnCount - 1}\n >\n \n \n \n \n \n \n \n \n \n\n {columns.length > 1 && (\n \n \n Column proportions\n \n \n {weights.map((weight, index) => (\n \n Column {index + 1}\n \n \n \n \n }\n onClick={() =>\n setLayoutProperty('weights', Object.assign(weights.slice(), { [index]: Math.max(1, weight - 1) }))\n }\n bg='white'\n variant='secondary'\n size='xs'\n aria-label='Decrease weight'\n isDisabled={weight <= 1}\n />\n \n {weight}\n \n \n \n \n }\n variant='secondary'\n onClick={() =>\n setLayoutProperty('weights', Object.assign(weights.slice(), { [index]: weight + 1 }))\n }\n bg='white'\n size='xs'\n aria-label='Increase weight'\n />\n \n \n ))}\n \n \n )}\n \n \n \n Alignment\n \n \n Horizontally{' '}\n \n \n \n \n \n \n \n {horizontalOptions.map(({ label, IconComponent, property, value }, index) => (\n svg {\n background: var(--chakra-colors-blackAlpha-50);\n ${horizontal.value === value\n ? 'background: var(--chakra-colors-primary-100);' +\n 'border-radius: 2px;' +\n 'outline: 2px solid var(--chakra-colors-primary-600);' +\n '> rect {' +\n 'border-radius: 2px;' +\n 'outline: 1px solid var(--chakra-colors-primary-300);' +\n '}'\n : '&:hover {' + 'background: var(--chakra-colors-blackAlpha-200);' + '}'}\n }\n `}\n onClick={() => {\n setLayoutProperty(property, value as any)\n }}\n >\n \n \n {label}\n \n \n ))}\n \n \n Vertically{' '}\n \n \n \n \n \n \n \n {verticalOptions.map(({ label, IconComponent, property, value }, index) => (\n svg {\n background: var(--chakra-colors-blackAlpha-50);\n ${vertical.value === value\n ? 'background: var(--chakra-colors-primary-100);' +\n 'border-radius: 2px;' +\n 'outline: 2px solid var(--chakra-colors-primary-600);' +\n '> rect {' +\n 'border-radius: 2px;' +\n 'outline: 1px solid var(--chakra-colors-primary-300);' +\n '}'\n : ''}\n &:hover {\n background: var(--chakra-colors-blackAlpha-200);\n }\n }\n `}\n onClick={() => {\n setLayoutProperty(property, value as any)\n }}\n >\n \n \n {label}\n \n \n ))}{' '}\n \n \n \n )\n}\n","import { Flex, FormControl, FormLabel, Icon, IconButton } from '@chakra-ui/react'\nimport { mdiChevronUp, mdiPlus } from '@mdi/js'\nimport { isDeepEquals, Style } from '@sitecore-feaas/sdk'\nimport { FunctionComponent, ReactElement } from 'react'\n\ninterface Props {\n onChange: (value: [x: Style.Length, y: Style.Length]) => void\n value: [x: Style.Length, y: Style.Length]\n label?: string\n disabled?: boolean\n}\n\nconst AlignmentField: FunctionComponent = (props: Props): ReactElement => {\n const { onChange, value, label = 'Alignment', disabled } = props\n\n return (\n \n \n {label}\n\n \n onChange([Style.LengthOrPosition('left'), Style.LengthOrPosition('top')])}\n aria-label='Top left'\n icon={\n \n \n \n }\n />\n onChange([Style.LengthOrPosition('center'), Style.LengthOrPosition('top')])}\n aria-label='Top'\n icon={\n \n \n \n }\n />\n onChange([Style.LengthOrPosition('right'), Style.LengthOrPosition('top')])}\n aria-label='Top right'\n icon={\n \n \n \n }\n />\n onChange([Style.LengthOrPosition('left'), Style.LengthOrPosition('center')])}\n aria-label='Left'\n icon={\n \n \n \n }\n />\n onChange([Style.LengthOrPosition('center'), Style.LengthOrPosition('center')])}\n aria-label='Center'\n icon={\n \n \n \n }\n />\n onChange([Style.LengthOrPosition('right'), Style.LengthOrPosition('center')])}\n aria-label='Right'\n icon={\n \n \n \n }\n />\n onChange([Style.LengthOrPosition('left'), Style.LengthOrPosition('bottom')])}\n aria-label='Bottom left'\n icon={\n \n \n \n }\n />\n onChange([Style.LengthOrPosition('center'), Style.LengthOrPosition('bottom')])}\n aria-label='Bottom'\n icon={\n \n \n \n }\n />\n onChange([Style.LengthOrPosition('right'), Style.LengthOrPosition('bottom')])}\n aria-label='Bottom right'\n icon={\n \n \n \n }\n />\n \n \n \n )\n}\n\nexport default AlignmentField\n","import { Box, Button, FormLabel, Switch, Text } from '@chakra-ui/react'\nimport type * as CK from '@sitecore-feaas/ckeditor5'\nimport { Style, isDeepEquals, mergeDeep } from '@sitecore-feaas/sdk'\nimport { ChangeEvent, useState } from 'react'\nimport ButtonGroupSwitch from '../../ButtonGroupSwitch.js'\nimport FieldsetField from '../../FieldsetField.js'\nimport { CreatableSelect } from '../../Select.js'\nimport AlignmentField from '../../styles/fields/AlignmentField.js'\nimport SizeField from '../../styles/fields/SizeField.js'\nimport type { DialogStyleProps } from './Dialog.js'\ninterface Props {\n editor: CK.Editor\n context: CK.ModelElement\n}\n\nexport default function DialogMediaSizing({ context, rules, customRules, onChange }: DialogStyleProps) {\n const style = Style.Set.getContextElementAspect(rules, context, 'media', customRules) || Style.Rule({ type: 'media' })\n\n const onObjectFitChange = (objectFit: Style.Media.Fit) => {\n setProperties({\n objectFit: objectFit\n })\n }\n\n function setProperties(props: Partial) {\n onChange(\n mergeDeep(style, {\n props: props\n })\n )\n }\n\n const [isCustomHeight, setCustomHeight] = useState(style.props.width == null)\n\n const [customSize, setCustomSize] = useState(style.props.height)\n const defaultSizeOptions = [\n { value: null, label: 'Intrinsic proportion' },\n { value: { value: 1, unit: 'ratio' } as Style.Length, label: 'Ratio 1:1' },\n { value: { value: 2 / 1, unit: 'ratio' } as Style.Length, label: 'Ratio 2:1' },\n { value: { value: 4 / 3, unit: 'ratio' } as Style.Length, label: 'Ratio 4:3' },\n { value: { value: 16 / 9, unit: 'ratio' } as Style.Length, label: 'Ratio 16:9' }\n ]\n const sizeOptions = [\n ...defaultSizeOptions,\n customSize != null &&\n !defaultSizeOptions.find((v) => isDeepEquals(v.value, style.props.height)) && {\n value: customSize,\n label:\n customSize?.unit == 'ratio'\n ? 'Ratio ' + parseFloat(customSize.value.toFixed(2)) + ':1'\n : Style.stringifyLength(customSize)\n }\n ].filter(Boolean)\n\n return (\n <>\n {Style.Context.getContextName(context) == 'media' && (\n <>\n \n {/*@ts-ignore */}\n \n \n Full\n \n ) => {\n if (e.target.checked) setProperties({ width: { value: 100, unit: '%' } })\n else setProperties({ width: null })\n }}\n />\n \n \n {\n if (style.props.height == null) {\n setCustomHeight(false)\n }\n if (width == null) {\n setCustomHeight(true)\n }\n setProperties({ width })\n }}\n allowEmpty={true}\n />\n \n \n \n {/*@ts-ignore */}\n \n \n Proportional\n \n ) => {\n setCustomHeight(!e.target.checked)\n if (!e.target.checked) {\n if (style.props.height?.unit == 'ratio') setProperties({ height: null })\n } else {\n setProperties({ height: null })\n }\n }}\n />\n \n \n {!isCustomHeight && (\n isDeepEquals(v.value, style.props.height)) || sizeOptions[0]}\n onChange={({ value }: (typeof sizeOptions)[0]) => setProperties({ height: value })}\n onCreateOption={(value: any) => {\n // FIXME: Typing of argument doesnt work in TS.5\n const height = Style.Length(value)?.value != 0 ? Style.Length(value) : null\n setCustomSize(height)\n setProperties({ height })\n }}\n >\n )}\n {isCustomHeight && (\n setProperties({ height })}\n units={['px', 'rem', 'em']}\n />\n )}\n {isCustomHeight && style.props.width != null && (\n \n You can type in custom ratio (e.g. 3:4) or size (100% or 300px)\n \n )}\n \n \n \n )}\n \n \n Size fitting method\n \n \n \n \n \n \n \n \n {style.props.objectFit != 'fill' && (\n setProperties({ objectPositionX, objectPositionY })}\n />\n )}\n \n )\n}\n","import { Box, Button, FormLabel, HStack, Switch, Text } from '@chakra-ui/react'\nimport { Style, Unformatted, mergeDeep } from '@sitecore-feaas/sdk'\nimport { useState } from 'react'\nimport ButtonGroupSwitch from '../../ButtonGroupSwitch.js'\nimport FieldsetField from '../../FieldsetField.js'\nimport { Select } from '../../Select.js'\nimport { DialogStyleProps } from './Dialog.js'\n\nexport default function DialogSpacing({ context, customRules, rules, themeClassList, onChange }: DialogStyleProps) {\n const classList = Style.Context.getClassList(context)\n const elementStyle = Style.Set.getContextElement(rules, classList)\n const [allValues, setAllValues] = useState(false)\n const allowedInitialSpacingStyles = allValues\n ? Style.Set.filterByType(rules, 'spacing')\n : Style.Set.getContextAspectChoices(rules, context, 'spacing')\n\n // get currently active spacing rule\n const style =\n Style.Set.getContextElementAspect(rules, context, 'spacing', customRules) ||\n Style.Set.getContextComboAspect(rules, context, 'spacing', themeClassList) ||\n Style.Rule({ type: 'spacing' })\n\n const [index, setIndex] = useState(() => {\n const stringified: Unformatted = Object.keys(style.props).reduce(\n (obj, key: keyof typeof style.props) => {\n return Object.assign(obj, { [key]: Style.stringifyLength(style.props[key]) })\n },\n Style.Spacing.Props()\n )\n if (\n stringified.paddingTop == stringified.paddingBottom &&\n stringified.paddingTop == stringified.paddingLeft &&\n stringified.paddingTop == stringified.paddingRight &&\n stringified.columnGap == stringified.rowGap\n ) {\n return 0\n }\n if (stringified.paddingTop == stringified.paddingBottom && stringified.paddingLeft == stringified.paddingRight) {\n return 1\n }\n return 2\n })\n\n const setTabIndex = (nextIndex: number) => {\n const oldIndex = index\n setIndex(nextIndex)\n onChange(\n mergeDeep(style, {\n props: {\n paddingBottom: style.props.paddingTop,\n paddingLeft: oldIndex == 0 ? style.props.paddingTop : style.props.paddingLeft,\n paddingRight: oldIndex == 0 ? style.props.paddingTop : style.props.paddingLeft,\n columnGap: style.props.columnGap,\n rowGap: nextIndex == 0 ? style.props.columnGap : style.props.rowGap\n }\n })\n )\n }\n\n function aggregateValues(properties: (keyof Style.Rule<'spacing'>['props'])[], includeZero: boolean = false) {\n return properties\n .reduce((values, property) => {\n return values.concat(\n ...allowedInitialSpacingStyles.map((spacingStyle: Style.Rule<'spacing'>) => {\n return (spacingStyle.props[property] || []) as Style.Length[]\n })\n )\n }, [])\n .concat(includeZero ? { value: 0, unit: 'px' } : [])\n .map((value) => {\n return Style.stringifyLength(value)\n })\n .filter(Boolean)\n .filter((v, i, a) => a.indexOf(v) === i)\n .sort((a, b) => {\n return parseFloat(a) - parseFloat(b)\n })\n }\n\n function SelectFor(properties: (keyof Style.Rule<'spacing'>['props'])[]) {\n const options = aggregateValues(properties, !!properties[0].match('Gap')).map((value) => {\n return { label: value, value: value }\n })\n const current = Style.stringifyLength(style.props[properties[0]])\n var value = options.find((opt) => current == opt.value)\n if (value == null) {\n value = { value: current, label: current }\n options.push(value)\n }\n return (\n {\n onChange(\n mergeDeep(style, {\n props: Style.Spacing.Props(\n properties.reduce(\n (obj, key) => {\n return Object.assign(obj, { [key]: Style.stringifyLength(value) })\n },\n { ...style.props }\n )\n )\n })\n )\n }}\n />\n )\n }\n\n return (\n <>\n \n \n \n \n \n \n \n\n {elementStyle?.props && 'spacingIds' in elementStyle?.props && elementStyle.props.spacingIds.length > 0 && (\n \n setAllValues((v) => !v)} />\n Only values appropriate for element\n \n )}\n\n {index == 0 && (\n \n \n {SelectFor(['paddingTop', 'paddingBottom', 'paddingLeft', 'paddingRight'])}\n \n {SelectFor(['rowGap', 'columnGap'])}\n \n )}\n\n {index == 1 && (\n <>\n \n {SelectFor(['paddingTop', 'paddingBottom'])}\n {SelectFor(['rowGap'])}\n \n \n {SelectFor(['paddingLeft', 'paddingRight'])}\n {SelectFor(['columnGap'])}\n \n \n )}\n\n {index == 2 && (\n <>\n \n {SelectFor(['paddingTop'])}\n\n {SelectFor(['paddingBottom'])}\n \n \n {SelectFor(['paddingLeft'])}\n\n {SelectFor(['paddingRight'])}\n \n \n {SelectFor(['columnGap'])}\n\n {SelectFor(['rowGap'])}\n \n \n )}\n \n )\n}\n","import { Button, VStack } from '@chakra-ui/react'\nimport type * as CK from '@sitecore-feaas/ckeditor5'\nimport { Style, mergeDeep } from '@sitecore-feaas/sdk'\nimport ButtonGroupSwitch from '../../ButtonGroupSwitch.js'\nimport FieldsetField from '../../FieldsetField.js'\nimport { DialogAttributeGeneric, DialogStyleProps } from './Dialog.js'\n\ninterface Props {\n editor: CK.Editor\n onCommand?: (name: string, ...values: any[]) => void | (() => void)\n context: CK.ModelElement\n}\n\nexport default function DialogTextAlignment({ context, customRules, rules, onChange }: DialogStyleProps) {\n const style = Style.Set.getContextElementAspect(rules, context, 'lines', customRules) || Style.Rule({ type: 'lines' })\n\n function setProperties(props: Partial) {\n onChange(\n mergeDeep(style, {\n props: props\n })\n )\n }\n const definition = Style.Context.getDefinition(context)\n\n return (\n \n \n \n setProperties({\n textAlign\n })\n }\n >\n \n \n \n \n \n \n {definition.type == 'text' && (\n \n \n setProperties({\n lines,\n ellipsis: lines == 1\n })\n }\n >\n \n \n \n \n \n \n \n \n )}\n {definition.type == 'text' && style.props.lines == 1 && (\n \n \n setProperties({\n ellipsis\n })\n }\n >\n {/*@ts-ignore */}\n \n \n \n \n )}\n {definition.type == 'text' && style.props.lines != 1 && (\n \n \n setProperties({\n wordBreak\n })\n }\n >\n \n \n \n \n \n )}\n \n )\n}\n","import {\n Alert,\n AlertDescription,\n AlertIcon,\n AlertTitle,\n Badge,\n Button,\n HStack,\n Icon,\n Switch,\n Text,\n Tooltip\n} from '@chakra-ui/react'\nimport {\n mdiArrowExpandAll,\n mdiArrowExpandHorizontal,\n mdiArrowUpLeft,\n mdiContentPaste,\n mdiDatabaseOutline,\n mdiEyeOutline,\n mdiFormatAlignLeft,\n mdiGhostOutline,\n mdiImageOutline,\n mdiImageSizeSelectLarge,\n mdiLinkVariant,\n mdiScriptOutline,\n mdiSync,\n mdiTextLong,\n mdiToyBrickOutline,\n mdiViewColumnOutline\n} from '@mdi/js'\nimport { DataPath } from '@sitecore-feaas/clientside/headless'\nimport { GroupBy, Style, getEmbedDefinition } from '@sitecore-feaas/sdk'\nimport { ChangeEvent, FunctionComponent } from 'react'\nimport { PickerProps } from '../../picker/Picker.js'\nimport DialogAttributeBadge from './DialogAttributeBadge.js'\nimport DialogAttributes from './DialogAttributes.js'\nimport DialogAttributesFallback from './DialogAttributesFallback.js'\nimport DialogStyleBadge from './DialogStyleBadge.js'\nimport DialogStyleElementBadge from './DialogStyleElementBadge.js'\nimport DialogStyleDimensions from './DialogStyleDimensions.js'\nimport DialogStyleGrid from './DialogStyleGrid.js'\nimport DialogStyleLayout from './DialogStyleLayout.js'\nimport DialogStyleMediaSizing from './DialogStyleMediaSizing.js'\nimport DialogStyleSpacing from './DialogStyleSpacing.js'\nimport DialogStyleTextAlignment from './DialogStyleTextAlignment.js'\nimport { singularize } from 'inflection'\n\n/** A single configurable aspect of context element. It consists of static and dynamic parts, the static are readonly and unchangable, while the dynamic ones are computed on each re-render */\nexport type ContextCallback = (context: Style.Context) => void\nexport type AttributeSetter = (context: Style.Context, attribute: string, value: unknown) => void\nexport type AttributeCallback = (attribute: string, value: unknown, context?: Style.Context) => void\nexport type AttributeGetter = (context: Style.Context, attribute: string) => unknown\nexport type RuleSetter = (context: Style.Context, rule: Style.Rule | Style.Empty) => void\nexport type RuleCallback = (rule: Style.Rule | Style.Empty, context?: Style.Context) => void\n\nexport interface DialogEnvironment {\n context: Style.Context\n parent?: Style.Context\n definition: Style.ElementDefinition\n getAttribute: AttributeGetter\n onAttributeChange: AttributeCallback\n onNavigate: (id: Dialog['id']) => void\n onSelect: (style: Style.Context) => void\n}\n\n/** The following types achieve two tasks:\n * 1. Define a generic DialogBase definition type that can be used to validate dialog definitions and as a unspecific type matching all dialogs\n * 2. And a specific Dialog/Dialog type, that infers all of its defined properties from constant definition. It helps typescript to do extra type checking and narrowing. E.g. `dialog.id == 'repeating' && [dialog.group, dialog.label]` will infer that [`attribute`, `Repeating collection`]`. It is important though that unlike typical const definitions it also includes the types for generic properties of a DialogBase type.\n *\n * I have to say it turned out to be a mess to implement. Main issue was that typescript has quite strict rules with function calls.\n */\n\nexport interface DialogBasics {\n readonly icon: string\n readonly label: string\n readonly ariaLabel?: string\n readonly id: string\n readonly tooltip?: string\n readonly isDisabled?: boolean\n readonly level?: number\n}\nexport interface DialogComponents

{\n component?: FunctionComponent

\n badge?: FunctionComponent

\n preview?: FunctionComponent

\n below?: FunctionComponent

void; index: number }>\n above?: FunctionComponent

void; index: number }>\n}\nexport interface DialogBase<\n G extends DialogType | 'other' = DialogType,\n P = {},\n E extends Record = DialogEnvironment\n> extends DialogBasics,\n DialogComponents {\n readonly group: G\n readonly condition: (environment: E) => boolean\n readonly prepare?: (environment: E) => P\n}\n/** Map of types of configuration with extra runtime options */\nexport type DialogDefinitionTypeMap = {\n style: DialogBase<\n 'style',\n {\n onChange: (rule: Style.Rule | Style.Empty) => void\n },\n DialogEnvironment & {\n rules: Style.Rule[]\n customRules: Style.Rule[]\n themeClassList: string[]\n classList: string[]\n onRuleChange: RuleCallback\n }\n >\n attribute: DialogBase<\n 'attribute',\n {\n value: any\n type: 'url' | 'html' | 'image' | 'string' | 'boolean' | 'array' | 'object' | 'custom'\n jsonpath: string\n onChange: (value: any, attribute?: string) => void\n onConfigure?: (value: any, attribute?: string) => void\n onModeChange?: (mode?: PickerProps['mode'], dialog?: string) => void\n isNonNullable?: boolean\n labels: {\n none?: string\n static?: string\n mapped?: string\n }\n },\n DialogEnvironment & {\n contextVariable: Style.Context\n contextLink: Style.Context\n definition: Style.ElementDefinition\n //[name: string]: any\n }\n >\n}\n\n/** List of all dialog types types */\nexport type DialogType = keyof DialogDefinitionTypeMap\n\n/** Helper to Retrieve runtime props interface from configure definition */\nexport type DialogProps = T extends DialogBase ? P & E : never\n\n/** Definition + runtime properties in one interface */\nexport type DialogResolved = T & DialogProps\n\n/** Map of resolved dialogs by type */\nexport type DialogTypeMap = {\n [key in DialogType]: DialogResolved\n}\n\n/** Union of all definitions (const) */\nexport type DialogList = (typeof dialogs)[number]\n\n/** Dialog definitions by id */\nexport type DialogIdMap = GroupBy\n\n/* Combine generic type properties with properties inferred from const definitions */\nexport type DialogIdMapAugmented = {\n [key in keyof DialogIdMap]: Omit & DialogIdMap[key]\n}\n\n/** Union of all definitions */\nexport type DialogDefinition = DialogDefinitionTypeMap[DialogType]\nexport type DialogGeneric = DialogTypeMap[DialogType]\n\n/** Union of all resolved configurations, but with components of generic types to avoid typescript complications */\nexport type Dialog = DialogIdMapAugmented[Id] & DialogComponents

\nexport type DialogMenuItem = DialogBasics &\n DialogComponents<{}> & {\n onNavigate: (id: string) => void\n }\n\n/** Generic attribute dialog */\nexport type DialogAttributeGeneric = DialogTypeMap['attribute']\nexport type DialogAttribute = Extract\n/** Generic style dialog */\nexport type DialogStyleGeneric = DialogTypeMap['style']\nexport type DialogStyle = Extract\n/** Minimal amount of properties needed for style dialog */\nexport type DialogStyleProps = Pick<\n DialogStyleGeneric,\n 'context' | 'rules' | 'customRules' | 'onChange' | 'themeClassList'\n>\n\nfunction getFallbackProperty(definition: Style.ElementDefinition) {\n return definition.type == 'block' ? 'data-path-src' : definition.name == 'var' ? 'data-path' : 'data-path-text'\n}\n\nexport const dialogs = [\n {\n group: 'style',\n icon: mdiFormatAlignLeft,\n label: 'No style',\n ariaLabel: 'Pick style',\n id: 'style',\n component: null as DialogStyleGeneric['component'],\n condition: ({ definition }) => definition.name != 'container' && definition.name != 'var',\n prepare: ({ onRuleChange, rules, context, themeClassList }) => {\n const definition = Style.Set.getContextDefinition(rules, context)\n return {\n onChange: onRuleChange,\n label: `${definition.label} style`,\n badge: DialogStyleElementBadge\n }\n }\n } as const satisfies DialogDefinition,\n {\n group: 'style',\n icon: mdiFormatAlignLeft,\n label: 'Text settings',\n id: 'lines',\n component: DialogStyleTextAlignment,\n condition: ({ definition }) => definition.type == 'text' || definition.name == 'button',\n prepare: ({ onRuleChange }) => ({\n onChange: onRuleChange\n }),\n badge: DialogStyleBadge\n } as const satisfies DialogDefinition,\n {\n group: 'style',\n icon: mdiImageSizeSelectLarge,\n label: 'Image sizing',\n id: 'media',\n component: DialogStyleMediaSizing,\n condition: ({ context, getAttribute, definition }) =>\n definition.type == 'block' && getAttribute(context, 'image') != null,\n prepare: ({ onRuleChange }) => ({\n onChange: onRuleChange\n }),\n badge: DialogStyleBadge\n } as const satisfies DialogDefinition,\n {\n group: 'style',\n icon: mdiViewColumnOutline,\n label: 'Grid sizing',\n id: 'grid',\n component: DialogStyleGrid,\n condition: ({ definition }) => definition.name == 'section',\n prepare: ({ onRuleChange }) => ({\n onChange: onRuleChange\n }),\n badge: DialogStyleBadge\n } as const satisfies DialogDefinition,\n {\n group: 'style',\n icon: mdiViewColumnOutline,\n label: 'Layout & alignment',\n id: 'layout',\n component: DialogStyleLayout,\n condition: ({ definition }) =>\n definition.type == 'block' &&\n definition.name != 'section' &&\n definition.name != 'media' &&\n definition.name != 'blockquote' &&\n definition.group != 'external',\n prepare: ({ onRuleChange }) => ({\n onChange: onRuleChange\n }),\n badge: DialogStyleBadge\n } as const satisfies DialogDefinition,\n {\n group: 'style',\n icon: mdiArrowExpandAll,\n label: 'Dimensions',\n id: 'dimensions',\n component: DialogStyleDimensions,\n condition: ({ definition, parent }) =>\n definition.type != 'text' && definition.name != 'media' && Style.Context.getContextName(parent) != 'section',\n prepare: ({ onRuleChange }) => ({\n onChange: onRuleChange\n }),\n badge: DialogStyleBadge\n } as const satisfies DialogDefinition,\n {\n group: 'style',\n icon: mdiArrowExpandHorizontal,\n label: 'Spacing',\n id: 'spacing',\n component: DialogStyleSpacing,\n condition: ({ definition }) => definition.type != 'text',\n prepare: ({ onRuleChange }) => ({\n onChange: onRuleChange\n }),\n badge: DialogStyleBadge\n } as const satisfies DialogDefinition,\n {\n group: 'attribute',\n id: 'repeating',\n label: 'Data collection',\n icon: mdiSync,\n prepare: ({ context, getAttribute, onAttributeChange }) => ({\n labels: {\n none: 'No repeating',\n mapped: 'Mapped'\n },\n type: 'array',\n value: null,\n jsonpath: getAttribute(context, 'data-path-scope') as string,\n onConfigure: (datapath) => {\n onAttributeChange('data-path-scope', datapath)\n },\n onChange: () => null\n }),\n component: DialogAttributes,\n badge: DialogAttributeBadge,\n condition: ({ definition, context }) =>\n definition.name != 'var' &&\n definition.name != 'component' &&\n //YF: hack to avoid repeating on grid items\n !((context as any).parent?.name == 'section')\n } as const satisfies DialogDefinition,\n\n {\n group: 'attribute',\n id: 'component',\n label: 'Tag name',\n icon: mdiToyBrickOutline,\n prepare: ({ context, getAttribute, onAttributeChange }) => ({\n labels: {\n static: 'Static'\n },\n type: 'string',\n jsonpath: null,\n value: getAttribute(context, 'data-embed-as'),\n onChange: (value, attribute) => {\n onAttributeChange('data-embed-as', value)\n }\n }),\n component: DialogAttributes,\n badge: (props: DialogAttributeGeneric) => {\n const { getAttribute, context } = props\n return DialogAttributeBadge(props)\n },\n condition: ({ definition, context, getAttribute }) =>\n definition.name == 'component' && ['embed', 'web'].includes(getEmbedDefinition(context)?.type)\n } as const satisfies DialogDefinition,\n\n {\n group: 'attribute',\n id: 'html',\n label: 'HTML content',\n icon: mdiContentPaste,\n prepare: ({ context, getAttribute, onAttributeChange }) => ({\n type: 'html',\n labels: {\n none: 'None',\n static: 'Static ',\n mapped: 'Mapped'\n },\n value: getAttribute(context, 'data-embed-html'),\n jsonpath: (getAttribute(context, 'data-path') as string) || '',\n onConfigure: (datapath) => {\n if (getAttribute(context, 'data-embed-html') != null) onAttributeChange('data-embed-html', null)\n onAttributeChange('data-path', datapath || null)\n },\n onChange: (value) => {\n if (getAttribute(context, 'data-path')) onAttributeChange('data-path', null)\n onAttributeChange('data-embed-html', value || '')\n }\n }),\n component: DialogAttributes,\n badge: DialogAttributeBadge,\n below: ({ index }) =>\n index == 0 && (\n <>\n \n \n \n In this mode component acts like a card. Any child elements will be passed to the component as children.\n \n \n \n ),\n condition: ({ definition, context }) =>\n ['embed', 'component'].includes(definition.name) && !['feaas', 'byoc'].includes(getEmbedDefinition(context)?.type)\n } as const satisfies DialogDefinition,\n\n {\n group: 'attribute',\n id: 'embed-src',\n label: 'JavaScript code',\n icon: mdiScriptOutline,\n prepare: ({ onAttributeChange, getAttribute, context, contextVariable }) => ({\n type: 'url',\n labels: {\n none: 'None',\n static: 'From URL',\n mapped: 'Mapped '\n },\n value: getAttribute(context, 'data-embed-src') || null,\n jsonpath: (getAttribute(context, 'data-path-embed-src') as string) || '',\n onConfigure: (datapath) => {\n onAttributeChange('data-path-embed-src', datapath || null, contextVariable)\n },\n onChange: (value) => {\n onAttributeChange('data-embed-src', value || '')\n }\n }),\n above: ({ index }) =>\n index > 0 && (\n <>\n \n \n \n Loading untrusted code is a security risk. Script will be loaded once per page when component is first\n displayed.\n \n \n \n ),\n component: DialogAttributes,\n badge: DialogAttributeBadge,\n condition: ({ definition, context }) =>\n ['embed', 'component'].includes(definition.name) && !['feaas', 'byoc'].includes(getEmbedDefinition(context)?.type)\n } as const satisfies DialogDefinition,\n {\n group: 'attribute',\n id: 'attributes',\n label: 'Attributes',\n icon: mdiDatabaseOutline,\n prepare: ({ context, getAttribute, onAttributeChange }) => ({\n type: 'object',\n value: getAttribute(context, 'data-attributes'),\n jsonpath: getAttribute(context, 'data-path-attributes') as string,\n onConfigure: (datapath) => {\n onAttributeChange('data-path-attributes', datapath)\n },\n onChange: (value, attribute = 'data-attributes') => {\n onAttributeChange(attribute, value)\n },\n labels: {\n none: 'None',\n static: getEmbedDefinition(context)?.type == 'byoc' ? null : 'Static',\n mapped: 'Mapped'\n },\n label: getEmbedDefinition(context)?.type == 'byoc' ? 'Data item' : 'Attributes'\n }),\n component: DialogAttributes,\n badge: DialogAttributeBadge,\n condition: ({ context, definition }) =>\n ['web', 'byoc'].includes(getEmbedDefinition(context)?.type) || definition.name == 'byoc'\n } as const satisfies DialogDefinition,\n {\n group: 'attribute',\n id: 'image',\n label: 'Image source',\n icon: mdiImageOutline,\n component: DialogAttributes,\n badge: DialogAttributeBadge,\n prepare: ({ definition, getAttribute, context, onAttributeChange }) => ({\n type: 'image',\n label:\n definition?.name == 'media' ? 'Image source' : definition.type != 'block' ? 'Icon source' : 'Background image',\n isNonNullable: true,\n value: getAttribute(context, 'image'),\n jsonpath: getAttribute(context, 'data-path-src') as string,\n onConfigure: (datapath) => {\n onAttributeChange('data-path-src', datapath)\n },\n onChange: (value) => {\n onAttributeChange('image', value)\n },\n labels: {\n none: definition?.name == 'media' ? null : 'None',\n static: 'Static',\n mapped: 'Mapped'\n }\n }),\n condition: ({ definition }) => definition.name != 'embed' && definition.group != 'external'\n } as const satisfies DialogDefinition,\n\n {\n group: 'attribute',\n id: 'fallback-image',\n label: 'Fallback',\n level: 2,\n prepare: ({ definition, getAttribute, onAttributeChange, context }) => {\n const prop = getFallbackProperty(definition)\n return {\n type: 'image',\n value: getAttribute(context, 'data-path-placeholder'),\n jsonpath:\n getAttribute(context, 'data-path-hidden') == getAttribute(context, prop)\n ? (getAttribute(context, prop) as string)\n : null,\n onConfigure: (datapath, attribute?: string) => {},\n onChange: (value, attribute?: string) => {\n if (value === false) {\n if (getAttribute(context, prop)) {\n onAttributeChange('data-path-placeholder', null, context)\n onAttributeChange('data-path-hidden', getAttribute(context, prop))\n }\n } else if (value == null) {\n if (getAttribute(context, 'data-path-hidden') == getAttribute(context, prop)) {\n onAttributeChange('data-path-hidden', null)\n }\n onAttributeChange('data-path-placeholder', null, context)\n } else {\n if (getAttribute(context, 'data-path-hidden') == getAttribute(context, prop)) {\n onAttributeChange('data-path-hidden', null)\n }\n if (value === true) {\n value = DataPath.getHumanizedLabel(String(getAttribute(context, prop)))\n }\n onAttributeChange('data-path-placeholder', value || null, context)\n }\n },\n labels: {}\n }\n },\n icon: mdiGhostOutline,\n above: ({ onNavigate, getAttribute, context }) =>\n getAttribute(context, 'hidden') != null && (\n \n \n Element is set to be hidden \n onNavigate('visibility')}\n size='sm'\n style={{ marginLeft: 'auto', marginRight: 0 }}\n >\n Change\n \n \n ),\n component: DialogAttributesFallback,\n badge: (props: DialogAttributeGeneric) => {\n const { jsonpath, value } = props\n return (\n \n {jsonpath ? 'Hide element' : props.value == null ? 'No fallback' : value}\n \n )\n },\n condition: ({ context, getAttribute, definition, contextVariable }) =>\n getAttribute(context, getFallbackProperty(definition)) != null && definition.type == 'block'\n } as const satisfies DialogDefinition,\n\n {\n group: 'attribute',\n id: 'text',\n label: 'Text',\n icon: mdiTextLong,\n prepare: ({ onAttributeChange, getAttribute, contextVariable, context, definition }) => ({\n type: 'string',\n value: Style.Context.getContextName(contextVariable) == 'var' ? null : getAttribute(context, 'data-child-text'),\n jsonpath: getAttribute(contextVariable, 'data-path') as string,\n onConfigure: (datapath) => {\n if (Style.Context.getContextName(contextVariable) == 'var') {\n onAttributeChange('data-path', datapath || '', contextVariable)\n } else {\n onAttributeChange('data-path-text', datapath)\n }\n },\n onChange: (value) => {\n onAttributeChange('data-child-text', value)\n },\n labels: {\n static: definition.name == 'var' ? null : 'Static',\n mapped: 'Mapped'\n },\n label: definition.name == 'media' ? 'Caption' : 'Text'\n }),\n component: DialogAttributes,\n badge: DialogAttributeBadge,\n condition: ({ definition }) => definition.type != 'block' || definition.name == 'media'\n } as const satisfies DialogDefinition,\n {\n group: 'attribute',\n id: 'fallback-text',\n label: 'Fallback',\n level: 2,\n prepare: ({ definition, getAttribute, onAttributeChange, context }) => {\n const prop = getFallbackProperty(definition)\n return {\n type: definition.name == 'media' ? 'image' : 'string',\n value: getAttribute(context, 'data-path-placeholder'),\n jsonpath:\n getAttribute(context, 'data-path-hidden') == getAttribute(context, prop)\n ? (getAttribute(context, prop) as string)\n : null,\n onConfigure: (datapath, attribute?: string) => {},\n onChange: (value, attribute?: string) => {\n if (value === false) {\n if (getAttribute(context, prop)) {\n onAttributeChange('data-path-placeholder', null, context)\n onAttributeChange('data-path-hidden', getAttribute(context, prop))\n }\n } else if (value == null) {\n if (getAttribute(context, 'data-path-hidden') == getAttribute(context, prop)) {\n onAttributeChange('data-path-hidden', null)\n }\n onAttributeChange('data-path-placeholder', null, context)\n } else {\n if (getAttribute(context, 'data-path-hidden') == getAttribute(context, prop)) {\n onAttributeChange('data-path-hidden', null)\n }\n if (value === true) {\n value = DataPath.getHumanizedLabel(String(getAttribute(context, prop)))\n }\n onAttributeChange('data-path-placeholder', value || null, context)\n }\n },\n labels: {}\n }\n },\n icon: mdiGhostOutline,\n above: ({ onNavigate, getAttribute, context }) =>\n getAttribute(context, 'hidden') != null && (\n \n \n Element is set to be hidden \n onNavigate('visibility')}\n size='sm'\n style={{ marginLeft: 'auto', marginRight: 0 }}\n >\n Change\n \n \n ),\n component: DialogAttributesFallback,\n badge: (props: DialogAttributeGeneric) => {\n const { jsonpath, value } = props\n return (\n \n {jsonpath ? 'Hide element' : props.value == null ? 'No fallback' : value}\n \n )\n },\n condition: ({ context, getAttribute, definition, contextVariable }) =>\n getAttribute(context, getFallbackProperty(definition)) != null && definition.type != 'block'\n } as const satisfies DialogDefinition,\n\n {\n group: 'attribute',\n label: 'Image alternative text',\n id: 'alt-text',\n icon: 'M4,7c-.5,0-1,.2-1.4,.6-.4,.4-.6,.9-.6,1.4v8h2v-4h2v4h2V9c0-.5-.2-1-.6-1.4-.4-.4-.9-.6-1.4-.6h-2Zm0,2h2v2h-2m6-4v10h6v-2h-4V7h-2Zm6,0v2h2v8h2V9h2v-2h-6Z',\n component: DialogAttributes,\n badge: DialogAttributeBadge,\n prepare: ({ getAttribute, onAttributeChange, context, contextVariable }) => ({\n type: 'string',\n value: getAttribute(context, 'alt') || null,\n jsonpath: (getAttribute(context, 'data-path-alt') as string) || '',\n onConfigure: (datapath) => {\n onAttributeChange('data-path-alt', datapath || null, context)\n },\n onChange: (value) => {\n onAttributeChange('alt', value || '')\n },\n labels: {\n none: 'No text',\n static: 'Static',\n mapped: 'Mapped'\n }\n }),\n condition: ({ definition }) => definition.name == 'media'\n } as const satisfies DialogDefinition,\n {\n group: 'attribute',\n id: 'link',\n label: 'Link',\n icon: mdiLinkVariant,\n prepare: ({ getAttribute, onAttributeChange, contextLink }) => ({\n type: 'url',\n value: getAttribute(contextLink, 'linkHref'),\n jsonpath: getAttribute(contextLink, 'data-path-href') as string,\n onConfigure: (datapath) => {\n onAttributeChange('data-path-href', datapath, contextLink)\n },\n onChange: (value, attribute = 'linkHref') => {\n onAttributeChange(attribute, value, contextLink)\n },\n labels: {\n none: 'None',\n static: 'Static',\n mapped: 'Mapped'\n }\n }),\n component: DialogAttributes,\n badge: DialogAttributeBadge,\n above: ({ contextLink, context, onSelect }) =>\n contextLink != context && (\n \n \n Set on parent \n onSelect(contextLink)}\n size='sm'\n variant='solid'\n colorScheme='purple'\n style={{ marginLeft: 'auto', marginRight: 0 }}\n leftIcon={\n \n \n \n }\n >\n {Style.Context.getDefinition(contextLink).label}\n \n \n ),\n below: ({ onAttributeChange, getAttribute, contextLink, index }) =>\n index != 0 && (\n <>\n \n ) =>\n onAttributeChange('linkIsExternal', e.target.checked ? true : null, contextLink)\n }\n >\n Open in a new tab\n \n {/* false &&\n (contextLink.name == 'card' ||\n contextLink.name == 'button' ||\n contextLink.name == 'inline' ||\n contextLink.name == 'block') && (\n \n onAttributeChange(contextLink, 'linkStyle', e.target.checked ? 'explicit' : null)}\n >\n Apply link style to contents\n \n )*/}\n \n ),\n condition: ({ definition }) =>\n definition.name != 'section' && definition.name != 'embed' && definition.group != 'external'\n } as const satisfies DialogDefinition,\n\n {\n group: 'attribute',\n id: 'visibility',\n label: 'Visibility',\n icon: mdiEyeOutline,\n component: DialogAttributes,\n badge: DialogAttributeBadge,\n prepare: ({ context, getAttribute, onAttributeChange }) => ({\n type: 'boolean' as const,\n remember: false,\n value: getAttribute(context, 'hidden') ?? null,\n jsonpath: getAttribute(context, 'data-path-hidden') as string,\n onConfigure: (datapath) => {\n onAttributeChange('data-path-hidden', datapath)\n },\n onChange: (value) => {\n onAttributeChange('hidden', value === null && getAttribute(context, 'hidden') == null ? 'hidden' : null)\n },\n labels: {\n none: 'Visible',\n static: 'Hidden',\n mapped: 'Conditional'\n }\n }),\n condition: () => true\n } as const satisfies DialogDefinition\n] as const satisfies readonly DialogDefinition[]\n","var hasExcape = /~/\nvar escapeMatcher = /~[01]/g\nfunction escapeReplacer (m) {\n switch (m) {\n case '~1': return '/'\n case '~0': return '~'\n }\n throw new Error('Invalid tilde escape: ' + m)\n}\n\nfunction untilde (str) {\n if (!hasExcape.test(str)) return str\n return str.replace(escapeMatcher, escapeReplacer)\n}\n\nfunction setter (obj, pointer, value) {\n var part\n var hasNextPart\n\n for (var p = 1, len = pointer.length; p < len;) {\n if (pointer[p] === 'constructor' || pointer[p] === 'prototype' || pointer[p] === '__proto__') return obj\n\n part = untilde(pointer[p++])\n hasNextPart = len > p\n\n if (typeof obj[part] === 'undefined') {\n // support setting of /-\n if (Array.isArray(obj) && part === '-') {\n part = obj.length\n }\n\n // support nested objects/array when setting values\n if (hasNextPart) {\n if ((pointer[p] !== '' && pointer[p] < Infinity) || pointer[p] === '-') obj[part] = []\n else obj[part] = {}\n }\n }\n\n if (!hasNextPart) break\n obj = obj[part]\n }\n\n var oldValue = obj[part]\n if (value === undefined) delete obj[part]\n else obj[part] = value\n return oldValue\n}\n\nfunction compilePointer (pointer) {\n if (typeof pointer === 'string') {\n pointer = pointer.split('/')\n if (pointer[0] === '') return pointer\n throw new Error('Invalid JSON pointer.')\n } else if (Array.isArray(pointer)) {\n for (const part of pointer) {\n if (typeof part !== 'string' && typeof part !== 'number') {\n throw new Error('Invalid JSON pointer. Must be of type string or number.')\n }\n }\n return pointer\n }\n\n throw new Error('Invalid JSON pointer.')\n}\n\nfunction get (obj, pointer) {\n if (typeof obj !== 'object') throw new Error('Invalid input object.')\n pointer = compilePointer(pointer)\n var len = pointer.length\n if (len === 1) return obj\n\n for (var p = 1; p < len;) {\n obj = obj[untilde(pointer[p++])]\n if (len === p) return obj\n if (typeof obj !== 'object' || obj === null) return undefined\n }\n}\n\nfunction set (obj, pointer, value) {\n if (typeof obj !== 'object') throw new Error('Invalid input object.')\n pointer = compilePointer(pointer)\n if (pointer.length === 0) throw new Error('Invalid JSON pointer for set.')\n return setter(obj, pointer, value)\n}\n\nfunction compile (pointer) {\n var compiled = compilePointer(pointer)\n return {\n get: function (object) {\n return get(object, compiled)\n },\n set: function (object, value) {\n return set(object, compiled, value)\n }\n }\n}\n\nexports.get = get\nexports.set = set\nexports.compile = compile\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\nmodule.exports = listCacheClear;\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\nmodule.exports = eq;\n","var eq = require('./eq');\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\nmodule.exports = assocIndexOf;\n","var assocIndexOf = require('./_assocIndexOf');\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\nmodule.exports = listCacheDelete;\n","var assocIndexOf = require('./_assocIndexOf');\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\nmodule.exports = listCacheGet;\n","var assocIndexOf = require('./_assocIndexOf');\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\nmodule.exports = listCacheHas;\n","var assocIndexOf = require('./_assocIndexOf');\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\nmodule.exports = listCacheSet;\n","var listCacheClear = require('./_listCacheClear'),\n listCacheDelete = require('./_listCacheDelete'),\n listCacheGet = require('./_listCacheGet'),\n listCacheHas = require('./_listCacheHas'),\n listCacheSet = require('./_listCacheSet');\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\nmodule.exports = ListCache;\n","var ListCache = require('./_ListCache');\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\nmodule.exports = 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\nmodule.exports = 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\nmodule.exports = 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\nmodule.exports = stackHas;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","var freeGlobal = require('./_freeGlobal');\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\nmodule.exports = root;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n","var Symbol = require('./_Symbol');\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\nmodule.exports = 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\nmodule.exports = objectToString;\n","var Symbol = require('./_Symbol'),\n getRawTag = require('./_getRawTag'),\n objectToString = require('./_objectToString');\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\nmodule.exports = baseGetTag;\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\nmodule.exports = isObject;\n","var baseGetTag = require('./_baseGetTag'),\n isObject = require('./isObject');\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\nmodule.exports = isFunction;\n","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\n","var coreJsData = require('./_coreJsData');\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\nmodule.exports = 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\nmodule.exports = toSource;\n","var isFunction = require('./isFunction'),\n isMasked = require('./_isMasked'),\n isObject = require('./isObject'),\n toSource = require('./_toSource');\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\nmodule.exports = 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\nmodule.exports = getValue;\n","var baseIsNative = require('./_baseIsNative'),\n getValue = require('./_getValue');\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\nmodule.exports = getNative;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n","var nativeCreate = require('./_nativeCreate');\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\nmodule.exports = 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\nmodule.exports = hashDelete;\n","var nativeCreate = require('./_nativeCreate');\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\nmodule.exports = hashGet;\n","var nativeCreate = require('./_nativeCreate');\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\nmodule.exports = hashHas;\n","var nativeCreate = require('./_nativeCreate');\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\nmodule.exports = hashSet;\n","var hashClear = require('./_hashClear'),\n hashDelete = require('./_hashDelete'),\n hashGet = require('./_hashGet'),\n hashHas = require('./_hashHas'),\n hashSet = require('./_hashSet');\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\nmodule.exports = Hash;\n","var Hash = require('./_Hash'),\n ListCache = require('./_ListCache'),\n Map = require('./_Map');\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\nmodule.exports = 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\nmodule.exports = isKeyable;\n","var isKeyable = require('./_isKeyable');\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\nmodule.exports = getMapData;\n","var getMapData = require('./_getMapData');\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\nmodule.exports = mapCacheDelete;\n","var getMapData = require('./_getMapData');\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\nmodule.exports = mapCacheGet;\n","var getMapData = require('./_getMapData');\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\nmodule.exports = mapCacheHas;\n","var getMapData = require('./_getMapData');\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\nmodule.exports = mapCacheSet;\n","var mapCacheClear = require('./_mapCacheClear'),\n mapCacheDelete = require('./_mapCacheDelete'),\n mapCacheGet = require('./_mapCacheGet'),\n mapCacheHas = require('./_mapCacheHas'),\n mapCacheSet = require('./_mapCacheSet');\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\nmodule.exports = MapCache;\n","var ListCache = require('./_ListCache'),\n Map = require('./_Map'),\n MapCache = require('./_MapCache');\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\nmodule.exports = stackSet;\n","var ListCache = require('./_ListCache'),\n stackClear = require('./_stackClear'),\n stackDelete = require('./_stackDelete'),\n stackGet = require('./_stackGet'),\n stackHas = require('./_stackHas'),\n stackSet = require('./_stackSet');\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\nmodule.exports = Stack;\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\nmodule.exports = arrayEach;\n","var getNative = require('./_getNative');\n\nvar defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n}());\n\nmodule.exports = defineProperty;\n","var defineProperty = require('./_defineProperty');\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\nmodule.exports = baseAssignValue;\n","var baseAssignValue = require('./_baseAssignValue'),\n eq = require('./eq');\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\nmodule.exports = assignValue;\n","var assignValue = require('./_assignValue'),\n baseAssignValue = require('./_baseAssignValue');\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\nmodule.exports = copyObject;\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\nmodule.exports = baseTimes;\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\nmodule.exports = isObjectLike;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\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\nmodule.exports = baseIsArguments;\n","var baseIsArguments = require('./_baseIsArguments'),\n isObjectLike = require('./isObjectLike');\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\nmodule.exports = isArguments;\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\nmodule.exports = isArray;\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\nmodule.exports = stubFalse;\n","var root = require('./_root'),\n stubFalse = require('./stubFalse');\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\nmodule.exports = isBuffer;\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\nmodule.exports = isIndex;\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\nmodule.exports = isLength;\n","var baseGetTag = require('./_baseGetTag'),\n isLength = require('./isLength'),\n isObjectLike = require('./isObjectLike');\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\nmodule.exports = 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\nmodule.exports = baseUnary;\n","var freeGlobal = require('./_freeGlobal');\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\nmodule.exports = nodeUtil;\n","var baseIsTypedArray = require('./_baseIsTypedArray'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\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\nmodule.exports = isTypedArray;\n","var baseTimes = require('./_baseTimes'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isIndex = require('./_isIndex'),\n isTypedArray = require('./isTypedArray');\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\nmodule.exports = arrayLikeKeys;\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\nmodule.exports = isPrototype;\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\nmodule.exports = overArg;\n","var overArg = require('./_overArg');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nmodule.exports = nativeKeys;\n","var isPrototype = require('./_isPrototype'),\n nativeKeys = require('./_nativeKeys');\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\nmodule.exports = baseKeys;\n","var isFunction = require('./isFunction'),\n isLength = require('./isLength');\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\nmodule.exports = isArrayLike;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeys = require('./_baseKeys'),\n isArrayLike = require('./isArrayLike');\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\nmodule.exports = keys;\n","var copyObject = require('./_copyObject'),\n keys = require('./keys');\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\nmodule.exports = baseAssign;\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\nmodule.exports = nativeKeysIn;\n","var isObject = require('./isObject'),\n isPrototype = require('./_isPrototype'),\n nativeKeysIn = require('./_nativeKeysIn');\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\nmodule.exports = baseKeysIn;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeysIn = require('./_baseKeysIn'),\n isArrayLike = require('./isArrayLike');\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\nmodule.exports = keysIn;\n","var copyObject = require('./_copyObject'),\n keysIn = require('./keysIn');\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\nmodule.exports = baseAssignIn;\n","var root = require('./_root');\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\nmodule.exports = cloneBuffer;\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\nmodule.exports = copyArray;\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\nmodule.exports = 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\nmodule.exports = stubArray;\n","var arrayFilter = require('./_arrayFilter'),\n stubArray = require('./stubArray');\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\nmodule.exports = getSymbols;\n","var copyObject = require('./_copyObject'),\n getSymbols = require('./_getSymbols');\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\nmodule.exports = copySymbols;\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\nmodule.exports = arrayPush;\n","var overArg = require('./_overArg');\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nmodule.exports = getPrototype;\n","var arrayPush = require('./_arrayPush'),\n getPrototype = require('./_getPrototype'),\n getSymbols = require('./_getSymbols'),\n stubArray = require('./stubArray');\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\nmodule.exports = getSymbolsIn;\n","var copyObject = require('./_copyObject'),\n getSymbolsIn = require('./_getSymbolsIn');\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\nmodule.exports = copySymbolsIn;\n","var arrayPush = require('./_arrayPush'),\n isArray = require('./isArray');\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\nmodule.exports = baseGetAllKeys;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbols = require('./_getSymbols'),\n keys = require('./keys');\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\nmodule.exports = getAllKeys;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbolsIn = require('./_getSymbolsIn'),\n keysIn = require('./keysIn');\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\nmodule.exports = getAllKeysIn;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nmodule.exports = DataView;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nmodule.exports = Promise;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nmodule.exports = Set;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nmodule.exports = WeakMap;\n","var DataView = require('./_DataView'),\n Map = require('./_Map'),\n Promise = require('./_Promise'),\n Set = require('./_Set'),\n WeakMap = require('./_WeakMap'),\n baseGetTag = require('./_baseGetTag'),\n toSource = require('./_toSource');\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\nmodule.exports = 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\nmodule.exports = initCloneArray;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n","var Uint8Array = require('./_Uint8Array');\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\nmodule.exports = cloneArrayBuffer;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer');\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\nmodule.exports = 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\nmodule.exports = cloneRegExp;\n","var Symbol = require('./_Symbol');\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\nmodule.exports = cloneSymbol;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer');\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\nmodule.exports = cloneTypedArray;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer'),\n cloneDataView = require('./_cloneDataView'),\n cloneRegExp = require('./_cloneRegExp'),\n cloneSymbol = require('./_cloneSymbol'),\n cloneTypedArray = require('./_cloneTypedArray');\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\nmodule.exports = initCloneByTag;\n","var isObject = require('./isObject');\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\nmodule.exports = baseCreate;\n","var baseCreate = require('./_baseCreate'),\n getPrototype = require('./_getPrototype'),\n isPrototype = require('./_isPrototype');\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\nmodule.exports = initCloneObject;\n","var getTag = require('./_getTag'),\n isObjectLike = require('./isObjectLike');\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\nmodule.exports = baseIsMap;\n","var baseIsMap = require('./_baseIsMap'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\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\nmodule.exports = isMap;\n","var getTag = require('./_getTag'),\n isObjectLike = require('./isObjectLike');\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\nmodule.exports = baseIsSet;\n","var baseIsSet = require('./_baseIsSet'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\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\nmodule.exports = isSet;\n","var Stack = require('./_Stack'),\n arrayEach = require('./_arrayEach'),\n assignValue = require('./_assignValue'),\n baseAssign = require('./_baseAssign'),\n baseAssignIn = require('./_baseAssignIn'),\n cloneBuffer = require('./_cloneBuffer'),\n copyArray = require('./_copyArray'),\n copySymbols = require('./_copySymbols'),\n copySymbolsIn = require('./_copySymbolsIn'),\n getAllKeys = require('./_getAllKeys'),\n getAllKeysIn = require('./_getAllKeysIn'),\n getTag = require('./_getTag'),\n initCloneArray = require('./_initCloneArray'),\n initCloneByTag = require('./_initCloneByTag'),\n initCloneObject = require('./_initCloneObject'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isMap = require('./isMap'),\n isObject = require('./isObject'),\n isSet = require('./isSet'),\n keys = require('./keys'),\n keysIn = require('./keysIn');\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\nmodule.exports = baseClone;\n","var baseClone = require('./_baseClone');\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\nmodule.exports = cloneDeep;\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\nmodule.exports = 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\nmodule.exports = setCacheHas;\n","var MapCache = require('./_MapCache'),\n setCacheAdd = require('./_setCacheAdd'),\n setCacheHas = require('./_setCacheHas');\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\nmodule.exports = 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\nmodule.exports = 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\nmodule.exports = cacheHas;\n","var SetCache = require('./_SetCache'),\n arraySome = require('./_arraySome'),\n cacheHas = require('./_cacheHas');\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\nmodule.exports = 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\nmodule.exports = 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\nmodule.exports = setToArray;\n","var Symbol = require('./_Symbol'),\n Uint8Array = require('./_Uint8Array'),\n eq = require('./eq'),\n equalArrays = require('./_equalArrays'),\n mapToArray = require('./_mapToArray'),\n setToArray = require('./_setToArray');\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\nmodule.exports = equalByTag;\n","var getAllKeys = require('./_getAllKeys');\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\nmodule.exports = equalObjects;\n","var Stack = require('./_Stack'),\n equalArrays = require('./_equalArrays'),\n equalByTag = require('./_equalByTag'),\n equalObjects = require('./_equalObjects'),\n getTag = require('./_getTag'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isTypedArray = require('./isTypedArray');\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\nmodule.exports = baseIsEqualDeep;\n","var baseIsEqualDeep = require('./_baseIsEqualDeep'),\n isObjectLike = require('./isObjectLike');\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\nmodule.exports = baseIsEqual;\n","var baseIsEqual = require('./_baseIsEqual');\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\nmodule.exports = isEqual;\n","var Symbol = require('./_Symbol'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray');\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\nmodule.exports = isFlattenable;\n","var arrayPush = require('./_arrayPush'),\n isFlattenable = require('./_isFlattenable');\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\nmodule.exports = baseFlatten;\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\nmodule.exports = arrayMap;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\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\nmodule.exports = isSymbol;\n","var isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\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\nmodule.exports = isKey;\n","var MapCache = require('./_MapCache');\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\nmodule.exports = memoize;\n","var memoize = require('./memoize');\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\nmodule.exports = memoizeCapped;\n","var memoizeCapped = require('./_memoizeCapped');\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\nmodule.exports = stringToPath;\n","var Symbol = require('./_Symbol'),\n arrayMap = require('./_arrayMap'),\n isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\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\nmodule.exports = baseToString;\n","var baseToString = require('./_baseToString');\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\nmodule.exports = toString;\n","var isArray = require('./isArray'),\n isKey = require('./_isKey'),\n stringToPath = require('./_stringToPath'),\n toString = require('./toString');\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\nmodule.exports = castPath;\n","var isSymbol = require('./isSymbol');\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\nmodule.exports = toKey;\n","var castPath = require('./_castPath'),\n toKey = require('./_toKey');\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\nmodule.exports = baseGet;\n","var Stack = require('./_Stack'),\n baseIsEqual = require('./_baseIsEqual');\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\nmodule.exports = baseIsMatch;\n","var isObject = require('./isObject');\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\nmodule.exports = isStrictComparable;\n","var isStrictComparable = require('./_isStrictComparable'),\n keys = require('./keys');\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\nmodule.exports = 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\nmodule.exports = matchesStrictComparable;\n","var baseIsMatch = require('./_baseIsMatch'),\n getMatchData = require('./_getMatchData'),\n matchesStrictComparable = require('./_matchesStrictComparable');\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\nmodule.exports = baseMatches;\n","var baseGet = require('./_baseGet');\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\nmodule.exports = get;\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\nmodule.exports = baseHasIn;\n","var castPath = require('./_castPath'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isIndex = require('./_isIndex'),\n isLength = require('./isLength'),\n toKey = require('./_toKey');\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\nmodule.exports = hasPath;\n","var baseHasIn = require('./_baseHasIn'),\n hasPath = require('./_hasPath');\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\nmodule.exports = hasIn;\n","var baseIsEqual = require('./_baseIsEqual'),\n get = require('./get'),\n hasIn = require('./hasIn'),\n isKey = require('./_isKey'),\n isStrictComparable = require('./_isStrictComparable'),\n matchesStrictComparable = require('./_matchesStrictComparable'),\n toKey = require('./_toKey');\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\nmodule.exports = baseMatchesProperty;\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\nmodule.exports = identity;\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\nmodule.exports = baseProperty;\n","var baseGet = require('./_baseGet');\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\nmodule.exports = basePropertyDeep;\n","var baseProperty = require('./_baseProperty'),\n basePropertyDeep = require('./_basePropertyDeep'),\n isKey = require('./_isKey'),\n toKey = require('./_toKey');\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\nmodule.exports = property;\n","var baseMatches = require('./_baseMatches'),\n baseMatchesProperty = require('./_baseMatchesProperty'),\n identity = require('./identity'),\n isArray = require('./isArray'),\n property = require('./property');\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\nmodule.exports = baseIteratee;\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\nmodule.exports = createBaseFor;\n","var createBaseFor = require('./_createBaseFor');\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\nmodule.exports = baseFor;\n","var baseFor = require('./_baseFor'),\n keys = require('./keys');\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\nmodule.exports = baseForOwn;\n","var isArrayLike = require('./isArrayLike');\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\nmodule.exports = createBaseEach;\n","var baseForOwn = require('./_baseForOwn'),\n createBaseEach = require('./_createBaseEach');\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\nmodule.exports = baseEach;\n","var baseEach = require('./_baseEach'),\n isArrayLike = require('./isArrayLike');\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\nmodule.exports = baseMap;\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\nmodule.exports = baseSortBy;\n","var isSymbol = require('./isSymbol');\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\nmodule.exports = compareAscending;\n","var compareAscending = require('./_compareAscending');\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\nmodule.exports = compareMultiple;\n","var arrayMap = require('./_arrayMap'),\n baseGet = require('./_baseGet'),\n baseIteratee = require('./_baseIteratee'),\n baseMap = require('./_baseMap'),\n baseSortBy = require('./_baseSortBy'),\n baseUnary = require('./_baseUnary'),\n compareMultiple = require('./_compareMultiple'),\n identity = require('./identity'),\n isArray = require('./isArray');\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\nmodule.exports = baseOrderBy;\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\nmodule.exports = apply;\n","var apply = require('./_apply');\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\nmodule.exports = overRest;\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\nmodule.exports = constant;\n","var constant = require('./constant'),\n defineProperty = require('./_defineProperty'),\n identity = require('./identity');\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\nmodule.exports = baseSetToString;\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\nmodule.exports = shortOut;\n","var baseSetToString = require('./_baseSetToString'),\n shortOut = require('./_shortOut');\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\nmodule.exports = setToString;\n","var identity = require('./identity'),\n overRest = require('./_overRest'),\n setToString = require('./_setToString');\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\nmodule.exports = baseRest;\n","var eq = require('./eq'),\n isArrayLike = require('./isArrayLike'),\n isIndex = require('./_isIndex'),\n isObject = require('./isObject');\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\nmodule.exports = isIterateeCall;\n","var baseFlatten = require('./_baseFlatten'),\n baseOrderBy = require('./_baseOrderBy'),\n baseRest = require('./_baseRest'),\n isIterateeCall = require('./_isIterateeCall');\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\nmodule.exports = sortBy;\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\nmodule.exports = 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\nmodule.exports = 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\nmodule.exports = strictIndexOf;\n","var baseFindIndex = require('./_baseFindIndex'),\n baseIsNaN = require('./_baseIsNaN'),\n strictIndexOf = require('./_strictIndexOf');\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\nmodule.exports = baseIndexOf;\n","var baseIndexOf = require('./_baseIndexOf');\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\nmodule.exports = arrayIncludes;\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\nmodule.exports = arrayIncludesWith;\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\nmodule.exports = noop;\n","var Set = require('./_Set'),\n noop = require('./noop'),\n setToArray = require('./_setToArray');\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\nmodule.exports = createSet;\n","var SetCache = require('./_SetCache'),\n arrayIncludes = require('./_arrayIncludes'),\n arrayIncludesWith = require('./_arrayIncludesWith'),\n cacheHas = require('./_cacheHas'),\n createSet = require('./_createSet'),\n setToArray = require('./_setToArray');\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\nmodule.exports = baseUniq;\n","var baseUniq = require('./_baseUniq');\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\nmodule.exports = uniq;\n","var baseUniq = require('./_baseUniq');\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\nmodule.exports = uniqWith;\n","var baseRest = require('./_baseRest'),\n eq = require('./eq'),\n isIterateeCall = require('./_isIterateeCall'),\n keysIn = require('./keysIn');\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\nmodule.exports = defaults;\n","var SetCache = require('./_SetCache'),\n arrayIncludes = require('./_arrayIncludes'),\n arrayIncludesWith = require('./_arrayIncludesWith'),\n arrayMap = require('./_arrayMap'),\n baseUnary = require('./_baseUnary'),\n cacheHas = require('./_cacheHas');\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\nmodule.exports = baseIntersection;\n","var isArrayLike = require('./isArrayLike'),\n isObjectLike = require('./isObjectLike');\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\nmodule.exports = isArrayLikeObject;\n","var isArrayLikeObject = require('./isArrayLikeObject');\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\nmodule.exports = castArrayLikeObject;\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\nmodule.exports = last;\n","var arrayMap = require('./_arrayMap'),\n baseIntersection = require('./_baseIntersection'),\n baseRest = require('./_baseRest'),\n castArrayLikeObject = require('./_castArrayLikeObject'),\n last = require('./last');\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\nmodule.exports = intersectionWith;\n","var baseGetTag = require('./_baseGetTag'),\n getPrototype = require('./_getPrototype'),\n isObjectLike = require('./isObjectLike');\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\nmodule.exports = isPlainObject;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\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\nmodule.exports = isBoolean;\n","var isEqual = require('lodash/isEqual')\nvar sortBy = require('lodash/sortBy')\nvar uniq = require('lodash/uniq')\nvar uniqWith = require('lodash/uniqWith')\nvar defaults = require('lodash/defaults')\nvar intersectionWith = require('lodash/intersectionWith')\nvar isPlainObject = require('lodash/isPlainObject')\nvar isBoolean = require('lodash/isBoolean')\n\nvar normalizeArray = val => Array.isArray(val)\n ? val : [val]\nvar undef = val => val === undefined\nvar keys = obj => isPlainObject(obj) || Array.isArray(obj) ? Object.keys(obj) : []\nvar has = (obj, key) => obj.hasOwnProperty(key)\nvar stringArray = arr => sortBy(uniq(arr))\nvar undefEmpty = val => undef(val) || (Array.isArray(val) && val.length === 0)\nvar keyValEqual = (a, b, key, compare) => b && has(b, key) && a && has(a, key) && compare(a[key], b[key])\nvar undefAndZero = (a, b) => (undef(a) && b === 0) || (undef(b) && a === 0) || isEqual(a, b)\nvar falseUndefined = (a, b) => (undef(a) && b === false) || (undef(b) && a === false) || isEqual(a, b)\nvar emptySchema = schema => undef(schema) || isEqual(schema, {}) || schema === true\nvar emptyObjUndef = schema => undef(schema) || isEqual(schema, {})\nvar isSchema = val => undef(val) || isPlainObject(val) || val === true || val === false\n\nfunction undefArrayEqual(a, b) {\n if (undefEmpty(a) && undefEmpty(b)) {\n return true\n } else {\n return isEqual(stringArray(a), stringArray(b))\n }\n}\n\nfunction unsortedNormalizedArray(a, b) {\n a = normalizeArray(a)\n b = normalizeArray(b)\n return isEqual(stringArray(a), stringArray(b))\n}\n\nfunction schemaGroup(a, b, key, compare) {\n var allProps = uniq(keys(a).concat(keys(b)))\n if (emptyObjUndef(a) && emptyObjUndef(b)) {\n return true\n } else if (emptyObjUndef(a) && keys(b).length) {\n return false\n } else if (emptyObjUndef(b) && keys(a).length) {\n return false\n }\n\n return allProps.every(function(key) {\n var aVal = a[key]\n var bVal = b[key]\n if (Array.isArray(aVal) && Array.isArray(bVal)) {\n return isEqual(stringArray(a), stringArray(b))\n } else if (Array.isArray(aVal) && !Array.isArray(bVal)) {\n return false\n } else if (Array.isArray(bVal) && !Array.isArray(aVal)) {\n return false\n }\n return keyValEqual(a, b, key, compare)\n })\n}\n\nfunction items(a, b, key, compare) {\n if (isPlainObject(a) && isPlainObject(b)) {\n return compare(a, b)\n } else if (Array.isArray(a) && Array.isArray(b)) {\n return schemaGroup(a, b, key, compare)\n } else {\n return isEqual(a, b)\n }\n}\n\nfunction unsortedArray(a, b, key, compare) {\n var uniqueA = uniqWith(a, compare)\n var uniqueB = uniqWith(b, compare)\n var inter = intersectionWith(uniqueA, uniqueB, compare)\n return inter.length === Math.max(uniqueA.length, uniqueB.length)\n}\n\nvar comparers = {\n title: isEqual,\n uniqueItems: falseUndefined,\n minLength: undefAndZero,\n minItems: undefAndZero,\n minProperties: undefAndZero,\n required: undefArrayEqual,\n enum: undefArrayEqual,\n type: unsortedNormalizedArray,\n items: items,\n anyOf: unsortedArray,\n allOf: unsortedArray,\n oneOf: unsortedArray,\n properties: schemaGroup,\n patternProperties: schemaGroup,\n dependencies: schemaGroup\n}\n\nvar acceptsUndefined = [\n 'properties',\n 'patternProperties',\n 'dependencies',\n 'uniqueItems',\n 'minLength',\n 'minItems',\n 'minProperties',\n 'required'\n]\n\nvar schemaProps = ['additionalProperties', 'additionalItems', 'contains', 'propertyNames', 'not']\n\nfunction compare(a, b, options) {\n options = defaults(options, {\n ignore: []\n })\n\n if (emptySchema(a) && emptySchema(b)) {\n return true\n }\n\n if (!isSchema(a) || !isSchema(b)) {\n throw new Error('Either of the values are not a JSON schema.')\n }\n if (a === b) {\n return true\n }\n\n if (isBoolean(a) && isBoolean(b)) {\n return a === b\n }\n\n if ((a === undefined && b === false) || (b === undefined && a === false)) {\n return false\n }\n\n if ((undef(a) && !undef(b)) || (!undef(a) && undef(b))) {\n return false\n }\n\n var allKeys = uniq(Object.keys(a).concat(Object.keys(b)))\n\n if (options.ignore.length) {\n allKeys = allKeys.filter(k => options.ignore.indexOf(k) === -1)\n }\n\n if (!allKeys.length) {\n return true\n }\n\n function innerCompare(a, b) {\n return compare(a, b, options)\n }\n\n return allKeys.every(function(key) {\n var aValue = a[key]\n var bValue = b[key]\n\n if (schemaProps.indexOf(key) !== -1) {\n return compare(aValue, bValue, options)\n }\n\n var comparer = comparers[key]\n if (!comparer) {\n comparer = isEqual\n }\n\n // do simple lodash check first\n if (isEqual(aValue, bValue)) {\n return true\n }\n\n if (acceptsUndefined.indexOf(key) === -1) {\n if ((!has(a, key) && has(b, key)) || (has(a, key) && !has(b, key))) {\n return aValue === bValue\n }\n }\n\n var result = comparer(aValue, bValue, key, innerCompare)\n if (!isBoolean(result)) {\n throw new Error('Comparer must return true or false')\n }\n return result\n })\n}\n\nmodule.exports = compare\n","'use strict';\n\n/**\n* FUNCTION: isArray( value )\n*\tValidates if a value is an array.\n*\n* @param {*} value - value to be validated\n* @returns {Boolean} boolean indicating whether value is an array\n*/\nfunction isArray( value ) {\n\treturn Object.prototype.toString.call( value ) === '[object Array]';\n} // end FUNCTION isArray()\n\n// EXPORTS //\n\nmodule.exports = Array.isArray || isArray;\n","/**\n*\n*\tVALIDATE: number\n*\n*\n*\tDESCRIPTION:\n*\t\t- Validates if a value is a number.\n*\n*\n*\tNOTES:\n*\t\t[1]\n*\n*\n*\tTODO:\n*\t\t[1]\n*\n*\n*\tLICENSE:\n*\t\tMIT\n*\n*\tCopyright (c) 2014. Athan Reines.\n*\n*\n*\tAUTHOR:\n*\t\tAthan Reines. kgryte@gmail.com. 2014.\n*\n*/\n\n'use strict';\n\n/**\n* FUNCTION: isNumber( value )\n*\tValidates if a value is a number.\n*\n* @param {*} value - value to be validated\n* @returns {Boolean} boolean indicating whether value is a number\n*/\nfunction isNumber( value ) {\n\treturn ( typeof value === 'number' || Object.prototype.toString.call( value ) === '[object Number]' ) && value.valueOf() === value.valueOf();\n} // end FUNCTION isNumber()\n\n\n// EXPORTS //\n\nmodule.exports = isNumber;\n","/**\n*\n*\tVALIDATE: integer\n*\n*\n*\tDESCRIPTION:\n*\t\t- Validates if a value is an integer.\n*\n*\n*\tNOTES:\n*\t\t[1]\n*\n*\n*\tTODO:\n*\t\t[1]\n*\n*\n*\tLICENSE:\n*\t\tMIT\n*\n*\tCopyright (c) 2014. Athan Reines.\n*\n*\n*\tAUTHOR:\n*\t\tAthan Reines. kgryte@gmail.com. 2014.\n*\n*/\n\n'use strict';\n\n// MODULES //\n\nvar isNumber = require( 'validate.io-number' );\n\n\n// ISINTEGER //\n\n/**\n* FUNCTION: isInteger( value )\n*\tValidates if a value is an integer.\n*\n* @param {Number} value - value to be validated\n* @returns {Boolean} boolean indicating whether value is an integer\n*/\nfunction isInteger( value ) {\n\treturn isNumber( value ) && value%1 === 0;\n} // end FUNCTION isInteger()\n\n\n// EXPORTS //\n\nmodule.exports = isInteger;\n","/**\n*\n*\tVALIDATE: integer-array\n*\n*\n*\tDESCRIPTION:\n*\t\t- Validates if a value is an integer array.\n*\n*\n*\tNOTES:\n*\t\t[1]\n*\n*\n*\tTODO:\n*\t\t[1]\n*\n*\n*\tLICENSE:\n*\t\tMIT\n*\n*\tCopyright (c) 2015. Athan Reines.\n*\n*\n*\tAUTHOR:\n*\t\tAthan Reines. kgryte@gmail.com. 2015.\n*\n*/\n\n'use strict';\n\n// MODULES //\n\nvar isArray = require( 'validate.io-array' ),\n\tisInteger = require( 'validate.io-integer' );\n\n\n// IS INTEGER ARRAY //\n\n/**\n* FUNCTION: isIntegerArray( value )\n*\tValidates if a value is an integer array.\n*\n* @param {*} value - value to be validated\n* @returns {Boolean} boolean indicating if a value is an integer array\n*/\nfunction isIntegerArray( value ) {\n\tvar len;\n\tif ( !isArray( value ) ) {\n\t\treturn false;\n\t}\n\tlen = value.length;\n\tif ( !len ) {\n\t\treturn false;\n\t}\n\tfor ( var i = 0; i < len; i++ ) {\n\t\tif ( !isInteger( value[i] ) ) {\n\t\t\treturn false;\n\t\t}\n\t}\n\treturn true;\n} // end FUNCTION isIntegerArray()\n\n\n// EXPORTS //\n\nmodule.exports = isIntegerArray;\n","/**\n*\n*\tVALIDATE: function\n*\n*\n*\tDESCRIPTION:\n*\t\t- Validates if a value is a function.\n*\n*\n*\tNOTES:\n*\t\t[1]\n*\n*\n*\tTODO:\n*\t\t[1]\n*\n*\n*\tLICENSE:\n*\t\tMIT\n*\n*\tCopyright (c) 2014. Athan Reines.\n*\n*\n*\tAUTHOR:\n*\t\tAthan Reines. kgryte@gmail.com. 2014.\n*\n*/\n\n'use strict';\n\n/**\n* FUNCTION: isFunction( value )\n*\tValidates if a value is a function.\n*\n* @param {*} value - value to be validated\n* @returns {Boolean} boolean indicating whether value is a function\n*/\nfunction isFunction( value ) {\n\treturn ( typeof value === 'function' );\n} // end FUNCTION isFunction()\n\n\n// EXPORTS //\n\nmodule.exports = isFunction;\n","'use strict';\n\n// MODULES //\n\nvar isArray = require( 'validate.io-array' ),\n\tisIntegerArray = require( 'validate.io-integer-array' ),\n\tisFunction = require( 'validate.io-function' );\n\n\n// VARIABLES //\n\nvar MAXINT = Math.pow( 2, 31 ) - 1;\n\n\n// FUNCTIONS //\n\n/**\n* FUNCTION: gcd( a, b )\n*\tComputes the greatest common divisor of two integers `a` and `b`, using the binary GCD algorithm.\n*\n* @param {Number} a - integer\n* @param {Number} b - integer\n* @returns {Number} greatest common divisor\n*/\nfunction gcd( a, b ) {\n\tvar k = 1,\n\t\tt;\n\t// Simple cases:\n\tif ( a === 0 ) {\n\t\treturn b;\n\t}\n\tif ( b === 0 ) {\n\t\treturn a;\n\t}\n\t// Reduce `a` and/or `b` to odd numbers and keep track of the greatest power of 2 dividing both `a` and `b`...\n\twhile ( a%2 === 0 && b%2 === 0 ) {\n\t\ta = a / 2; // right shift\n\t\tb = b / 2; // right shift\n\t\tk = k * 2; // left shift\n\t}\n\t// Reduce `a` to an odd number...\n\twhile ( a%2 === 0 ) {\n\t\ta = a / 2; // right shift\n\t}\n\t// Henceforth, `a` is always odd...\n\twhile ( b ) {\n\t\t// Remove all factors of 2 in `b`, as they are not common...\n\t\twhile ( b%2 === 0 ) {\n\t\t\tb = b / 2; // right shift\n\t\t}\n\t\t// `a` and `b` are both odd. Swap values such that `b` is the larger of the two values, and then set `b` to the difference (which is even)...\n\t\tif ( a > b ) {\n\t\t\tt = b;\n\t\t\tb = a;\n\t\t\ta = t;\n\t\t}\n\t\tb = b - a; // b=0 iff b=a\n\t}\n\t// Restore common factors of 2...\n\treturn k * a;\n} // end FUNCTION gcd()\n\n/**\n* FUNCTION: bitwise( a, b )\n*\tComputes the greatest common divisor of two integers `a` and `b`, using the binary GCD algorithm and bitwise operations.\n*\n* @param {Number} a - safe integer\n* @param {Number} b - safe integer\n* @returns {Number} greatest common divisor\n*/\nfunction bitwise( a, b ) {\n\tvar k = 0,\n\t\tt;\n\t// Simple cases:\n\tif ( a === 0 ) {\n\t\treturn b;\n\t}\n\tif ( b === 0 ) {\n\t\treturn a;\n\t}\n\t// Reduce `a` and/or `b` to odd numbers and keep track of the greatest power of 2 dividing both `a` and `b`...\n\twhile ( (a & 1) === 0 && (b & 1) === 0 ) {\n\t\ta >>>= 1; // right shift\n\t\tb >>>= 1; // right shift\n\t\tk++;\n\t}\n\t// Reduce `a` to an odd number...\n\twhile ( (a & 1) === 0 ) {\n\t\ta >>>= 1; // right shift\n\t}\n\t// Henceforth, `a` is always odd...\n\twhile ( b ) {\n\t\t// Remove all factors of 2 in `b`, as they are not common...\n\t\twhile ( (b & 1) === 0 ) {\n\t\t\tb >>>= 1; // right shift\n\t\t}\n\t\t// `a` and `b` are both odd. Swap values such that `b` is the larger of the two values, and then set `b` to the difference (which is even)...\n\t\tif ( a > b ) {\n\t\t\tt = b;\n\t\t\tb = a;\n\t\t\ta = t;\n\t\t}\n\t\tb = b - a; // b=0 iff b=a\n\t}\n\t// Restore common factors of 2...\n\treturn a << k;\n} // end FUNCTION bitwise()\n\n\n// GREATEST COMMON DIVISOR //\n\n/**\n* FUNCTION: compute( arr[, clbk] )\n*\tComputes the greatest common divisor.\n*\n* @param {Number[]|Number} arr - input array of integers\n* @param {Function|Number} [clbk] - accessor function for accessing array values\n* @returns {Number|Null} greatest common divisor or null\n*/\nfunction compute() {\n\tvar nargs = arguments.length,\n\t\targs,\n\t\tclbk,\n\t\tarr,\n\t\tlen,\n\t\ta, b,\n\t\ti;\n\n\t// Copy the input arguments to an array...\n\targs = new Array( nargs );\n\tfor ( i = 0; i < nargs; i++ ) {\n\t\targs[ i ] = arguments[ i ];\n\t}\n\t// Have we been provided with integer arguments?\n\tif ( isIntegerArray( args ) ) {\n\t\tif ( nargs === 2 ) {\n\t\t\ta = args[ 0 ];\n\t\t\tb = args[ 1 ];\n\t\t\tif ( a < 0 ) {\n\t\t\t\ta = -a;\n\t\t\t}\n\t\t\tif ( b < 0 ) {\n\t\t\t\tb = -b;\n\t\t\t}\n\t\t\tif ( a <= MAXINT && b <= MAXINT ) {\n\t\t\t\treturn bitwise( a, b );\n\t\t\t} else {\n\t\t\t\treturn gcd( a, b );\n\t\t\t}\n\t\t}\n\t\tarr = args;\n\t}\n\t// If not integers, ensure the first argument is an array...\n\telse if ( !isArray( args[ 0 ] ) ) {\n\t\tthrow new TypeError( 'gcd()::invalid input argument. Must provide an array of integers. Value: `' + args[ 0 ] + '`.' );\n\t}\n\t// Have we been provided with more than one argument? If so, ensure that the accessor argument is a function...\n\telse if ( nargs > 1 ) {\n\t\tarr = args[ 0 ];\n\t\tclbk = args[ 1 ];\n\t\tif ( !isFunction( clbk ) ) {\n\t\t\tthrow new TypeError( 'gcd()::invalid input argument. Accessor must be a function. Value: `' + clbk + '`.' );\n\t\t}\n\t}\n\t// We have been provided an array...\n\telse {\n\t\tarr = args[ 0 ];\n\t}\n\tlen = arr.length;\n\n\t// Check if a sufficient number of values have been provided...\n\tif ( len < 2 ) {\n\t\treturn null;\n\t}\n\t// If an accessor is provided, extract the array values...\n\tif ( clbk ) {\n\t\ta = new Array( len );\n\t\tfor ( i = 0; i < len; i++ ) {\n\t\t\ta[ i ] = clbk( arr[ i ], i );\n\t\t}\n\t\tarr = a;\n\t}\n\t// Given an input array, ensure all array values are integers...\n\tif ( nargs < 3 ) {\n\t\tif ( !isIntegerArray( arr ) ) {\n\t\t\tthrow new TypeError( 'gcd()::invalid input argument. Accessed array values must be integers. Value: `' + arr + '`.' );\n\t\t}\n\t}\n\t// Convert any negative integers to positive integers...\n\tfor ( i = 0; i < len; i++ ) {\n\t\ta = arr[ i ];\n\t\tif ( a < 0 ) {\n\t\t\tarr[ i ] = -a;\n\t\t}\n\t}\n\t// Exploit the fact that the gcd is an associative function...\n\ta = arr[ 0 ];\n\tfor ( i = 1; i < len; i++ ) {\n\t\tb = arr[ i ];\n\t\tif ( b <= MAXINT && a <= MAXINT ) {\n\t\t\ta = bitwise( a, b );\n\t\t} else {\n\t\t\ta = gcd( a, b );\n\t\t}\n\t}\n\treturn a;\n} // end FUNCTION compute()\n\n\n// EXPORTS //\n\nmodule.exports = compute;\n","'use strict';\n\n// MODULES //\n\nvar gcd = require( 'compute-gcd' ),\n\tisArray = require( 'validate.io-array' ),\n\tisIntegerArray = require( 'validate.io-integer-array' ),\n\tisFunction = require( 'validate.io-function' );\n\n\n// LEAST COMMON MULTIPLE //\n\n/**\n* FUNCTION: lcm( arr[, clbk] )\n*\tComputes the least common multiple (lcm).\n*\n* @param {Number[]|Number} arr - input array of integers\n* @param {Function|Number} [accessor] - accessor function for accessing array values\n* @returns {Number|Null} least common multiple or null\n*/\nfunction lcm() {\n\tvar nargs = arguments.length,\n\t\targs,\n\t\tclbk,\n\t\tarr,\n\t\tlen,\n\t\ta, b,\n\t\ti;\n\n\t// Copy the input arguments to an array...\n\targs = new Array( nargs );\n\tfor ( i = 0; i < nargs; i++ ) {\n\t\targs[ i ] = arguments[ i ];\n\t}\n\t// Have we been provided with integer arguments?\n\tif ( isIntegerArray( args ) ) {\n\t\tif ( nargs === 2 ) {\n\t\t\ta = args[ 0 ];\n\t\t\tb = args[ 1 ];\n\t\t\tif ( a < 0 ) {\n\t\t\t\ta = -a;\n\t\t\t}\n\t\t\tif ( b < 0 ) {\n\t\t\t\tb = -b;\n\t\t\t}\n\t\t\tif ( a === 0 || b === 0 ) {\n\t\t\t\treturn 0;\n\t\t\t}\n\t\t\treturn ( a/gcd(a,b) ) * b;\n\t\t}\n\t\tarr = args;\n\t}\n\t// If not integers, ensure that the first argument is an array...\n\telse if ( !isArray( args[ 0 ] ) ) {\n\t\tthrow new TypeError( 'lcm()::invalid input argument. Must provide an array of integers. Value: `' + args[ 0 ] + '`.' );\n\t}\n\t// Have we been provided with more than one argument? If so, ensure that the accessor argument is a function...\n\telse if ( nargs > 1 ) {\n\t\tarr = args[ 0 ];\n\t\tclbk = args[ 1 ];\n\t\tif ( !isFunction( clbk ) ) {\n\t\t\tthrow new TypeError( 'lcm()::invalid input argument. Accessor must be a function. Value: `' + clbk + '`.' );\n\t\t}\n\t}\n\t// We have been provided an array...\n\telse {\n\t\tarr = args[ 0 ];\n\t}\n\tlen = arr.length;\n\n\t// Check if a sufficient number of values have been provided...\n\tif ( len < 2 ) {\n\t\treturn null;\n\t}\n\t// If an accessor is provided, extract the array values...\n\tif ( clbk ) {\n\t\ta = new Array( len );\n\t\tfor ( i = 0; i < len; i++ ) {\n\t\t\ta[ i ] = clbk( arr[ i ], i );\n\t\t}\n\t\tarr = a;\n\t}\n\t// Given an input array, ensure all array values are integers...\n\tif ( nargs < 3 ) {\n\t\tif ( !isIntegerArray( arr ) ) {\n\t\t\tthrow new TypeError( 'lcm()::invalid input argument. Accessed array values must be integers. Value: `' + arr + '`.' );\n\t\t}\n\t}\n\t// Convert any negative integers to positive integers...\n\tfor ( i = 0; i < len; i++ ) {\n\t\ta = arr[ i ];\n\t\tif ( a < 0 ) {\n\t\t\tarr[ i ] = -a;\n\t\t}\n\t}\n\t// Exploit the fact that the lcm is an associative function...\n\ta = arr[ 0 ];\n\tfor ( i = 1; i < len; i++ ) {\n\t\tb = arr[ i ];\n\t\tif ( a === 0 || b === 0 ) {\n\t\t\treturn 0;\n\t\t}\n\t\ta = ( a/gcd(a,b) ) * b;\n\t}\n\treturn a;\n} // end FUNCTION lcm()\n\n\n// EXPORTS //\n\nmodule.exports = lcm;\n","var baseAssignValue = require('./_baseAssignValue'),\n eq = require('./eq');\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\nmodule.exports = assignMergeValue;\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\nmodule.exports = safeGet;\n","var copyObject = require('./_copyObject'),\n keysIn = require('./keysIn');\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\nmodule.exports = toPlainObject;\n","var assignMergeValue = require('./_assignMergeValue'),\n cloneBuffer = require('./_cloneBuffer'),\n cloneTypedArray = require('./_cloneTypedArray'),\n copyArray = require('./_copyArray'),\n initCloneObject = require('./_initCloneObject'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isArrayLikeObject = require('./isArrayLikeObject'),\n isBuffer = require('./isBuffer'),\n isFunction = require('./isFunction'),\n isObject = require('./isObject'),\n isPlainObject = require('./isPlainObject'),\n isTypedArray = require('./isTypedArray'),\n safeGet = require('./_safeGet'),\n toPlainObject = require('./toPlainObject');\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\nmodule.exports = baseMergeDeep;\n","var Stack = require('./_Stack'),\n assignMergeValue = require('./_assignMergeValue'),\n baseFor = require('./_baseFor'),\n baseMergeDeep = require('./_baseMergeDeep'),\n isObject = require('./isObject'),\n keysIn = require('./keysIn'),\n safeGet = require('./_safeGet');\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\nmodule.exports = baseMerge;\n","var baseMerge = require('./_baseMerge'),\n isObject = require('./isObject');\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\nmodule.exports = customDefaultsMerge;\n","var baseRest = require('./_baseRest'),\n isIterateeCall = require('./_isIterateeCall');\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\nmodule.exports = createAssigner;\n","var baseMerge = require('./_baseMerge'),\n createAssigner = require('./_createAssigner');\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\nmodule.exports = mergeWith;\n","var apply = require('./_apply'),\n baseRest = require('./_baseRest'),\n customDefaultsMerge = require('./_customDefaultsMerge'),\n mergeWith = require('./mergeWith');\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\nmodule.exports = defaultsDeep;\n","var baseFlatten = require('./_baseFlatten');\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\nmodule.exports = flatten;\n","var baseFlatten = require('./_baseFlatten');\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\nmodule.exports = flattenDeep;\n","var arrayMap = require('./_arrayMap'),\n baseIntersection = require('./_baseIntersection'),\n baseRest = require('./_baseRest'),\n castArrayLikeObject = require('./_castArrayLikeObject');\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\nmodule.exports = intersection;\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\nmodule.exports = baseIndexOfWith;\n","var arrayMap = require('./_arrayMap'),\n baseIndexOf = require('./_baseIndexOf'),\n baseIndexOfWith = require('./_baseIndexOfWith'),\n baseUnary = require('./_baseUnary'),\n copyArray = require('./_copyArray');\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\nmodule.exports = basePullAll;\n","var basePullAll = require('./_basePullAll');\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\nmodule.exports = pullAll;\n","var identity = require('./identity');\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\nmodule.exports = castFunction;\n","var arrayEach = require('./_arrayEach'),\n baseEach = require('./_baseEach'),\n castFunction = require('./_castFunction'),\n isArray = require('./isArray');\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\nmodule.exports = forEach;\n","var SetCache = require('./_SetCache'),\n arrayIncludes = require('./_arrayIncludes'),\n arrayIncludesWith = require('./_arrayIncludesWith'),\n arrayMap = require('./_arrayMap'),\n baseUnary = require('./_baseUnary'),\n cacheHas = require('./_cacheHas');\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\nmodule.exports = baseDifference;\n","var baseDifference = require('./_baseDifference'),\n baseRest = require('./_baseRest'),\n isArrayLikeObject = require('./isArrayLikeObject');\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\nmodule.exports = without;\n","const flatten = require('lodash/flatten')\nconst flattenDeep = require('lodash/flattenDeep')\nconst isPlainObject = require('lodash/isPlainObject')\nconst uniq = require('lodash/uniq')\nconst uniqWith = require('lodash/uniqWith')\nconst without = require('lodash/without')\n\nfunction deleteUndefinedProps(returnObject) {\n // cleanup empty\n for (const prop in returnObject) {\n if (has(returnObject, prop) && isEmptySchema(returnObject[prop])) {\n delete returnObject[prop]\n }\n }\n return returnObject\n}\n\nconst allUniqueKeys = (arr) => uniq(flattenDeep(arr.map(keys)))\nconst getValues = (schemas, key) => schemas.map(schema => schema && schema[key])\nconst has = (obj, propName) => Object.prototype.hasOwnProperty.call(obj, propName)\nconst keys = obj => {\n if (isPlainObject(obj) || Array.isArray(obj)) {\n return Object.keys(obj)\n } else {\n return []\n }\n}\n\nconst notUndefined = (val) => val !== undefined\nconst isSchema = (val) => isPlainObject(val) || val === true || val === false\nconst isEmptySchema = (obj) => (!keys(obj).length) && obj !== false && obj !== true\nconst withoutArr = (arr, ...rest) => without.apply(null, [arr].concat(flatten(rest)))\n\nmodule.exports = {\n allUniqueKeys,\n deleteUndefinedProps,\n getValues,\n has,\n isEmptySchema,\n isSchema,\n keys,\n notUndefined,\n uniqWith,\n withoutArr\n}\n","\nconst compare = require('json-schema-compare')\nconst forEach = require('lodash/forEach')\nconst {\n allUniqueKeys,\n deleteUndefinedProps,\n getValues,\n keys,\n notUndefined,\n uniqWith,\n withoutArr\n} = require('../common')\n\nfunction removeFalseSchemas(target) {\n forEach(target, function(schema, prop) {\n if (schema === false) {\n delete target[prop]\n }\n })\n}\n\nfunction mergeSchemaGroup(group, mergeSchemas) {\n const allKeys = allUniqueKeys(group)\n return allKeys.reduce(function(all, key) {\n const schemas = getValues(group, key)\n const compacted = uniqWith(schemas.filter(notUndefined), compare)\n all[key] = mergeSchemas(compacted, key)\n return all\n }, {})\n}\n\nmodule.exports = {\n keywords: ['properties', 'patternProperties', 'additionalProperties'],\n resolver(values, parents, mergers, options) {\n // first get rid of all non permitted properties\n if (!options.ignoreAdditionalProperties) {\n values.forEach(function(subSchema) {\n const otherSubSchemas = values.filter(s => s !== subSchema)\n const ownKeys = keys(subSchema.properties)\n const ownPatternKeys = keys(subSchema.patternProperties)\n const ownPatterns = ownPatternKeys.map(k => new RegExp(k))\n otherSubSchemas.forEach(function(other) {\n const allOtherKeys = keys(other.properties)\n const keysMatchingPattern = allOtherKeys.filter(k => ownPatterns.some(pk => pk.test(k)))\n const additionalKeys = withoutArr(allOtherKeys, ownKeys, keysMatchingPattern)\n additionalKeys.forEach(function(key) {\n other.properties[key] = mergers.properties([\n other.properties[key], subSchema.additionalProperties\n ], key)\n })\n })\n })\n\n // remove disallowed patternProperties\n values.forEach(function(subSchema) {\n const otherSubSchemas = values.filter(s => s !== subSchema)\n const ownPatternKeys = keys(subSchema.patternProperties)\n if (subSchema.additionalProperties === false) {\n otherSubSchemas.forEach(function(other) {\n const allOtherPatterns = keys(other.patternProperties)\n const additionalPatternKeys = withoutArr(allOtherPatterns, ownPatternKeys)\n additionalPatternKeys.forEach(key => delete other.patternProperties[key])\n })\n }\n })\n }\n\n const returnObject = {\n additionalProperties: mergers.additionalProperties(values.map(s => s.additionalProperties)),\n patternProperties: mergeSchemaGroup(values.map(s => s.patternProperties), mergers.patternProperties),\n properties: mergeSchemaGroup(values.map(s => s.properties), mergers.properties)\n }\n\n if (returnObject.additionalProperties === false) {\n removeFalseSchemas(returnObject.properties)\n }\n\n return deleteUndefinedProps(returnObject)\n }\n}\n","\nconst compare = require('json-schema-compare')\nconst forEach = require('lodash/forEach')\nconst {\n allUniqueKeys,\n deleteUndefinedProps,\n has,\n isSchema,\n notUndefined,\n uniqWith\n} = require('../common')\n\nfunction removeFalseSchemasFromArray(target) {\n forEach(target, function(schema, index) {\n if (schema === false) {\n target.splice(index, 1)\n }\n })\n}\n\nfunction getItemSchemas(subSchemas, key) {\n return subSchemas.map(function(sub) {\n if (!sub) {\n return undefined\n }\n\n if (Array.isArray(sub.items)) {\n const schemaAtPos = sub.items[key]\n if (isSchema(schemaAtPos)) {\n return schemaAtPos\n } else if (has(sub, 'additionalItems')) {\n return sub.additionalItems\n }\n } else {\n return sub.items\n }\n\n return undefined\n })\n}\n\nfunction getAdditionalSchemas(subSchemas) {\n return subSchemas.map(function(sub) {\n if (!sub) {\n return undefined\n }\n if (Array.isArray(sub.items)) {\n return sub.additionalItems\n }\n return sub.items\n })\n}\n\n// Provide source when array\nfunction mergeItems(group, mergeSchemas, items) {\n const allKeys = allUniqueKeys(items)\n return allKeys.reduce(function(all, key) {\n const schemas = getItemSchemas(group, key)\n const compacted = uniqWith(schemas.filter(notUndefined), compare)\n all[key] = mergeSchemas(compacted, key)\n return all\n }, [])\n}\n\nmodule.exports = {\n keywords: ['items', 'additionalItems'],\n resolver(values, parents, mergers) {\n // const createSubMerger = groupKey => (schemas, key) => mergeSchemas(schemas, parents.concat(groupKey, key))\n const items = values.map(s => s.items)\n const itemsCompacted = items.filter(notUndefined)\n const returnObject = {}\n\n // if all items keyword values are schemas, we can merge them as simple schemas\n // if not we need to merge them as mixed\n if (itemsCompacted.every(isSchema)) {\n returnObject.items = mergers.items(items)\n } else {\n returnObject.items = mergeItems(values, mergers.items, items)\n }\n\n let schemasAtLastPos\n if (itemsCompacted.every(Array.isArray)) {\n schemasAtLastPos = values.map(s => s.additionalItems)\n } else if (itemsCompacted.some(Array.isArray)) {\n schemasAtLastPos = getAdditionalSchemas(values)\n }\n\n if (schemasAtLastPos) {\n returnObject.additionalItems = mergers.additionalItems(schemasAtLastPos)\n }\n\n if (returnObject.additionalItems === false && Array.isArray(returnObject.items)) {\n removeFalseSchemasFromArray(returnObject.items)\n }\n\n return deleteUndefinedProps(returnObject)\n }\n}\n","const cloneDeep = require('lodash/cloneDeep')\nconst compare = require('json-schema-compare')\nconst computeLcm = require('compute-lcm')\nconst defaultsDeep = require('lodash/defaultsDeep')\nconst flatten = require('lodash/flatten')\nconst flattenDeep = require('lodash/flattenDeep')\nconst intersection = require('lodash/intersection')\nconst intersectionWith = require('lodash/intersectionWith')\nconst isEqual = require('lodash/isEqual')\nconst isPlainObject = require('lodash/isPlainObject')\nconst pullAll = require('lodash/pullAll')\nconst sortBy = require('lodash/sortBy')\nconst uniq = require('lodash/uniq')\nconst uniqWith = require('lodash/uniqWith')\n\nconst propertiesResolver = require('./complex-resolvers/properties')\nconst itemsResolver = require('./complex-resolvers/items')\n\nconst contains = (arr, val) => arr.indexOf(val) !== -1\nconst isSchema = (val) => isPlainObject(val) || val === true || val === false\nconst isFalse = (val) => val === false\nconst isTrue = (val) => val === true\nconst schemaResolver = (compacted, key, mergeSchemas) => mergeSchemas(compacted)\nconst stringArray = (values) => sortBy(uniq(flattenDeep(values)))\nconst notUndefined = (val) => val !== undefined\nconst allUniqueKeys = (arr) => uniq(flattenDeep(arr.map(keys)))\n\n// resolvers\nconst first = compacted => compacted[0]\nconst required = compacted => stringArray(compacted)\nconst maximumValue = compacted => Math.max.apply(Math, compacted)\nconst minimumValue = compacted => Math.min.apply(Math, compacted)\nconst uniqueItems = compacted => compacted.some(isTrue)\nconst examples = compacted => uniqWith(flatten(compacted), isEqual)\n\nfunction compareProp(key) {\n return function(a, b) {\n return compare({\n [key]: a\n }, { [key]: b })\n }\n}\n\nfunction getAllOf(schema) {\n let { allOf = [], ...copy } = schema\n copy = isPlainObject(schema) ? copy : schema // if schema is boolean\n return [copy, ...allOf.map(getAllOf)]\n}\n\nfunction getValues(schemas, key) {\n return schemas.map(schema => schema && schema[key])\n}\n\nfunction tryMergeSchemaGroups(schemaGroups, mergeSchemas) {\n return schemaGroups.map(function(schemas, index) {\n try {\n return mergeSchemas(schemas, index)\n } catch (e) {\n return undefined\n }\n }).filter(notUndefined)\n}\n\nfunction keys(obj) {\n if (isPlainObject(obj) || Array.isArray(obj)) {\n return Object.keys(obj)\n } else {\n return []\n }\n}\n\nfunction getAnyOfCombinations(arrOfArrays, combinations) {\n combinations = combinations || []\n if (!arrOfArrays.length) {\n return combinations\n }\n\n const values = arrOfArrays.slice(0).shift()\n const rest = arrOfArrays.slice(1)\n if (combinations.length) {\n return getAnyOfCombinations(rest, flatten(combinations.map(combination => values.map(item => ([item].concat(combination))))))\n }\n return getAnyOfCombinations(rest, values.map(item => (item)))\n}\n\nfunction throwIncompatible(values, paths) {\n let asJSON\n try {\n asJSON = values.map(function(val) {\n return JSON.stringify(val, null, 2)\n }).join('\\n')\n } catch (variable) {\n asJSON = values.join(', ')\n }\n throw new Error('Could not resolve values for path:\"' + paths.join('.') + '\". They are probably incompatible. Values: \\n' + asJSON)\n}\n\nfunction callGroupResolver(complexKeywords, resolverName, schemas, mergeSchemas, options, parents) {\n if (complexKeywords.length) {\n const resolverConfig = options.complexResolvers[resolverName]\n if (!resolverConfig || !resolverConfig.resolver) {\n throw new Error('No resolver found for ' + resolverName)\n }\n\n // extract all keywords from all the schemas that have one or more\n // then remove all undefined ones and not unique\n const extractedKeywordsOnly = schemas.map(schema => complexKeywords.reduce((all, key) => {\n if (schema[key] !== undefined) all[key] = schema[key]\n return all\n }, {}))\n const unique = uniqWith(extractedKeywordsOnly, compare)\n\n // create mergers that automatically add the path of the keyword for use in the complex resolver\n const mergers = resolverConfig.keywords.reduce((all, key) => ({\n ...all,\n [key]: (schemas, extraKey = []) => mergeSchemas(schemas, null, parents.concat(key, extraKey))\n }), {})\n\n const result = resolverConfig.resolver(unique, parents.concat(resolverName), mergers, options)\n\n if (!isPlainObject(result)) {\n throwIncompatible(unique, parents.concat(resolverName))\n }\n\n return result\n }\n}\n\nfunction createRequiredMetaArray(arr) {\n return { required: arr }\n}\n\nconst schemaGroupProps = ['properties', 'patternProperties', 'definitions', 'dependencies']\nconst schemaArrays = ['anyOf', 'oneOf']\nconst schemaProps = [\n 'additionalProperties',\n 'additionalItems',\n 'contains',\n 'propertyNames',\n 'not',\n 'items'\n]\n\nconst defaultResolvers = {\n type(compacted) {\n if (compacted.some(Array.isArray)) {\n const normalized = compacted.map(function(val) {\n return Array.isArray(val)\n ? val\n : [val]\n })\n const common = intersection.apply(null, normalized)\n\n if (common.length === 1) {\n return common[0]\n } else if (common.length > 1) {\n return uniq(common)\n }\n }\n },\n dependencies(compacted, paths, mergeSchemas) {\n const allChildren = allUniqueKeys(compacted)\n\n return allChildren.reduce(function(all, childKey) {\n const childSchemas = getValues(compacted, childKey)\n let innerCompacted = uniqWith(childSchemas.filter(notUndefined), isEqual)\n\n // to support dependencies\n const innerArrays = innerCompacted.filter(Array.isArray)\n\n if (innerArrays.length) {\n if (innerArrays.length === innerCompacted.length) {\n all[childKey] = stringArray(innerCompacted)\n } else {\n const innerSchemas = innerCompacted.filter(isSchema)\n const arrayMetaScheams = innerArrays.map(createRequiredMetaArray)\n all[childKey] = mergeSchemas(innerSchemas.concat(arrayMetaScheams), childKey)\n }\n return all\n }\n\n innerCompacted = uniqWith(innerCompacted, compare)\n\n all[childKey] = mergeSchemas(innerCompacted, childKey)\n return all\n }, {})\n },\n oneOf(compacted, paths, mergeSchemas) {\n const combinations = getAnyOfCombinations(cloneDeep(compacted))\n const result = tryMergeSchemaGroups(combinations, mergeSchemas)\n const unique = uniqWith(result, compare)\n\n if (unique.length) {\n return unique\n }\n },\n not(compacted) {\n return { anyOf: compacted }\n },\n pattern(compacted) {\n return compacted.map(r => '(?=' + r + ')').join('')\n },\n multipleOf(compacted) {\n let integers = compacted.slice(0)\n let factor = 1\n while (integers.some(n => !Number.isInteger(n))) {\n integers = integers.map(n => n * 10)\n factor = factor * 10\n }\n return computeLcm(integers) / factor\n },\n enum(compacted) {\n const enums = intersectionWith.apply(null, compacted.concat(isEqual))\n if (enums.length) {\n return sortBy(enums)\n }\n }\n}\n\ndefaultResolvers.$id = first\ndefaultResolvers.$ref = first\ndefaultResolvers.$schema = first\ndefaultResolvers.additionalItems = schemaResolver\ndefaultResolvers.additionalProperties = schemaResolver\ndefaultResolvers.anyOf = defaultResolvers.oneOf\ndefaultResolvers.contains = schemaResolver\ndefaultResolvers.default = first\ndefaultResolvers.definitions = defaultResolvers.dependencies\ndefaultResolvers.description = first\ndefaultResolvers.examples = examples\ndefaultResolvers.exclusiveMaximum = minimumValue\ndefaultResolvers.exclusiveMinimum = maximumValue\ndefaultResolvers.items = itemsResolver\ndefaultResolvers.maximum = minimumValue\ndefaultResolvers.maxItems = minimumValue\ndefaultResolvers.maxLength = minimumValue\ndefaultResolvers.maxProperties = minimumValue\ndefaultResolvers.minimum = maximumValue\ndefaultResolvers.minItems = maximumValue\ndefaultResolvers.minLength = maximumValue\ndefaultResolvers.minProperties = maximumValue\ndefaultResolvers.properties = propertiesResolver\ndefaultResolvers.propertyNames = schemaResolver\ndefaultResolvers.required = required\ndefaultResolvers.title = first\ndefaultResolvers.uniqueItems = uniqueItems\n\nconst defaultComplexResolvers = {\n properties: propertiesResolver,\n items: itemsResolver\n}\n\nfunction merger(rootSchema, options, totalSchemas) {\n totalSchemas = totalSchemas || []\n options = defaultsDeep(options, {\n ignoreAdditionalProperties: false,\n resolvers: defaultResolvers,\n complexResolvers: defaultComplexResolvers,\n deep: true\n })\n\n const complexResolvers = Object.entries(options.complexResolvers)\n\n function mergeSchemas(schemas, base, parents) {\n schemas = cloneDeep(schemas.filter(notUndefined))\n parents = parents || []\n const merged = isPlainObject(base)\n ? base\n : {}\n\n // return undefined, an empty schema\n if (!schemas.length) {\n return\n }\n\n if (schemas.some(isFalse)) {\n return false\n }\n\n if (schemas.every(isTrue)) {\n return true\n }\n\n // there are no false and we don't need the true ones as they accept everything\n schemas = schemas.filter(isPlainObject)\n\n const allKeys = allUniqueKeys(schemas)\n if (options.deep && contains(allKeys, 'allOf')) {\n return merger({\n allOf: schemas\n }, options, totalSchemas)\n }\n\n const complexKeysArr = complexResolvers.map(([mainKeyWord, resolverConf]) =>\n allKeys.filter(k => resolverConf.keywords.includes(k)))\n\n // remove all complex keys before simple resolvers\n complexKeysArr.forEach(keys => pullAll(allKeys, keys))\n\n // call all simple resolvers for relevant keywords\n allKeys.forEach(function(key) {\n const values = getValues(schemas, key)\n const compacted = uniqWith(values.filter(notUndefined), compareProp(key))\n\n // arrayprops like anyOf and oneOf must be merged first, as they contains schemas\n // allOf is treated differently alltogether\n if (compacted.length === 1 && contains(schemaArrays, key)) {\n merged[key] = compacted[0].map(schema => mergeSchemas([schema], schema))\n // prop groups must always be resolved\n } else if (compacted.length === 1 && !contains(schemaGroupProps, key) && !contains(schemaProps, key)) {\n merged[key] = compacted[0]\n } else {\n const resolver = options.resolvers[key] || options.resolvers.defaultResolver\n if (!resolver) throw new Error('No resolver found for key ' + key + '. You can provide a resolver for this keyword in the options, or provide a default resolver.')\n\n const merger = (schemas, extraKey = []) => mergeSchemas(schemas, null, parents.concat(key, extraKey))\n merged[key] = resolver(compacted, parents.concat(key), merger, options)\n\n if (merged[key] === undefined) {\n throwIncompatible(compacted, parents.concat(key))\n } else if (merged[key] === undefined) {\n delete merged[key]\n }\n }\n })\n\n return complexResolvers.reduce((all, [resolverKeyword, config], index) => ({\n ...all,\n ...callGroupResolver(complexKeysArr[index], resolverKeyword, schemas, mergeSchemas, options, parents)\n }), merged)\n }\n\n const allSchemas = flattenDeep(getAllOf(rootSchema))\n const merged = mergeSchemas(allSchemas)\n\n return merged\n}\n\nmerger.options = {\n resolvers: defaultResolvers\n}\n\nmodule.exports = merger\n","/**\n * @license React\n * react-is.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nif (process.env.NODE_ENV !== \"production\") {\n (function() {\n'use strict';\n\n// ATTENTION\n// When adding new symbols to this file,\n// Please consider also adding to 'react-devtools-shared/src/backend/ReactSymbols'\n// The Symbol used to tag the ReactElement-like types.\nvar REACT_ELEMENT_TYPE = Symbol.for('react.element');\nvar REACT_PORTAL_TYPE = Symbol.for('react.portal');\nvar REACT_FRAGMENT_TYPE = Symbol.for('react.fragment');\nvar REACT_STRICT_MODE_TYPE = Symbol.for('react.strict_mode');\nvar REACT_PROFILER_TYPE = Symbol.for('react.profiler');\nvar REACT_PROVIDER_TYPE = Symbol.for('react.provider');\nvar REACT_CONTEXT_TYPE = Symbol.for('react.context');\nvar REACT_SERVER_CONTEXT_TYPE = Symbol.for('react.server_context');\nvar REACT_FORWARD_REF_TYPE = Symbol.for('react.forward_ref');\nvar REACT_SUSPENSE_TYPE = Symbol.for('react.suspense');\nvar REACT_SUSPENSE_LIST_TYPE = Symbol.for('react.suspense_list');\nvar REACT_MEMO_TYPE = Symbol.for('react.memo');\nvar REACT_LAZY_TYPE = Symbol.for('react.lazy');\nvar REACT_OFFSCREEN_TYPE = Symbol.for('react.offscreen');\n\n// -----------------------------------------------------------------------------\n\nvar enableScopeAPI = false; // Experimental Create Event Handle API.\nvar enableCacheElement = false;\nvar enableTransitionTracing = false; // No known bugs, but needs performance testing\n\nvar enableLegacyHidden = false; // Enables unstable_avoidThisFallback feature in Fiber\n// stuff. Intended to enable React core members to more easily debug scheduling\n// issues in DEV builds.\n\nvar enableDebugTracing = false; // Track which Fiber(s) schedule render work.\n\nvar REACT_MODULE_REFERENCE;\n\n{\n REACT_MODULE_REFERENCE = Symbol.for('react.module.reference');\n}\n\nfunction isValidElementType(type) {\n if (typeof type === 'string' || typeof type === 'function') {\n return true;\n } // Note: typeof might be other than 'symbol' or 'number' (e.g. if it's a polyfill).\n\n\n if (type === REACT_FRAGMENT_TYPE || type === REACT_PROFILER_TYPE || enableDebugTracing || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || enableLegacyHidden || type === REACT_OFFSCREEN_TYPE || enableScopeAPI || enableCacheElement || enableTransitionTracing ) {\n return true;\n }\n\n if (typeof type === 'object' && type !== null) {\n if (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || // This needs to include all possible module reference object\n // types supported by any Flight configuration anywhere since\n // we don't know which Flight build this will end up being used\n // with.\n type.$$typeof === REACT_MODULE_REFERENCE || type.getModuleId !== undefined) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction typeOf(object) {\n if (typeof object === 'object' && object !== null) {\n var $$typeof = object.$$typeof;\n\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE:\n var type = object.type;\n\n switch (type) {\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n case REACT_SUSPENSE_LIST_TYPE:\n return type;\n\n default:\n var $$typeofType = type && type.$$typeof;\n\n switch ($$typeofType) {\n case REACT_SERVER_CONTEXT_TYPE:\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n case REACT_PROVIDER_TYPE:\n return $$typeofType;\n\n default:\n return $$typeof;\n }\n\n }\n\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n\n return undefined;\n}\nvar ContextConsumer = REACT_CONTEXT_TYPE;\nvar ContextProvider = REACT_PROVIDER_TYPE;\nvar Element = REACT_ELEMENT_TYPE;\nvar ForwardRef = REACT_FORWARD_REF_TYPE;\nvar Fragment = REACT_FRAGMENT_TYPE;\nvar Lazy = REACT_LAZY_TYPE;\nvar Memo = REACT_MEMO_TYPE;\nvar Portal = REACT_PORTAL_TYPE;\nvar Profiler = REACT_PROFILER_TYPE;\nvar StrictMode = REACT_STRICT_MODE_TYPE;\nvar Suspense = REACT_SUSPENSE_TYPE;\nvar SuspenseList = REACT_SUSPENSE_LIST_TYPE;\nvar hasWarnedAboutDeprecatedIsAsyncMode = false;\nvar hasWarnedAboutDeprecatedIsConcurrentMode = false; // AsyncMode should be deprecated\n\nfunction isAsyncMode(object) {\n {\n if (!hasWarnedAboutDeprecatedIsAsyncMode) {\n hasWarnedAboutDeprecatedIsAsyncMode = true; // Using console['warn'] to evade Babel and ESLint\n\n console['warn']('The ReactIs.isAsyncMode() alias has been deprecated, ' + 'and will be removed in React 18+.');\n }\n }\n\n return false;\n}\nfunction isConcurrentMode(object) {\n {\n if (!hasWarnedAboutDeprecatedIsConcurrentMode) {\n hasWarnedAboutDeprecatedIsConcurrentMode = true; // Using console['warn'] to evade Babel and ESLint\n\n console['warn']('The ReactIs.isConcurrentMode() alias has been deprecated, ' + 'and will be removed in React 18+.');\n }\n }\n\n return false;\n}\nfunction isContextConsumer(object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n}\nfunction isContextProvider(object) {\n return typeOf(object) === REACT_PROVIDER_TYPE;\n}\nfunction isElement(object) {\n return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;\n}\nfunction isForwardRef(object) {\n return typeOf(object) === REACT_FORWARD_REF_TYPE;\n}\nfunction isFragment(object) {\n return typeOf(object) === REACT_FRAGMENT_TYPE;\n}\nfunction isLazy(object) {\n return typeOf(object) === REACT_LAZY_TYPE;\n}\nfunction isMemo(object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n}\nfunction isPortal(object) {\n return typeOf(object) === REACT_PORTAL_TYPE;\n}\nfunction isProfiler(object) {\n return typeOf(object) === REACT_PROFILER_TYPE;\n}\nfunction isStrictMode(object) {\n return typeOf(object) === REACT_STRICT_MODE_TYPE;\n}\nfunction isSuspense(object) {\n return typeOf(object) === REACT_SUSPENSE_TYPE;\n}\nfunction isSuspenseList(object) {\n return typeOf(object) === REACT_SUSPENSE_LIST_TYPE;\n}\n\nexports.ContextConsumer = ContextConsumer;\nexports.ContextProvider = ContextProvider;\nexports.Element = Element;\nexports.ForwardRef = ForwardRef;\nexports.Fragment = Fragment;\nexports.Lazy = Lazy;\nexports.Memo = Memo;\nexports.Portal = Portal;\nexports.Profiler = Profiler;\nexports.StrictMode = StrictMode;\nexports.Suspense = Suspense;\nexports.SuspenseList = SuspenseList;\nexports.isAsyncMode = isAsyncMode;\nexports.isConcurrentMode = isConcurrentMode;\nexports.isContextConsumer = isContextConsumer;\nexports.isContextProvider = isContextProvider;\nexports.isElement = isElement;\nexports.isForwardRef = isForwardRef;\nexports.isFragment = isFragment;\nexports.isLazy = isLazy;\nexports.isMemo = isMemo;\nexports.isPortal = isPortal;\nexports.isProfiler = isProfiler;\nexports.isStrictMode = isStrictMode;\nexports.isSuspense = isSuspense;\nexports.isSuspenseList = isSuspenseList;\nexports.isValidElementType = isValidElementType;\nexports.typeOf = typeOf;\n })();\n}\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","import isEqualWith from 'lodash-es/isEqualWith';\nimport get from 'lodash-es/get';\nimport isEmpty from 'lodash-es/isEmpty';\nimport jsonpointer from 'jsonpointer';\nimport omit from 'lodash-es/omit';\nimport has from 'lodash-es/has';\nimport isObject$1 from 'lodash-es/isObject';\nimport isString from 'lodash-es/isString';\nimport reduce from 'lodash-es/reduce';\nimport times from 'lodash-es/times';\nimport set from 'lodash-es/set';\nimport mergeAllOf from 'json-schema-merge-allof';\nimport union from 'lodash-es/union';\nimport isEqual from 'lodash-es/isEqual';\nimport cloneDeep from 'lodash-es/cloneDeep';\nimport { jsx } from 'react/jsx-runtime';\nimport { createElement } from 'react';\nimport ReactIs from 'react-is';\n\n/** Determines whether a `thing` is an object for the purposes of RSJF. In this case, `thing` is an object if it has\r\n * the type `object` but is NOT null, an array or a File.\r\n *\r\n * @param thing - The thing to check to see whether it is an object\r\n * @returns - True if it is a non-null, non-array, non-File object\r\n */\nfunction isObject(thing) {\n if (typeof File !== 'undefined' && thing instanceof File) {\n return false;\n }\n if (typeof Date !== 'undefined' && thing instanceof Date) {\n return false;\n }\n return typeof thing === 'object' && thing !== null && !Array.isArray(thing);\n}\n\n/** Checks the schema to see if it is allowing additional items, by verifying that `schema.additionalItems` is an\r\n * object. The user is warned in the console if `schema.additionalItems` has the value `true`.\r\n *\r\n * @param schema - The schema object to check\r\n * @returns - True if additional items is allowed, otherwise false\r\n */\nfunction allowAdditionalItems(schema) {\n if (schema.additionalItems === true) {\n console.warn('additionalItems=true is currently not supported');\n }\n return isObject(schema.additionalItems);\n}\n\n/** Attempts to convert the string into a number. If an empty string is provided, then `undefined` is returned. If a\r\n * `null` is provided, it is returned. If the string ends in a `.` then the string is returned because the user may be\r\n * in the middle of typing a float number. If a number ends in a pattern like `.0`, `.20`, `.030`, string is returned\r\n * because the user may be typing number that will end in a non-zero digit. Otherwise, the string is wrapped by\r\n * `Number()` and if that result is not `NaN`, that number will be returned, otherwise the string `value` will be.\r\n *\r\n * @param value - The string or null value to convert to a number\r\n * @returns - The `value` converted to a number when appropriate, otherwise the `value`\r\n */\nfunction asNumber(value) {\n if (value === '') {\n return undefined;\n }\n if (value === null) {\n return null;\n }\n if (/\\.$/.test(value)) {\n // '3.' can't really be considered a number even if it parses in js. The\n // user is most likely entering a float.\n return value;\n }\n if (/\\.0$/.test(value)) {\n // we need to return this as a string here, to allow for input like 3.07\n return value;\n }\n if (/\\.\\d*0$/.test(value)) {\n // It's a number, that's cool - but we need it as a string so it doesn't screw\n // with the user when entering dollar amounts or other values (such as those with\n // specific precision or number of significant digits)\n return value;\n }\n var n = Number(value);\n var valid = typeof n === 'number' && !Number.isNaN(n);\n return valid ? n : value;\n}\n\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nfunction _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\nfunction _objectDestructuringEmpty(obj) {\n if (obj == null) throw new TypeError(\"Cannot destructure \" + obj);\n}\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\nfunction _toPrimitive(input, hint) {\n if (typeof input !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (typeof res !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nfunction _toPropertyKey(arg) {\n var key = _toPrimitive(arg, \"string\");\n return typeof key === \"symbol\" ? key : String(key);\n}\n\n/** Below are the list of all the keys into various elements of a RJSFSchema or UiSchema that are used by the various\r\n * utility functions. In addition to those keys, there are the special `ADDITIONAL_PROPERTY_FLAG` and\r\n * `RJSF_ADDITONAL_PROPERTIES_FLAG` flags that is added to a schema under certain conditions by the `retrieveSchema()`\r\n * utility.\r\n */\nvar ADDITIONAL_PROPERTY_FLAG = '__additional_property';\nvar ADDITIONAL_PROPERTIES_KEY = 'additionalProperties';\nvar ALL_OF_KEY = 'allOf';\nvar ANY_OF_KEY = 'anyOf';\nvar CONST_KEY = 'const';\nvar DEFAULT_KEY = 'default';\nvar DEFINITIONS_KEY = 'definitions';\nvar DEPENDENCIES_KEY = 'dependencies';\nvar ENUM_KEY = 'enum';\nvar ERRORS_KEY = '__errors';\nvar ID_KEY = '$id';\nvar ITEMS_KEY = 'items';\nvar NAME_KEY = '$name';\nvar ONE_OF_KEY = 'oneOf';\nvar PROPERTIES_KEY = 'properties';\nvar REQUIRED_KEY = 'required';\nvar SUBMIT_BTN_OPTIONS_KEY = 'submitButtonOptions';\nvar REF_KEY = '$ref';\nvar RJSF_ADDITONAL_PROPERTIES_FLAG = '__rjsf_additionalProperties';\nvar UI_FIELD_KEY = 'ui:field';\nvar UI_WIDGET_KEY = 'ui:widget';\nvar UI_OPTIONS_KEY = 'ui:options';\nvar UI_GLOBAL_OPTIONS_KEY = 'ui:globalOptions';\n\n/** Get all passed options from ui:options, and ui:, returning them in an object with the `ui:`\r\n * stripped off. Any `globalOptions` will always be returned, unless they are overridden by options in the `uiSchema`.\r\n *\r\n * @param [uiSchema={}] - The UI Schema from which to get any `ui:xxx` options\r\n * @param [globalOptions={}] - The optional Global UI Schema from which to get any fallback `xxx` options\r\n * @returns - An object containing all the `ui:xxx` options with the `ui:` stripped off along with all `globalOptions`\r\n */\nfunction getUiOptions(uiSchema, globalOptions) {\n if (uiSchema === void 0) {\n uiSchema = {};\n }\n if (globalOptions === void 0) {\n globalOptions = {};\n }\n return Object.keys(uiSchema).filter(function (key) {\n return key.indexOf('ui:') === 0;\n }).reduce(function (options, key) {\n var _extends2;\n var value = uiSchema[key];\n if (key === UI_WIDGET_KEY && isObject(value)) {\n console.error('Setting options via ui:widget object is no longer supported, use ui:options instead');\n return options;\n }\n if (key === UI_OPTIONS_KEY && isObject(value)) {\n return _extends({}, options, value);\n }\n return _extends({}, options, (_extends2 = {}, _extends2[key.substring(3)] = value, _extends2));\n }, _extends({}, globalOptions));\n}\n\n/** Checks whether the field described by `schema`, having the `uiSchema` and `formData` supports expanding. The UI for\r\n * the field can expand if it has additional properties, is not forced as non-expandable by the `uiSchema` and the\r\n * `formData` object doesn't already have `schema.maxProperties` elements.\r\n *\r\n * @param schema - The schema for the field that is being checked\r\n * @param [uiSchema={}] - The uiSchema for the field\r\n * @param [formData] - The formData for the field\r\n * @returns - True if the schema element has additionalProperties, is expandable, and not at the maxProperties limit\r\n */\nfunction canExpand(schema, uiSchema, formData) {\n if (uiSchema === void 0) {\n uiSchema = {};\n }\n if (!schema.additionalProperties) {\n return false;\n }\n var _getUiOptions = getUiOptions(uiSchema),\n _getUiOptions$expanda = _getUiOptions.expandable,\n expandable = _getUiOptions$expanda === void 0 ? true : _getUiOptions$expanda;\n if (expandable === false) {\n return expandable;\n }\n // if ui:options.expandable was not explicitly set to false, we can add\n // another property if we have not exceeded maxProperties yet\n if (schema.maxProperties !== undefined && formData) {\n return Object.keys(formData).length < schema.maxProperties;\n }\n return true;\n}\n\n/** Implements a deep equals using the `lodash.isEqualWith` function, that provides a customized comparator that\r\n * assumes all functions are equivalent.\r\n *\r\n * @param a - The first element to compare\r\n * @param b - The second element to compare\r\n * @returns - True if the `a` and `b` are deeply equal, false otherwise\r\n */\nfunction deepEquals(a, b) {\n return isEqualWith(a, b, function (obj, other) {\n if (typeof obj === 'function' && typeof other === 'function') {\n // Assume all functions are equivalent\n // see https://github.com/rjsf-team/react-jsonschema-form/issues/255\n return true;\n }\n return undefined; // fallback to default isEquals behavior\n });\n}\n\n/** Splits out the value at the `key` in `object` from the `object`, returning an array that contains in the first\r\n * location, the `object` minus the `key: value` and in the second location the `value`.\r\n *\r\n * @param key - The key from the object to extract\r\n * @param object - The object from which to extract the element\r\n * @returns - An array with the first value being the object minus the `key` element and the second element being the\r\n * value from `object[key]`\r\n */\nfunction splitKeyElementFromObject(key, object) {\n var value = object[key];\n var remaining = omit(object, [key]);\n return [remaining, value];\n}\n/** Given the name of a `$ref` from within a schema, using the `rootSchema`, look up and return the sub-schema using the\r\n * path provided by that reference. If `#` is not the first character of the reference, or the path does not exist in\r\n * the schema, then throw an Error. Otherwise return the sub-schema. Also deals with nested `$ref`s in the sub-schema.\r\n *\r\n * @param $ref - The ref string for which the schema definition is desired\r\n * @param [rootSchema={}] - The root schema in which to search for the definition\r\n * @returns - The sub-schema within the `rootSchema` which matches the `$ref` if it exists\r\n * @throws - Error indicating that no schema for that reference exists\r\n */\nfunction findSchemaDefinition($ref, rootSchema) {\n if (rootSchema === void 0) {\n rootSchema = {};\n }\n var ref = $ref || '';\n if (ref.startsWith('#')) {\n // Decode URI fragment representation.\n ref = decodeURIComponent(ref.substring(1));\n } else {\n throw new Error(\"Could not find a definition for \" + $ref + \".\");\n }\n var current = jsonpointer.get(rootSchema, ref);\n if (current === undefined) {\n throw new Error(\"Could not find a definition for \" + $ref + \".\");\n }\n if (current[REF_KEY]) {\n var _splitKeyElementFromO = splitKeyElementFromObject(REF_KEY, current),\n remaining = _splitKeyElementFromO[0],\n theRef = _splitKeyElementFromO[1];\n var subSchema = findSchemaDefinition(theRef, rootSchema);\n if (Object.keys(remaining).length > 0) {\n return _extends({}, remaining, subSchema);\n }\n return subSchema;\n }\n return current;\n}\n\n/** Given the `formData` and list of `options`, attempts to find the index of the option that best matches the data.\r\n * Deprecated, use `getFirstMatchingOption()` instead.\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param formData - The current formData, if any, used to figure out a match\r\n * @param options - The list of options to find a matching options from\r\n * @param rootSchema - The root schema, used to primarily to look up `$ref`s\r\n * @returns - The index of the matched option or 0 if none is available\r\n * @deprecated\r\n */\nfunction getMatchingOption(validator, formData, options, rootSchema) {\n // For performance, skip validating subschemas if formData is undefined. We just\n // want to get the first option in that case.\n if (formData === undefined) {\n return 0;\n }\n for (var i = 0; i < options.length; i++) {\n var option = options[i];\n // If the schema describes an object then we need to add slightly more\n // strict matching to the schema, because unless the schema uses the\n // \"requires\" keyword, an object will match the schema as long as it\n // doesn't have matching keys with a conflicting type. To do this we use an\n // \"anyOf\" with an array of requires. This augmentation expresses that the\n // schema should match if any of the keys in the schema are present on the\n // object and pass validation.\n if (option.properties) {\n // Create an \"anyOf\" schema that requires at least one of the keys in the\n // \"properties\" object\n var requiresAnyOf = {\n anyOf: Object.keys(option.properties).map(function (key) {\n return {\n required: [key]\n };\n })\n };\n var augmentedSchema = void 0;\n // If the \"anyOf\" keyword already exists, wrap the augmentation in an \"allOf\"\n if (option.anyOf) {\n // Create a shallow clone of the option\n var shallowClone = _extends({}, (_objectDestructuringEmpty(option), option));\n if (!shallowClone.allOf) {\n shallowClone.allOf = [];\n } else {\n // If \"allOf\" already exists, shallow clone the array\n shallowClone.allOf = shallowClone.allOf.slice();\n }\n shallowClone.allOf.push(requiresAnyOf);\n augmentedSchema = shallowClone;\n } else {\n augmentedSchema = Object.assign({}, option, requiresAnyOf);\n }\n // Remove the \"required\" field as it's likely that not all fields have\n // been filled in yet, which will mean that the schema is not valid\n delete augmentedSchema.required;\n if (validator.isValid(augmentedSchema, formData, rootSchema)) {\n return i;\n }\n } else if (validator.isValid(option, formData, rootSchema)) {\n return i;\n }\n }\n return 0;\n}\n\n/** Given the `formData` and list of `options`, attempts to find the index of the first option that matches the data.\r\n * Always returns the first option if there is nothing that matches.\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param formData - The current formData, if any, used to figure out a match\r\n * @param options - The list of options to find a matching options from\r\n * @param rootSchema - The root schema, used to primarily to look up `$ref`s\r\n * @returns - The index of the first matched option or 0 if none is available\r\n */\nfunction getFirstMatchingOption(validator, formData, options, rootSchema) {\n return getMatchingOption(validator, formData, options, rootSchema);\n}\n\n/** Given a specific `value` attempts to guess the type of a schema element. In the case where we have to implicitly\r\n * create a schema, it is useful to know what type to use based on the data we are defining.\r\n *\r\n * @param value - The value from which to guess the type\r\n * @returns - The best guess for the object type\r\n */\nfunction guessType(value) {\n if (Array.isArray(value)) {\n return 'array';\n }\n if (typeof value === 'string') {\n return 'string';\n }\n if (value == null) {\n return 'null';\n }\n if (typeof value === 'boolean') {\n return 'boolean';\n }\n if (!isNaN(value)) {\n return 'number';\n }\n if (typeof value === 'object') {\n return 'object';\n }\n // Default to string if we can't figure it out\n return 'string';\n}\n\n/** Gets the type of a given `schema`. If the type is not explicitly defined, then an attempt is made to infer it from\r\n * other elements of the schema as follows:\r\n * - schema.const: Returns the `guessType()` of that value\r\n * - schema.enum: Returns `string`\r\n * - schema.properties: Returns `object`\r\n * - schema.additionalProperties: Returns `object`\r\n * - type is an array with a length of 2 and one type is 'null': Returns the other type\r\n *\r\n * @param schema - The schema for which to get the type\r\n * @returns - The type of the schema\r\n */\nfunction getSchemaType(schema) {\n var type = schema.type;\n if (!type && schema[\"const\"]) {\n return guessType(schema[\"const\"]);\n }\n if (!type && schema[\"enum\"]) {\n return 'string';\n }\n if (!type && (schema.properties || schema.additionalProperties)) {\n return 'object';\n }\n if (Array.isArray(type) && type.length === 2 && type.includes('null')) {\n type = type.find(function (type) {\n return type !== 'null';\n });\n }\n return type;\n}\n\n/** Recursively merge deeply nested schemas. The difference between `mergeSchemas` and `mergeObjects` is that\r\n * `mergeSchemas` only concats arrays for values under the 'required' keyword, and when it does, it doesn't include\r\n * duplicate values.\r\n *\r\n * @param obj1 - The first schema object to merge\r\n * @param obj2 - The second schema object to merge\r\n * @returns - The merged schema object\r\n */\nfunction mergeSchemas(obj1, obj2) {\n var acc = Object.assign({}, obj1); // Prevent mutation of source object.\n return Object.keys(obj2).reduce(function (acc, key) {\n var left = obj1 ? obj1[key] : {},\n right = obj2[key];\n if (obj1 && key in obj1 && isObject(right)) {\n acc[key] = mergeSchemas(left, right);\n } else if (obj1 && obj2 && (getSchemaType(obj1) === 'object' || getSchemaType(obj2) === 'object') && key === REQUIRED_KEY && Array.isArray(left) && Array.isArray(right)) {\n // Don't include duplicate values when merging 'required' fields.\n acc[key] = union(left, right);\n } else {\n acc[key] = right;\n }\n return acc;\n }, acc);\n}\n\nvar _excluded$1 = [\"if\", \"then\", \"else\"],\n _excluded2 = [\"$ref\"],\n _excluded3 = [\"allOf\"],\n _excluded4 = [\"dependencies\"],\n _excluded5 = [\"oneOf\"];\n/** Resolves a conditional block (if/else/then) by removing the condition and merging the appropriate conditional branch\r\n * with the rest of the schema\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that is used to detect valid schema conditions\r\n * @param schema - The schema for which resolving a condition is desired\r\n * @param rootSchema - The root schema that will be forwarded to all the APIs\r\n * @param [formData] - The current formData to assist retrieving a schema\r\n * @returns - A schema with the appropriate condition resolved\r\n */\nfunction resolveCondition(validator, schema, rootSchema, formData) {\n var expression = schema[\"if\"],\n then = schema.then,\n otherwise = schema[\"else\"],\n resolvedSchemaLessConditional = _objectWithoutPropertiesLoose(schema, _excluded$1);\n var conditionalSchema = validator.isValid(expression, formData, rootSchema) ? then : otherwise;\n if (conditionalSchema && typeof conditionalSchema !== 'boolean') {\n return retrieveSchema(validator, mergeSchemas(resolvedSchemaLessConditional, retrieveSchema(validator, conditionalSchema, rootSchema, formData)), rootSchema, formData);\n }\n return retrieveSchema(validator, resolvedSchemaLessConditional, rootSchema, formData);\n}\n/** Resolves references and dependencies within a schema and its 'allOf' children.\r\n * Called internally by retrieveSchema.\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be forwarded to all the APIs\r\n * @param schema - The schema for which resolving a schema is desired\r\n * @param [rootSchema={}] - The root schema that will be forwarded to all the APIs\r\n * @param [formData] - The current formData, if any, to assist retrieving a schema\r\n * @returns - The schema having its references and dependencies resolved\r\n */\nfunction resolveSchema(validator, schema, rootSchema, formData) {\n if (rootSchema === void 0) {\n rootSchema = {};\n }\n if (REF_KEY in schema) {\n return resolveReference(validator, schema, rootSchema, formData);\n }\n if (DEPENDENCIES_KEY in schema) {\n var resolvedSchema = resolveDependencies(validator, schema, rootSchema, formData);\n return retrieveSchema(validator, resolvedSchema, rootSchema, formData);\n }\n if (ALL_OF_KEY in schema) {\n return _extends({}, schema, {\n allOf: schema.allOf.map(function (allOfSubschema) {\n return retrieveSchema(validator, allOfSubschema, rootSchema, formData);\n })\n });\n }\n // No $ref or dependencies attribute found, returning the original schema.\n return schema;\n}\n/** Resolves references within a schema and its 'allOf' children.\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be forwarded to all the APIs\r\n * @param schema - The schema for which resolving a reference is desired\r\n * @param rootSchema - The root schema that will be forwarded to all the APIs\r\n * @param [formData] - The current formData, if any, to assist retrieving a schema\r\n * @returns - The schema having its references resolved\r\n */\nfunction resolveReference(validator, schema, rootSchema, formData) {\n // Retrieve the referenced schema definition.\n var $refSchema = findSchemaDefinition(schema.$ref, rootSchema);\n // Drop the $ref property of the source schema.\n var localSchema = _objectWithoutPropertiesLoose(schema, _excluded2);\n // Update referenced schema definition with local schema properties.\n return retrieveSchema(validator, _extends({}, $refSchema, localSchema), rootSchema, formData);\n}\n/** Creates new 'properties' items for each key in the `formData`\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param theSchema - The schema for which the existing additional properties is desired\r\n * @param [rootSchema] - The root schema, used to primarily to look up `$ref`s * @param validator\r\n * @param [aFormData] - The current formData, if any, to assist retrieving a schema\r\n * @returns - The updated schema with additional properties stubbed\r\n */\nfunction stubExistingAdditionalProperties(validator, theSchema, rootSchema, aFormData) {\n // Clone the schema so we don't ruin the consumer's original\n var schema = _extends({}, theSchema, {\n properties: _extends({}, theSchema.properties)\n });\n // make sure formData is an object\n var formData = aFormData && isObject(aFormData) ? aFormData : {};\n Object.keys(formData).forEach(function (key) {\n if (key in schema.properties) {\n // No need to stub, our schema already has the property\n return;\n }\n var additionalProperties = {};\n if (typeof schema.additionalProperties !== 'boolean') {\n if (REF_KEY in schema.additionalProperties) {\n additionalProperties = retrieveSchema(validator, {\n $ref: get(schema.additionalProperties, [REF_KEY])\n }, rootSchema, formData);\n } else if ('type' in schema.additionalProperties) {\n additionalProperties = _extends({}, schema.additionalProperties);\n } else if (ANY_OF_KEY in schema.additionalProperties || ONE_OF_KEY in schema.additionalProperties) {\n additionalProperties = _extends({\n type: 'object'\n }, schema.additionalProperties);\n } else {\n additionalProperties = {\n type: guessType(get(formData, [key]))\n };\n }\n } else {\n additionalProperties = {\n type: guessType(get(formData, [key]))\n };\n }\n // The type of our new key should match the additionalProperties value;\n schema.properties[key] = additionalProperties;\n // Set our additional property flag so we know it was dynamically added\n set(schema.properties, [key, ADDITIONAL_PROPERTY_FLAG], true);\n });\n return schema;\n}\n/** Retrieves an expanded schema that has had all of its conditions, additional properties, references and dependencies\r\n * resolved and merged into the `schema` given a `validator`, `rootSchema` and `rawFormData` that is used to do the\r\n * potentially recursive resolution.\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be forwarded to all the APIs\r\n * @param schema - The schema for which retrieving a schema is desired\r\n * @param [rootSchema={}] - The root schema that will be forwarded to all the APIs\r\n * @param [rawFormData] - The current formData, if any, to assist retrieving a schema\r\n * @returns - The schema having its conditions, additional properties, references and dependencies resolved\r\n */\nfunction retrieveSchema(validator, schema, rootSchema, rawFormData) {\n if (rootSchema === void 0) {\n rootSchema = {};\n }\n if (!isObject(schema)) {\n return {};\n }\n var resolvedSchema = resolveSchema(validator, schema, rootSchema, rawFormData);\n if ('if' in schema) {\n return resolveCondition(validator, schema, rootSchema, rawFormData);\n }\n var formData = rawFormData || {};\n if (ALL_OF_KEY in schema) {\n try {\n resolvedSchema = mergeAllOf(resolvedSchema, {\n deep: false\n });\n } catch (e) {\n console.warn('could not merge subschemas in allOf:\\n' + e);\n var _resolvedSchema = resolvedSchema,\n resolvedSchemaWithoutAllOf = _objectWithoutPropertiesLoose(_resolvedSchema, _excluded3);\n return resolvedSchemaWithoutAllOf;\n }\n }\n var hasAdditionalProperties = ADDITIONAL_PROPERTIES_KEY in resolvedSchema && resolvedSchema.additionalProperties !== false;\n if (hasAdditionalProperties) {\n return stubExistingAdditionalProperties(validator, resolvedSchema, rootSchema, formData);\n }\n return resolvedSchema;\n}\n/** Resolves dependencies within a schema and its 'allOf' children.\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be forwarded to all the APIs\r\n * @param schema - The schema for which resolving a dependency is desired\r\n * @param rootSchema - The root schema that will be forwarded to all the APIs\r\n * @param [formData] - The current formData, if any, to assist retrieving a schema\r\n * @returns - The schema with its dependencies resolved\r\n */\nfunction resolveDependencies(validator, schema, rootSchema, formData) {\n // Drop the dependencies from the source schema.\n var dependencies = schema.dependencies,\n remainingSchema = _objectWithoutPropertiesLoose(schema, _excluded4);\n var resolvedSchema = remainingSchema;\n if (Array.isArray(resolvedSchema.oneOf)) {\n resolvedSchema = resolvedSchema.oneOf[getFirstMatchingOption(validator, formData, resolvedSchema.oneOf, rootSchema)];\n } else if (Array.isArray(resolvedSchema.anyOf)) {\n resolvedSchema = resolvedSchema.anyOf[getFirstMatchingOption(validator, formData, resolvedSchema.anyOf, rootSchema)];\n }\n return processDependencies(validator, dependencies, resolvedSchema, rootSchema, formData);\n}\n/** Processes all the `dependencies` recursively into the `resolvedSchema` as needed\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be forwarded to all the APIs\r\n * @param dependencies - The set of dependencies that needs to be processed\r\n * @param resolvedSchema - The schema for which processing dependencies is desired\r\n * @param rootSchema - The root schema that will be forwarded to all the APIs\r\n * @param [formData] - The current formData, if any, to assist retrieving a schema\r\n * @returns - The schema with the `dependencies` resolved into it\r\n */\nfunction processDependencies(validator, dependencies, resolvedSchema, rootSchema, formData) {\n var schema = resolvedSchema;\n // Process dependencies updating the local schema properties as appropriate.\n for (var dependencyKey in dependencies) {\n // Skip this dependency if its trigger property is not present.\n if (get(formData, [dependencyKey]) === undefined) {\n continue;\n }\n // Skip this dependency if it is not included in the schema (such as when dependencyKey is itself a hidden dependency.)\n if (schema.properties && !(dependencyKey in schema.properties)) {\n continue;\n }\n var _splitKeyElementFromO = splitKeyElementFromObject(dependencyKey, dependencies),\n remainingDependencies = _splitKeyElementFromO[0],\n dependencyValue = _splitKeyElementFromO[1];\n if (Array.isArray(dependencyValue)) {\n schema = withDependentProperties(schema, dependencyValue);\n } else if (isObject(dependencyValue)) {\n schema = withDependentSchema(validator, schema, rootSchema, dependencyKey, dependencyValue, formData);\n }\n return processDependencies(validator, remainingDependencies, schema, rootSchema, formData);\n }\n return schema;\n}\n/** Updates a schema with additionally required properties added\r\n *\r\n * @param schema - The schema for which resolving a dependent properties is desired\r\n * @param [additionallyRequired] - An optional array of additionally required names\r\n * @returns - The schema with the additional required values merged in\r\n */\nfunction withDependentProperties(schema, additionallyRequired) {\n if (!additionallyRequired) {\n return schema;\n }\n var required = Array.isArray(schema.required) ? Array.from(new Set([].concat(schema.required, additionallyRequired))) : additionallyRequired;\n return _extends({}, schema, {\n required: required\n });\n}\n/** Merges a dependent schema into the `schema` dealing with oneOfs and references\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be forwarded to all the APIs\r\n * @param schema - The schema for which resolving a dependent schema is desired\r\n * @param rootSchema - The root schema that will be forwarded to all the APIs\r\n * @param dependencyKey - The key name of the dependency\r\n * @param dependencyValue - The potentially dependent schema\r\n * @param formData- The current formData to assist retrieving a schema\r\n * @returns - The schema with the dependent schema resolved into it\r\n */\nfunction withDependentSchema(validator, schema, rootSchema, dependencyKey, dependencyValue, formData) {\n var _retrieveSchema = retrieveSchema(validator, dependencyValue, rootSchema, formData),\n oneOf = _retrieveSchema.oneOf,\n dependentSchema = _objectWithoutPropertiesLoose(_retrieveSchema, _excluded5);\n schema = mergeSchemas(schema, dependentSchema);\n // Since it does not contain oneOf, we return the original schema.\n if (oneOf === undefined) {\n return schema;\n }\n // Resolve $refs inside oneOf.\n var resolvedOneOf = oneOf.map(function (subschema) {\n if (typeof subschema === 'boolean' || !(REF_KEY in subschema)) {\n return subschema;\n }\n return resolveReference(validator, subschema, rootSchema, formData);\n });\n return withExactlyOneSubschema(validator, schema, rootSchema, dependencyKey, resolvedOneOf, formData);\n}\n/** Returns a `schema` with the best choice from the `oneOf` options merged into it\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used to validate oneOf options\r\n * @param schema - The schema for which resolving a oneOf subschema is desired\r\n * @param rootSchema - The root schema that will be forwarded to all the APIs\r\n * @param dependencyKey - The key name of the oneOf dependency\r\n * @param oneOf - The list of schemas representing the oneOf options\r\n * @param [formData] - The current formData to assist retrieving a schema\r\n * @returns The schema with the best choice of oneOf schemas merged into\r\n */\nfunction withExactlyOneSubschema(validator, schema, rootSchema, dependencyKey, oneOf, formData) {\n var validSubschemas = oneOf.filter(function (subschema) {\n if (typeof subschema === 'boolean' || !subschema || !subschema.properties) {\n return false;\n }\n var conditionPropertySchema = subschema.properties[dependencyKey];\n if (conditionPropertySchema) {\n var _properties;\n var conditionSchema = {\n type: 'object',\n properties: (_properties = {}, _properties[dependencyKey] = conditionPropertySchema, _properties)\n };\n var _validator$validateFo = validator.validateFormData(formData, conditionSchema),\n errors = _validator$validateFo.errors;\n return errors.length === 0;\n }\n return false;\n });\n if (validSubschemas.length !== 1) {\n console.warn(\"ignoring oneOf in dependencies because there isn't exactly one subschema that is valid\");\n return schema;\n }\n var subschema = validSubschemas[0];\n var _splitKeyElementFromO2 = splitKeyElementFromObject(dependencyKey, subschema.properties),\n dependentSubschema = _splitKeyElementFromO2[0];\n var dependentSchema = _extends({}, subschema, {\n properties: dependentSubschema\n });\n return mergeSchemas(schema, retrieveSchema(validator, dependentSchema, rootSchema, formData));\n}\n\n/** A junk option used to determine when the getFirstMatchingOption call really matches an option rather than returning\r\n * the first item\r\n */\nvar JUNK_OPTION = {\n type: 'object',\n properties: {\n __not_really_there__: {\n type: 'number'\n }\n }\n};\n/** Recursive function that calculates the score of a `formData` against the given `schema`. The computation is fairly\r\n * simple. Initially the total score is 0. When `schema.properties` object exists, then all the `key/value` pairs within\r\n * the object are processed as follows after obtaining the formValue from `formData` using the `key`:\r\n * - If the `value` contains a `$ref`, `calculateIndexScore()` is called recursively with the formValue and the new\r\n * schema that is the result of the ref in the schema being resolved and that sub-schema's resulting score is added to\r\n * the total.\r\n * - If the `value` contains a `oneOf` and there is a formValue, then score based on the index returned from calling\r\n * `getClosestMatchingOption()` of that oneOf.\r\n * - If the type of the `value` is 'object', `calculateIndexScore()` is called recursively with the formValue and the\r\n * `value` itself as the sub-schema, and the score is added to the total.\r\n * - If the type of the `value` matches the guessed-type of the `formValue`, the score is incremented by 1, UNLESS the\r\n * value has a `default` or `const`. In those case, if the `default` or `const` and the `formValue` match, the score\r\n * is incremented by another 1 otherwise it is decremented by 1.\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param rootSchema - The root JSON schema of the entire form\r\n * @param schema - The schema for which the score is being calculated\r\n * @param formData - The form data associated with the schema, used to calculate the score\r\n * @returns - The score a schema against the formData\r\n */\nfunction calculateIndexScore(validator, rootSchema, schema, formData) {\n if (formData === void 0) {\n formData = {};\n }\n var totalScore = 0;\n if (schema) {\n if (isObject$1(schema.properties)) {\n totalScore += reduce(schema.properties, function (score, value, key) {\n var formValue = get(formData, key);\n if (typeof value === 'boolean') {\n return score;\n }\n if (has(value, REF_KEY)) {\n var newSchema = retrieveSchema(validator, value, rootSchema, formValue);\n return score + calculateIndexScore(validator, rootSchema, newSchema, formValue || {});\n }\n if (has(value, ONE_OF_KEY) && formValue) {\n return score + getClosestMatchingOption(validator, rootSchema, formValue, get(value, ONE_OF_KEY));\n }\n if (value.type === 'object') {\n return score + calculateIndexScore(validator, rootSchema, value, formValue || {});\n }\n if (value.type === guessType(formValue)) {\n // If the types match, then we bump the score by one\n var newScore = score + 1;\n if (value[\"default\"]) {\n // If the schema contains a readonly default value score the value that matches the default higher and\n // any non-matching value lower\n newScore += formValue === value[\"default\"] ? 1 : -1;\n } else if (value[\"const\"]) {\n // If the schema contains a const value score the value that matches the default higher and\n // any non-matching value lower\n newScore += formValue === value[\"const\"] ? 1 : -1;\n }\n // TODO eventually, deal with enums/arrays\n return newScore;\n }\n return score;\n }, 0);\n } else if (isString(schema.type) && schema.type === guessType(formData)) {\n totalScore += 1;\n }\n }\n return totalScore;\n}\n/** Determines which of the given `options` provided most closely matches the `formData`. Using\r\n * `getFirstMatchingOption()` to match two schemas that differ only by the readOnly, default or const value of a field\r\n * based on the `formData` and returns 0 when there is no match. Rather than passing in all the `options` at once to\r\n * this utility, instead an array of valid option indexes is created by iterating over the list of options, call\r\n * `getFirstMatchingOptions` with a list of one junk option and one good option, seeing if the good option is considered\r\n * matched.\r\n *\r\n * Once the list of valid indexes is created, if there is only one valid index, just return it. Otherwise, if there are\r\n * no valid indexes, then fill the valid indexes array with the indexes of all the options. Next, the index of the\r\n * option with the highest score is determined by iterating over the list of valid options, calling\r\n * `calculateIndexScore()` on each, comparing it against the current best score, and returning the index of the one that\r\n * eventually has the best score.\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param rootSchema - The root JSON schema of the entire form\r\n * @param formData - The form data associated with the schema\r\n * @param options - The list of options that can be selected from\r\n * @param [selectedOption=-1] - The index of the currently selected option, defaulted to -1 if not specified\r\n * @returns - The index of the option that is the closest match to the `formData` or the `selectedOption` if no match\r\n */\nfunction getClosestMatchingOption(validator, rootSchema, formData, options, selectedOption) {\n if (selectedOption === void 0) {\n selectedOption = -1;\n }\n // Reduce the array of options down to a list of the indexes that are considered matching options\n var allValidIndexes = options.reduce(function (validList, option, index) {\n var testOptions = [JUNK_OPTION, option];\n var match = getFirstMatchingOption(validator, formData, testOptions, rootSchema);\n // The match is the real option, so add its index to list of valid indexes\n if (match === 1) {\n validList.push(index);\n }\n return validList;\n }, []);\n // There is only one valid index, so return it!\n if (allValidIndexes.length === 1) {\n return allValidIndexes[0];\n }\n if (!allValidIndexes.length) {\n // No indexes were valid, so we'll score all the options, add all the indexes\n times(options.length, function (i) {\n return allValidIndexes.push(i);\n });\n }\n // Score all the options in the list of valid indexes and return the index with the best score\n var _allValidIndexes$redu = allValidIndexes.reduce(function (scoreData, index) {\n var bestScore = scoreData.bestScore;\n var option = options[index];\n if (has(option, REF_KEY)) {\n option = retrieveSchema(validator, option, rootSchema, formData);\n }\n var score = calculateIndexScore(validator, rootSchema, option, formData);\n if (score > bestScore) {\n return {\n bestIndex: index,\n bestScore: score\n };\n }\n return scoreData;\n }, {\n bestIndex: selectedOption,\n bestScore: 0\n }),\n bestIndex = _allValidIndexes$redu.bestIndex;\n return bestIndex;\n}\n\n/** Detects whether the given `schema` contains fixed items. This is the case when `schema.items` is a non-empty array\r\n * that only contains objects.\r\n *\r\n * @param schema - The schema in which to check for fixed items\r\n * @returns - True if there are fixed items in the schema, false otherwise\r\n */\nfunction isFixedItems(schema) {\n return Array.isArray(schema.items) && schema.items.length > 0 && schema.items.every(function (item) {\n return isObject(item);\n });\n}\n\n/** Merges the `defaults` object of type `T` into the `formData` of type `T`\r\n *\r\n * When merging defaults and form data, we want to merge in this specific way:\r\n * - objects are deeply merged\r\n * - arrays are merged in such a way that:\r\n * - when the array is set in form data, only array entries set in form data\r\n * are deeply merged; additional entries from the defaults are ignored\r\n * - when the array is not set in form data, the default is copied over\r\n * - scalars are overwritten/set by form data\r\n *\r\n * @param [defaults] - The defaults to merge\r\n * @param [formData] - The form data into which the defaults will be merged\r\n * @returns - The resulting merged form data with defaults\r\n */\nfunction mergeDefaultsWithFormData(defaults, formData) {\n if (Array.isArray(formData)) {\n var defaultsArray = Array.isArray(defaults) ? defaults : [];\n var mapped = formData.map(function (value, idx) {\n if (defaultsArray[idx]) {\n return mergeDefaultsWithFormData(defaultsArray[idx], value);\n }\n return value;\n });\n return mapped;\n }\n if (isObject(formData)) {\n var acc = Object.assign({}, defaults); // Prevent mutation of source object.\n return Object.keys(formData).reduce(function (acc, key) {\n acc[key] = mergeDefaultsWithFormData(defaults ? get(defaults, key) : {}, get(formData, key));\n return acc;\n }, acc);\n }\n return formData;\n}\n\n/** Recursively merge deeply nested objects.\r\n *\r\n * @param obj1 - The first object to merge\r\n * @param obj2 - The second object to merge\r\n * @param [concatArrays=false] - Optional flag that, when true, will cause arrays to be concatenated. Use\r\n * \"preventDuplicates\" to merge arrays in a manner that prevents any duplicate entries from being merged.\r\n * NOTE: Uses shallow comparison for the duplicate checking.\r\n * @returns - A new object that is the merge of the two given objects\r\n */\nfunction mergeObjects(obj1, obj2, concatArrays) {\n if (concatArrays === void 0) {\n concatArrays = false;\n }\n return Object.keys(obj2).reduce(function (acc, key) {\n var left = obj1 ? obj1[key] : {},\n right = obj2[key];\n if (obj1 && key in obj1 && isObject(right)) {\n acc[key] = mergeObjects(left, right, concatArrays);\n } else if (concatArrays && Array.isArray(left) && Array.isArray(right)) {\n var toMerge = right;\n if (concatArrays === 'preventDuplicates') {\n toMerge = right.reduce(function (result, value) {\n if (!left.includes(value)) {\n result.push(value);\n }\n return result;\n }, []);\n }\n acc[key] = left.concat(toMerge);\n } else {\n acc[key] = right;\n }\n return acc;\n }, Object.assign({}, obj1)); // Prevent mutation of source object.\n}\n\n/** This function checks if the given `schema` matches a single constant value. This happens when either the schema has\r\n * an `enum` array with a single value or there is a `const` defined.\r\n *\r\n * @param schema - The schema for a field\r\n * @returns - True if the `schema` has a single constant value, false otherwise\r\n */\nfunction isConstant(schema) {\n return Array.isArray(schema[\"enum\"]) && schema[\"enum\"].length === 1 || CONST_KEY in schema;\n}\n\n/** Checks to see if the `schema` combination represents a select\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param theSchema - The schema for which check for a select flag is desired\r\n * @param [rootSchema] - The root schema, used to primarily to look up `$ref`s\r\n * @returns - True if schema contains a select, otherwise false\r\n */\nfunction isSelect(validator, theSchema, rootSchema) {\n if (rootSchema === void 0) {\n rootSchema = {};\n }\n var schema = retrieveSchema(validator, theSchema, rootSchema, undefined);\n var altSchemas = schema.oneOf || schema.anyOf;\n if (Array.isArray(schema[\"enum\"])) {\n return true;\n }\n if (Array.isArray(altSchemas)) {\n return altSchemas.every(function (altSchemas) {\n return typeof altSchemas !== 'boolean' && isConstant(altSchemas);\n });\n }\n return false;\n}\n\n/** Checks to see if the `schema` combination represents a multi-select\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param schema - The schema for which check for a multi-select flag is desired\r\n * @param [rootSchema] - The root schema, used to primarily to look up `$ref`s\r\n * @returns - True if schema contains a multi-select, otherwise false\r\n */\nfunction isMultiSelect(validator, schema, rootSchema) {\n if (!schema.uniqueItems || !schema.items || typeof schema.items === 'boolean') {\n return false;\n }\n return isSelect(validator, schema.items, rootSchema);\n}\n\n/** Enum that indicates how `schema.additionalItems` should be handled by the `getInnerSchemaForArrayItem()` function.\r\n */\nvar AdditionalItemsHandling;\n(function (AdditionalItemsHandling) {\n AdditionalItemsHandling[AdditionalItemsHandling[\"Ignore\"] = 0] = \"Ignore\";\n AdditionalItemsHandling[AdditionalItemsHandling[\"Invert\"] = 1] = \"Invert\";\n AdditionalItemsHandling[AdditionalItemsHandling[\"Fallback\"] = 2] = \"Fallback\";\n})(AdditionalItemsHandling || (AdditionalItemsHandling = {}));\n/** Given a `schema` will return an inner schema that for an array item. This is computed differently based on the\r\n * `additionalItems` enum and the value of `idx`. There are four possible returns:\r\n * 1. If `idx` is >= 0, then if `schema.items` is an array the `idx`th element of the array is returned if it is a valid\r\n * index and not a boolean, otherwise it falls through to 3.\r\n * 2. If `schema.items` is not an array AND truthy and not a boolean, then `schema.items` is returned since it actually\r\n * is a schema, otherwise it falls through to 3.\r\n * 3. If `additionalItems` is not `AdditionalItemsHandling.Ignore` and `schema.additionalItems` is an object, then\r\n * `schema.additionalItems` is returned since it actually is a schema, otherwise it falls through to 4.\r\n * 4. {} is returned representing an empty schema\r\n *\r\n * @param schema - The schema from which to get the particular item\r\n * @param [additionalItems=AdditionalItemsHandling.Ignore] - How do we want to handle additional items?\r\n * @param [idx=-1] - Index, if non-negative, will be used to return the idx-th element in a `schema.items` array\r\n * @returns - The best fit schema object from the `schema` given the `additionalItems` and `idx` modifiers\r\n */\nfunction getInnerSchemaForArrayItem(schema, additionalItems, idx) {\n if (additionalItems === void 0) {\n additionalItems = AdditionalItemsHandling.Ignore;\n }\n if (idx === void 0) {\n idx = -1;\n }\n if (idx >= 0) {\n if (Array.isArray(schema.items) && idx < schema.items.length) {\n var item = schema.items[idx];\n if (typeof item !== 'boolean') {\n return item;\n }\n }\n } else if (schema.items && !Array.isArray(schema.items) && typeof schema.items !== 'boolean') {\n return schema.items;\n }\n if (additionalItems !== AdditionalItemsHandling.Ignore && isObject(schema.additionalItems)) {\n return schema.additionalItems;\n }\n return {};\n}\n/** Either add `computedDefault` at `key` into `obj` or not add it based on its value and the value of\r\n * `includeUndefinedValues`. Generally undefined `computedDefault` values are added only when `includeUndefinedValues`\r\n * is either true or \"excludeObjectChildren\". If `includeUndefinedValues` is false, then non-undefined and\r\n * non-empty-object values will be added.\r\n *\r\n * @param obj - The object into which the computed default may be added\r\n * @param key - The key into the object at which the computed default may be added\r\n * @param computedDefault - The computed default value that maybe should be added to the obj\r\n * @param includeUndefinedValues - Optional flag, if true, cause undefined values to be added as defaults.\r\n * If \"excludeObjectChildren\", cause undefined values for this object and pass `includeUndefinedValues` as\r\n * false when computing defaults for any nested object properties. If \"allowEmptyObject\", prevents undefined\r\n * values in this object while allow the object itself to be empty and passing `includeUndefinedValues` as\r\n * false when computing defaults for any nested object properties.\r\n * @param requiredFields - The list of fields that are required\r\n */\nfunction maybeAddDefaultToObject(obj, key, computedDefault, includeUndefinedValues, requiredFields) {\n if (requiredFields === void 0) {\n requiredFields = [];\n }\n if (includeUndefinedValues) {\n obj[key] = computedDefault;\n } else if (isObject(computedDefault)) {\n // Store computedDefault if it's a non-empty object (e.g. not {})\n if (!isEmpty(computedDefault) || requiredFields.includes(key)) {\n obj[key] = computedDefault;\n }\n } else if (computedDefault !== undefined) {\n // Store computedDefault if it's a defined primitive (e.g. true)\n obj[key] = computedDefault;\n }\n}\n/** Computes the defaults for the current `schema` given the `rawFormData` and `parentDefaults` if any. This drills into\r\n * each level of the schema, recursively, to fill out every level of defaults provided by the schema.\r\n *\r\n * @param validator - an implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param rawSchema - The schema for which the default state is desired\r\n * @param [parentDefaults] - Any defaults provided by the parent field in the schema\r\n * @param [rootSchema] - The options root schema, used to primarily to look up `$ref`s\r\n * @param [rawFormData] - The current formData, if any, onto which to provide any missing defaults\r\n * @param [includeUndefinedValues=false] - Optional flag, if true, cause undefined values to be added as defaults.\r\n * If \"excludeObjectChildren\", cause undefined values for this object and pass `includeUndefinedValues` as\r\n * false when computing defaults for any nested object properties.\r\n * @returns - The resulting `formData` with all the defaults provided\r\n */\nfunction computeDefaults(validator, rawSchema, parentDefaults, rootSchema, rawFormData, includeUndefinedValues) {\n if (rootSchema === void 0) {\n rootSchema = {};\n }\n if (includeUndefinedValues === void 0) {\n includeUndefinedValues = false;\n }\n var formData = isObject(rawFormData) ? rawFormData : {};\n var schema = isObject(rawSchema) ? rawSchema : {};\n // Compute the defaults recursively: give highest priority to deepest nodes.\n var defaults = parentDefaults;\n if (isObject(defaults) && isObject(schema[\"default\"])) {\n // For object defaults, only override parent defaults that are defined in\n // schema.default.\n defaults = mergeObjects(defaults, schema[\"default\"]);\n } else if (DEFAULT_KEY in schema) {\n defaults = schema[\"default\"];\n } else if (REF_KEY in schema) {\n // Use referenced schema defaults for this node.\n var refSchema = findSchemaDefinition(schema[REF_KEY], rootSchema);\n return computeDefaults(validator, refSchema, defaults, rootSchema, formData, includeUndefinedValues);\n } else if (DEPENDENCIES_KEY in schema) {\n var resolvedSchema = resolveDependencies(validator, schema, rootSchema, formData);\n return computeDefaults(validator, resolvedSchema, defaults, rootSchema, formData, includeUndefinedValues);\n } else if (isFixedItems(schema)) {\n defaults = schema.items.map(function (itemSchema, idx) {\n return computeDefaults(validator, itemSchema, Array.isArray(parentDefaults) ? parentDefaults[idx] : undefined, rootSchema, formData, includeUndefinedValues);\n });\n } else if (ONE_OF_KEY in schema) {\n if (schema.oneOf.length === 0) {\n return undefined;\n }\n schema = schema.oneOf[getClosestMatchingOption(validator, rootSchema, isEmpty(formData) ? undefined : formData, schema.oneOf, 0)];\n } else if (ANY_OF_KEY in schema) {\n if (schema.anyOf.length === 0) {\n return undefined;\n }\n schema = schema.anyOf[getClosestMatchingOption(validator, rootSchema, isEmpty(formData) ? undefined : formData, schema.anyOf, 0)];\n }\n // Not defaults defined for this node, fallback to generic typed ones.\n if (typeof defaults === 'undefined') {\n defaults = schema[\"default\"];\n }\n switch (getSchemaType(schema)) {\n // We need to recur for object schema inner default values.\n case 'object':\n {\n var objectDefaults = Object.keys(schema.properties || {}).reduce(function (acc, key) {\n // Compute the defaults for this node, with the parent defaults we might\n // have from a previous run: defaults[key].\n var computedDefault = computeDefaults(validator, get(schema, [PROPERTIES_KEY, key]), get(defaults, [key]), rootSchema, get(formData, [key]), includeUndefinedValues === true);\n maybeAddDefaultToObject(acc, key, computedDefault, includeUndefinedValues, schema.required);\n return acc;\n }, {});\n if (schema.additionalProperties && isObject(defaults)) {\n var additionalPropertiesSchema = isObject(schema.additionalProperties) ? schema.additionalProperties : {}; // as per spec additionalProperties may be either schema or boolean\n Object.keys(defaults).filter(function (key) {\n return !schema.properties || !schema.properties[key];\n }).forEach(function (key) {\n var computedDefault = computeDefaults(validator, additionalPropertiesSchema, get(defaults, [key]), rootSchema, get(formData, [key]), includeUndefinedValues === true);\n maybeAddDefaultToObject(objectDefaults, key, computedDefault, includeUndefinedValues);\n });\n }\n return objectDefaults;\n }\n case 'array':\n // Inject defaults into existing array defaults\n if (Array.isArray(defaults)) {\n defaults = defaults.map(function (item, idx) {\n var schemaItem = getInnerSchemaForArrayItem(schema, AdditionalItemsHandling.Fallback, idx);\n return computeDefaults(validator, schemaItem, item, rootSchema);\n });\n }\n // Deeply inject defaults into already existing form data\n if (Array.isArray(rawFormData)) {\n var schemaItem = getInnerSchemaForArrayItem(schema);\n defaults = rawFormData.map(function (item, idx) {\n return computeDefaults(validator, schemaItem, get(defaults, [idx]), rootSchema, item);\n });\n }\n if (schema.minItems) {\n if (!isMultiSelect(validator, schema, rootSchema)) {\n var defaultsLength = Array.isArray(defaults) ? defaults.length : 0;\n if (schema.minItems > defaultsLength) {\n var defaultEntries = defaults || [];\n // populate the array with the defaults\n var fillerSchema = getInnerSchemaForArrayItem(schema, AdditionalItemsHandling.Invert);\n var fillerDefault = fillerSchema[\"default\"];\n var fillerEntries = new Array(schema.minItems - defaultsLength).fill(computeDefaults(validator, fillerSchema, fillerDefault, rootSchema));\n // then fill up the rest with either the item default or empty, up to minItems\n return defaultEntries.concat(fillerEntries);\n }\n }\n return defaults ? defaults : [];\n }\n }\n return defaults;\n}\n/** Returns the superset of `formData` that includes the given set updated to include any missing fields that have\r\n * computed to have defaults provided in the `schema`.\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param theSchema - The schema for which the default state is desired\r\n * @param [formData] - The current formData, if any, onto which to provide any missing defaults\r\n * @param [rootSchema] - The root schema, used to primarily to look up `$ref`s\r\n * @param [includeUndefinedValues=false] - Optional flag, if true, cause undefined values to be added as defaults.\r\n * If \"excludeObjectChildren\", cause undefined values for this object and pass `includeUndefinedValues` as\r\n * false when computing defaults for any nested object properties.\r\n * @returns - The resulting `formData` with all the defaults provided\r\n */\nfunction getDefaultFormState(validator, theSchema, formData, rootSchema, includeUndefinedValues) {\n if (includeUndefinedValues === void 0) {\n includeUndefinedValues = false;\n }\n if (!isObject(theSchema)) {\n throw new Error('Invalid schema: ' + theSchema);\n }\n var schema = retrieveSchema(validator, theSchema, rootSchema, formData);\n var defaults = computeDefaults(validator, schema, undefined, rootSchema, formData, includeUndefinedValues);\n if (typeof formData === 'undefined' || formData === null || typeof formData === 'number' && isNaN(formData)) {\n // No form data? Use schema defaults.\n return defaults;\n }\n if (isObject(formData)) {\n return mergeDefaultsWithFormData(defaults, formData);\n }\n if (Array.isArray(formData)) {\n return mergeDefaultsWithFormData(defaults, formData);\n }\n return formData;\n}\n\n/** Checks to see if the `uiSchema` contains the `widget` field and that the widget is not `hidden`\r\n *\r\n * @param uiSchema - The UI Schema from which to detect if it is customized\r\n * @returns - True if the `uiSchema` describes a custom widget, false otherwise\r\n */\nfunction isCustomWidget(uiSchema) {\n if (uiSchema === void 0) {\n uiSchema = {};\n }\n return (\n // TODO: Remove the `&& uiSchema['ui:widget'] !== 'hidden'` once we support hidden widgets for arrays.\n // https://rjsf-team.github.io/react-jsonschema-form/docs/usage/widgets/#hidden-widgets\n 'widget' in getUiOptions(uiSchema) && getUiOptions(uiSchema)['widget'] !== 'hidden'\n );\n}\n\n/** Checks to see if the `schema` and `uiSchema` combination represents an array of files\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param schema - The schema for which check for array of files flag is desired\r\n * @param [uiSchema={}] - The UI schema from which to check the widget\r\n * @param [rootSchema] - The root schema, used to primarily to look up `$ref`s\r\n * @returns - True if schema/uiSchema contains an array of files, otherwise false\r\n */\nfunction isFilesArray(validator, schema, uiSchema, rootSchema) {\n if (uiSchema === void 0) {\n uiSchema = {};\n }\n if (uiSchema[UI_WIDGET_KEY] === 'files') {\n return true;\n }\n if (schema.items) {\n var itemsSchema = retrieveSchema(validator, schema.items, rootSchema);\n return itemsSchema.type === 'string' && itemsSchema.format === 'data-url';\n }\n return false;\n}\n\n/** Determines whether the combination of `schema` and `uiSchema` properties indicates that the label for the `schema`\r\n * should be displayed in a UI.\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param schema - The schema for which the display label flag is desired\r\n * @param [uiSchema={}] - The UI schema from which to derive potentially displayable information\r\n * @param [rootSchema] - The root schema, used to primarily to look up `$ref`s\r\n * @param [globalOptions={}] - The optional Global UI Schema from which to get any fallback `xxx` options\r\n * @returns - True if the label should be displayed or false if it should not\r\n */\nfunction getDisplayLabel(validator, schema, uiSchema, rootSchema, globalOptions) {\n if (uiSchema === void 0) {\n uiSchema = {};\n }\n var uiOptions = getUiOptions(uiSchema, globalOptions);\n var _uiOptions$label = uiOptions.label,\n label = _uiOptions$label === void 0 ? true : _uiOptions$label;\n var displayLabel = !!label;\n var schemaType = getSchemaType(schema);\n if (schemaType === 'array') {\n displayLabel = isMultiSelect(validator, schema, rootSchema) || isFilesArray(validator, schema, uiSchema, rootSchema) || isCustomWidget(uiSchema);\n }\n if (schemaType === 'object') {\n displayLabel = false;\n }\n if (schemaType === 'boolean' && !uiSchema[UI_WIDGET_KEY]) {\n displayLabel = false;\n }\n if (uiSchema[UI_FIELD_KEY]) {\n displayLabel = false;\n }\n return displayLabel;\n}\n\n/** Merges the errors in `additionalErrorSchema` into the existing `validationData` by combining the hierarchies in the\r\n * two `ErrorSchema`s and then appending the error list from the `additionalErrorSchema` obtained by calling\r\n * `validator.toErrorList()` onto the `errors` in the `validationData`. If no `additionalErrorSchema` is passed, then\r\n * `validationData` is returned.\r\n *\r\n * @param validator - The validator used to convert an ErrorSchema to a list of errors\r\n * @param validationData - The current `ValidationData` into which to merge the additional errors\r\n * @param [additionalErrorSchema] - The additional set of errors in an `ErrorSchema`\r\n * @returns - The `validationData` with the additional errors from `additionalErrorSchema` merged into it, if provided.\r\n */\nfunction mergeValidationData(validator, validationData, additionalErrorSchema) {\n if (!additionalErrorSchema) {\n return validationData;\n }\n var oldErrors = validationData.errors,\n oldErrorSchema = validationData.errorSchema;\n var errors = validator.toErrorList(additionalErrorSchema);\n var errorSchema = additionalErrorSchema;\n if (!isEmpty(oldErrorSchema)) {\n errorSchema = mergeObjects(oldErrorSchema, additionalErrorSchema, true);\n errors = [].concat(oldErrors).concat(errors);\n }\n return {\n errorSchema: errorSchema,\n errors: errors\n };\n}\n\nvar NO_VALUE = /*#__PURE__*/Symbol('no Value');\n/** Sanitize the `data` associated with the `oldSchema` so it is considered appropriate for the `newSchema`. If the new\r\n * schema does not contain any properties, then `undefined` is returned to clear all the form data. Due to the nature\r\n * of schemas, this sanitization happens recursively for nested objects of data. Also, any properties in the old schema\r\n * that are non-existent in the new schema are set to `undefined`. The data sanitization process has the following flow:\r\n *\r\n * - If the new schema is an object that contains a `properties` object then:\r\n * - Create a `removeOldSchemaData` object, setting each key in the `oldSchema.properties` having `data` to undefined\r\n * - Create an empty `nestedData` object for use in the key filtering below:\r\n * - Iterate over each key in the `newSchema.properties` as follows:\r\n * - Get the `formValue` of the key from the `data`\r\n * - Get the `oldKeySchema` and `newKeyedSchema` for the key, defaulting to `{}` when it doesn't exist\r\n * - Retrieve the schema for any refs within each `oldKeySchema` and/or `newKeySchema`\r\n * - Get the types of the old and new keyed schemas and if the old doesn't exist or the old & new are the same then:\r\n * - If `removeOldSchemaData` has an entry for the key, delete it since the new schema has the same property\r\n * - If type of the key in the new schema is `object`:\r\n * - Store the value from the recursive `sanitizeDataForNewSchema` call in `nestedData[key]`\r\n * - Otherwise, check for default or const values:\r\n * - Get the old and new `default` values from the schema and check:\r\n * - If the new `default` value does not match the form value:\r\n * - If the old `default` value DOES match the form value, then:\r\n * - Replace `removeOldSchemaData[key]` with the new `default`\r\n * - Otherwise, if the new schema is `readOnly` then replace `removeOldSchemaData[key]` with undefined\r\n * - Get the old and new `const` values from the schema and check:\r\n * - If the new `const` value does not match the form value:\r\n * - If the old `const` value DOES match the form value, then:\r\n * - Replace `removeOldSchemaData[key]` with the new `const`\r\n * - Otherwise, replace `removeOldSchemaData[key]` with undefined\r\n * - Once all keys have been processed, return an object built as follows:\r\n * - `{ ...removeOldSchemaData, ...nestedData, ...pick(data, keysToKeep) }`\r\n * - If the new and old schema types are array and the `data` is an array then:\r\n * - If the type of the old and new schema `items` are a non-array objects:\r\n * - Retrieve the schema for any refs within each `oldKeySchema.items` and/or `newKeySchema.items`\r\n * - If the `type`s of both items are the same (or the old does not have a type):\r\n * - If the type is \"object\", then:\r\n * - For each element in the `data` recursively sanitize the data, stopping at `maxItems` if specified\r\n * - Otherwise, just return the `data` removing any values after `maxItems` if it is set\r\n * - If the type of the old and new schema `items` are booleans of the same value, return `data` as is\r\n * - Otherwise return `undefined`\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param rootSchema - The root JSON schema of the entire form\r\n * @param [newSchema] - The new schema for which the data is being sanitized\r\n * @param [oldSchema] - The old schema from which the data originated\r\n * @param [data={}] - The form data associated with the schema, defaulting to an empty object when undefined\r\n * @returns - The new form data, with all the fields uniquely associated with the old schema set\r\n * to `undefined`. Will return `undefined` if the new schema is not an object containing properties.\r\n */\nfunction sanitizeDataForNewSchema(validator, rootSchema, newSchema, oldSchema, data) {\n if (data === void 0) {\n data = {};\n }\n // By default, we will clear the form data\n var newFormData;\n // If the new schema is of type object and that object contains a list of properties\n if (has(newSchema, PROPERTIES_KEY)) {\n // Create an object containing root-level keys in the old schema, setting each key to undefined to remove the data\n var removeOldSchemaData = {};\n if (has(oldSchema, PROPERTIES_KEY)) {\n var properties = get(oldSchema, PROPERTIES_KEY, {});\n Object.keys(properties).forEach(function (key) {\n if (has(data, key)) {\n removeOldSchemaData[key] = undefined;\n }\n });\n }\n var keys = Object.keys(get(newSchema, PROPERTIES_KEY, {}));\n // Create a place to store nested data that will be a side-effect of the filter\n var nestedData = {};\n keys.forEach(function (key) {\n var formValue = get(data, key);\n var oldKeyedSchema = get(oldSchema, [PROPERTIES_KEY, key], {});\n var newKeyedSchema = get(newSchema, [PROPERTIES_KEY, key], {});\n // Resolve the refs if they exist\n if (has(oldKeyedSchema, REF_KEY)) {\n oldKeyedSchema = retrieveSchema(validator, oldKeyedSchema, rootSchema, formValue);\n }\n if (has(newKeyedSchema, REF_KEY)) {\n newKeyedSchema = retrieveSchema(validator, newKeyedSchema, rootSchema, formValue);\n }\n // Now get types and see if they are the same\n var oldSchemaTypeForKey = get(oldKeyedSchema, 'type');\n var newSchemaTypeForKey = get(newKeyedSchema, 'type');\n // Check if the old option has the same key with the same type\n if (!oldSchemaTypeForKey || oldSchemaTypeForKey === newSchemaTypeForKey) {\n if (has(removeOldSchemaData, key)) {\n // SIDE-EFFECT: remove the undefined value for a key that has the same type between the old and new schemas\n delete removeOldSchemaData[key];\n }\n // If it is an object, we'll recurse and store the resulting sanitized data for the key\n if (newSchemaTypeForKey === 'object' || newSchemaTypeForKey === 'array' && Array.isArray(formValue)) {\n // SIDE-EFFECT: process the new schema type of object recursively to save iterations\n var itemData = sanitizeDataForNewSchema(validator, rootSchema, newKeyedSchema, oldKeyedSchema, formValue);\n if (itemData !== undefined || newSchemaTypeForKey === 'array') {\n // only put undefined values for the array type and not the object type\n nestedData[key] = itemData;\n }\n } else {\n // Ok, the non-object types match, let's make sure that a default or a const of a different value is replaced\n // with the new default or const. This allows the case where two schemas differ that only by the default/const\n // value to be properly selected\n var newOptionDefault = get(newKeyedSchema, 'default', NO_VALUE);\n var oldOptionDefault = get(oldKeyedSchema, 'default', NO_VALUE);\n if (newOptionDefault !== NO_VALUE && newOptionDefault !== formValue) {\n if (oldOptionDefault === formValue) {\n // If the old default matches the formValue, we'll update the new value to match the new default\n removeOldSchemaData[key] = newOptionDefault;\n } else if (get(newKeyedSchema, 'readOnly') === true) {\n // If the new schema has the default set to read-only, treat it like a const and remove the value\n removeOldSchemaData[key] = undefined;\n }\n }\n var newOptionConst = get(newKeyedSchema, 'const', NO_VALUE);\n var oldOptionConst = get(oldKeyedSchema, 'const', NO_VALUE);\n if (newOptionConst !== NO_VALUE && newOptionConst !== formValue) {\n // Since this is a const, if the old value matches, replace the value with the new const otherwise clear it\n removeOldSchemaData[key] = oldOptionConst === formValue ? newOptionConst : undefined;\n }\n }\n }\n });\n newFormData = _extends({}, data, removeOldSchemaData, nestedData);\n // First apply removing the old schema data, then apply the nested data, then apply the old data keys to keep\n } else if (get(oldSchema, 'type') === 'array' && get(newSchema, 'type') === 'array' && Array.isArray(data)) {\n var oldSchemaItems = get(oldSchema, 'items');\n var newSchemaItems = get(newSchema, 'items');\n // If any of the array types `items` are arrays (remember arrays are objects) then we'll just drop the data\n // Eventually, we may want to deal with when either of the `items` are arrays since those tuple validations\n if (typeof oldSchemaItems === 'object' && typeof newSchemaItems === 'object' && !Array.isArray(oldSchemaItems) && !Array.isArray(newSchemaItems)) {\n if (has(oldSchemaItems, REF_KEY)) {\n oldSchemaItems = retrieveSchema(validator, oldSchemaItems, rootSchema, data);\n }\n if (has(newSchemaItems, REF_KEY)) {\n newSchemaItems = retrieveSchema(validator, newSchemaItems, rootSchema, data);\n }\n // Now get types and see if they are the same\n var oldSchemaType = get(oldSchemaItems, 'type');\n var newSchemaType = get(newSchemaItems, 'type');\n // Check if the old option has the same key with the same type\n if (!oldSchemaType || oldSchemaType === newSchemaType) {\n var maxItems = get(newSchema, 'maxItems', -1);\n if (newSchemaType === 'object') {\n newFormData = data.reduce(function (newValue, aValue) {\n var itemValue = sanitizeDataForNewSchema(validator, rootSchema, newSchemaItems, oldSchemaItems, aValue);\n if (itemValue !== undefined && (maxItems < 0 || newValue.length < maxItems)) {\n newValue.push(itemValue);\n }\n return newValue;\n }, []);\n } else {\n newFormData = maxItems > 0 && data.length > maxItems ? data.slice(0, maxItems) : data;\n }\n }\n } else if (typeof oldSchemaItems === 'boolean' && typeof newSchemaItems === 'boolean' && oldSchemaItems === newSchemaItems) {\n // If they are both booleans and have the same value just return the data as is otherwise fall-thru to undefined\n newFormData = data;\n }\n // Also probably want to deal with `prefixItems` as tuples with the latest 2020 draft\n }\n\n return newFormData;\n}\n\n/** Generates an `IdSchema` object for the `schema`, recursively\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param schema - The schema for which the `IdSchema` is desired\r\n * @param [id] - The base id for the schema\r\n * @param [rootSchema] - The root schema, used to primarily to look up `$ref`s\r\n * @param [formData] - The current formData, if any, to assist retrieving a schema\r\n * @param [idPrefix='root'] - The prefix to use for the id\r\n * @param [idSeparator='_'] - The separator to use for the path segments in the id\r\n * @returns - The `IdSchema` object for the `schema`\r\n */\nfunction toIdSchema(validator, schema, id, rootSchema, formData, idPrefix, idSeparator) {\n if (idPrefix === void 0) {\n idPrefix = 'root';\n }\n if (idSeparator === void 0) {\n idSeparator = '_';\n }\n if (REF_KEY in schema || DEPENDENCIES_KEY in schema || ALL_OF_KEY in schema) {\n var _schema = retrieveSchema(validator, schema, rootSchema, formData);\n return toIdSchema(validator, _schema, id, rootSchema, formData, idPrefix, idSeparator);\n }\n if (ITEMS_KEY in schema && !get(schema, [ITEMS_KEY, REF_KEY])) {\n return toIdSchema(validator, get(schema, ITEMS_KEY), id, rootSchema, formData, idPrefix, idSeparator);\n }\n var $id = id || idPrefix;\n var idSchema = {\n $id: $id\n };\n if (schema.type === 'object' && PROPERTIES_KEY in schema) {\n for (var name in schema.properties) {\n var field = get(schema, [PROPERTIES_KEY, name]);\n var fieldId = idSchema[ID_KEY] + idSeparator + name;\n idSchema[name] = toIdSchema(validator, isObject(field) ? field : {}, fieldId, rootSchema,\n // It's possible that formData is not an object -- this can happen if an\n // array item has just been added, but not populated with data yet\n get(formData, [name]), idPrefix, idSeparator);\n }\n }\n return idSchema;\n}\n\n/** Generates an `PathSchema` object for the `schema`, recursively\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be used when necessary\r\n * @param schema - The schema for which the `PathSchema` is desired\r\n * @param [name=''] - The base name for the schema\r\n * @param [rootSchema] - The root schema, used to primarily to look up `$ref`s\r\n * @param [formData] - The current formData, if any, to assist retrieving a schema\r\n * @returns - The `PathSchema` object for the `schema`\r\n */\nfunction toPathSchema(validator, schema, name, rootSchema, formData) {\n var _pathSchema;\n if (name === void 0) {\n name = '';\n }\n if (REF_KEY in schema || DEPENDENCIES_KEY in schema || ALL_OF_KEY in schema) {\n var _schema = retrieveSchema(validator, schema, rootSchema, formData);\n return toPathSchema(validator, _schema, name, rootSchema, formData);\n }\n var pathSchema = (_pathSchema = {}, _pathSchema[NAME_KEY] = name.replace(/^\\./, ''), _pathSchema);\n if (ONE_OF_KEY in schema) {\n var index = getClosestMatchingOption(validator, rootSchema, formData, schema.oneOf, 0);\n var _schema2 = schema.oneOf[index];\n return toPathSchema(validator, _schema2, name, rootSchema, formData);\n }\n if (ANY_OF_KEY in schema) {\n var _index = getClosestMatchingOption(validator, rootSchema, formData, schema.anyOf, 0);\n var _schema3 = schema.anyOf[_index];\n return toPathSchema(validator, _schema3, name, rootSchema, formData);\n }\n if (ADDITIONAL_PROPERTIES_KEY in schema && schema[ADDITIONAL_PROPERTIES_KEY] !== false) {\n set(pathSchema, RJSF_ADDITONAL_PROPERTIES_FLAG, true);\n }\n if (ITEMS_KEY in schema && Array.isArray(formData)) {\n formData.forEach(function (element, i) {\n pathSchema[i] = toPathSchema(validator, schema.items, name + \".\" + i, rootSchema, element);\n });\n } else if (PROPERTIES_KEY in schema) {\n for (var property in schema.properties) {\n var field = get(schema, [PROPERTIES_KEY, property]);\n pathSchema[property] = toPathSchema(validator, field, name + \".\" + property, rootSchema,\n // It's possible that formData is not an object -- this can happen if an\n // array item has just been added, but not populated with data yet\n get(formData, [property]));\n }\n }\n return pathSchema;\n}\n\n/** The `SchemaUtils` class provides a wrapper around the publicly exported APIs in the `utils/schema` directory such\r\n * that one does not have to explicitly pass the `validator` or `rootSchema` to each method. Since both the `validator`\r\n * and `rootSchema` generally does not change across a `Form`, this allows for providing a simplified set of APIs to the\r\n * `@rjsf/core` components and the various themes as well. This class implements the `SchemaUtilsType` interface.\r\n */\nvar SchemaUtils = /*#__PURE__*/function () {\n /** Constructs the `SchemaUtils` instance with the given `validator` and `rootSchema` stored as instance variables\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be forwarded to all the APIs\r\n * @param rootSchema - The root schema that will be forwarded to all the APIs\r\n */\n function SchemaUtils(validator, rootSchema) {\n this.rootSchema = void 0;\n this.validator = void 0;\n this.rootSchema = rootSchema;\n this.validator = validator;\n }\n /** Returns the `ValidatorType` in the `SchemaUtilsType`\r\n *\r\n * @returns - The `ValidatorType`\r\n */\n var _proto = SchemaUtils.prototype;\n _proto.getValidator = function getValidator() {\n return this.validator;\n }\n /** Determines whether either the `validator` and `rootSchema` differ from the ones associated with this instance of\r\n * the `SchemaUtilsType`. If either `validator` or `rootSchema` are falsy, then return false to prevent the creation\r\n * of a new `SchemaUtilsType` with incomplete properties.\r\n *\r\n * @param validator - An implementation of the `ValidatorType` interface that will be compared against the current one\r\n * @param rootSchema - The root schema that will be compared against the current one\r\n * @returns - True if the `SchemaUtilsType` differs from the given `validator` or `rootSchema`\r\n */;\n _proto.doesSchemaUtilsDiffer = function doesSchemaUtilsDiffer(validator, rootSchema) {\n if (!validator || !rootSchema) {\n return false;\n }\n return this.validator !== validator || !deepEquals(this.rootSchema, rootSchema);\n }\n /** Returns the superset of `formData` that includes the given set updated to include any missing fields that have\r\n * computed to have defaults provided in the `schema`.\r\n *\r\n * @param schema - The schema for which the default state is desired\r\n * @param [formData] - The current formData, if any, onto which to provide any missing defaults\r\n * @param [includeUndefinedValues=false] - Optional flag, if true, cause undefined values to be added as defaults.\r\n * If \"excludeObjectChildren\", pass `includeUndefinedValues` as false when computing defaults for any nested\r\n * object properties.\r\n * @returns - The resulting `formData` with all the defaults provided\r\n */;\n _proto.getDefaultFormState = function getDefaultFormState$1(schema, formData, includeUndefinedValues) {\n if (includeUndefinedValues === void 0) {\n includeUndefinedValues = false;\n }\n return getDefaultFormState(this.validator, schema, formData, this.rootSchema, includeUndefinedValues);\n }\n /** Determines whether the combination of `schema` and `uiSchema` properties indicates that the label for the `schema`\r\n * should be displayed in a UI.\r\n *\r\n * @param schema - The schema for which the display label flag is desired\r\n * @param [uiSchema] - The UI schema from which to derive potentially displayable information\r\n * @param [globalOptions={}] - The optional Global UI Schema from which to get any fallback `xxx` options\r\n * @returns - True if the label should be displayed or false if it should not\r\n */;\n _proto.getDisplayLabel = function getDisplayLabel$1(schema, uiSchema, globalOptions) {\n return getDisplayLabel(this.validator, schema, uiSchema, this.rootSchema, globalOptions);\n }\n /** Determines which of the given `options` provided most closely matches the `formData`.\r\n * Returns the index of the option that is valid and is the closest match, or 0 if there is no match.\r\n *\r\n * The closest match is determined using the number of matching properties, and more heavily favors options with\r\n * matching readOnly, default, or const values.\r\n *\r\n * @param formData - The form data associated with the schema\r\n * @param options - The list of options that can be selected from\r\n * @param [selectedOption] - The index of the currently selected option, defaulted to -1 if not specified\r\n * @returns - The index of the option that is the closest match to the `formData` or the `selectedOption` if no match\r\n */;\n _proto.getClosestMatchingOption = function getClosestMatchingOption$1(formData, options, selectedOption) {\n return getClosestMatchingOption(this.validator, this.rootSchema, formData, options, selectedOption);\n }\n /** Given the `formData` and list of `options`, attempts to find the index of the first option that matches the data.\r\n * Always returns the first option if there is nothing that matches.\r\n *\r\n * @param formData - The current formData, if any, used to figure out a match\r\n * @param options - The list of options to find a matching options from\r\n * @returns - The firstindex of the matched option or 0 if none is available\r\n */;\n _proto.getFirstMatchingOption = function getFirstMatchingOption$1(formData, options) {\n return getFirstMatchingOption(this.validator, formData, options, this.rootSchema);\n }\n /** Given the `formData` and list of `options`, attempts to find the index of the option that best matches the data.\r\n * Deprecated, use `getFirstMatchingOption()` instead.\r\n *\r\n * @param formData - The current formData, if any, onto which to provide any missing defaults\r\n * @param options - The list of options to find a matching options from\r\n * @returns - The index of the matched option or 0 if none is available\r\n * @deprecated\r\n */;\n _proto.getMatchingOption = function getMatchingOption$1(formData, options) {\n return getMatchingOption(this.validator, formData, options, this.rootSchema);\n }\n /** Checks to see if the `schema` and `uiSchema` combination represents an array of files\r\n *\r\n * @param schema - The schema for which check for array of files flag is desired\r\n * @param [uiSchema] - The UI schema from which to check the widget\r\n * @returns - True if schema/uiSchema contains an array of files, otherwise false\r\n */;\n _proto.isFilesArray = function isFilesArray$1(schema, uiSchema) {\n return isFilesArray(this.validator, schema, uiSchema, this.rootSchema);\n }\n /** Checks to see if the `schema` combination represents a multi-select\r\n *\r\n * @param schema - The schema for which check for a multi-select flag is desired\r\n * @returns - True if schema contains a multi-select, otherwise false\r\n */;\n _proto.isMultiSelect = function isMultiSelect$1(schema) {\n return isMultiSelect(this.validator, schema, this.rootSchema);\n }\n /** Checks to see if the `schema` combination represents a select\r\n *\r\n * @param schema - The schema for which check for a select flag is desired\r\n * @returns - True if schema contains a select, otherwise false\r\n */;\n _proto.isSelect = function isSelect$1(schema) {\n return isSelect(this.validator, schema, this.rootSchema);\n }\n /** Merges the errors in `additionalErrorSchema` into the existing `validationData` by combining the hierarchies in\r\n * the two `ErrorSchema`s and then appending the error list from the `additionalErrorSchema` obtained by calling\r\n * `getValidator().toErrorList()` onto the `errors` in the `validationData`. If no `additionalErrorSchema` is passed,\r\n * then `validationData` is returned.\r\n *\r\n * @param validationData - The current `ValidationData` into which to merge the additional errors\r\n * @param [additionalErrorSchema] - The additional set of errors\r\n * @returns - The `validationData` with the additional errors from `additionalErrorSchema` merged into it, if provided.\r\n */;\n _proto.mergeValidationData = function mergeValidationData$1(validationData, additionalErrorSchema) {\n return mergeValidationData(this.validator, validationData, additionalErrorSchema);\n }\n /** Retrieves an expanded schema that has had all of its conditions, additional properties, references and\r\n * dependencies resolved and merged into the `schema` given a `rawFormData` that is used to do the potentially\r\n * recursive resolution.\r\n *\r\n * @param schema - The schema for which retrieving a schema is desired\r\n * @param [rawFormData] - The current formData, if any, to assist retrieving a schema\r\n * @returns - The schema having its conditions, additional properties, references and dependencies resolved\r\n */;\n _proto.retrieveSchema = function retrieveSchema$1(schema, rawFormData) {\n return retrieveSchema(this.validator, schema, this.rootSchema, rawFormData);\n }\n /** Sanitize the `data` associated with the `oldSchema` so it is considered appropriate for the `newSchema`. If the\r\n * new schema does not contain any properties, then `undefined` is returned to clear all the form data. Due to the\r\n * nature of schemas, this sanitization happens recursively for nested objects of data. Also, any properties in the\r\n * old schemas that are non-existent in the new schema are set to `undefined`.\r\n *\r\n * @param [newSchema] - The new schema for which the data is being sanitized\r\n * @param [oldSchema] - The old schema from which the data originated\r\n * @param [data={}] - The form data associated with the schema, defaulting to an empty object when undefined\r\n * @returns - The new form data, with all the fields uniquely associated with the old schema set\r\n * to `undefined`. Will return `undefined` if the new schema is not an object containing properties.\r\n */;\n _proto.sanitizeDataForNewSchema = function sanitizeDataForNewSchema$1(newSchema, oldSchema, data) {\n return sanitizeDataForNewSchema(this.validator, this.rootSchema, newSchema, oldSchema, data);\n }\n /** Generates an `IdSchema` object for the `schema`, recursively\r\n *\r\n * @param schema - The schema for which the display label flag is desired\r\n * @param [id] - The base id for the schema\r\n * @param [formData] - The current formData, if any, onto which to provide any missing defaults\r\n * @param [idPrefix='root'] - The prefix to use for the id\r\n * @param [idSeparator='_'] - The separator to use for the path segments in the id\r\n * @returns - The `IdSchema` object for the `schema`\r\n */;\n _proto.toIdSchema = function toIdSchema$1(schema, id, formData, idPrefix, idSeparator) {\n if (idPrefix === void 0) {\n idPrefix = 'root';\n }\n if (idSeparator === void 0) {\n idSeparator = '_';\n }\n return toIdSchema(this.validator, schema, id, this.rootSchema, formData, idPrefix, idSeparator);\n }\n /** Generates an `PathSchema` object for the `schema`, recursively\r\n *\r\n * @param schema - The schema for which the display label flag is desired\r\n * @param [name] - The base name for the schema\r\n * @param [formData] - The current formData, if any, onto which to provide any missing defaults\r\n * @returns - The `PathSchema` object for the `schema`\r\n */;\n _proto.toPathSchema = function toPathSchema$1(schema, name, formData) {\n return toPathSchema(this.validator, schema, name, this.rootSchema, formData);\n };\n return SchemaUtils;\n}();\n/** Creates a `SchemaUtilsType` interface that is based around the given `validator` and `rootSchema` parameters. The\r\n * resulting interface implementation will forward the `validator` and `rootSchema` to all the wrapped APIs.\r\n *\r\n * @param validator - an implementation of the `ValidatorType` interface that will be forwarded to all the APIs\r\n * @param rootSchema - The root schema that will be forwarded to all the APIs\r\n * @returns - An implementation of a `SchemaUtilsType` interface\r\n */\nfunction createSchemaUtils(validator, rootSchema) {\n return new SchemaUtils(validator, rootSchema);\n}\n\n/** Given the `FileReader.readAsDataURL()` based `dataURI` extracts that data into an actual Blob along with the name\r\n * of that Blob if provided in the URL. If no name is provided, then the name falls back to `unknown`.\r\n *\r\n * @param dataURI - The `DataUrl` potentially containing name and raw data to be converted to a Blob\r\n * @returns - an object containing a Blob and its name, extracted from the URI\r\n */\nfunction dataURItoBlob(dataURI) {\n // Split metadata from data\n var splitted = dataURI.split(',');\n // Split params\n var params = splitted[0].split(';');\n // Get mime-type from params\n var type = params[0].replace('data:', '');\n // Filter the name property from params\n var properties = params.filter(function (param) {\n return param.split('=')[0] === 'name';\n });\n // Look for the name and use unknown if no name property.\n var name;\n if (properties.length !== 1) {\n name = 'unknown';\n } else {\n // Because we filtered out the other property,\n // we only have the name case here, which we decode to make it human-readable\n name = decodeURI(properties[0].split('=')[1]);\n }\n // Built the Uint8Array Blob parameter from the base64 string.\n try {\n var binary = atob(splitted[1]);\n var array = [];\n for (var i = 0; i < binary.length; i++) {\n array.push(binary.charCodeAt(i));\n }\n // Create the blob object\n var blob = new window.Blob([new Uint8Array(array)], {\n type: type\n });\n return {\n blob: blob,\n name: name\n };\n } catch (error) {\n return {\n blob: {\n size: 0,\n type: error.message\n },\n name: dataURI\n };\n }\n}\n\n/** Potentially substitutes all replaceable parameters with the associated value(s) from the `params` if available. When\r\n * a `params` array is provided, each value in the array is used to replace any of the replaceable parameters in the\r\n * `inputString` using the `%1`, `%2`, etc. replacement specifiers.\r\n *\r\n * @param inputString - The string which will be potentially updated with replacement parameters\r\n * @param params - The optional list of replaceable parameter values to substitute into the english string\r\n * @returns - The updated string with any replacement specifiers replaced\r\n */\nfunction replaceStringParameters(inputString, params) {\n var output = inputString;\n if (Array.isArray(params)) {\n var parts = output.split(/(%\\d)/);\n params.forEach(function (param, index) {\n var partIndex = parts.findIndex(function (part) {\n return part === \"%\" + (index + 1);\n });\n if (partIndex >= 0) {\n parts[partIndex] = param;\n }\n });\n output = parts.join('');\n }\n return output;\n}\n\n/** Translates a `TranslatableString` value `stringToTranslate` into english. When a `params` array is provided, each\r\n * value in the array is used to replace any of the replaceable parameters in the `stringToTranslate` using the `%1`,\r\n * `%2`, etc. replacement specifiers.\r\n *\r\n * @param stringToTranslate - The `TranslatableString` value to convert to english\r\n * @param params - The optional list of replaceable parameter values to substitute into the english string\r\n * @returns - The `stringToTranslate` itself with any replaceable parameter values substituted\r\n */\nfunction englishStringTranslator(stringToTranslate, params) {\n return replaceStringParameters(stringToTranslate, params);\n}\n\n/** Returns the value(s) from `allEnumOptions` at the index(es) provided by `valueIndex`. If `valueIndex` is not an\r\n * array AND the index is not valid for `allEnumOptions`, `emptyValue` is returned. If `valueIndex` is an array, AND it\r\n * contains an invalid index, the returned array will have the resulting undefined values filtered out, leaving only\r\n * valid values or in the worst case, an empty array.\r\n *\r\n * @param valueIndex - The index(es) of the value(s) that should be returned\r\n * @param [allEnumOptions=[]] - The list of all the known enumOptions\r\n * @param [emptyValue] - The value to return when the non-array `valueIndex` does not refer to a real option\r\n * @returns - The single or list of values specified by the single or list of indexes if they are valid. Otherwise,\r\n * `emptyValue` or an empty list.\r\n */\nfunction enumOptionsValueForIndex(valueIndex, allEnumOptions, emptyValue) {\n if (allEnumOptions === void 0) {\n allEnumOptions = [];\n }\n if (Array.isArray(valueIndex)) {\n return valueIndex.map(function (index) {\n return enumOptionsValueForIndex(index, allEnumOptions);\n }).filter(function (val) {\n return val;\n });\n }\n // So Number(null) and Number('') both return 0, so use emptyValue for those two values\n var index = valueIndex === '' || valueIndex === null ? -1 : Number(valueIndex);\n var option = allEnumOptions[index];\n return option ? option.value : emptyValue;\n}\n\n/** Removes the enum option value at the `valueIndex` from the currently `selected` (list of) value(s). If `selected` is\r\n * a list, then that list is updated to remove the enum option value with the `valueIndex` in `allEnumOptions`. If it is\r\n * a single value, then if the enum option value with the `valueIndex` in `allEnumOptions` matches `selected`, undefined\r\n * is returned, otherwise the `selected` value is returned.\r\n *\r\n * @param valueIndex - The index of the value to be removed from the selected list or single value\r\n * @param selected - The current (list of) selected value(s)\r\n * @param [allEnumOptions=[]] - The list of all the known enumOptions\r\n * @returns - The updated `selected` with the enum option value at `valueIndex` in `allEnumOptions` removed from it,\r\n * unless `selected` is a single value. In that case, if the `valueIndex` value matches `selected`, returns\r\n * undefined, otherwise `selected`.\r\n */\nfunction enumOptionsDeselectValue(valueIndex, selected, allEnumOptions) {\n if (allEnumOptions === void 0) {\n allEnumOptions = [];\n }\n var value = enumOptionsValueForIndex(valueIndex, allEnumOptions);\n if (Array.isArray(selected)) {\n return selected.filter(function (v) {\n return !isEqual(v, value);\n });\n }\n return isEqual(value, selected) ? undefined : selected;\n}\n\n/** Determines whether the given `value` is (one of) the `selected` value(s).\r\n *\r\n * @param value - The value being checked to see if it is selected\r\n * @param selected - The current selected value or list of values\r\n * @returns - true if the `value` is one of the `selected` ones, false otherwise\r\n */\nfunction enumOptionsIsSelected(value, selected) {\n if (Array.isArray(selected)) {\n return selected.some(function (sel) {\n return isEqual(sel, value);\n });\n }\n return isEqual(selected, value);\n}\n\n/** Returns the index(es) of the options in `allEnumOptions` whose value(s) match the ones in `value`. All the\r\n * `enumOptions` are filtered based on whether they are a \"selected\" `value` and the index of each selected one is then\r\n * stored in an array. If `multiple` is true, that array is returned, otherwise the first element in the array is\r\n * returned.\r\n *\r\n * @param value - The single value or list of values for which indexes are desired\r\n * @param [allEnumOptions=[]] - The list of all the known enumOptions\r\n * @param [multiple=false] - Optional flag, if true will return a list of index, otherwise a single one\r\n * @returns - A single string index for the first `value` in `allEnumOptions`, if not `multiple`. Otherwise, the list\r\n * of indexes for (each of) the value(s) in `value`.\r\n */\nfunction enumOptionsIndexForValue(value, allEnumOptions, multiple) {\n if (allEnumOptions === void 0) {\n allEnumOptions = [];\n }\n if (multiple === void 0) {\n multiple = false;\n }\n var selectedIndexes = allEnumOptions.map(function (opt, index) {\n return enumOptionsIsSelected(opt.value, value) ? String(index) : undefined;\n }).filter(function (opt) {\n return typeof opt !== 'undefined';\n });\n if (!multiple) {\n return selectedIndexes[0];\n }\n return selectedIndexes;\n}\n\n/** Add the enum option value at the `valueIndex` to the list of `selected` values in the proper order as defined by\r\n * `allEnumOptions`\r\n *\r\n * @param valueIndex - The index of the value that should be selected\r\n * @param selected - The current list of selected values\r\n * @param [allEnumOptions=[]] - The list of all the known enumOptions\r\n * @returns - The updated list of selected enum values with enum value at the `valueIndex` added to it\r\n */\nfunction enumOptionsSelectValue(valueIndex, selected, allEnumOptions) {\n if (allEnumOptions === void 0) {\n allEnumOptions = [];\n }\n var value = enumOptionsValueForIndex(valueIndex, allEnumOptions);\n if (value) {\n var index = allEnumOptions.findIndex(function (opt) {\n return value === opt.value;\n });\n var all = allEnumOptions.map(function (_ref) {\n var val = _ref.value;\n return val;\n });\n var updated = selected.slice(0, index).concat(value, selected.slice(index));\n // As inserting values at predefined index positions doesn't work with empty\n // arrays, we need to reorder the updated selection to match the initial order\n return updated.sort(function (a, b) {\n return Number(all.indexOf(a) > all.indexOf(b));\n });\n }\n return selected;\n}\n\n/** The `ErrorSchemaBuilder` is used to build an `ErrorSchema` since the definition of the `ErrorSchema` type is\r\n * designed for reading information rather than writing it. Use this class to add, replace or clear errors in an error\r\n * schema by using either dotted path or an array of path names. Once you are done building the `ErrorSchema`, you can\r\n * get the result and/or reset all the errors back to an initial set and start again.\r\n */\nvar ErrorSchemaBuilder = /*#__PURE__*/function () {\n /** The error schema being built\r\n *\r\n * @private\r\n */\n\n /** Construct an `ErrorSchemaBuilder` with an optional initial set of errors in an `ErrorSchema`.\r\n *\r\n * @param [initialSchema] - The optional set of initial errors, that will be cloned into the class\r\n */\n function ErrorSchemaBuilder(initialSchema) {\n this.errorSchema = {};\n this.resetAllErrors(initialSchema);\n }\n /** Returns the `ErrorSchema` that has been updated by the methods of the `ErrorSchemaBuilder`\r\n */\n var _proto = ErrorSchemaBuilder.prototype;\n /** Will get an existing `ErrorSchema` at the specified `pathOfError` or create and return one.\r\n *\r\n * @param [pathOfError] - The optional path into the `ErrorSchema` at which to add the error(s)\r\n * @returns - The error block for the given `pathOfError` or the root if not provided\r\n * @private\r\n */\n _proto.getOrCreateErrorBlock = function getOrCreateErrorBlock(pathOfError) {\n var hasPath = Array.isArray(pathOfError) && pathOfError.length > 0 || typeof pathOfError === 'string';\n var errorBlock = hasPath ? get(this.errorSchema, pathOfError) : this.errorSchema;\n if (!errorBlock && pathOfError) {\n errorBlock = {};\n set(this.errorSchema, pathOfError, errorBlock);\n }\n return errorBlock;\n }\n /** Resets all errors in the `ErrorSchemaBuilder` back to the `initialSchema` if provided, otherwise an empty set.\r\n *\r\n * @param [initialSchema] - The optional set of initial errors, that will be cloned into the class\r\n * @returns - The `ErrorSchemaBuilder` object for chaining purposes\r\n */;\n _proto.resetAllErrors = function resetAllErrors(initialSchema) {\n this.errorSchema = initialSchema ? cloneDeep(initialSchema) : {};\n return this;\n }\n /** Adds the `errorOrList` to the list of errors in the `ErrorSchema` at either the root level or the location within\r\n * the schema described by the `pathOfError`. For more information about how to specify the path see the\r\n * [eslint lodash plugin docs](https://github.com/wix/eslint-plugin-lodash/blob/master/docs/rules/path-style.md).\r\n *\r\n * @param errorOrList - The error or list of errors to add into the `ErrorSchema`\r\n * @param [pathOfError] - The optional path into the `ErrorSchema` at which to add the error(s)\r\n * @returns - The `ErrorSchemaBuilder` object for chaining purposes\r\n */;\n _proto.addErrors = function addErrors(errorOrList, pathOfError) {\n var errorBlock = this.getOrCreateErrorBlock(pathOfError);\n var errorsList = get(errorBlock, ERRORS_KEY);\n if (!Array.isArray(errorsList)) {\n errorsList = [];\n errorBlock[ERRORS_KEY] = errorsList;\n }\n if (Array.isArray(errorOrList)) {\n var _errorsList;\n (_errorsList = errorsList).push.apply(_errorsList, errorOrList);\n } else {\n errorsList.push(errorOrList);\n }\n return this;\n }\n /** Sets/replaces the `errorOrList` as the error(s) in the `ErrorSchema` at either the root level or the location\r\n * within the schema described by the `pathOfError`. For more information about how to specify the path see the\r\n * [eslint lodash plugin docs](https://github.com/wix/eslint-plugin-lodash/blob/master/docs/rules/path-style.md).\r\n *\r\n * @param errorOrList - The error or list of errors to set into the `ErrorSchema`\r\n * @param [pathOfError] - The optional path into the `ErrorSchema` at which to set the error(s)\r\n * @returns - The `ErrorSchemaBuilder` object for chaining purposes\r\n */;\n _proto.setErrors = function setErrors(errorOrList, pathOfError) {\n var errorBlock = this.getOrCreateErrorBlock(pathOfError);\n // Effectively clone the array being given to prevent accidental outside manipulation of the given list\n var listToAdd = Array.isArray(errorOrList) ? [].concat(errorOrList) : [errorOrList];\n set(errorBlock, ERRORS_KEY, listToAdd);\n return this;\n }\n /** Clears the error(s) in the `ErrorSchema` at either the root level or the location within the schema described by\r\n * the `pathOfError`. For more information about how to specify the path see the\r\n * [eslint lodash plugin docs](https://github.com/wix/eslint-plugin-lodash/blob/master/docs/rules/path-style.md).\r\n *\r\n * @param [pathOfError] - The optional path into the `ErrorSchema` at which to clear the error(s)\r\n * @returns - The `ErrorSchemaBuilder` object for chaining purposes\r\n */;\n _proto.clearErrors = function clearErrors(pathOfError) {\n var errorBlock = this.getOrCreateErrorBlock(pathOfError);\n set(errorBlock, ERRORS_KEY, []);\n return this;\n };\n _createClass(ErrorSchemaBuilder, [{\n key: \"ErrorSchema\",\n get: function get() {\n return this.errorSchema;\n }\n }]);\n return ErrorSchemaBuilder;\n}();\n\n/** Extracts the range spec information `{ step?: number, min?: number, max?: number }` that can be spread onto an HTML\r\n * input from the range analog in the schema `{ multipleOf?: number, minimum?: number, maximum?: number }`.\r\n *\r\n * @param schema - The schema from which to extract the range spec\r\n * @returns - A range specification from the schema\r\n */\nfunction rangeSpec(schema) {\n var spec = {};\n if (schema.multipleOf) {\n spec.step = schema.multipleOf;\n }\n if (schema.minimum || schema.minimum === 0) {\n spec.min = schema.minimum;\n }\n if (schema.maximum || schema.maximum === 0) {\n spec.max = schema.maximum;\n }\n return spec;\n}\n\n/** Using the `schema`, `defaultType` and `options`, extract out the props for the element that make sense.\r\n *\r\n * @param schema - The schema for the field provided by the widget\r\n * @param [defaultType] - The default type, if any, for the field provided by the widget\r\n * @param [options={}] - The UI Options for the field provided by the widget\r\n * @param [autoDefaultStepAny=true] - Determines whether to auto-default step=any when the type is number and no step\r\n * @returns - The extracted `InputPropsType` object\r\n */\nfunction getInputProps(schema, defaultType, options, autoDefaultStepAny) {\n if (options === void 0) {\n options = {};\n }\n if (autoDefaultStepAny === void 0) {\n autoDefaultStepAny = true;\n }\n var inputProps = _extends({\n type: defaultType || 'text'\n }, rangeSpec(schema));\n // If options.inputType is set use that as the input type\n if (options.inputType) {\n inputProps.type = options.inputType;\n } else if (!defaultType) {\n // If the schema is of type number or integer, set the input type to number\n if (schema.type === 'number') {\n inputProps.type = 'number';\n // Only add step if one isn't already defined and we are auto-defaulting the \"any\" step\n if (autoDefaultStepAny && inputProps.step === undefined) {\n // Setting step to 'any' fixes a bug in Safari where decimals are not\n // allowed in number inputs\n inputProps.step = 'any';\n }\n } else if (schema.type === 'integer') {\n inputProps.type = 'number';\n // Only add step if one isn't already defined\n if (inputProps.step === undefined) {\n // Since this is integer, you always want to step up or down in multiples of 1\n inputProps.step = 1;\n }\n }\n }\n if (options.autocomplete) {\n inputProps.autoComplete = options.autocomplete;\n }\n return inputProps;\n}\n\n/** The default submit button options, exported for testing purposes\r\n */\nvar DEFAULT_OPTIONS = {\n props: {\n disabled: false\n },\n submitText: 'Submit',\n norender: false\n};\n/** Extracts any `ui:submitButtonOptions` from the `uiSchema` and merges them onto the `DEFAULT_OPTIONS`\r\n *\r\n * @param [uiSchema={}] - the UI Schema from which to extract submit button props\r\n * @returns - The merging of the `DEFAULT_OPTIONS` with any custom ones\r\n */\nfunction getSubmitButtonOptions(uiSchema) {\n if (uiSchema === void 0) {\n uiSchema = {};\n }\n var uiOptions = getUiOptions(uiSchema);\n if (uiOptions && uiOptions[SUBMIT_BTN_OPTIONS_KEY]) {\n var options = uiOptions[SUBMIT_BTN_OPTIONS_KEY];\n return _extends({}, DEFAULT_OPTIONS, options);\n }\n return DEFAULT_OPTIONS;\n}\n\n/** Returns the template with the given `name` from either the `uiSchema` if it is defined or from the `registry`\r\n * otherwise. NOTE, since `ButtonTemplates` are not overridden in `uiSchema` only those in the `registry` are returned.\r\n *\r\n * @param name - The name of the template to fetch, restricted to the keys of `TemplatesType`\r\n * @param registry - The `Registry` from which to read the template\r\n * @param [uiOptions={}] - The `UIOptionsType` from which to read an alternate template\r\n * @returns - The template from either the `uiSchema` or `registry` for the `name`\r\n */\nfunction getTemplate(name, registry, uiOptions) {\n if (uiOptions === void 0) {\n uiOptions = {};\n }\n var templates = registry.templates;\n if (name === 'ButtonTemplates') {\n return templates[name];\n }\n return (\n // Evaluating uiOptions[name] results in TS2590: Expression produces a union type that is too complex to represent\n // To avoid that, we cast uiOptions to `any` before accessing the name field\n uiOptions[name] || templates[name]\n );\n}\n\nvar _excluded = [\"options\"];\n/** The map of schema types to widget type to widget name\r\n */\nvar widgetMap = {\n \"boolean\": {\n checkbox: 'CheckboxWidget',\n radio: 'RadioWidget',\n select: 'SelectWidget',\n hidden: 'HiddenWidget'\n },\n string: {\n text: 'TextWidget',\n password: 'PasswordWidget',\n email: 'EmailWidget',\n hostname: 'TextWidget',\n ipv4: 'TextWidget',\n ipv6: 'TextWidget',\n uri: 'URLWidget',\n 'data-url': 'FileWidget',\n radio: 'RadioWidget',\n select: 'SelectWidget',\n textarea: 'TextareaWidget',\n hidden: 'HiddenWidget',\n date: 'DateWidget',\n datetime: 'DateTimeWidget',\n 'date-time': 'DateTimeWidget',\n 'alt-date': 'AltDateWidget',\n 'alt-datetime': 'AltDateTimeWidget',\n time: 'TimeWidget',\n color: 'ColorWidget',\n file: 'FileWidget'\n },\n number: {\n text: 'TextWidget',\n select: 'SelectWidget',\n updown: 'UpDownWidget',\n range: 'RangeWidget',\n radio: 'RadioWidget',\n hidden: 'HiddenWidget'\n },\n integer: {\n text: 'TextWidget',\n select: 'SelectWidget',\n updown: 'UpDownWidget',\n range: 'RangeWidget',\n radio: 'RadioWidget',\n hidden: 'HiddenWidget'\n },\n array: {\n select: 'SelectWidget',\n checkboxes: 'CheckboxesWidget',\n files: 'FileWidget',\n hidden: 'HiddenWidget'\n }\n};\n/** Wraps the given widget with stateless functional component that will merge any `defaultProps.options` with the\r\n * `options` that are provided in the props. It will add the wrapper component as a `MergedWidget` property onto the\r\n * `Widget` so that future attempts to wrap `AWidget` will return the already existing wrapper.\r\n *\r\n * @param AWidget - A widget that will be wrapped or one that is already wrapped\r\n * @returns - The wrapper widget\r\n */\nfunction mergeWidgetOptions(AWidget) {\n var MergedWidget = get(AWidget, 'MergedWidget');\n // cache return value as property of widget for proper react reconciliation\n if (!MergedWidget) {\n var defaultOptions = AWidget.defaultProps && AWidget.defaultProps.options || {};\n MergedWidget = function MergedWidget(_ref) {\n var options = _ref.options,\n props = _objectWithoutPropertiesLoose(_ref, _excluded);\n return jsx(AWidget, _extends({\n options: _extends({}, defaultOptions, options)\n }, props));\n };\n set(AWidget, 'MergedWidget', MergedWidget);\n }\n return MergedWidget;\n}\n/** Given a schema representing a field to render and either the name or actual `Widget` implementation, returns the\r\n * React component that is used to render the widget. If the `widget` is already a React component, then it is wrapped\r\n * with a `MergedWidget`. Otherwise an attempt is made to look up the widget inside of the `registeredWidgets` map based\r\n * on the schema type and `widget` name. If no widget component can be found an `Error` is thrown.\r\n *\r\n * @param schema - The schema for the field\r\n * @param [widget] - Either the name of the widget OR a `Widget` implementation to use\r\n * @param [registeredWidgets={}] - A registry of widget name to `Widget` implementation\r\n * @returns - The `Widget` component to use\r\n * @throws - An error if there is no `Widget` component that can be returned\r\n */\nfunction getWidget(schema, widget, registeredWidgets) {\n if (registeredWidgets === void 0) {\n registeredWidgets = {};\n }\n var type = getSchemaType(schema);\n if (typeof widget === 'function' || widget && ReactIs.isForwardRef( /*#__PURE__*/createElement(widget)) || ReactIs.isMemo(widget)) {\n return mergeWidgetOptions(widget);\n }\n if (typeof widget !== 'string') {\n throw new Error(\"Unsupported widget definition: \" + typeof widget);\n }\n if (widget in registeredWidgets) {\n var registeredWidget = registeredWidgets[widget];\n return getWidget(schema, registeredWidget, registeredWidgets);\n }\n if (typeof type === 'string') {\n if (!(type in widgetMap)) {\n throw new Error(\"No widget for type '\" + type + \"'\");\n }\n if (widget in widgetMap[type]) {\n var _registeredWidget = registeredWidgets[widgetMap[type][widget]];\n return getWidget(schema, _registeredWidget, registeredWidgets);\n }\n }\n throw new Error(\"No widget '\" + widget + \"' for type '\" + type + \"'\");\n}\n\n/** Detects whether the `widget` exists for the `schema` with the associated `registryWidgets` and returns true if it\r\n * does, or false if it doesn't.\r\n *\r\n * @param schema - The schema for the field\r\n * @param widget - Either the name of the widget OR a `Widget` implementation to use\r\n * @param [registeredWidgets={}] - A registry of widget name to `Widget` implementation\r\n * @returns - True if the widget exists, false otherwise\r\n */\nfunction hasWidget(schema, widget, registeredWidgets) {\n if (registeredWidgets === void 0) {\n registeredWidgets = {};\n }\n try {\n getWidget(schema, widget, registeredWidgets);\n return true;\n } catch (e) {\n var err = e;\n if (err.message && (err.message.startsWith('No widget') || err.message.startsWith('Unsupported widget'))) {\n return false;\n }\n throw e;\n }\n}\n\n/** Generates a consistent `id` pattern for a given `id` and a `suffix`\r\n *\r\n * @param id - Either simple string id or an IdSchema from which to extract it\r\n * @param suffix - The suffix to append to the id\r\n */\nfunction idGenerator(id, suffix) {\n var theId = isString(id) ? id : id[ID_KEY];\n return theId + \"__\" + suffix;\n}\n/** Return a consistent `id` for the field description element\r\n *\r\n * @param id - Either simple string id or an IdSchema from which to extract it\r\n * @returns - The consistent id for the field description element from the given `id`\r\n */\nfunction descriptionId(id) {\n return idGenerator(id, 'description');\n}\n/** Return a consistent `id` for the field error element\r\n *\r\n * @param id - Either simple string id or an IdSchema from which to extract it\r\n * @returns - The consistent id for the field error element from the given `id`\r\n */\nfunction errorId(id) {\n return idGenerator(id, 'error');\n}\n/** Return a consistent `id` for the field examples element\r\n *\r\n * @param id - Either simple string id or an IdSchema from which to extract it\r\n * @returns - The consistent id for the field examples element from the given `id`\r\n */\nfunction examplesId(id) {\n return idGenerator(id, 'examples');\n}\n/** Return a consistent `id` for the field help element\r\n *\r\n * @param id - Either simple string id or an IdSchema from which to extract it\r\n * @returns - The consistent id for the field help element from the given `id`\r\n */\nfunction helpId(id) {\n return idGenerator(id, 'help');\n}\n/** Return a consistent `id` for the field title element\r\n *\r\n * @param id - Either simple string id or an IdSchema from which to extract it\r\n * @returns - The consistent id for the field title element from the given `id`\r\n */\nfunction titleId(id) {\n return idGenerator(id, 'title');\n}\n/** Return a list of element ids that contain additional information about the field that can be used to as the aria\r\n * description of the field. This is correctly omitting `titleId` which would be \"labeling\" rather than \"describing\" the\r\n * element.\r\n *\r\n * @param id - Either simple string id or an IdSchema from which to extract it\r\n * @param [includeExamples=false] - Optional flag, if true, will add the `examplesId` into the list\r\n * @returns - The string containing the list of ids for use in an `aria-describedBy` attribute\r\n */\nfunction ariaDescribedByIds(id, includeExamples) {\n if (includeExamples === void 0) {\n includeExamples = false;\n }\n var examples = includeExamples ? \" \" + examplesId(id) : '';\n return errorId(id) + \" \" + descriptionId(id) + \" \" + helpId(id) + examples;\n}\n/** Return a consistent `id` for the `optionIndex`s of a `Radio` or `Checkboxes` widget\r\n *\r\n * @param id - The id of the parent component for the option\r\n * @param optionIndex - The index of the option for which the id is desired\r\n * @returns - An id for the option index based on the parent `id`\r\n */\nfunction optionId(id, optionIndex) {\n return id + \"-\" + optionIndex;\n}\n\nfunction labelValue(label, hideLabel, fallback) {\n return hideLabel ? fallback : label;\n}\n\n/** Converts a local Date string into a UTC date string\r\n *\r\n * @param dateString - The string representation of a date as accepted by the `Date()` constructor\r\n * @returns - A UTC date string if `dateString` is truthy, otherwise undefined\r\n */\nfunction localToUTC(dateString) {\n return dateString ? new Date(dateString).toJSON() : undefined;\n}\n\n/** Returns the constant value from the schema when it is either a single value enum or has a const key. Otherwise\r\n * throws an error.\r\n *\r\n * @param schema - The schema from which to obtain the constant value\r\n * @returns - The constant value for the schema\r\n * @throws - Error when the schema does not have a constant value\r\n */\nfunction toConstant(schema) {\n if (ENUM_KEY in schema && Array.isArray(schema[\"enum\"]) && schema[\"enum\"].length === 1) {\n return schema[\"enum\"][0];\n }\n if (CONST_KEY in schema) {\n return schema[\"const\"];\n }\n throw new Error('schema cannot be inferred as a constant');\n}\n\n/** Gets the list of options from the schema. If the schema has an enum list, then those enum values are returned. The\r\n * labels for the options will be extracted from the non-standard, RJSF-deprecated `enumNames` if it exists, otherwise\r\n * the label will be the same as the `value`. If the schema has a `oneOf` or `anyOf`, then the value is the list of\r\n * `const` values from the schema and the label is either the `schema.title` or the value.\r\n *\r\n * @param schema - The schema from which to extract the options list\r\n * @returns - The list of options from the schema\r\n */\nfunction optionsList(schema) {\n // enumNames was deprecated in v5 and is intentionally omitted from the RJSFSchema type.\n // Cast the type to include enumNames so the feature still works.\n var schemaWithEnumNames = schema;\n if (schemaWithEnumNames.enumNames && process.env.NODE_ENV !== 'production') {\n console.warn('The enumNames property is deprecated and may be removed in a future major release.');\n }\n if (schema[\"enum\"]) {\n return schema[\"enum\"].map(function (value, i) {\n var label = schemaWithEnumNames.enumNames && schemaWithEnumNames.enumNames[i] || String(value);\n return {\n label: label,\n value: value\n };\n });\n }\n var altSchemas = schema.oneOf || schema.anyOf;\n return altSchemas && altSchemas.map(function (aSchemaDef) {\n var aSchema = aSchemaDef;\n var value = toConstant(aSchema);\n var label = aSchema.title || String(value);\n return {\n schema: aSchema,\n label: label,\n value: value\n };\n });\n}\n\n/** Given a list of `properties` and an `order` list, returns a list that contains the `properties` ordered correctly.\r\n * If `order` is not an array, then the untouched `properties` list is returned. Otherwise `properties` is ordered per\r\n * the `order` list. If `order` contains a '*' then any `properties` that are not mentioned explicity in `order` will be\r\n * places in the location of the `*`.\r\n *\r\n * @param properties - The list of property keys to be ordered\r\n * @param order - An array of property keys to be ordered first, with an optional '*' property\r\n * @returns - A list with the `properties` ordered\r\n * @throws - Error when the properties cannot be ordered correctly\r\n */\nfunction orderProperties(properties, order) {\n if (!Array.isArray(order)) {\n return properties;\n }\n var arrayToHash = function arrayToHash(arr) {\n return arr.reduce(function (prev, curr) {\n prev[curr] = true;\n return prev;\n }, {});\n };\n var errorPropList = function errorPropList(arr) {\n return arr.length > 1 ? \"properties '\" + arr.join(\"', '\") + \"'\" : \"property '\" + arr[0] + \"'\";\n };\n var propertyHash = arrayToHash(properties);\n var orderFiltered = order.filter(function (prop) {\n return prop === '*' || propertyHash[prop];\n });\n var orderHash = arrayToHash(orderFiltered);\n var rest = properties.filter(function (prop) {\n return !orderHash[prop];\n });\n var restIndex = orderFiltered.indexOf('*');\n if (restIndex === -1) {\n if (rest.length) {\n throw new Error(\"uiSchema order list does not contain \" + errorPropList(rest));\n }\n return orderFiltered;\n }\n if (restIndex !== orderFiltered.lastIndexOf('*')) {\n throw new Error('uiSchema order list contains more than one wildcard item');\n }\n var complete = [].concat(orderFiltered);\n complete.splice.apply(complete, [restIndex, 1].concat(rest));\n return complete;\n}\n\n/** Returns a string representation of the `num` that is padded with leading \"0\"s if necessary\r\n *\r\n * @param num - The number to pad\r\n * @param width - The width of the string at which no lead padding is necessary\r\n * @returns - The number converted to a string with leading zero padding if the number of digits is less than `width`\r\n */\nfunction pad(num, width) {\n var s = String(num);\n while (s.length < width) {\n s = '0' + s;\n }\n return s;\n}\n\n/** Parses the `dateString` into a `DateObject`, including the time information when `includeTime` is true\r\n *\r\n * @param dateString - The date string to parse into a DateObject\r\n * @param [includeTime=true] - Optional flag, if false, will not include the time data into the object\r\n * @returns - The date string converted to a `DateObject`\r\n * @throws - Error when the date cannot be parsed from the string\r\n */\nfunction parseDateString(dateString, includeTime) {\n if (includeTime === void 0) {\n includeTime = true;\n }\n if (!dateString) {\n return {\n year: -1,\n month: -1,\n day: -1,\n hour: includeTime ? -1 : 0,\n minute: includeTime ? -1 : 0,\n second: includeTime ? -1 : 0\n };\n }\n var date = new Date(dateString);\n if (Number.isNaN(date.getTime())) {\n throw new Error('Unable to parse date ' + dateString);\n }\n return {\n year: date.getUTCFullYear(),\n month: date.getUTCMonth() + 1,\n day: date.getUTCDate(),\n hour: includeTime ? date.getUTCHours() : 0,\n minute: includeTime ? date.getUTCMinutes() : 0,\n second: includeTime ? date.getUTCSeconds() : 0\n };\n}\n\n/** Check to see if a `schema` specifies that a value must be true. This happens when:\r\n * - `schema.const` is truthy\r\n * - `schema.enum` == `[true]`\r\n * - `schema.anyOf` or `schema.oneOf` has a single value which recursively returns true\r\n * - `schema.allOf` has at least one value which recursively returns true\r\n *\r\n * @param schema - The schema to check\r\n * @returns - True if the schema specifies a value that must be true, false otherwise\r\n */\nfunction schemaRequiresTrueValue(schema) {\n // Check if const is a truthy value\n if (schema[\"const\"]) {\n return true;\n }\n // Check if an enum has a single value of true\n if (schema[\"enum\"] && schema[\"enum\"].length === 1 && schema[\"enum\"][0] === true) {\n return true;\n }\n // If anyOf has a single value, evaluate the subschema\n if (schema.anyOf && schema.anyOf.length === 1) {\n return schemaRequiresTrueValue(schema.anyOf[0]);\n }\n // If oneOf has a single value, evaluate the subschema\n if (schema.oneOf && schema.oneOf.length === 1) {\n return schemaRequiresTrueValue(schema.oneOf[0]);\n }\n // Evaluate each subschema in allOf, to see if one of them requires a true value\n if (schema.allOf) {\n var schemaSome = function schemaSome(subSchema) {\n return schemaRequiresTrueValue(subSchema);\n };\n return schema.allOf.some(schemaSome);\n }\n return false;\n}\n\n/** Determines whether the given `component` should be rerendered by comparing its current set of props and state\r\n * against the next set. If either of those two sets are not the same, then the component should be rerendered.\r\n *\r\n * @param component - A React component being checked\r\n * @param nextProps - The next set of props against which to check\r\n * @param nextState - The next set of state against which to check\r\n * @returns - True if the component should be re-rendered, false otherwise\r\n */\nfunction shouldRender(component, nextProps, nextState) {\n var props = component.props,\n state = component.state;\n return !deepEquals(props, nextProps) || !deepEquals(state, nextState);\n}\n\n/** Returns a UTC date string for the given `dateObject`. If `time` is false, then the time portion of the string is\r\n * removed.\r\n *\r\n * @param dateObject - The `DateObject` to convert to a date string\r\n * @param [time=true] - Optional flag used to remove the time portion of the date string if false\r\n * @returns - The UTC date string\r\n */\nfunction toDateString(dateObject, time) {\n if (time === void 0) {\n time = true;\n }\n var year = dateObject.year,\n month = dateObject.month,\n day = dateObject.day,\n _dateObject$hour = dateObject.hour,\n hour = _dateObject$hour === void 0 ? 0 : _dateObject$hour,\n _dateObject$minute = dateObject.minute,\n minute = _dateObject$minute === void 0 ? 0 : _dateObject$minute,\n _dateObject$second = dateObject.second,\n second = _dateObject$second === void 0 ? 0 : _dateObject$second;\n var utcTime = Date.UTC(year, month - 1, day, hour, minute, second);\n var datetime = new Date(utcTime).toJSON();\n return time ? datetime : datetime.slice(0, 10);\n}\n\n/** Converts a UTC date string into a local Date format\r\n *\r\n * @param jsonDate - A UTC date string\r\n * @returns - An empty string when `jsonDate` is falsey, otherwise a date string in local format\r\n */\nfunction utcToLocal(jsonDate) {\n if (!jsonDate) {\n return '';\n }\n // required format of `'yyyy-MM-ddThh:mm' followed by optional ':ss' or ':ss.SSS'\n // https://html.spec.whatwg.org/multipage/input.html#local-date-and-time-state-(type%3Ddatetime-local)\n // > should be a _valid local date and time string_ (not GMT)\n // Note - date constructor passed local ISO-8601 does not correctly\n // change time to UTC in node pre-8\n var date = new Date(jsonDate);\n var yyyy = pad(date.getFullYear(), 4);\n var MM = pad(date.getMonth() + 1, 2);\n var dd = pad(date.getDate(), 2);\n var hh = pad(date.getHours(), 2);\n var mm = pad(date.getMinutes(), 2);\n var ss = pad(date.getSeconds(), 2);\n var SSS = pad(date.getMilliseconds(), 3);\n return yyyy + \"-\" + MM + \"-\" + dd + \"T\" + hh + \":\" + mm + \":\" + ss + \".\" + SSS;\n}\n\n/** An enumeration of all the translatable strings used by `@rjsf/core` and its themes. The value of each of the\r\n * enumeration keys is expected to be the actual english string. Some strings contain replaceable parameter values\r\n * as indicated by `%1`, `%2`, etc. The number after the `%` indicates the order of the parameter. The ordering of\r\n * parameters is important because some languages may choose to put the second parameter before the first in its\r\n * translation. Also, some strings are rendered using `markdown-to-jsx` and thus support markdown and inline html.\r\n */\nvar TranslatableString;\n(function (TranslatableString) {\n /** Fallback title of an array item, used by ArrayField */\n TranslatableString[\"ArrayItemTitle\"] = \"Item\";\n /** Missing items reason, used by ArrayField */\n TranslatableString[\"MissingItems\"] = \"Missing items definition\";\n /** Yes label, used by BooleanField */\n TranslatableString[\"YesLabel\"] = \"Yes\";\n /** No label, used by BooleanField */\n TranslatableString[\"NoLabel\"] = \"No\";\n /** Close label, used by ErrorList */\n TranslatableString[\"CloseLabel\"] = \"Close\";\n /** Errors label, used by ErrorList */\n TranslatableString[\"ErrorsLabel\"] = \"Errors\";\n /** New additionalProperties string default value, used by ObjectField */\n TranslatableString[\"NewStringDefault\"] = \"New Value\";\n /** Add button title, used by AddButton */\n TranslatableString[\"AddButton\"] = \"Add\";\n /** Add button title, used by AddButton */\n TranslatableString[\"AddItemButton\"] = \"Add Item\";\n /** Copy button title, used by IconButton */\n TranslatableString[\"CopyButton\"] = \"Copy\";\n /** Move down button title, used by IconButton */\n TranslatableString[\"MoveDownButton\"] = \"Move down\";\n /** Move up button title, used by IconButton */\n TranslatableString[\"MoveUpButton\"] = \"Move up\";\n /** Remove button title, used by IconButton */\n TranslatableString[\"RemoveButton\"] = \"Remove\";\n /** Now label, used by AltDateWidget */\n TranslatableString[\"NowLabel\"] = \"Now\";\n /** Clear label, used by AltDateWidget */\n TranslatableString[\"ClearLabel\"] = \"Clear\";\n /** Aria date label, used by DateWidget */\n TranslatableString[\"AriaDateLabel\"] = \"Select a date\";\n /** File preview label, used by FileWidget */\n TranslatableString[\"PreviewLabel\"] = \"Preview\";\n /** Decrement button aria label, used by UpDownWidget */\n TranslatableString[\"DecrementAriaLabel\"] = \"Decrease value by 1\";\n /** Increment button aria label, used by UpDownWidget */\n TranslatableString[\"IncrementAriaLabel\"] = \"Increase value by 1\";\n // Strings with replaceable parameters\n /** Unknown field type reason, where %1 will be replaced with the type as provided by SchemaField */\n TranslatableString[\"UnknownFieldType\"] = \"Unknown field type %1\";\n /** Option prefix, where %1 will be replaced with the option index as provided by MultiSchemaField */\n TranslatableString[\"OptionPrefix\"] = \"Option %1\";\n /** Option prefix, where %1 and %2 will be replaced by the schema title and option index, respectively as provided by\r\n * MultiSchemaField\r\n */\n TranslatableString[\"TitleOptionPrefix\"] = \"%1 option %2\";\n /** Key label, where %1 will be replaced by the label as provided by WrapIfAdditionalTemplate */\n TranslatableString[\"KeyLabel\"] = \"%1 Key\";\n // Strings with replaceable parameters AND/OR that support markdown and html\n /** Invalid object field configuration as provided by the ObjectField */\n TranslatableString[\"InvalidObjectField\"] = \"Invalid \\\"%1\\\" object field configuration: %2.\";\n /** Unsupported field schema, used by UnsupportedField */\n TranslatableString[\"UnsupportedField\"] = \"Unsupported field schema.\";\n /** Unsupported field schema, where %1 will be replaced by the idSchema.$id as provided by UnsupportedField */\n TranslatableString[\"UnsupportedFieldWithId\"] = \"Unsupported field schema for field %1.\";\n /** Unsupported field schema, where %1 will be replaced by the reason string as provided by UnsupportedField */\n TranslatableString[\"UnsupportedFieldWithReason\"] = \"Unsupported field schema: %1.\";\n /** Unsupported field schema, where %1 and %2 will be replaced by the idSchema.$id and reason strings, respectively,\r\n * as provided by UnsupportedField\r\n */\n TranslatableString[\"UnsupportedFieldWithIdAndReason\"] = \"Unsupported field schema for field %1: %2.\";\n /** File name, type and size info, where %1, %2 and %3 will be replaced by the file name, file type and file size as\r\n * provided by FileWidget\r\n */\n TranslatableString[\"FilesInfo\"] = \"%1 (%2, %3 bytes)\";\n})(TranslatableString || (TranslatableString = {}));\n\nexport { ADDITIONAL_PROPERTIES_KEY, ADDITIONAL_PROPERTY_FLAG, ALL_OF_KEY, ANY_OF_KEY, CONST_KEY, DEFAULT_KEY, DEFINITIONS_KEY, DEPENDENCIES_KEY, ENUM_KEY, ERRORS_KEY, ErrorSchemaBuilder, ID_KEY, ITEMS_KEY, NAME_KEY, ONE_OF_KEY, PROPERTIES_KEY, REF_KEY, REQUIRED_KEY, RJSF_ADDITONAL_PROPERTIES_FLAG, SUBMIT_BTN_OPTIONS_KEY, TranslatableString, UI_FIELD_KEY, UI_GLOBAL_OPTIONS_KEY, UI_OPTIONS_KEY, UI_WIDGET_KEY, allowAdditionalItems, ariaDescribedByIds, asNumber, canExpand, createSchemaUtils, dataURItoBlob, deepEquals, descriptionId, englishStringTranslator, enumOptionsDeselectValue, enumOptionsIndexForValue, enumOptionsIsSelected, enumOptionsSelectValue, enumOptionsValueForIndex, errorId, examplesId, findSchemaDefinition, getClosestMatchingOption, getDefaultFormState, getDisplayLabel, getFirstMatchingOption, getInputProps, getMatchingOption, getSchemaType, getSubmitButtonOptions, getTemplate, getUiOptions, getWidget, guessType, hasWidget, helpId, isConstant, isCustomWidget, isFilesArray, isFixedItems, isMultiSelect, isObject, isSelect, labelValue, localToUTC, mergeDefaultsWithFormData, mergeObjects, mergeSchemas, mergeValidationData, optionId, optionsList, orderProperties, pad, parseDateString, rangeSpec, replaceStringParameters, retrieveSchema, sanitizeDataForNewSchema, schemaRequiresTrueValue, shouldRender, titleId, toConstant, toDateString, toIdSchema, toPathSchema, utcToLocal };\n//# sourceMappingURL=utils.esm.js.map\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.regexpCode = exports.getEsmExportName = exports.getProperty = exports.safeStringify = exports.stringify = exports.strConcat = exports.addCodeArg = exports.str = exports._ = exports.nil = exports._Code = exports.Name = exports.IDENTIFIER = exports._CodeOrName = void 0;\nclass _CodeOrName {\n}\nexports._CodeOrName = _CodeOrName;\nexports.IDENTIFIER = /^[a-z$_][a-z$_0-9]*$/i;\nclass Name extends _CodeOrName {\n constructor(s) {\n super();\n if (!exports.IDENTIFIER.test(s))\n throw new Error(\"CodeGen: name must be a valid identifier\");\n this.str = s;\n }\n toString() {\n return this.str;\n }\n emptyStr() {\n return false;\n }\n get names() {\n return { [this.str]: 1 };\n }\n}\nexports.Name = Name;\nclass _Code extends _CodeOrName {\n constructor(code) {\n super();\n this._items = typeof code === \"string\" ? [code] : code;\n }\n toString() {\n return this.str;\n }\n emptyStr() {\n if (this._items.length > 1)\n return false;\n const item = this._items[0];\n return item === \"\" || item === '\"\"';\n }\n get str() {\n var _a;\n return ((_a = this._str) !== null && _a !== void 0 ? _a : (this._str = this._items.reduce((s, c) => `${s}${c}`, \"\")));\n }\n get names() {\n var _a;\n return ((_a = this._names) !== null && _a !== void 0 ? _a : (this._names = this._items.reduce((names, c) => {\n if (c instanceof Name)\n names[c.str] = (names[c.str] || 0) + 1;\n return names;\n }, {})));\n }\n}\nexports._Code = _Code;\nexports.nil = new _Code(\"\");\nfunction _(strs, ...args) {\n const code = [strs[0]];\n let i = 0;\n while (i < args.length) {\n addCodeArg(code, args[i]);\n code.push(strs[++i]);\n }\n return new _Code(code);\n}\nexports._ = _;\nconst plus = new _Code(\"+\");\nfunction str(strs, ...args) {\n const expr = [safeStringify(strs[0])];\n let i = 0;\n while (i < args.length) {\n expr.push(plus);\n addCodeArg(expr, args[i]);\n expr.push(plus, safeStringify(strs[++i]));\n }\n optimize(expr);\n return new _Code(expr);\n}\nexports.str = str;\nfunction addCodeArg(code, arg) {\n if (arg instanceof _Code)\n code.push(...arg._items);\n else if (arg instanceof Name)\n code.push(arg);\n else\n code.push(interpolate(arg));\n}\nexports.addCodeArg = addCodeArg;\nfunction optimize(expr) {\n let i = 1;\n while (i < expr.length - 1) {\n if (expr[i] === plus) {\n const res = mergeExprItems(expr[i - 1], expr[i + 1]);\n if (res !== undefined) {\n expr.splice(i - 1, 3, res);\n continue;\n }\n expr[i++] = \"+\";\n }\n i++;\n }\n}\nfunction mergeExprItems(a, b) {\n if (b === '\"\"')\n return a;\n if (a === '\"\"')\n return b;\n if (typeof a == \"string\") {\n if (b instanceof Name || a[a.length - 1] !== '\"')\n return;\n if (typeof b != \"string\")\n return `${a.slice(0, -1)}${b}\"`;\n if (b[0] === '\"')\n return a.slice(0, -1) + b.slice(1);\n return;\n }\n if (typeof b == \"string\" && b[0] === '\"' && !(a instanceof Name))\n return `\"${a}${b.slice(1)}`;\n return;\n}\nfunction strConcat(c1, c2) {\n return c2.emptyStr() ? c1 : c1.emptyStr() ? c2 : str `${c1}${c2}`;\n}\nexports.strConcat = strConcat;\n// TODO do not allow arrays here\nfunction interpolate(x) {\n return typeof x == \"number\" || typeof x == \"boolean\" || x === null\n ? x\n : safeStringify(Array.isArray(x) ? x.join(\",\") : x);\n}\nfunction stringify(x) {\n return new _Code(safeStringify(x));\n}\nexports.stringify = stringify;\nfunction safeStringify(x) {\n return JSON.stringify(x)\n .replace(/\\u2028/g, \"\\\\u2028\")\n .replace(/\\u2029/g, \"\\\\u2029\");\n}\nexports.safeStringify = safeStringify;\nfunction getProperty(key) {\n return typeof key == \"string\" && exports.IDENTIFIER.test(key) ? new _Code(`.${key}`) : _ `[${key}]`;\n}\nexports.getProperty = getProperty;\n//Does best effort to format the name properly\nfunction getEsmExportName(key) {\n if (typeof key == \"string\" && exports.IDENTIFIER.test(key)) {\n return new _Code(`${key}`);\n }\n throw new Error(`CodeGen: invalid export name: ${key}, use explicit $id name mapping`);\n}\nexports.getEsmExportName = getEsmExportName;\nfunction regexpCode(rx) {\n return new _Code(rx.toString());\n}\nexports.regexpCode = regexpCode;\n//# sourceMappingURL=code.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ValueScope = exports.ValueScopeName = exports.Scope = exports.varKinds = exports.UsedValueState = void 0;\nconst code_1 = require(\"./code\");\nclass ValueError extends Error {\n constructor(name) {\n super(`CodeGen: \"code\" for ${name} not defined`);\n this.value = name.value;\n }\n}\nvar UsedValueState;\n(function (UsedValueState) {\n UsedValueState[UsedValueState[\"Started\"] = 0] = \"Started\";\n UsedValueState[UsedValueState[\"Completed\"] = 1] = \"Completed\";\n})(UsedValueState = exports.UsedValueState || (exports.UsedValueState = {}));\nexports.varKinds = {\n const: new code_1.Name(\"const\"),\n let: new code_1.Name(\"let\"),\n var: new code_1.Name(\"var\"),\n};\nclass Scope {\n constructor({ prefixes, parent } = {}) {\n this._names = {};\n this._prefixes = prefixes;\n this._parent = parent;\n }\n toName(nameOrPrefix) {\n return nameOrPrefix instanceof code_1.Name ? nameOrPrefix : this.name(nameOrPrefix);\n }\n name(prefix) {\n return new code_1.Name(this._newName(prefix));\n }\n _newName(prefix) {\n const ng = this._names[prefix] || this._nameGroup(prefix);\n return `${prefix}${ng.index++}`;\n }\n _nameGroup(prefix) {\n var _a, _b;\n if (((_b = (_a = this._parent) === null || _a === void 0 ? void 0 : _a._prefixes) === null || _b === void 0 ? void 0 : _b.has(prefix)) || (this._prefixes && !this._prefixes.has(prefix))) {\n throw new Error(`CodeGen: prefix \"${prefix}\" is not allowed in this scope`);\n }\n return (this._names[prefix] = { prefix, index: 0 });\n }\n}\nexports.Scope = Scope;\nclass ValueScopeName extends code_1.Name {\n constructor(prefix, nameStr) {\n super(nameStr);\n this.prefix = prefix;\n }\n setValue(value, { property, itemIndex }) {\n this.value = value;\n this.scopePath = (0, code_1._) `.${new code_1.Name(property)}[${itemIndex}]`;\n }\n}\nexports.ValueScopeName = ValueScopeName;\nconst line = (0, code_1._) `\\n`;\nclass ValueScope extends Scope {\n constructor(opts) {\n super(opts);\n this._values = {};\n this._scope = opts.scope;\n this.opts = { ...opts, _n: opts.lines ? line : code_1.nil };\n }\n get() {\n return this._scope;\n }\n name(prefix) {\n return new ValueScopeName(prefix, this._newName(prefix));\n }\n value(nameOrPrefix, value) {\n var _a;\n if (value.ref === undefined)\n throw new Error(\"CodeGen: ref must be passed in value\");\n const name = this.toName(nameOrPrefix);\n const { prefix } = name;\n const valueKey = (_a = value.key) !== null && _a !== void 0 ? _a : value.ref;\n let vs = this._values[prefix];\n if (vs) {\n const _name = vs.get(valueKey);\n if (_name)\n return _name;\n }\n else {\n vs = this._values[prefix] = new Map();\n }\n vs.set(valueKey, name);\n const s = this._scope[prefix] || (this._scope[prefix] = []);\n const itemIndex = s.length;\n s[itemIndex] = value.ref;\n name.setValue(value, { property: prefix, itemIndex });\n return name;\n }\n getValue(prefix, keyOrRef) {\n const vs = this._values[prefix];\n if (!vs)\n return;\n return vs.get(keyOrRef);\n }\n scopeRefs(scopeName, values = this._values) {\n return this._reduceValues(values, (name) => {\n if (name.scopePath === undefined)\n throw new Error(`CodeGen: name \"${name}\" has no value`);\n return (0, code_1._) `${scopeName}${name.scopePath}`;\n });\n }\n scopeCode(values = this._values, usedValues, getCode) {\n return this._reduceValues(values, (name) => {\n if (name.value === undefined)\n throw new Error(`CodeGen: name \"${name}\" has no value`);\n return name.value.code;\n }, usedValues, getCode);\n }\n _reduceValues(values, valueCode, usedValues = {}, getCode) {\n let code = code_1.nil;\n for (const prefix in values) {\n const vs = values[prefix];\n if (!vs)\n continue;\n const nameSet = (usedValues[prefix] = usedValues[prefix] || new Map());\n vs.forEach((name) => {\n if (nameSet.has(name))\n return;\n nameSet.set(name, UsedValueState.Started);\n let c = valueCode(name);\n if (c) {\n const def = this.opts.es5 ? exports.varKinds.var : exports.varKinds.const;\n code = (0, code_1._) `${code}${def} ${name} = ${c};${this.opts._n}`;\n }\n else if ((c = getCode === null || getCode === void 0 ? void 0 : getCode(name))) {\n code = (0, code_1._) `${code}${c}${this.opts._n}`;\n }\n else {\n throw new ValueError(name);\n }\n nameSet.set(name, UsedValueState.Completed);\n });\n }\n return code;\n }\n}\nexports.ValueScope = ValueScope;\n//# sourceMappingURL=scope.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.or = exports.and = exports.not = exports.CodeGen = exports.operators = exports.varKinds = exports.ValueScopeName = exports.ValueScope = exports.Scope = exports.Name = exports.regexpCode = exports.stringify = exports.getProperty = exports.nil = exports.strConcat = exports.str = exports._ = void 0;\nconst code_1 = require(\"./code\");\nconst scope_1 = require(\"./scope\");\nvar code_2 = require(\"./code\");\nObject.defineProperty(exports, \"_\", { enumerable: true, get: function () { return code_2._; } });\nObject.defineProperty(exports, \"str\", { enumerable: true, get: function () { return code_2.str; } });\nObject.defineProperty(exports, \"strConcat\", { enumerable: true, get: function () { return code_2.strConcat; } });\nObject.defineProperty(exports, \"nil\", { enumerable: true, get: function () { return code_2.nil; } });\nObject.defineProperty(exports, \"getProperty\", { enumerable: true, get: function () { return code_2.getProperty; } });\nObject.defineProperty(exports, \"stringify\", { enumerable: true, get: function () { return code_2.stringify; } });\nObject.defineProperty(exports, \"regexpCode\", { enumerable: true, get: function () { return code_2.regexpCode; } });\nObject.defineProperty(exports, \"Name\", { enumerable: true, get: function () { return code_2.Name; } });\nvar scope_2 = require(\"./scope\");\nObject.defineProperty(exports, \"Scope\", { enumerable: true, get: function () { return scope_2.Scope; } });\nObject.defineProperty(exports, \"ValueScope\", { enumerable: true, get: function () { return scope_2.ValueScope; } });\nObject.defineProperty(exports, \"ValueScopeName\", { enumerable: true, get: function () { return scope_2.ValueScopeName; } });\nObject.defineProperty(exports, \"varKinds\", { enumerable: true, get: function () { return scope_2.varKinds; } });\nexports.operators = {\n GT: new code_1._Code(\">\"),\n GTE: new code_1._Code(\">=\"),\n LT: new code_1._Code(\"<\"),\n LTE: new code_1._Code(\"<=\"),\n EQ: new code_1._Code(\"===\"),\n NEQ: new code_1._Code(\"!==\"),\n NOT: new code_1._Code(\"!\"),\n OR: new code_1._Code(\"||\"),\n AND: new code_1._Code(\"&&\"),\n ADD: new code_1._Code(\"+\"),\n};\nclass Node {\n optimizeNodes() {\n return this;\n }\n optimizeNames(_names, _constants) {\n return this;\n }\n}\nclass Def extends Node {\n constructor(varKind, name, rhs) {\n super();\n this.varKind = varKind;\n this.name = name;\n this.rhs = rhs;\n }\n render({ es5, _n }) {\n const varKind = es5 ? scope_1.varKinds.var : this.varKind;\n const rhs = this.rhs === undefined ? \"\" : ` = ${this.rhs}`;\n return `${varKind} ${this.name}${rhs};` + _n;\n }\n optimizeNames(names, constants) {\n if (!names[this.name.str])\n return;\n if (this.rhs)\n this.rhs = optimizeExpr(this.rhs, names, constants);\n return this;\n }\n get names() {\n return this.rhs instanceof code_1._CodeOrName ? this.rhs.names : {};\n }\n}\nclass Assign extends Node {\n constructor(lhs, rhs, sideEffects) {\n super();\n this.lhs = lhs;\n this.rhs = rhs;\n this.sideEffects = sideEffects;\n }\n render({ _n }) {\n return `${this.lhs} = ${this.rhs};` + _n;\n }\n optimizeNames(names, constants) {\n if (this.lhs instanceof code_1.Name && !names[this.lhs.str] && !this.sideEffects)\n return;\n this.rhs = optimizeExpr(this.rhs, names, constants);\n return this;\n }\n get names() {\n const names = this.lhs instanceof code_1.Name ? {} : { ...this.lhs.names };\n return addExprNames(names, this.rhs);\n }\n}\nclass AssignOp extends Assign {\n constructor(lhs, op, rhs, sideEffects) {\n super(lhs, rhs, sideEffects);\n this.op = op;\n }\n render({ _n }) {\n return `${this.lhs} ${this.op}= ${this.rhs};` + _n;\n }\n}\nclass Label extends Node {\n constructor(label) {\n super();\n this.label = label;\n this.names = {};\n }\n render({ _n }) {\n return `${this.label}:` + _n;\n }\n}\nclass Break extends Node {\n constructor(label) {\n super();\n this.label = label;\n this.names = {};\n }\n render({ _n }) {\n const label = this.label ? ` ${this.label}` : \"\";\n return `break${label};` + _n;\n }\n}\nclass Throw extends Node {\n constructor(error) {\n super();\n this.error = error;\n }\n render({ _n }) {\n return `throw ${this.error};` + _n;\n }\n get names() {\n return this.error.names;\n }\n}\nclass AnyCode extends Node {\n constructor(code) {\n super();\n this.code = code;\n }\n render({ _n }) {\n return `${this.code};` + _n;\n }\n optimizeNodes() {\n return `${this.code}` ? this : undefined;\n }\n optimizeNames(names, constants) {\n this.code = optimizeExpr(this.code, names, constants);\n return this;\n }\n get names() {\n return this.code instanceof code_1._CodeOrName ? this.code.names : {};\n }\n}\nclass ParentNode extends Node {\n constructor(nodes = []) {\n super();\n this.nodes = nodes;\n }\n render(opts) {\n return this.nodes.reduce((code, n) => code + n.render(opts), \"\");\n }\n optimizeNodes() {\n const { nodes } = this;\n let i = nodes.length;\n while (i--) {\n const n = nodes[i].optimizeNodes();\n if (Array.isArray(n))\n nodes.splice(i, 1, ...n);\n else if (n)\n nodes[i] = n;\n else\n nodes.splice(i, 1);\n }\n return nodes.length > 0 ? this : undefined;\n }\n optimizeNames(names, constants) {\n const { nodes } = this;\n let i = nodes.length;\n while (i--) {\n // iterating backwards improves 1-pass optimization\n const n = nodes[i];\n if (n.optimizeNames(names, constants))\n continue;\n subtractNames(names, n.names);\n nodes.splice(i, 1);\n }\n return nodes.length > 0 ? this : undefined;\n }\n get names() {\n return this.nodes.reduce((names, n) => addNames(names, n.names), {});\n }\n}\nclass BlockNode extends ParentNode {\n render(opts) {\n return \"{\" + opts._n + super.render(opts) + \"}\" + opts._n;\n }\n}\nclass Root extends ParentNode {\n}\nclass Else extends BlockNode {\n}\nElse.kind = \"else\";\nclass If extends BlockNode {\n constructor(condition, nodes) {\n super(nodes);\n this.condition = condition;\n }\n render(opts) {\n let code = `if(${this.condition})` + super.render(opts);\n if (this.else)\n code += \"else \" + this.else.render(opts);\n return code;\n }\n optimizeNodes() {\n super.optimizeNodes();\n const cond = this.condition;\n if (cond === true)\n return this.nodes; // else is ignored here\n let e = this.else;\n if (e) {\n const ns = e.optimizeNodes();\n e = this.else = Array.isArray(ns) ? new Else(ns) : ns;\n }\n if (e) {\n if (cond === false)\n return e instanceof If ? e : e.nodes;\n if (this.nodes.length)\n return this;\n return new If(not(cond), e instanceof If ? [e] : e.nodes);\n }\n if (cond === false || !this.nodes.length)\n return undefined;\n return this;\n }\n optimizeNames(names, constants) {\n var _a;\n this.else = (_a = this.else) === null || _a === void 0 ? void 0 : _a.optimizeNames(names, constants);\n if (!(super.optimizeNames(names, constants) || this.else))\n return;\n this.condition = optimizeExpr(this.condition, names, constants);\n return this;\n }\n get names() {\n const names = super.names;\n addExprNames(names, this.condition);\n if (this.else)\n addNames(names, this.else.names);\n return names;\n }\n}\nIf.kind = \"if\";\nclass For extends BlockNode {\n}\nFor.kind = \"for\";\nclass ForLoop extends For {\n constructor(iteration) {\n super();\n this.iteration = iteration;\n }\n render(opts) {\n return `for(${this.iteration})` + super.render(opts);\n }\n optimizeNames(names, constants) {\n if (!super.optimizeNames(names, constants))\n return;\n this.iteration = optimizeExpr(this.iteration, names, constants);\n return this;\n }\n get names() {\n return addNames(super.names, this.iteration.names);\n }\n}\nclass ForRange extends For {\n constructor(varKind, name, from, to) {\n super();\n this.varKind = varKind;\n this.name = name;\n this.from = from;\n this.to = to;\n }\n render(opts) {\n const varKind = opts.es5 ? scope_1.varKinds.var : this.varKind;\n const { name, from, to } = this;\n return `for(${varKind} ${name}=${from}; ${name}<${to}; ${name}++)` + super.render(opts);\n }\n get names() {\n const names = addExprNames(super.names, this.from);\n return addExprNames(names, this.to);\n }\n}\nclass ForIter extends For {\n constructor(loop, varKind, name, iterable) {\n super();\n this.loop = loop;\n this.varKind = varKind;\n this.name = name;\n this.iterable = iterable;\n }\n render(opts) {\n return `for(${this.varKind} ${this.name} ${this.loop} ${this.iterable})` + super.render(opts);\n }\n optimizeNames(names, constants) {\n if (!super.optimizeNames(names, constants))\n return;\n this.iterable = optimizeExpr(this.iterable, names, constants);\n return this;\n }\n get names() {\n return addNames(super.names, this.iterable.names);\n }\n}\nclass Func extends BlockNode {\n constructor(name, args, async) {\n super();\n this.name = name;\n this.args = args;\n this.async = async;\n }\n render(opts) {\n const _async = this.async ? \"async \" : \"\";\n return `${_async}function ${this.name}(${this.args})` + super.render(opts);\n }\n}\nFunc.kind = \"func\";\nclass Return extends ParentNode {\n render(opts) {\n return \"return \" + super.render(opts);\n }\n}\nReturn.kind = \"return\";\nclass Try extends BlockNode {\n render(opts) {\n let code = \"try\" + super.render(opts);\n if (this.catch)\n code += this.catch.render(opts);\n if (this.finally)\n code += this.finally.render(opts);\n return code;\n }\n optimizeNodes() {\n var _a, _b;\n super.optimizeNodes();\n (_a = this.catch) === null || _a === void 0 ? void 0 : _a.optimizeNodes();\n (_b = this.finally) === null || _b === void 0 ? void 0 : _b.optimizeNodes();\n return this;\n }\n optimizeNames(names, constants) {\n var _a, _b;\n super.optimizeNames(names, constants);\n (_a = this.catch) === null || _a === void 0 ? void 0 : _a.optimizeNames(names, constants);\n (_b = this.finally) === null || _b === void 0 ? void 0 : _b.optimizeNames(names, constants);\n return this;\n }\n get names() {\n const names = super.names;\n if (this.catch)\n addNames(names, this.catch.names);\n if (this.finally)\n addNames(names, this.finally.names);\n return names;\n }\n}\nclass Catch extends BlockNode {\n constructor(error) {\n super();\n this.error = error;\n }\n render(opts) {\n return `catch(${this.error})` + super.render(opts);\n }\n}\nCatch.kind = \"catch\";\nclass Finally extends BlockNode {\n render(opts) {\n return \"finally\" + super.render(opts);\n }\n}\nFinally.kind = \"finally\";\nclass CodeGen {\n constructor(extScope, opts = {}) {\n this._values = {};\n this._blockStarts = [];\n this._constants = {};\n this.opts = { ...opts, _n: opts.lines ? \"\\n\" : \"\" };\n this._extScope = extScope;\n this._scope = new scope_1.Scope({ parent: extScope });\n this._nodes = [new Root()];\n }\n toString() {\n return this._root.render(this.opts);\n }\n // returns unique name in the internal scope\n name(prefix) {\n return this._scope.name(prefix);\n }\n // reserves unique name in the external scope\n scopeName(prefix) {\n return this._extScope.name(prefix);\n }\n // reserves unique name in the external scope and assigns value to it\n scopeValue(prefixOrName, value) {\n const name = this._extScope.value(prefixOrName, value);\n const vs = this._values[name.prefix] || (this._values[name.prefix] = new Set());\n vs.add(name);\n return name;\n }\n getScopeValue(prefix, keyOrRef) {\n return this._extScope.getValue(prefix, keyOrRef);\n }\n // return code that assigns values in the external scope to the names that are used internally\n // (same names that were returned by gen.scopeName or gen.scopeValue)\n scopeRefs(scopeName) {\n return this._extScope.scopeRefs(scopeName, this._values);\n }\n scopeCode() {\n return this._extScope.scopeCode(this._values);\n }\n _def(varKind, nameOrPrefix, rhs, constant) {\n const name = this._scope.toName(nameOrPrefix);\n if (rhs !== undefined && constant)\n this._constants[name.str] = rhs;\n this._leafNode(new Def(varKind, name, rhs));\n return name;\n }\n // `const` declaration (`var` in es5 mode)\n const(nameOrPrefix, rhs, _constant) {\n return this._def(scope_1.varKinds.const, nameOrPrefix, rhs, _constant);\n }\n // `let` declaration with optional assignment (`var` in es5 mode)\n let(nameOrPrefix, rhs, _constant) {\n return this._def(scope_1.varKinds.let, nameOrPrefix, rhs, _constant);\n }\n // `var` declaration with optional assignment\n var(nameOrPrefix, rhs, _constant) {\n return this._def(scope_1.varKinds.var, nameOrPrefix, rhs, _constant);\n }\n // assignment code\n assign(lhs, rhs, sideEffects) {\n return this._leafNode(new Assign(lhs, rhs, sideEffects));\n }\n // `+=` code\n add(lhs, rhs) {\n return this._leafNode(new AssignOp(lhs, exports.operators.ADD, rhs));\n }\n // appends passed SafeExpr to code or executes Block\n code(c) {\n if (typeof c == \"function\")\n c();\n else if (c !== code_1.nil)\n this._leafNode(new AnyCode(c));\n return this;\n }\n // returns code for object literal for the passed argument list of key-value pairs\n object(...keyValues) {\n const code = [\"{\"];\n for (const [key, value] of keyValues) {\n if (code.length > 1)\n code.push(\",\");\n code.push(key);\n if (key !== value || this.opts.es5) {\n code.push(\":\");\n (0, code_1.addCodeArg)(code, value);\n }\n }\n code.push(\"}\");\n return new code_1._Code(code);\n }\n // `if` clause (or statement if `thenBody` and, optionally, `elseBody` are passed)\n if(condition, thenBody, elseBody) {\n this._blockNode(new If(condition));\n if (thenBody && elseBody) {\n this.code(thenBody).else().code(elseBody).endIf();\n }\n else if (thenBody) {\n this.code(thenBody).endIf();\n }\n else if (elseBody) {\n throw new Error('CodeGen: \"else\" body without \"then\" body');\n }\n return this;\n }\n // `else if` clause - invalid without `if` or after `else` clauses\n elseIf(condition) {\n return this._elseNode(new If(condition));\n }\n // `else` clause - only valid after `if` or `else if` clauses\n else() {\n return this._elseNode(new Else());\n }\n // end `if` statement (needed if gen.if was used only with condition)\n endIf() {\n return this._endBlockNode(If, Else);\n }\n _for(node, forBody) {\n this._blockNode(node);\n if (forBody)\n this.code(forBody).endFor();\n return this;\n }\n // a generic `for` clause (or statement if `forBody` is passed)\n for(iteration, forBody) {\n return this._for(new ForLoop(iteration), forBody);\n }\n // `for` statement for a range of values\n forRange(nameOrPrefix, from, to, forBody, varKind = this.opts.es5 ? scope_1.varKinds.var : scope_1.varKinds.let) {\n const name = this._scope.toName(nameOrPrefix);\n return this._for(new ForRange(varKind, name, from, to), () => forBody(name));\n }\n // `for-of` statement (in es5 mode replace with a normal for loop)\n forOf(nameOrPrefix, iterable, forBody, varKind = scope_1.varKinds.const) {\n const name = this._scope.toName(nameOrPrefix);\n if (this.opts.es5) {\n const arr = iterable instanceof code_1.Name ? iterable : this.var(\"_arr\", iterable);\n return this.forRange(\"_i\", 0, (0, code_1._) `${arr}.length`, (i) => {\n this.var(name, (0, code_1._) `${arr}[${i}]`);\n forBody(name);\n });\n }\n return this._for(new ForIter(\"of\", varKind, name, iterable), () => forBody(name));\n }\n // `for-in` statement.\n // With option `ownProperties` replaced with a `for-of` loop for object keys\n forIn(nameOrPrefix, obj, forBody, varKind = this.opts.es5 ? scope_1.varKinds.var : scope_1.varKinds.const) {\n if (this.opts.ownProperties) {\n return this.forOf(nameOrPrefix, (0, code_1._) `Object.keys(${obj})`, forBody);\n }\n const name = this._scope.toName(nameOrPrefix);\n return this._for(new ForIter(\"in\", varKind, name, obj), () => forBody(name));\n }\n // end `for` loop\n endFor() {\n return this._endBlockNode(For);\n }\n // `label` statement\n label(label) {\n return this._leafNode(new Label(label));\n }\n // `break` statement\n break(label) {\n return this._leafNode(new Break(label));\n }\n // `return` statement\n return(value) {\n const node = new Return();\n this._blockNode(node);\n this.code(value);\n if (node.nodes.length !== 1)\n throw new Error('CodeGen: \"return\" should have one node');\n return this._endBlockNode(Return);\n }\n // `try` statement\n try(tryBody, catchCode, finallyCode) {\n if (!catchCode && !finallyCode)\n throw new Error('CodeGen: \"try\" without \"catch\" and \"finally\"');\n const node = new Try();\n this._blockNode(node);\n this.code(tryBody);\n if (catchCode) {\n const error = this.name(\"e\");\n this._currNode = node.catch = new Catch(error);\n catchCode(error);\n }\n if (finallyCode) {\n this._currNode = node.finally = new Finally();\n this.code(finallyCode);\n }\n return this._endBlockNode(Catch, Finally);\n }\n // `throw` statement\n throw(error) {\n return this._leafNode(new Throw(error));\n }\n // start self-balancing block\n block(body, nodeCount) {\n this._blockStarts.push(this._nodes.length);\n if (body)\n this.code(body).endBlock(nodeCount);\n return this;\n }\n // end the current self-balancing block\n endBlock(nodeCount) {\n const len = this._blockStarts.pop();\n if (len === undefined)\n throw new Error(\"CodeGen: not in self-balancing block\");\n const toClose = this._nodes.length - len;\n if (toClose < 0 || (nodeCount !== undefined && toClose !== nodeCount)) {\n throw new Error(`CodeGen: wrong number of nodes: ${toClose} vs ${nodeCount} expected`);\n }\n this._nodes.length = len;\n return this;\n }\n // `function` heading (or definition if funcBody is passed)\n func(name, args = code_1.nil, async, funcBody) {\n this._blockNode(new Func(name, args, async));\n if (funcBody)\n this.code(funcBody).endFunc();\n return this;\n }\n // end function definition\n endFunc() {\n return this._endBlockNode(Func);\n }\n optimize(n = 1) {\n while (n-- > 0) {\n this._root.optimizeNodes();\n this._root.optimizeNames(this._root.names, this._constants);\n }\n }\n _leafNode(node) {\n this._currNode.nodes.push(node);\n return this;\n }\n _blockNode(node) {\n this._currNode.nodes.push(node);\n this._nodes.push(node);\n }\n _endBlockNode(N1, N2) {\n const n = this._currNode;\n if (n instanceof N1 || (N2 && n instanceof N2)) {\n this._nodes.pop();\n return this;\n }\n throw new Error(`CodeGen: not in block \"${N2 ? `${N1.kind}/${N2.kind}` : N1.kind}\"`);\n }\n _elseNode(node) {\n const n = this._currNode;\n if (!(n instanceof If)) {\n throw new Error('CodeGen: \"else\" without \"if\"');\n }\n this._currNode = n.else = node;\n return this;\n }\n get _root() {\n return this._nodes[0];\n }\n get _currNode() {\n const ns = this._nodes;\n return ns[ns.length - 1];\n }\n set _currNode(node) {\n const ns = this._nodes;\n ns[ns.length - 1] = node;\n }\n}\nexports.CodeGen = CodeGen;\nfunction addNames(names, from) {\n for (const n in from)\n names[n] = (names[n] || 0) + (from[n] || 0);\n return names;\n}\nfunction addExprNames(names, from) {\n return from instanceof code_1._CodeOrName ? addNames(names, from.names) : names;\n}\nfunction optimizeExpr(expr, names, constants) {\n if (expr instanceof code_1.Name)\n return replaceName(expr);\n if (!canOptimize(expr))\n return expr;\n return new code_1._Code(expr._items.reduce((items, c) => {\n if (c instanceof code_1.Name)\n c = replaceName(c);\n if (c instanceof code_1._Code)\n items.push(...c._items);\n else\n items.push(c);\n return items;\n }, []));\n function replaceName(n) {\n const c = constants[n.str];\n if (c === undefined || names[n.str] !== 1)\n return n;\n delete names[n.str];\n return c;\n }\n function canOptimize(e) {\n return (e instanceof code_1._Code &&\n e._items.some((c) => c instanceof code_1.Name && names[c.str] === 1 && constants[c.str] !== undefined));\n }\n}\nfunction subtractNames(names, from) {\n for (const n in from)\n names[n] = (names[n] || 0) - (from[n] || 0);\n}\nfunction not(x) {\n return typeof x == \"boolean\" || typeof x == \"number\" || x === null ? !x : (0, code_1._) `!${par(x)}`;\n}\nexports.not = not;\nconst andCode = mappend(exports.operators.AND);\n// boolean AND (&&) expression with the passed arguments\nfunction and(...args) {\n return args.reduce(andCode);\n}\nexports.and = and;\nconst orCode = mappend(exports.operators.OR);\n// boolean OR (||) expression with the passed arguments\nfunction or(...args) {\n return args.reduce(orCode);\n}\nexports.or = or;\nfunction mappend(op) {\n return (x, y) => (x === code_1.nil ? y : y === code_1.nil ? x : (0, code_1._) `${par(x)} ${op} ${par(y)}`);\n}\nfunction par(x) {\n return x instanceof code_1.Name ? x : (0, code_1._) `(${x})`;\n}\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.checkStrictMode = exports.getErrorPath = exports.Type = exports.useFunc = exports.setEvaluated = exports.evaluatedPropsToName = exports.mergeEvaluated = exports.eachItem = exports.unescapeJsonPointer = exports.escapeJsonPointer = exports.escapeFragment = exports.unescapeFragment = exports.schemaRefOrVal = exports.schemaHasRulesButRef = exports.schemaHasRules = exports.checkUnknownRules = exports.alwaysValidSchema = exports.toHash = void 0;\nconst codegen_1 = require(\"./codegen\");\nconst code_1 = require(\"./codegen/code\");\n// TODO refactor to use Set\nfunction toHash(arr) {\n const hash = {};\n for (const item of arr)\n hash[item] = true;\n return hash;\n}\nexports.toHash = toHash;\nfunction alwaysValidSchema(it, schema) {\n if (typeof schema == \"boolean\")\n return schema;\n if (Object.keys(schema).length === 0)\n return true;\n checkUnknownRules(it, schema);\n return !schemaHasRules(schema, it.self.RULES.all);\n}\nexports.alwaysValidSchema = alwaysValidSchema;\nfunction checkUnknownRules(it, schema = it.schema) {\n const { opts, self } = it;\n if (!opts.strictSchema)\n return;\n if (typeof schema === \"boolean\")\n return;\n const rules = self.RULES.keywords;\n for (const key in schema) {\n if (!rules[key])\n checkStrictMode(it, `unknown keyword: \"${key}\"`);\n }\n}\nexports.checkUnknownRules = checkUnknownRules;\nfunction schemaHasRules(schema, rules) {\n if (typeof schema == \"boolean\")\n return !schema;\n for (const key in schema)\n if (rules[key])\n return true;\n return false;\n}\nexports.schemaHasRules = schemaHasRules;\nfunction schemaHasRulesButRef(schema, RULES) {\n if (typeof schema == \"boolean\")\n return !schema;\n for (const key in schema)\n if (key !== \"$ref\" && RULES.all[key])\n return true;\n return false;\n}\nexports.schemaHasRulesButRef = schemaHasRulesButRef;\nfunction schemaRefOrVal({ topSchemaRef, schemaPath }, schema, keyword, $data) {\n if (!$data) {\n if (typeof schema == \"number\" || typeof schema == \"boolean\")\n return schema;\n if (typeof schema == \"string\")\n return (0, codegen_1._) `${schema}`;\n }\n return (0, codegen_1._) `${topSchemaRef}${schemaPath}${(0, codegen_1.getProperty)(keyword)}`;\n}\nexports.schemaRefOrVal = schemaRefOrVal;\nfunction unescapeFragment(str) {\n return unescapeJsonPointer(decodeURIComponent(str));\n}\nexports.unescapeFragment = unescapeFragment;\nfunction escapeFragment(str) {\n return encodeURIComponent(escapeJsonPointer(str));\n}\nexports.escapeFragment = escapeFragment;\nfunction escapeJsonPointer(str) {\n if (typeof str == \"number\")\n return `${str}`;\n return str.replace(/~/g, \"~0\").replace(/\\//g, \"~1\");\n}\nexports.escapeJsonPointer = escapeJsonPointer;\nfunction unescapeJsonPointer(str) {\n return str.replace(/~1/g, \"/\").replace(/~0/g, \"~\");\n}\nexports.unescapeJsonPointer = unescapeJsonPointer;\nfunction eachItem(xs, f) {\n if (Array.isArray(xs)) {\n for (const x of xs)\n f(x);\n }\n else {\n f(xs);\n }\n}\nexports.eachItem = eachItem;\nfunction makeMergeEvaluated({ mergeNames, mergeToName, mergeValues, resultToName, }) {\n return (gen, from, to, toName) => {\n const res = to === undefined\n ? from\n : to instanceof codegen_1.Name\n ? (from instanceof codegen_1.Name ? mergeNames(gen, from, to) : mergeToName(gen, from, to), to)\n : from instanceof codegen_1.Name\n ? (mergeToName(gen, to, from), from)\n : mergeValues(from, to);\n return toName === codegen_1.Name && !(res instanceof codegen_1.Name) ? resultToName(gen, res) : res;\n };\n}\nexports.mergeEvaluated = {\n props: makeMergeEvaluated({\n mergeNames: (gen, from, to) => gen.if((0, codegen_1._) `${to} !== true && ${from} !== undefined`, () => {\n gen.if((0, codegen_1._) `${from} === true`, () => gen.assign(to, true), () => gen.assign(to, (0, codegen_1._) `${to} || {}`).code((0, codegen_1._) `Object.assign(${to}, ${from})`));\n }),\n mergeToName: (gen, from, to) => gen.if((0, codegen_1._) `${to} !== true`, () => {\n if (from === true) {\n gen.assign(to, true);\n }\n else {\n gen.assign(to, (0, codegen_1._) `${to} || {}`);\n setEvaluated(gen, to, from);\n }\n }),\n mergeValues: (from, to) => (from === true ? true : { ...from, ...to }),\n resultToName: evaluatedPropsToName,\n }),\n items: makeMergeEvaluated({\n mergeNames: (gen, from, to) => gen.if((0, codegen_1._) `${to} !== true && ${from} !== undefined`, () => gen.assign(to, (0, codegen_1._) `${from} === true ? true : ${to} > ${from} ? ${to} : ${from}`)),\n mergeToName: (gen, from, to) => gen.if((0, codegen_1._) `${to} !== true`, () => gen.assign(to, from === true ? true : (0, codegen_1._) `${to} > ${from} ? ${to} : ${from}`)),\n mergeValues: (from, to) => (from === true ? true : Math.max(from, to)),\n resultToName: (gen, items) => gen.var(\"items\", items),\n }),\n};\nfunction evaluatedPropsToName(gen, ps) {\n if (ps === true)\n return gen.var(\"props\", true);\n const props = gen.var(\"props\", (0, codegen_1._) `{}`);\n if (ps !== undefined)\n setEvaluated(gen, props, ps);\n return props;\n}\nexports.evaluatedPropsToName = evaluatedPropsToName;\nfunction setEvaluated(gen, props, ps) {\n Object.keys(ps).forEach((p) => gen.assign((0, codegen_1._) `${props}${(0, codegen_1.getProperty)(p)}`, true));\n}\nexports.setEvaluated = setEvaluated;\nconst snippets = {};\nfunction useFunc(gen, f) {\n return gen.scopeValue(\"func\", {\n ref: f,\n code: snippets[f.code] || (snippets[f.code] = new code_1._Code(f.code)),\n });\n}\nexports.useFunc = useFunc;\nvar Type;\n(function (Type) {\n Type[Type[\"Num\"] = 0] = \"Num\";\n Type[Type[\"Str\"] = 1] = \"Str\";\n})(Type = exports.Type || (exports.Type = {}));\nfunction getErrorPath(dataProp, dataPropType, jsPropertySyntax) {\n // let path\n if (dataProp instanceof codegen_1.Name) {\n const isNumber = dataPropType === Type.Num;\n return jsPropertySyntax\n ? isNumber\n ? (0, codegen_1._) `\"[\" + ${dataProp} + \"]\"`\n : (0, codegen_1._) `\"['\" + ${dataProp} + \"']\"`\n : isNumber\n ? (0, codegen_1._) `\"/\" + ${dataProp}`\n : (0, codegen_1._) `\"/\" + ${dataProp}.replace(/~/g, \"~0\").replace(/\\\\//g, \"~1\")`; // TODO maybe use global escapePointer\n }\n return jsPropertySyntax ? (0, codegen_1.getProperty)(dataProp).toString() : \"/\" + escapeJsonPointer(dataProp);\n}\nexports.getErrorPath = getErrorPath;\nfunction checkStrictMode(it, msg, mode = it.opts.strictSchema) {\n if (!mode)\n return;\n msg = `strict mode: ${msg}`;\n if (mode === true)\n throw new Error(msg);\n it.self.logger.warn(msg);\n}\nexports.checkStrictMode = checkStrictMode;\n//# sourceMappingURL=util.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"./codegen\");\nconst names = {\n // validation function arguments\n data: new codegen_1.Name(\"data\"),\n // args passed from referencing schema\n valCxt: new codegen_1.Name(\"valCxt\"),\n instancePath: new codegen_1.Name(\"instancePath\"),\n parentData: new codegen_1.Name(\"parentData\"),\n parentDataProperty: new codegen_1.Name(\"parentDataProperty\"),\n rootData: new codegen_1.Name(\"rootData\"),\n dynamicAnchors: new codegen_1.Name(\"dynamicAnchors\"),\n // function scoped variables\n vErrors: new codegen_1.Name(\"vErrors\"),\n errors: new codegen_1.Name(\"errors\"),\n this: new codegen_1.Name(\"this\"),\n // \"globals\"\n self: new codegen_1.Name(\"self\"),\n scope: new codegen_1.Name(\"scope\"),\n // JTD serialize/parse name for JSON string and position\n json: new codegen_1.Name(\"json\"),\n jsonPos: new codegen_1.Name(\"jsonPos\"),\n jsonLen: new codegen_1.Name(\"jsonLen\"),\n jsonPart: new codegen_1.Name(\"jsonPart\"),\n};\nexports.default = names;\n//# sourceMappingURL=names.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.extendErrors = exports.resetErrorsCount = exports.reportExtraError = exports.reportError = exports.keyword$DataError = exports.keywordError = void 0;\nconst codegen_1 = require(\"./codegen\");\nconst util_1 = require(\"./util\");\nconst names_1 = require(\"./names\");\nexports.keywordError = {\n message: ({ keyword }) => (0, codegen_1.str) `must pass \"${keyword}\" keyword validation`,\n};\nexports.keyword$DataError = {\n message: ({ keyword, schemaType }) => schemaType\n ? (0, codegen_1.str) `\"${keyword}\" keyword must be ${schemaType} ($data)`\n : (0, codegen_1.str) `\"${keyword}\" keyword is invalid ($data)`,\n};\nfunction reportError(cxt, error = exports.keywordError, errorPaths, overrideAllErrors) {\n const { it } = cxt;\n const { gen, compositeRule, allErrors } = it;\n const errObj = errorObjectCode(cxt, error, errorPaths);\n if (overrideAllErrors !== null && overrideAllErrors !== void 0 ? overrideAllErrors : (compositeRule || allErrors)) {\n addError(gen, errObj);\n }\n else {\n returnErrors(it, (0, codegen_1._) `[${errObj}]`);\n }\n}\nexports.reportError = reportError;\nfunction reportExtraError(cxt, error = exports.keywordError, errorPaths) {\n const { it } = cxt;\n const { gen, compositeRule, allErrors } = it;\n const errObj = errorObjectCode(cxt, error, errorPaths);\n addError(gen, errObj);\n if (!(compositeRule || allErrors)) {\n returnErrors(it, names_1.default.vErrors);\n }\n}\nexports.reportExtraError = reportExtraError;\nfunction resetErrorsCount(gen, errsCount) {\n gen.assign(names_1.default.errors, errsCount);\n gen.if((0, codegen_1._) `${names_1.default.vErrors} !== null`, () => gen.if(errsCount, () => gen.assign((0, codegen_1._) `${names_1.default.vErrors}.length`, errsCount), () => gen.assign(names_1.default.vErrors, null)));\n}\nexports.resetErrorsCount = resetErrorsCount;\nfunction extendErrors({ gen, keyword, schemaValue, data, errsCount, it, }) {\n /* istanbul ignore if */\n if (errsCount === undefined)\n throw new Error(\"ajv implementation error\");\n const err = gen.name(\"err\");\n gen.forRange(\"i\", errsCount, names_1.default.errors, (i) => {\n gen.const(err, (0, codegen_1._) `${names_1.default.vErrors}[${i}]`);\n gen.if((0, codegen_1._) `${err}.instancePath === undefined`, () => gen.assign((0, codegen_1._) `${err}.instancePath`, (0, codegen_1.strConcat)(names_1.default.instancePath, it.errorPath)));\n gen.assign((0, codegen_1._) `${err}.schemaPath`, (0, codegen_1.str) `${it.errSchemaPath}/${keyword}`);\n if (it.opts.verbose) {\n gen.assign((0, codegen_1._) `${err}.schema`, schemaValue);\n gen.assign((0, codegen_1._) `${err}.data`, data);\n }\n });\n}\nexports.extendErrors = extendErrors;\nfunction addError(gen, errObj) {\n const err = gen.const(\"err\", errObj);\n gen.if((0, codegen_1._) `${names_1.default.vErrors} === null`, () => gen.assign(names_1.default.vErrors, (0, codegen_1._) `[${err}]`), (0, codegen_1._) `${names_1.default.vErrors}.push(${err})`);\n gen.code((0, codegen_1._) `${names_1.default.errors}++`);\n}\nfunction returnErrors(it, errs) {\n const { gen, validateName, schemaEnv } = it;\n if (schemaEnv.$async) {\n gen.throw((0, codegen_1._) `new ${it.ValidationError}(${errs})`);\n }\n else {\n gen.assign((0, codegen_1._) `${validateName}.errors`, errs);\n gen.return(false);\n }\n}\nconst E = {\n keyword: new codegen_1.Name(\"keyword\"),\n schemaPath: new codegen_1.Name(\"schemaPath\"),\n params: new codegen_1.Name(\"params\"),\n propertyName: new codegen_1.Name(\"propertyName\"),\n message: new codegen_1.Name(\"message\"),\n schema: new codegen_1.Name(\"schema\"),\n parentSchema: new codegen_1.Name(\"parentSchema\"),\n};\nfunction errorObjectCode(cxt, error, errorPaths) {\n const { createErrors } = cxt.it;\n if (createErrors === false)\n return (0, codegen_1._) `{}`;\n return errorObject(cxt, error, errorPaths);\n}\nfunction errorObject(cxt, error, errorPaths = {}) {\n const { gen, it } = cxt;\n const keyValues = [\n errorInstancePath(it, errorPaths),\n errorSchemaPath(cxt, errorPaths),\n ];\n extraErrorProps(cxt, error, keyValues);\n return gen.object(...keyValues);\n}\nfunction errorInstancePath({ errorPath }, { instancePath }) {\n const instPath = instancePath\n ? (0, codegen_1.str) `${errorPath}${(0, util_1.getErrorPath)(instancePath, util_1.Type.Str)}`\n : errorPath;\n return [names_1.default.instancePath, (0, codegen_1.strConcat)(names_1.default.instancePath, instPath)];\n}\nfunction errorSchemaPath({ keyword, it: { errSchemaPath } }, { schemaPath, parentSchema }) {\n let schPath = parentSchema ? errSchemaPath : (0, codegen_1.str) `${errSchemaPath}/${keyword}`;\n if (schemaPath) {\n schPath = (0, codegen_1.str) `${schPath}${(0, util_1.getErrorPath)(schemaPath, util_1.Type.Str)}`;\n }\n return [E.schemaPath, schPath];\n}\nfunction extraErrorProps(cxt, { params, message }, keyValues) {\n const { keyword, data, schemaValue, it } = cxt;\n const { opts, propertyName, topSchemaRef, schemaPath } = it;\n keyValues.push([E.keyword, keyword], [E.params, typeof params == \"function\" ? params(cxt) : params || (0, codegen_1._) `{}`]);\n if (opts.messages) {\n keyValues.push([E.message, typeof message == \"function\" ? message(cxt) : message]);\n }\n if (opts.verbose) {\n keyValues.push([E.schema, schemaValue], [E.parentSchema, (0, codegen_1._) `${topSchemaRef}${schemaPath}`], [names_1.default.data, data]);\n }\n if (propertyName)\n keyValues.push([E.propertyName, propertyName]);\n}\n//# sourceMappingURL=errors.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.boolOrEmptySchema = exports.topBoolOrEmptySchema = void 0;\nconst errors_1 = require(\"../errors\");\nconst codegen_1 = require(\"../codegen\");\nconst names_1 = require(\"../names\");\nconst boolError = {\n message: \"boolean schema is false\",\n};\nfunction topBoolOrEmptySchema(it) {\n const { gen, schema, validateName } = it;\n if (schema === false) {\n falseSchemaError(it, false);\n }\n else if (typeof schema == \"object\" && schema.$async === true) {\n gen.return(names_1.default.data);\n }\n else {\n gen.assign((0, codegen_1._) `${validateName}.errors`, null);\n gen.return(true);\n }\n}\nexports.topBoolOrEmptySchema = topBoolOrEmptySchema;\nfunction boolOrEmptySchema(it, valid) {\n const { gen, schema } = it;\n if (schema === false) {\n gen.var(valid, false); // TODO var\n falseSchemaError(it);\n }\n else {\n gen.var(valid, true); // TODO var\n }\n}\nexports.boolOrEmptySchema = boolOrEmptySchema;\nfunction falseSchemaError(it, overrideAllErrors) {\n const { gen, data } = it;\n // TODO maybe some other interface should be used for non-keyword validation errors...\n const cxt = {\n gen,\n keyword: \"false schema\",\n data,\n schema: false,\n schemaCode: false,\n schemaValue: false,\n params: {},\n it,\n };\n (0, errors_1.reportError)(cxt, boolError, undefined, overrideAllErrors);\n}\n//# sourceMappingURL=boolSchema.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getRules = exports.isJSONType = void 0;\nconst _jsonTypes = [\"string\", \"number\", \"integer\", \"boolean\", \"null\", \"object\", \"array\"];\nconst jsonTypes = new Set(_jsonTypes);\nfunction isJSONType(x) {\n return typeof x == \"string\" && jsonTypes.has(x);\n}\nexports.isJSONType = isJSONType;\nfunction getRules() {\n const groups = {\n number: { type: \"number\", rules: [] },\n string: { type: \"string\", rules: [] },\n array: { type: \"array\", rules: [] },\n object: { type: \"object\", rules: [] },\n };\n return {\n types: { ...groups, integer: true, boolean: true, null: true },\n rules: [{ rules: [] }, groups.number, groups.string, groups.array, groups.object],\n post: { rules: [] },\n all: {},\n keywords: {},\n };\n}\nexports.getRules = getRules;\n//# sourceMappingURL=rules.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.shouldUseRule = exports.shouldUseGroup = exports.schemaHasRulesForType = void 0;\nfunction schemaHasRulesForType({ schema, self }, type) {\n const group = self.RULES.types[type];\n return group && group !== true && shouldUseGroup(schema, group);\n}\nexports.schemaHasRulesForType = schemaHasRulesForType;\nfunction shouldUseGroup(schema, group) {\n return group.rules.some((rule) => shouldUseRule(schema, rule));\n}\nexports.shouldUseGroup = shouldUseGroup;\nfunction shouldUseRule(schema, rule) {\n var _a;\n return (schema[rule.keyword] !== undefined ||\n ((_a = rule.definition.implements) === null || _a === void 0 ? void 0 : _a.some((kwd) => schema[kwd] !== undefined)));\n}\nexports.shouldUseRule = shouldUseRule;\n//# sourceMappingURL=applicability.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.reportTypeError = exports.checkDataTypes = exports.checkDataType = exports.coerceAndCheckDataType = exports.getJSONTypes = exports.getSchemaTypes = exports.DataType = void 0;\nconst rules_1 = require(\"../rules\");\nconst applicability_1 = require(\"./applicability\");\nconst errors_1 = require(\"../errors\");\nconst codegen_1 = require(\"../codegen\");\nconst util_1 = require(\"../util\");\nvar DataType;\n(function (DataType) {\n DataType[DataType[\"Correct\"] = 0] = \"Correct\";\n DataType[DataType[\"Wrong\"] = 1] = \"Wrong\";\n})(DataType = exports.DataType || (exports.DataType = {}));\nfunction getSchemaTypes(schema) {\n const types = getJSONTypes(schema.type);\n const hasNull = types.includes(\"null\");\n if (hasNull) {\n if (schema.nullable === false)\n throw new Error(\"type: null contradicts nullable: false\");\n }\n else {\n if (!types.length && schema.nullable !== undefined) {\n throw new Error('\"nullable\" cannot be used without \"type\"');\n }\n if (schema.nullable === true)\n types.push(\"null\");\n }\n return types;\n}\nexports.getSchemaTypes = getSchemaTypes;\nfunction getJSONTypes(ts) {\n const types = Array.isArray(ts) ? ts : ts ? [ts] : [];\n if (types.every(rules_1.isJSONType))\n return types;\n throw new Error(\"type must be JSONType or JSONType[]: \" + types.join(\",\"));\n}\nexports.getJSONTypes = getJSONTypes;\nfunction coerceAndCheckDataType(it, types) {\n const { gen, data, opts } = it;\n const coerceTo = coerceToTypes(types, opts.coerceTypes);\n const checkTypes = types.length > 0 &&\n !(coerceTo.length === 0 && types.length === 1 && (0, applicability_1.schemaHasRulesForType)(it, types[0]));\n if (checkTypes) {\n const wrongType = checkDataTypes(types, data, opts.strictNumbers, DataType.Wrong);\n gen.if(wrongType, () => {\n if (coerceTo.length)\n coerceData(it, types, coerceTo);\n else\n reportTypeError(it);\n });\n }\n return checkTypes;\n}\nexports.coerceAndCheckDataType = coerceAndCheckDataType;\nconst COERCIBLE = new Set([\"string\", \"number\", \"integer\", \"boolean\", \"null\"]);\nfunction coerceToTypes(types, coerceTypes) {\n return coerceTypes\n ? types.filter((t) => COERCIBLE.has(t) || (coerceTypes === \"array\" && t === \"array\"))\n : [];\n}\nfunction coerceData(it, types, coerceTo) {\n const { gen, data, opts } = it;\n const dataType = gen.let(\"dataType\", (0, codegen_1._) `typeof ${data}`);\n const coerced = gen.let(\"coerced\", (0, codegen_1._) `undefined`);\n if (opts.coerceTypes === \"array\") {\n gen.if((0, codegen_1._) `${dataType} == 'object' && Array.isArray(${data}) && ${data}.length == 1`, () => gen\n .assign(data, (0, codegen_1._) `${data}[0]`)\n .assign(dataType, (0, codegen_1._) `typeof ${data}`)\n .if(checkDataTypes(types, data, opts.strictNumbers), () => gen.assign(coerced, data)));\n }\n gen.if((0, codegen_1._) `${coerced} !== undefined`);\n for (const t of coerceTo) {\n if (COERCIBLE.has(t) || (t === \"array\" && opts.coerceTypes === \"array\")) {\n coerceSpecificType(t);\n }\n }\n gen.else();\n reportTypeError(it);\n gen.endIf();\n gen.if((0, codegen_1._) `${coerced} !== undefined`, () => {\n gen.assign(data, coerced);\n assignParentData(it, coerced);\n });\n function coerceSpecificType(t) {\n switch (t) {\n case \"string\":\n gen\n .elseIf((0, codegen_1._) `${dataType} == \"number\" || ${dataType} == \"boolean\"`)\n .assign(coerced, (0, codegen_1._) `\"\" + ${data}`)\n .elseIf((0, codegen_1._) `${data} === null`)\n .assign(coerced, (0, codegen_1._) `\"\"`);\n return;\n case \"number\":\n gen\n .elseIf((0, codegen_1._) `${dataType} == \"boolean\" || ${data} === null\n || (${dataType} == \"string\" && ${data} && ${data} == +${data})`)\n .assign(coerced, (0, codegen_1._) `+${data}`);\n return;\n case \"integer\":\n gen\n .elseIf((0, codegen_1._) `${dataType} === \"boolean\" || ${data} === null\n || (${dataType} === \"string\" && ${data} && ${data} == +${data} && !(${data} % 1))`)\n .assign(coerced, (0, codegen_1._) `+${data}`);\n return;\n case \"boolean\":\n gen\n .elseIf((0, codegen_1._) `${data} === \"false\" || ${data} === 0 || ${data} === null`)\n .assign(coerced, false)\n .elseIf((0, codegen_1._) `${data} === \"true\" || ${data} === 1`)\n .assign(coerced, true);\n return;\n case \"null\":\n gen.elseIf((0, codegen_1._) `${data} === \"\" || ${data} === 0 || ${data} === false`);\n gen.assign(coerced, null);\n return;\n case \"array\":\n gen\n .elseIf((0, codegen_1._) `${dataType} === \"string\" || ${dataType} === \"number\"\n || ${dataType} === \"boolean\" || ${data} === null`)\n .assign(coerced, (0, codegen_1._) `[${data}]`);\n }\n }\n}\nfunction assignParentData({ gen, parentData, parentDataProperty }, expr) {\n // TODO use gen.property\n gen.if((0, codegen_1._) `${parentData} !== undefined`, () => gen.assign((0, codegen_1._) `${parentData}[${parentDataProperty}]`, expr));\n}\nfunction checkDataType(dataType, data, strictNums, correct = DataType.Correct) {\n const EQ = correct === DataType.Correct ? codegen_1.operators.EQ : codegen_1.operators.NEQ;\n let cond;\n switch (dataType) {\n case \"null\":\n return (0, codegen_1._) `${data} ${EQ} null`;\n case \"array\":\n cond = (0, codegen_1._) `Array.isArray(${data})`;\n break;\n case \"object\":\n cond = (0, codegen_1._) `${data} && typeof ${data} == \"object\" && !Array.isArray(${data})`;\n break;\n case \"integer\":\n cond = numCond((0, codegen_1._) `!(${data} % 1) && !isNaN(${data})`);\n break;\n case \"number\":\n cond = numCond();\n break;\n default:\n return (0, codegen_1._) `typeof ${data} ${EQ} ${dataType}`;\n }\n return correct === DataType.Correct ? cond : (0, codegen_1.not)(cond);\n function numCond(_cond = codegen_1.nil) {\n return (0, codegen_1.and)((0, codegen_1._) `typeof ${data} == \"number\"`, _cond, strictNums ? (0, codegen_1._) `isFinite(${data})` : codegen_1.nil);\n }\n}\nexports.checkDataType = checkDataType;\nfunction checkDataTypes(dataTypes, data, strictNums, correct) {\n if (dataTypes.length === 1) {\n return checkDataType(dataTypes[0], data, strictNums, correct);\n }\n let cond;\n const types = (0, util_1.toHash)(dataTypes);\n if (types.array && types.object) {\n const notObj = (0, codegen_1._) `typeof ${data} != \"object\"`;\n cond = types.null ? notObj : (0, codegen_1._) `!${data} || ${notObj}`;\n delete types.null;\n delete types.array;\n delete types.object;\n }\n else {\n cond = codegen_1.nil;\n }\n if (types.number)\n delete types.integer;\n for (const t in types)\n cond = (0, codegen_1.and)(cond, checkDataType(t, data, strictNums, correct));\n return cond;\n}\nexports.checkDataTypes = checkDataTypes;\nconst typeError = {\n message: ({ schema }) => `must be ${schema}`,\n params: ({ schema, schemaValue }) => typeof schema == \"string\" ? (0, codegen_1._) `{type: ${schema}}` : (0, codegen_1._) `{type: ${schemaValue}}`,\n};\nfunction reportTypeError(it) {\n const cxt = getTypeErrorContext(it);\n (0, errors_1.reportError)(cxt, typeError);\n}\nexports.reportTypeError = reportTypeError;\nfunction getTypeErrorContext(it) {\n const { gen, data, schema } = it;\n const schemaCode = (0, util_1.schemaRefOrVal)(it, schema, \"type\");\n return {\n gen,\n keyword: \"type\",\n data,\n schema: schema.type,\n schemaCode,\n schemaValue: schemaCode,\n parentSchema: schema,\n params: {},\n it,\n };\n}\n//# sourceMappingURL=dataType.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.assignDefaults = void 0;\nconst codegen_1 = require(\"../codegen\");\nconst util_1 = require(\"../util\");\nfunction assignDefaults(it, ty) {\n const { properties, items } = it.schema;\n if (ty === \"object\" && properties) {\n for (const key in properties) {\n assignDefault(it, key, properties[key].default);\n }\n }\n else if (ty === \"array\" && Array.isArray(items)) {\n items.forEach((sch, i) => assignDefault(it, i, sch.default));\n }\n}\nexports.assignDefaults = assignDefaults;\nfunction assignDefault(it, prop, defaultValue) {\n const { gen, compositeRule, data, opts } = it;\n if (defaultValue === undefined)\n return;\n const childData = (0, codegen_1._) `${data}${(0, codegen_1.getProperty)(prop)}`;\n if (compositeRule) {\n (0, util_1.checkStrictMode)(it, `default is ignored for: ${childData}`);\n return;\n }\n let condition = (0, codegen_1._) `${childData} === undefined`;\n if (opts.useDefaults === \"empty\") {\n condition = (0, codegen_1._) `${condition} || ${childData} === null || ${childData} === \"\"`;\n }\n // `${childData} === undefined` +\n // (opts.useDefaults === \"empty\" ? ` || ${childData} === null || ${childData} === \"\"` : \"\")\n gen.if(condition, (0, codegen_1._) `${childData} = ${(0, codegen_1.stringify)(defaultValue)}`);\n}\n//# sourceMappingURL=defaults.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateUnion = exports.validateArray = exports.usePattern = exports.callValidateCode = exports.schemaProperties = exports.allSchemaProperties = exports.noPropertyInData = exports.propertyInData = exports.isOwnProperty = exports.hasPropFunc = exports.reportMissingProp = exports.checkMissingProp = exports.checkReportMissingProp = void 0;\nconst codegen_1 = require(\"../compile/codegen\");\nconst util_1 = require(\"../compile/util\");\nconst names_1 = require(\"../compile/names\");\nconst util_2 = require(\"../compile/util\");\nfunction checkReportMissingProp(cxt, prop) {\n const { gen, data, it } = cxt;\n gen.if(noPropertyInData(gen, data, prop, it.opts.ownProperties), () => {\n cxt.setParams({ missingProperty: (0, codegen_1._) `${prop}` }, true);\n cxt.error();\n });\n}\nexports.checkReportMissingProp = checkReportMissingProp;\nfunction checkMissingProp({ gen, data, it: { opts } }, properties, missing) {\n return (0, codegen_1.or)(...properties.map((prop) => (0, codegen_1.and)(noPropertyInData(gen, data, prop, opts.ownProperties), (0, codegen_1._) `${missing} = ${prop}`)));\n}\nexports.checkMissingProp = checkMissingProp;\nfunction reportMissingProp(cxt, missing) {\n cxt.setParams({ missingProperty: missing }, true);\n cxt.error();\n}\nexports.reportMissingProp = reportMissingProp;\nfunction hasPropFunc(gen) {\n return gen.scopeValue(\"func\", {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n ref: Object.prototype.hasOwnProperty,\n code: (0, codegen_1._) `Object.prototype.hasOwnProperty`,\n });\n}\nexports.hasPropFunc = hasPropFunc;\nfunction isOwnProperty(gen, data, property) {\n return (0, codegen_1._) `${hasPropFunc(gen)}.call(${data}, ${property})`;\n}\nexports.isOwnProperty = isOwnProperty;\nfunction propertyInData(gen, data, property, ownProperties) {\n const cond = (0, codegen_1._) `${data}${(0, codegen_1.getProperty)(property)} !== undefined`;\n return ownProperties ? (0, codegen_1._) `${cond} && ${isOwnProperty(gen, data, property)}` : cond;\n}\nexports.propertyInData = propertyInData;\nfunction noPropertyInData(gen, data, property, ownProperties) {\n const cond = (0, codegen_1._) `${data}${(0, codegen_1.getProperty)(property)} === undefined`;\n return ownProperties ? (0, codegen_1.or)(cond, (0, codegen_1.not)(isOwnProperty(gen, data, property))) : cond;\n}\nexports.noPropertyInData = noPropertyInData;\nfunction allSchemaProperties(schemaMap) {\n return schemaMap ? Object.keys(schemaMap).filter((p) => p !== \"__proto__\") : [];\n}\nexports.allSchemaProperties = allSchemaProperties;\nfunction schemaProperties(it, schemaMap) {\n return allSchemaProperties(schemaMap).filter((p) => !(0, util_1.alwaysValidSchema)(it, schemaMap[p]));\n}\nexports.schemaProperties = schemaProperties;\nfunction callValidateCode({ schemaCode, data, it: { gen, topSchemaRef, schemaPath, errorPath }, it }, func, context, passSchema) {\n const dataAndSchema = passSchema ? (0, codegen_1._) `${schemaCode}, ${data}, ${topSchemaRef}${schemaPath}` : data;\n const valCxt = [\n [names_1.default.instancePath, (0, codegen_1.strConcat)(names_1.default.instancePath, errorPath)],\n [names_1.default.parentData, it.parentData],\n [names_1.default.parentDataProperty, it.parentDataProperty],\n [names_1.default.rootData, names_1.default.rootData],\n ];\n if (it.opts.dynamicRef)\n valCxt.push([names_1.default.dynamicAnchors, names_1.default.dynamicAnchors]);\n const args = (0, codegen_1._) `${dataAndSchema}, ${gen.object(...valCxt)}`;\n return context !== codegen_1.nil ? (0, codegen_1._) `${func}.call(${context}, ${args})` : (0, codegen_1._) `${func}(${args})`;\n}\nexports.callValidateCode = callValidateCode;\nconst newRegExp = (0, codegen_1._) `new RegExp`;\nfunction usePattern({ gen, it: { opts } }, pattern) {\n const u = opts.unicodeRegExp ? \"u\" : \"\";\n const { regExp } = opts.code;\n const rx = regExp(pattern, u);\n return gen.scopeValue(\"pattern\", {\n key: rx.toString(),\n ref: rx,\n code: (0, codegen_1._) `${regExp.code === \"new RegExp\" ? newRegExp : (0, util_2.useFunc)(gen, regExp)}(${pattern}, ${u})`,\n });\n}\nexports.usePattern = usePattern;\nfunction validateArray(cxt) {\n const { gen, data, keyword, it } = cxt;\n const valid = gen.name(\"valid\");\n if (it.allErrors) {\n const validArr = gen.let(\"valid\", true);\n validateItems(() => gen.assign(validArr, false));\n return validArr;\n }\n gen.var(valid, true);\n validateItems(() => gen.break());\n return valid;\n function validateItems(notValid) {\n const len = gen.const(\"len\", (0, codegen_1._) `${data}.length`);\n gen.forRange(\"i\", 0, len, (i) => {\n cxt.subschema({\n keyword,\n dataProp: i,\n dataPropType: util_1.Type.Num,\n }, valid);\n gen.if((0, codegen_1.not)(valid), notValid);\n });\n }\n}\nexports.validateArray = validateArray;\nfunction validateUnion(cxt) {\n const { gen, schema, keyword, it } = cxt;\n /* istanbul ignore if */\n if (!Array.isArray(schema))\n throw new Error(\"ajv implementation error\");\n const alwaysValid = schema.some((sch) => (0, util_1.alwaysValidSchema)(it, sch));\n if (alwaysValid && !it.opts.unevaluated)\n return;\n const valid = gen.let(\"valid\", false);\n const schValid = gen.name(\"_valid\");\n gen.block(() => schema.forEach((_sch, i) => {\n const schCxt = cxt.subschema({\n keyword,\n schemaProp: i,\n compositeRule: true,\n }, schValid);\n gen.assign(valid, (0, codegen_1._) `${valid} || ${schValid}`);\n const merged = cxt.mergeValidEvaluated(schCxt, schValid);\n // can short-circuit if `unevaluatedProperties/Items` not supported (opts.unevaluated !== true)\n // or if all properties and items were evaluated (it.props === true && it.items === true)\n if (!merged)\n gen.if((0, codegen_1.not)(valid));\n }));\n cxt.result(valid, () => cxt.reset(), () => cxt.error(true));\n}\nexports.validateUnion = validateUnion;\n//# sourceMappingURL=code.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateKeywordUsage = exports.validSchemaType = exports.funcKeywordCode = exports.macroKeywordCode = void 0;\nconst codegen_1 = require(\"../codegen\");\nconst names_1 = require(\"../names\");\nconst code_1 = require(\"../../vocabularies/code\");\nconst errors_1 = require(\"../errors\");\nfunction macroKeywordCode(cxt, def) {\n const { gen, keyword, schema, parentSchema, it } = cxt;\n const macroSchema = def.macro.call(it.self, schema, parentSchema, it);\n const schemaRef = useKeyword(gen, keyword, macroSchema);\n if (it.opts.validateSchema !== false)\n it.self.validateSchema(macroSchema, true);\n const valid = gen.name(\"valid\");\n cxt.subschema({\n schema: macroSchema,\n schemaPath: codegen_1.nil,\n errSchemaPath: `${it.errSchemaPath}/${keyword}`,\n topSchemaRef: schemaRef,\n compositeRule: true,\n }, valid);\n cxt.pass(valid, () => cxt.error(true));\n}\nexports.macroKeywordCode = macroKeywordCode;\nfunction funcKeywordCode(cxt, def) {\n var _a;\n const { gen, keyword, schema, parentSchema, $data, it } = cxt;\n checkAsyncKeyword(it, def);\n const validate = !$data && def.compile ? def.compile.call(it.self, schema, parentSchema, it) : def.validate;\n const validateRef = useKeyword(gen, keyword, validate);\n const valid = gen.let(\"valid\");\n cxt.block$data(valid, validateKeyword);\n cxt.ok((_a = def.valid) !== null && _a !== void 0 ? _a : valid);\n function validateKeyword() {\n if (def.errors === false) {\n assignValid();\n if (def.modifying)\n modifyData(cxt);\n reportErrs(() => cxt.error());\n }\n else {\n const ruleErrs = def.async ? validateAsync() : validateSync();\n if (def.modifying)\n modifyData(cxt);\n reportErrs(() => addErrs(cxt, ruleErrs));\n }\n }\n function validateAsync() {\n const ruleErrs = gen.let(\"ruleErrs\", null);\n gen.try(() => assignValid((0, codegen_1._) `await `), (e) => gen.assign(valid, false).if((0, codegen_1._) `${e} instanceof ${it.ValidationError}`, () => gen.assign(ruleErrs, (0, codegen_1._) `${e}.errors`), () => gen.throw(e)));\n return ruleErrs;\n }\n function validateSync() {\n const validateErrs = (0, codegen_1._) `${validateRef}.errors`;\n gen.assign(validateErrs, null);\n assignValid(codegen_1.nil);\n return validateErrs;\n }\n function assignValid(_await = def.async ? (0, codegen_1._) `await ` : codegen_1.nil) {\n const passCxt = it.opts.passContext ? names_1.default.this : names_1.default.self;\n const passSchema = !((\"compile\" in def && !$data) || def.schema === false);\n gen.assign(valid, (0, codegen_1._) `${_await}${(0, code_1.callValidateCode)(cxt, validateRef, passCxt, passSchema)}`, def.modifying);\n }\n function reportErrs(errors) {\n var _a;\n gen.if((0, codegen_1.not)((_a = def.valid) !== null && _a !== void 0 ? _a : valid), errors);\n }\n}\nexports.funcKeywordCode = funcKeywordCode;\nfunction modifyData(cxt) {\n const { gen, data, it } = cxt;\n gen.if(it.parentData, () => gen.assign(data, (0, codegen_1._) `${it.parentData}[${it.parentDataProperty}]`));\n}\nfunction addErrs(cxt, errs) {\n const { gen } = cxt;\n gen.if((0, codegen_1._) `Array.isArray(${errs})`, () => {\n gen\n .assign(names_1.default.vErrors, (0, codegen_1._) `${names_1.default.vErrors} === null ? ${errs} : ${names_1.default.vErrors}.concat(${errs})`)\n .assign(names_1.default.errors, (0, codegen_1._) `${names_1.default.vErrors}.length`);\n (0, errors_1.extendErrors)(cxt);\n }, () => cxt.error());\n}\nfunction checkAsyncKeyword({ schemaEnv }, def) {\n if (def.async && !schemaEnv.$async)\n throw new Error(\"async keyword in sync schema\");\n}\nfunction useKeyword(gen, keyword, result) {\n if (result === undefined)\n throw new Error(`keyword \"${keyword}\" failed to compile`);\n return gen.scopeValue(\"keyword\", typeof result == \"function\" ? { ref: result } : { ref: result, code: (0, codegen_1.stringify)(result) });\n}\nfunction validSchemaType(schema, schemaType, allowUndefined = false) {\n // TODO add tests\n return (!schemaType.length ||\n schemaType.some((st) => st === \"array\"\n ? Array.isArray(schema)\n : st === \"object\"\n ? schema && typeof schema == \"object\" && !Array.isArray(schema)\n : typeof schema == st || (allowUndefined && typeof schema == \"undefined\")));\n}\nexports.validSchemaType = validSchemaType;\nfunction validateKeywordUsage({ schema, opts, self, errSchemaPath }, def, keyword) {\n /* istanbul ignore if */\n if (Array.isArray(def.keyword) ? !def.keyword.includes(keyword) : def.keyword !== keyword) {\n throw new Error(\"ajv implementation error\");\n }\n const deps = def.dependencies;\n if (deps === null || deps === void 0 ? void 0 : deps.some((kwd) => !Object.prototype.hasOwnProperty.call(schema, kwd))) {\n throw new Error(`parent schema must have dependencies of ${keyword}: ${deps.join(\",\")}`);\n }\n if (def.validateSchema) {\n const valid = def.validateSchema(schema[keyword]);\n if (!valid) {\n const msg = `keyword \"${keyword}\" value is invalid at path \"${errSchemaPath}\": ` +\n self.errorsText(def.validateSchema.errors);\n if (opts.validateSchema === \"log\")\n self.logger.error(msg);\n else\n throw new Error(msg);\n }\n }\n}\nexports.validateKeywordUsage = validateKeywordUsage;\n//# sourceMappingURL=keyword.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.extendSubschemaMode = exports.extendSubschemaData = exports.getSubschema = void 0;\nconst codegen_1 = require(\"../codegen\");\nconst util_1 = require(\"../util\");\nfunction getSubschema(it, { keyword, schemaProp, schema, schemaPath, errSchemaPath, topSchemaRef }) {\n if (keyword !== undefined && schema !== undefined) {\n throw new Error('both \"keyword\" and \"schema\" passed, only one allowed');\n }\n if (keyword !== undefined) {\n const sch = it.schema[keyword];\n return schemaProp === undefined\n ? {\n schema: sch,\n schemaPath: (0, codegen_1._) `${it.schemaPath}${(0, codegen_1.getProperty)(keyword)}`,\n errSchemaPath: `${it.errSchemaPath}/${keyword}`,\n }\n : {\n schema: sch[schemaProp],\n schemaPath: (0, codegen_1._) `${it.schemaPath}${(0, codegen_1.getProperty)(keyword)}${(0, codegen_1.getProperty)(schemaProp)}`,\n errSchemaPath: `${it.errSchemaPath}/${keyword}/${(0, util_1.escapeFragment)(schemaProp)}`,\n };\n }\n if (schema !== undefined) {\n if (schemaPath === undefined || errSchemaPath === undefined || topSchemaRef === undefined) {\n throw new Error('\"schemaPath\", \"errSchemaPath\" and \"topSchemaRef\" are required with \"schema\"');\n }\n return {\n schema,\n schemaPath,\n topSchemaRef,\n errSchemaPath,\n };\n }\n throw new Error('either \"keyword\" or \"schema\" must be passed');\n}\nexports.getSubschema = getSubschema;\nfunction extendSubschemaData(subschema, it, { dataProp, dataPropType: dpType, data, dataTypes, propertyName }) {\n if (data !== undefined && dataProp !== undefined) {\n throw new Error('both \"data\" and \"dataProp\" passed, only one allowed');\n }\n const { gen } = it;\n if (dataProp !== undefined) {\n const { errorPath, dataPathArr, opts } = it;\n const nextData = gen.let(\"data\", (0, codegen_1._) `${it.data}${(0, codegen_1.getProperty)(dataProp)}`, true);\n dataContextProps(nextData);\n subschema.errorPath = (0, codegen_1.str) `${errorPath}${(0, util_1.getErrorPath)(dataProp, dpType, opts.jsPropertySyntax)}`;\n subschema.parentDataProperty = (0, codegen_1._) `${dataProp}`;\n subschema.dataPathArr = [...dataPathArr, subschema.parentDataProperty];\n }\n if (data !== undefined) {\n const nextData = data instanceof codegen_1.Name ? data : gen.let(\"data\", data, true); // replaceable if used once?\n dataContextProps(nextData);\n if (propertyName !== undefined)\n subschema.propertyName = propertyName;\n // TODO something is possibly wrong here with not changing parentDataProperty and not appending dataPathArr\n }\n if (dataTypes)\n subschema.dataTypes = dataTypes;\n function dataContextProps(_nextData) {\n subschema.data = _nextData;\n subschema.dataLevel = it.dataLevel + 1;\n subschema.dataTypes = [];\n it.definedProperties = new Set();\n subschema.parentData = it.data;\n subschema.dataNames = [...it.dataNames, _nextData];\n }\n}\nexports.extendSubschemaData = extendSubschemaData;\nfunction extendSubschemaMode(subschema, { jtdDiscriminator, jtdMetadata, compositeRule, createErrors, allErrors }) {\n if (compositeRule !== undefined)\n subschema.compositeRule = compositeRule;\n if (createErrors !== undefined)\n subschema.createErrors = createErrors;\n if (allErrors !== undefined)\n subschema.allErrors = allErrors;\n subschema.jtdDiscriminator = jtdDiscriminator; // not inherited\n subschema.jtdMetadata = jtdMetadata; // not inherited\n}\nexports.extendSubschemaMode = extendSubschemaMode;\n//# sourceMappingURL=subschema.js.map","'use strict';\n\n// do not edit .js files directly - edit src/index.jst\n\n\n\nmodule.exports = function equal(a, b) {\n if (a === b) return true;\n\n if (a && b && typeof a == 'object' && typeof b == 'object') {\n if (a.constructor !== b.constructor) return false;\n\n var length, i, keys;\n if (Array.isArray(a)) {\n length = a.length;\n if (length != b.length) return false;\n for (i = length; i-- !== 0;)\n if (!equal(a[i], b[i])) return false;\n return true;\n }\n\n\n\n if (a.constructor === RegExp) return a.source === b.source && a.flags === b.flags;\n if (a.valueOf !== Object.prototype.valueOf) return a.valueOf() === b.valueOf();\n if (a.toString !== Object.prototype.toString) return a.toString() === b.toString();\n\n keys = Object.keys(a);\n length = keys.length;\n if (length !== Object.keys(b).length) return false;\n\n for (i = length; i-- !== 0;)\n if (!Object.prototype.hasOwnProperty.call(b, keys[i])) return false;\n\n for (i = length; i-- !== 0;) {\n var key = keys[i];\n\n if (!equal(a[key], b[key])) return false;\n }\n\n return true;\n }\n\n // true if both NaN, false otherwise\n return a!==a && b!==b;\n};\n","'use strict';\n\nvar traverse = module.exports = function (schema, opts, cb) {\n // Legacy support for v0.3.1 and earlier.\n if (typeof opts == 'function') {\n cb = opts;\n opts = {};\n }\n\n cb = opts.cb || cb;\n var pre = (typeof cb == 'function') ? cb : cb.pre || function() {};\n var post = cb.post || function() {};\n\n _traverse(opts, pre, post, schema, '', schema);\n};\n\n\ntraverse.keywords = {\n additionalItems: true,\n items: true,\n contains: true,\n additionalProperties: true,\n propertyNames: true,\n not: true,\n if: true,\n then: true,\n else: true\n};\n\ntraverse.arrayKeywords = {\n items: true,\n allOf: true,\n anyOf: true,\n oneOf: true\n};\n\ntraverse.propsKeywords = {\n $defs: true,\n definitions: true,\n properties: true,\n patternProperties: true,\n dependencies: true\n};\n\ntraverse.skipKeywords = {\n default: true,\n enum: true,\n const: true,\n required: true,\n maximum: true,\n minimum: true,\n exclusiveMaximum: true,\n exclusiveMinimum: true,\n multipleOf: true,\n maxLength: true,\n minLength: true,\n pattern: true,\n format: true,\n maxItems: true,\n minItems: true,\n uniqueItems: true,\n maxProperties: true,\n minProperties: true\n};\n\n\nfunction _traverse(opts, pre, post, schema, jsonPtr, rootSchema, parentJsonPtr, parentKeyword, parentSchema, keyIndex) {\n if (schema && typeof schema == 'object' && !Array.isArray(schema)) {\n pre(schema, jsonPtr, rootSchema, parentJsonPtr, parentKeyword, parentSchema, keyIndex);\n for (var key in schema) {\n var sch = schema[key];\n if (Array.isArray(sch)) {\n if (key in traverse.arrayKeywords) {\n for (var i=0; i (count += countKeys(sch)));\n }\n if (count === Infinity)\n return Infinity;\n }\n return count;\n}\nfunction getFullPath(resolver, id = \"\", normalize) {\n if (normalize !== false)\n id = normalizeId(id);\n const p = resolver.parse(id);\n return _getFullPath(resolver, p);\n}\nexports.getFullPath = getFullPath;\nfunction _getFullPath(resolver, p) {\n const serialized = resolver.serialize(p);\n return serialized.split(\"#\")[0] + \"#\";\n}\nexports._getFullPath = _getFullPath;\nconst TRAILING_SLASH_HASH = /#\\/?$/;\nfunction normalizeId(id) {\n return id ? id.replace(TRAILING_SLASH_HASH, \"\") : \"\";\n}\nexports.normalizeId = normalizeId;\nfunction resolveUrl(resolver, baseId, id) {\n id = normalizeId(id);\n return resolver.resolve(baseId, id);\n}\nexports.resolveUrl = resolveUrl;\nconst ANCHOR = /^[a-z_][-a-z0-9._]*$/i;\nfunction getSchemaRefs(schema, baseId) {\n if (typeof schema == \"boolean\")\n return {};\n const { schemaId, uriResolver } = this.opts;\n const schId = normalizeId(schema[schemaId] || baseId);\n const baseIds = { \"\": schId };\n const pathPrefix = getFullPath(uriResolver, schId, false);\n const localRefs = {};\n const schemaRefs = new Set();\n traverse(schema, { allKeys: true }, (sch, jsonPtr, _, parentJsonPtr) => {\n if (parentJsonPtr === undefined)\n return;\n const fullPath = pathPrefix + jsonPtr;\n let baseId = baseIds[parentJsonPtr];\n if (typeof sch[schemaId] == \"string\")\n baseId = addRef.call(this, sch[schemaId]);\n addAnchor.call(this, sch.$anchor);\n addAnchor.call(this, sch.$dynamicAnchor);\n baseIds[jsonPtr] = baseId;\n function addRef(ref) {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n const _resolve = this.opts.uriResolver.resolve;\n ref = normalizeId(baseId ? _resolve(baseId, ref) : ref);\n if (schemaRefs.has(ref))\n throw ambiguos(ref);\n schemaRefs.add(ref);\n let schOrRef = this.refs[ref];\n if (typeof schOrRef == \"string\")\n schOrRef = this.refs[schOrRef];\n if (typeof schOrRef == \"object\") {\n checkAmbiguosRef(sch, schOrRef.schema, ref);\n }\n else if (ref !== normalizeId(fullPath)) {\n if (ref[0] === \"#\") {\n checkAmbiguosRef(sch, localRefs[ref], ref);\n localRefs[ref] = sch;\n }\n else {\n this.refs[ref] = fullPath;\n }\n }\n return ref;\n }\n function addAnchor(anchor) {\n if (typeof anchor == \"string\") {\n if (!ANCHOR.test(anchor))\n throw new Error(`invalid anchor \"${anchor}\"`);\n addRef.call(this, `#${anchor}`);\n }\n }\n });\n return localRefs;\n function checkAmbiguosRef(sch1, sch2, ref) {\n if (sch2 !== undefined && !equal(sch1, sch2))\n throw ambiguos(ref);\n }\n function ambiguos(ref) {\n return new Error(`reference \"${ref}\" resolves to more than one schema`);\n }\n}\nexports.getSchemaRefs = getSchemaRefs;\n//# sourceMappingURL=resolve.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getData = exports.KeywordCxt = exports.validateFunctionCode = void 0;\nconst boolSchema_1 = require(\"./boolSchema\");\nconst dataType_1 = require(\"./dataType\");\nconst applicability_1 = require(\"./applicability\");\nconst dataType_2 = require(\"./dataType\");\nconst defaults_1 = require(\"./defaults\");\nconst keyword_1 = require(\"./keyword\");\nconst subschema_1 = require(\"./subschema\");\nconst codegen_1 = require(\"../codegen\");\nconst names_1 = require(\"../names\");\nconst resolve_1 = require(\"../resolve\");\nconst util_1 = require(\"../util\");\nconst errors_1 = require(\"../errors\");\n// schema compilation - generates validation function, subschemaCode (below) is used for subschemas\nfunction validateFunctionCode(it) {\n if (isSchemaObj(it)) {\n checkKeywords(it);\n if (schemaCxtHasRules(it)) {\n topSchemaObjCode(it);\n return;\n }\n }\n validateFunction(it, () => (0, boolSchema_1.topBoolOrEmptySchema)(it));\n}\nexports.validateFunctionCode = validateFunctionCode;\nfunction validateFunction({ gen, validateName, schema, schemaEnv, opts }, body) {\n if (opts.code.es5) {\n gen.func(validateName, (0, codegen_1._) `${names_1.default.data}, ${names_1.default.valCxt}`, schemaEnv.$async, () => {\n gen.code((0, codegen_1._) `\"use strict\"; ${funcSourceUrl(schema, opts)}`);\n destructureValCxtES5(gen, opts);\n gen.code(body);\n });\n }\n else {\n gen.func(validateName, (0, codegen_1._) `${names_1.default.data}, ${destructureValCxt(opts)}`, schemaEnv.$async, () => gen.code(funcSourceUrl(schema, opts)).code(body));\n }\n}\nfunction destructureValCxt(opts) {\n return (0, codegen_1._) `{${names_1.default.instancePath}=\"\", ${names_1.default.parentData}, ${names_1.default.parentDataProperty}, ${names_1.default.rootData}=${names_1.default.data}${opts.dynamicRef ? (0, codegen_1._) `, ${names_1.default.dynamicAnchors}={}` : codegen_1.nil}}={}`;\n}\nfunction destructureValCxtES5(gen, opts) {\n gen.if(names_1.default.valCxt, () => {\n gen.var(names_1.default.instancePath, (0, codegen_1._) `${names_1.default.valCxt}.${names_1.default.instancePath}`);\n gen.var(names_1.default.parentData, (0, codegen_1._) `${names_1.default.valCxt}.${names_1.default.parentData}`);\n gen.var(names_1.default.parentDataProperty, (0, codegen_1._) `${names_1.default.valCxt}.${names_1.default.parentDataProperty}`);\n gen.var(names_1.default.rootData, (0, codegen_1._) `${names_1.default.valCxt}.${names_1.default.rootData}`);\n if (opts.dynamicRef)\n gen.var(names_1.default.dynamicAnchors, (0, codegen_1._) `${names_1.default.valCxt}.${names_1.default.dynamicAnchors}`);\n }, () => {\n gen.var(names_1.default.instancePath, (0, codegen_1._) `\"\"`);\n gen.var(names_1.default.parentData, (0, codegen_1._) `undefined`);\n gen.var(names_1.default.parentDataProperty, (0, codegen_1._) `undefined`);\n gen.var(names_1.default.rootData, names_1.default.data);\n if (opts.dynamicRef)\n gen.var(names_1.default.dynamicAnchors, (0, codegen_1._) `{}`);\n });\n}\nfunction topSchemaObjCode(it) {\n const { schema, opts, gen } = it;\n validateFunction(it, () => {\n if (opts.$comment && schema.$comment)\n commentKeyword(it);\n checkNoDefault(it);\n gen.let(names_1.default.vErrors, null);\n gen.let(names_1.default.errors, 0);\n if (opts.unevaluated)\n resetEvaluated(it);\n typeAndKeywords(it);\n returnResults(it);\n });\n return;\n}\nfunction resetEvaluated(it) {\n // TODO maybe some hook to execute it in the end to check whether props/items are Name, as in assignEvaluated\n const { gen, validateName } = it;\n it.evaluated = gen.const(\"evaluated\", (0, codegen_1._) `${validateName}.evaluated`);\n gen.if((0, codegen_1._) `${it.evaluated}.dynamicProps`, () => gen.assign((0, codegen_1._) `${it.evaluated}.props`, (0, codegen_1._) `undefined`));\n gen.if((0, codegen_1._) `${it.evaluated}.dynamicItems`, () => gen.assign((0, codegen_1._) `${it.evaluated}.items`, (0, codegen_1._) `undefined`));\n}\nfunction funcSourceUrl(schema, opts) {\n const schId = typeof schema == \"object\" && schema[opts.schemaId];\n return schId && (opts.code.source || opts.code.process) ? (0, codegen_1._) `/*# sourceURL=${schId} */` : codegen_1.nil;\n}\n// schema compilation - this function is used recursively to generate code for sub-schemas\nfunction subschemaCode(it, valid) {\n if (isSchemaObj(it)) {\n checkKeywords(it);\n if (schemaCxtHasRules(it)) {\n subSchemaObjCode(it, valid);\n return;\n }\n }\n (0, boolSchema_1.boolOrEmptySchema)(it, valid);\n}\nfunction schemaCxtHasRules({ schema, self }) {\n if (typeof schema == \"boolean\")\n return !schema;\n for (const key in schema)\n if (self.RULES.all[key])\n return true;\n return false;\n}\nfunction isSchemaObj(it) {\n return typeof it.schema != \"boolean\";\n}\nfunction subSchemaObjCode(it, valid) {\n const { schema, gen, opts } = it;\n if (opts.$comment && schema.$comment)\n commentKeyword(it);\n updateContext(it);\n checkAsyncSchema(it);\n const errsCount = gen.const(\"_errs\", names_1.default.errors);\n typeAndKeywords(it, errsCount);\n // TODO var\n gen.var(valid, (0, codegen_1._) `${errsCount} === ${names_1.default.errors}`);\n}\nfunction checkKeywords(it) {\n (0, util_1.checkUnknownRules)(it);\n checkRefsAndKeywords(it);\n}\nfunction typeAndKeywords(it, errsCount) {\n if (it.opts.jtd)\n return schemaKeywords(it, [], false, errsCount);\n const types = (0, dataType_1.getSchemaTypes)(it.schema);\n const checkedTypes = (0, dataType_1.coerceAndCheckDataType)(it, types);\n schemaKeywords(it, types, !checkedTypes, errsCount);\n}\nfunction checkRefsAndKeywords(it) {\n const { schema, errSchemaPath, opts, self } = it;\n if (schema.$ref && opts.ignoreKeywordsWithRef && (0, util_1.schemaHasRulesButRef)(schema, self.RULES)) {\n self.logger.warn(`$ref: keywords ignored in schema at path \"${errSchemaPath}\"`);\n }\n}\nfunction checkNoDefault(it) {\n const { schema, opts } = it;\n if (schema.default !== undefined && opts.useDefaults && opts.strictSchema) {\n (0, util_1.checkStrictMode)(it, \"default is ignored in the schema root\");\n }\n}\nfunction updateContext(it) {\n const schId = it.schema[it.opts.schemaId];\n if (schId)\n it.baseId = (0, resolve_1.resolveUrl)(it.opts.uriResolver, it.baseId, schId);\n}\nfunction checkAsyncSchema(it) {\n if (it.schema.$async && !it.schemaEnv.$async)\n throw new Error(\"async schema in sync schema\");\n}\nfunction commentKeyword({ gen, schemaEnv, schema, errSchemaPath, opts }) {\n const msg = schema.$comment;\n if (opts.$comment === true) {\n gen.code((0, codegen_1._) `${names_1.default.self}.logger.log(${msg})`);\n }\n else if (typeof opts.$comment == \"function\") {\n const schemaPath = (0, codegen_1.str) `${errSchemaPath}/$comment`;\n const rootName = gen.scopeValue(\"root\", { ref: schemaEnv.root });\n gen.code((0, codegen_1._) `${names_1.default.self}.opts.$comment(${msg}, ${schemaPath}, ${rootName}.schema)`);\n }\n}\nfunction returnResults(it) {\n const { gen, schemaEnv, validateName, ValidationError, opts } = it;\n if (schemaEnv.$async) {\n // TODO assign unevaluated\n gen.if((0, codegen_1._) `${names_1.default.errors} === 0`, () => gen.return(names_1.default.data), () => gen.throw((0, codegen_1._) `new ${ValidationError}(${names_1.default.vErrors})`));\n }\n else {\n gen.assign((0, codegen_1._) `${validateName}.errors`, names_1.default.vErrors);\n if (opts.unevaluated)\n assignEvaluated(it);\n gen.return((0, codegen_1._) `${names_1.default.errors} === 0`);\n }\n}\nfunction assignEvaluated({ gen, evaluated, props, items }) {\n if (props instanceof codegen_1.Name)\n gen.assign((0, codegen_1._) `${evaluated}.props`, props);\n if (items instanceof codegen_1.Name)\n gen.assign((0, codegen_1._) `${evaluated}.items`, items);\n}\nfunction schemaKeywords(it, types, typeErrors, errsCount) {\n const { gen, schema, data, allErrors, opts, self } = it;\n const { RULES } = self;\n if (schema.$ref && (opts.ignoreKeywordsWithRef || !(0, util_1.schemaHasRulesButRef)(schema, RULES))) {\n gen.block(() => keywordCode(it, \"$ref\", RULES.all.$ref.definition)); // TODO typecast\n return;\n }\n if (!opts.jtd)\n checkStrictTypes(it, types);\n gen.block(() => {\n for (const group of RULES.rules)\n groupKeywords(group);\n groupKeywords(RULES.post);\n });\n function groupKeywords(group) {\n if (!(0, applicability_1.shouldUseGroup)(schema, group))\n return;\n if (group.type) {\n gen.if((0, dataType_2.checkDataType)(group.type, data, opts.strictNumbers));\n iterateKeywords(it, group);\n if (types.length === 1 && types[0] === group.type && typeErrors) {\n gen.else();\n (0, dataType_2.reportTypeError)(it);\n }\n gen.endIf();\n }\n else {\n iterateKeywords(it, group);\n }\n // TODO make it \"ok\" call?\n if (!allErrors)\n gen.if((0, codegen_1._) `${names_1.default.errors} === ${errsCount || 0}`);\n }\n}\nfunction iterateKeywords(it, group) {\n const { gen, schema, opts: { useDefaults }, } = it;\n if (useDefaults)\n (0, defaults_1.assignDefaults)(it, group.type);\n gen.block(() => {\n for (const rule of group.rules) {\n if ((0, applicability_1.shouldUseRule)(schema, rule)) {\n keywordCode(it, rule.keyword, rule.definition, group.type);\n }\n }\n });\n}\nfunction checkStrictTypes(it, types) {\n if (it.schemaEnv.meta || !it.opts.strictTypes)\n return;\n checkContextTypes(it, types);\n if (!it.opts.allowUnionTypes)\n checkMultipleTypes(it, types);\n checkKeywordTypes(it, it.dataTypes);\n}\nfunction checkContextTypes(it, types) {\n if (!types.length)\n return;\n if (!it.dataTypes.length) {\n it.dataTypes = types;\n return;\n }\n types.forEach((t) => {\n if (!includesType(it.dataTypes, t)) {\n strictTypesError(it, `type \"${t}\" not allowed by context \"${it.dataTypes.join(\",\")}\"`);\n }\n });\n narrowSchemaTypes(it, types);\n}\nfunction checkMultipleTypes(it, ts) {\n if (ts.length > 1 && !(ts.length === 2 && ts.includes(\"null\"))) {\n strictTypesError(it, \"use allowUnionTypes to allow union type keyword\");\n }\n}\nfunction checkKeywordTypes(it, ts) {\n const rules = it.self.RULES.all;\n for (const keyword in rules) {\n const rule = rules[keyword];\n if (typeof rule == \"object\" && (0, applicability_1.shouldUseRule)(it.schema, rule)) {\n const { type } = rule.definition;\n if (type.length && !type.some((t) => hasApplicableType(ts, t))) {\n strictTypesError(it, `missing type \"${type.join(\",\")}\" for keyword \"${keyword}\"`);\n }\n }\n }\n}\nfunction hasApplicableType(schTs, kwdT) {\n return schTs.includes(kwdT) || (kwdT === \"number\" && schTs.includes(\"integer\"));\n}\nfunction includesType(ts, t) {\n return ts.includes(t) || (t === \"integer\" && ts.includes(\"number\"));\n}\nfunction narrowSchemaTypes(it, withTypes) {\n const ts = [];\n for (const t of it.dataTypes) {\n if (includesType(withTypes, t))\n ts.push(t);\n else if (withTypes.includes(\"integer\") && t === \"number\")\n ts.push(\"integer\");\n }\n it.dataTypes = ts;\n}\nfunction strictTypesError(it, msg) {\n const schemaPath = it.schemaEnv.baseId + it.errSchemaPath;\n msg += ` at \"${schemaPath}\" (strictTypes)`;\n (0, util_1.checkStrictMode)(it, msg, it.opts.strictTypes);\n}\nclass KeywordCxt {\n constructor(it, def, keyword) {\n (0, keyword_1.validateKeywordUsage)(it, def, keyword);\n this.gen = it.gen;\n this.allErrors = it.allErrors;\n this.keyword = keyword;\n this.data = it.data;\n this.schema = it.schema[keyword];\n this.$data = def.$data && it.opts.$data && this.schema && this.schema.$data;\n this.schemaValue = (0, util_1.schemaRefOrVal)(it, this.schema, keyword, this.$data);\n this.schemaType = def.schemaType;\n this.parentSchema = it.schema;\n this.params = {};\n this.it = it;\n this.def = def;\n if (this.$data) {\n this.schemaCode = it.gen.const(\"vSchema\", getData(this.$data, it));\n }\n else {\n this.schemaCode = this.schemaValue;\n if (!(0, keyword_1.validSchemaType)(this.schema, def.schemaType, def.allowUndefined)) {\n throw new Error(`${keyword} value must be ${JSON.stringify(def.schemaType)}`);\n }\n }\n if (\"code\" in def ? def.trackErrors : def.errors !== false) {\n this.errsCount = it.gen.const(\"_errs\", names_1.default.errors);\n }\n }\n result(condition, successAction, failAction) {\n this.failResult((0, codegen_1.not)(condition), successAction, failAction);\n }\n failResult(condition, successAction, failAction) {\n this.gen.if(condition);\n if (failAction)\n failAction();\n else\n this.error();\n if (successAction) {\n this.gen.else();\n successAction();\n if (this.allErrors)\n this.gen.endIf();\n }\n else {\n if (this.allErrors)\n this.gen.endIf();\n else\n this.gen.else();\n }\n }\n pass(condition, failAction) {\n this.failResult((0, codegen_1.not)(condition), undefined, failAction);\n }\n fail(condition) {\n if (condition === undefined) {\n this.error();\n if (!this.allErrors)\n this.gen.if(false); // this branch will be removed by gen.optimize\n return;\n }\n this.gen.if(condition);\n this.error();\n if (this.allErrors)\n this.gen.endIf();\n else\n this.gen.else();\n }\n fail$data(condition) {\n if (!this.$data)\n return this.fail(condition);\n const { schemaCode } = this;\n this.fail((0, codegen_1._) `${schemaCode} !== undefined && (${(0, codegen_1.or)(this.invalid$data(), condition)})`);\n }\n error(append, errorParams, errorPaths) {\n if (errorParams) {\n this.setParams(errorParams);\n this._error(append, errorPaths);\n this.setParams({});\n return;\n }\n this._error(append, errorPaths);\n }\n _error(append, errorPaths) {\n ;\n (append ? errors_1.reportExtraError : errors_1.reportError)(this, this.def.error, errorPaths);\n }\n $dataError() {\n (0, errors_1.reportError)(this, this.def.$dataError || errors_1.keyword$DataError);\n }\n reset() {\n if (this.errsCount === undefined)\n throw new Error('add \"trackErrors\" to keyword definition');\n (0, errors_1.resetErrorsCount)(this.gen, this.errsCount);\n }\n ok(cond) {\n if (!this.allErrors)\n this.gen.if(cond);\n }\n setParams(obj, assign) {\n if (assign)\n Object.assign(this.params, obj);\n else\n this.params = obj;\n }\n block$data(valid, codeBlock, $dataValid = codegen_1.nil) {\n this.gen.block(() => {\n this.check$data(valid, $dataValid);\n codeBlock();\n });\n }\n check$data(valid = codegen_1.nil, $dataValid = codegen_1.nil) {\n if (!this.$data)\n return;\n const { gen, schemaCode, schemaType, def } = this;\n gen.if((0, codegen_1.or)((0, codegen_1._) `${schemaCode} === undefined`, $dataValid));\n if (valid !== codegen_1.nil)\n gen.assign(valid, true);\n if (schemaType.length || def.validateSchema) {\n gen.elseIf(this.invalid$data());\n this.$dataError();\n if (valid !== codegen_1.nil)\n gen.assign(valid, false);\n }\n gen.else();\n }\n invalid$data() {\n const { gen, schemaCode, schemaType, def, it } = this;\n return (0, codegen_1.or)(wrong$DataType(), invalid$DataSchema());\n function wrong$DataType() {\n if (schemaType.length) {\n /* istanbul ignore if */\n if (!(schemaCode instanceof codegen_1.Name))\n throw new Error(\"ajv implementation error\");\n const st = Array.isArray(schemaType) ? schemaType : [schemaType];\n return (0, codegen_1._) `${(0, dataType_2.checkDataTypes)(st, schemaCode, it.opts.strictNumbers, dataType_2.DataType.Wrong)}`;\n }\n return codegen_1.nil;\n }\n function invalid$DataSchema() {\n if (def.validateSchema) {\n const validateSchemaRef = gen.scopeValue(\"validate$data\", { ref: def.validateSchema }); // TODO value.code for standalone\n return (0, codegen_1._) `!${validateSchemaRef}(${schemaCode})`;\n }\n return codegen_1.nil;\n }\n }\n subschema(appl, valid) {\n const subschema = (0, subschema_1.getSubschema)(this.it, appl);\n (0, subschema_1.extendSubschemaData)(subschema, this.it, appl);\n (0, subschema_1.extendSubschemaMode)(subschema, appl);\n const nextContext = { ...this.it, ...subschema, items: undefined, props: undefined };\n subschemaCode(nextContext, valid);\n return nextContext;\n }\n mergeEvaluated(schemaCxt, toName) {\n const { it, gen } = this;\n if (!it.opts.unevaluated)\n return;\n if (it.props !== true && schemaCxt.props !== undefined) {\n it.props = util_1.mergeEvaluated.props(gen, schemaCxt.props, it.props, toName);\n }\n if (it.items !== true && schemaCxt.items !== undefined) {\n it.items = util_1.mergeEvaluated.items(gen, schemaCxt.items, it.items, toName);\n }\n }\n mergeValidEvaluated(schemaCxt, valid) {\n const { it, gen } = this;\n if (it.opts.unevaluated && (it.props !== true || it.items !== true)) {\n gen.if(valid, () => this.mergeEvaluated(schemaCxt, codegen_1.Name));\n return true;\n }\n }\n}\nexports.KeywordCxt = KeywordCxt;\nfunction keywordCode(it, keyword, def, ruleType) {\n const cxt = new KeywordCxt(it, def, keyword);\n if (\"code\" in def) {\n def.code(cxt, ruleType);\n }\n else if (cxt.$data && def.validate) {\n (0, keyword_1.funcKeywordCode)(cxt, def);\n }\n else if (\"macro\" in def) {\n (0, keyword_1.macroKeywordCode)(cxt, def);\n }\n else if (def.compile || def.validate) {\n (0, keyword_1.funcKeywordCode)(cxt, def);\n }\n}\nconst JSON_POINTER = /^\\/(?:[^~]|~0|~1)*$/;\nconst RELATIVE_JSON_POINTER = /^([0-9]+)(#|\\/(?:[^~]|~0|~1)*)?$/;\nfunction getData($data, { dataLevel, dataNames, dataPathArr }) {\n let jsonPointer;\n let data;\n if ($data === \"\")\n return names_1.default.rootData;\n if ($data[0] === \"/\") {\n if (!JSON_POINTER.test($data))\n throw new Error(`Invalid JSON-pointer: ${$data}`);\n jsonPointer = $data;\n data = names_1.default.rootData;\n }\n else {\n const matches = RELATIVE_JSON_POINTER.exec($data);\n if (!matches)\n throw new Error(`Invalid JSON-pointer: ${$data}`);\n const up = +matches[1];\n jsonPointer = matches[2];\n if (jsonPointer === \"#\") {\n if (up >= dataLevel)\n throw new Error(errorMsg(\"property/index\", up));\n return dataPathArr[dataLevel - up];\n }\n if (up > dataLevel)\n throw new Error(errorMsg(\"data\", up));\n data = dataNames[dataLevel - up];\n if (!jsonPointer)\n return data;\n }\n let expr = data;\n const segments = jsonPointer.split(\"/\");\n for (const segment of segments) {\n if (segment) {\n data = (0, codegen_1._) `${data}${(0, codegen_1.getProperty)((0, util_1.unescapeJsonPointer)(segment))}`;\n expr = (0, codegen_1._) `${expr} && ${data}`;\n }\n }\n return expr;\n function errorMsg(pointerType, up) {\n return `Cannot access ${pointerType} ${up} levels up, current level is ${dataLevel}`;\n }\n}\nexports.getData = getData;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nclass ValidationError extends Error {\n constructor(errors) {\n super(\"validation failed\");\n this.errors = errors;\n this.ajv = this.validation = true;\n }\n}\nexports.default = ValidationError;\n//# sourceMappingURL=validation_error.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst resolve_1 = require(\"./resolve\");\nclass MissingRefError extends Error {\n constructor(resolver, baseId, ref, msg) {\n super(msg || `can't resolve reference ${ref} from id ${baseId}`);\n this.missingRef = (0, resolve_1.resolveUrl)(resolver, baseId, ref);\n this.missingSchema = (0, resolve_1.normalizeId)((0, resolve_1.getFullPath)(resolver, this.missingRef));\n }\n}\nexports.default = MissingRefError;\n//# sourceMappingURL=ref_error.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.resolveSchema = exports.getCompilingSchema = exports.resolveRef = exports.compileSchema = exports.SchemaEnv = void 0;\nconst codegen_1 = require(\"./codegen\");\nconst validation_error_1 = require(\"../runtime/validation_error\");\nconst names_1 = require(\"./names\");\nconst resolve_1 = require(\"./resolve\");\nconst util_1 = require(\"./util\");\nconst validate_1 = require(\"./validate\");\nclass SchemaEnv {\n constructor(env) {\n var _a;\n this.refs = {};\n this.dynamicAnchors = {};\n let schema;\n if (typeof env.schema == \"object\")\n schema = env.schema;\n this.schema = env.schema;\n this.schemaId = env.schemaId;\n this.root = env.root || this;\n this.baseId = (_a = env.baseId) !== null && _a !== void 0 ? _a : (0, resolve_1.normalizeId)(schema === null || schema === void 0 ? void 0 : schema[env.schemaId || \"$id\"]);\n this.schemaPath = env.schemaPath;\n this.localRefs = env.localRefs;\n this.meta = env.meta;\n this.$async = schema === null || schema === void 0 ? void 0 : schema.$async;\n this.refs = {};\n }\n}\nexports.SchemaEnv = SchemaEnv;\n// let codeSize = 0\n// let nodeCount = 0\n// Compiles schema in SchemaEnv\nfunction compileSchema(sch) {\n // TODO refactor - remove compilations\n const _sch = getCompilingSchema.call(this, sch);\n if (_sch)\n return _sch;\n const rootId = (0, resolve_1.getFullPath)(this.opts.uriResolver, sch.root.baseId); // TODO if getFullPath removed 1 tests fails\n const { es5, lines } = this.opts.code;\n const { ownProperties } = this.opts;\n const gen = new codegen_1.CodeGen(this.scope, { es5, lines, ownProperties });\n let _ValidationError;\n if (sch.$async) {\n _ValidationError = gen.scopeValue(\"Error\", {\n ref: validation_error_1.default,\n code: (0, codegen_1._) `require(\"ajv/dist/runtime/validation_error\").default`,\n });\n }\n const validateName = gen.scopeName(\"validate\");\n sch.validateName = validateName;\n const schemaCxt = {\n gen,\n allErrors: this.opts.allErrors,\n data: names_1.default.data,\n parentData: names_1.default.parentData,\n parentDataProperty: names_1.default.parentDataProperty,\n dataNames: [names_1.default.data],\n dataPathArr: [codegen_1.nil],\n dataLevel: 0,\n dataTypes: [],\n definedProperties: new Set(),\n topSchemaRef: gen.scopeValue(\"schema\", this.opts.code.source === true\n ? { ref: sch.schema, code: (0, codegen_1.stringify)(sch.schema) }\n : { ref: sch.schema }),\n validateName,\n ValidationError: _ValidationError,\n schema: sch.schema,\n schemaEnv: sch,\n rootId,\n baseId: sch.baseId || rootId,\n schemaPath: codegen_1.nil,\n errSchemaPath: sch.schemaPath || (this.opts.jtd ? \"\" : \"#\"),\n errorPath: (0, codegen_1._) `\"\"`,\n opts: this.opts,\n self: this,\n };\n let sourceCode;\n try {\n this._compilations.add(sch);\n (0, validate_1.validateFunctionCode)(schemaCxt);\n gen.optimize(this.opts.code.optimize);\n // gen.optimize(1)\n const validateCode = gen.toString();\n sourceCode = `${gen.scopeRefs(names_1.default.scope)}return ${validateCode}`;\n // console.log((codeSize += sourceCode.length), (nodeCount += gen.nodeCount))\n if (this.opts.code.process)\n sourceCode = this.opts.code.process(sourceCode, sch);\n // console.log(\"\\n\\n\\n *** \\n\", sourceCode)\n const makeValidate = new Function(`${names_1.default.self}`, `${names_1.default.scope}`, sourceCode);\n const validate = makeValidate(this, this.scope.get());\n this.scope.value(validateName, { ref: validate });\n validate.errors = null;\n validate.schema = sch.schema;\n validate.schemaEnv = sch;\n if (sch.$async)\n validate.$async = true;\n if (this.opts.code.source === true) {\n validate.source = { validateName, validateCode, scopeValues: gen._values };\n }\n if (this.opts.unevaluated) {\n const { props, items } = schemaCxt;\n validate.evaluated = {\n props: props instanceof codegen_1.Name ? undefined : props,\n items: items instanceof codegen_1.Name ? undefined : items,\n dynamicProps: props instanceof codegen_1.Name,\n dynamicItems: items instanceof codegen_1.Name,\n };\n if (validate.source)\n validate.source.evaluated = (0, codegen_1.stringify)(validate.evaluated);\n }\n sch.validate = validate;\n return sch;\n }\n catch (e) {\n delete sch.validate;\n delete sch.validateName;\n if (sourceCode)\n this.logger.error(\"Error compiling schema, function code:\", sourceCode);\n // console.log(\"\\n\\n\\n *** \\n\", sourceCode, this.opts)\n throw e;\n }\n finally {\n this._compilations.delete(sch);\n }\n}\nexports.compileSchema = compileSchema;\nfunction resolveRef(root, baseId, ref) {\n var _a;\n ref = (0, resolve_1.resolveUrl)(this.opts.uriResolver, baseId, ref);\n const schOrFunc = root.refs[ref];\n if (schOrFunc)\n return schOrFunc;\n let _sch = resolve.call(this, root, ref);\n if (_sch === undefined) {\n const schema = (_a = root.localRefs) === null || _a === void 0 ? void 0 : _a[ref]; // TODO maybe localRefs should hold SchemaEnv\n const { schemaId } = this.opts;\n if (schema)\n _sch = new SchemaEnv({ schema, schemaId, root, baseId });\n }\n if (_sch === undefined)\n return;\n return (root.refs[ref] = inlineOrCompile.call(this, _sch));\n}\nexports.resolveRef = resolveRef;\nfunction inlineOrCompile(sch) {\n if ((0, resolve_1.inlineRef)(sch.schema, this.opts.inlineRefs))\n return sch.schema;\n return sch.validate ? sch : compileSchema.call(this, sch);\n}\n// Index of schema compilation in the currently compiled list\nfunction getCompilingSchema(schEnv) {\n for (const sch of this._compilations) {\n if (sameSchemaEnv(sch, schEnv))\n return sch;\n }\n}\nexports.getCompilingSchema = getCompilingSchema;\nfunction sameSchemaEnv(s1, s2) {\n return s1.schema === s2.schema && s1.root === s2.root && s1.baseId === s2.baseId;\n}\n// resolve and compile the references ($ref)\n// TODO returns AnySchemaObject (if the schema can be inlined) or validation function\nfunction resolve(root, // information about the root schema for the current schema\nref // reference to resolve\n) {\n let sch;\n while (typeof (sch = this.refs[ref]) == \"string\")\n ref = sch;\n return sch || this.schemas[ref] || resolveSchema.call(this, root, ref);\n}\n// Resolve schema, its root and baseId\nfunction resolveSchema(root, // root object with properties schema, refs TODO below SchemaEnv is assigned to it\nref // reference to resolve\n) {\n const p = this.opts.uriResolver.parse(ref);\n const refPath = (0, resolve_1._getFullPath)(this.opts.uriResolver, p);\n let baseId = (0, resolve_1.getFullPath)(this.opts.uriResolver, root.baseId, undefined);\n // TODO `Object.keys(root.schema).length > 0` should not be needed - but removing breaks 2 tests\n if (Object.keys(root.schema).length > 0 && refPath === baseId) {\n return getJsonPointer.call(this, p, root);\n }\n const id = (0, resolve_1.normalizeId)(refPath);\n const schOrRef = this.refs[id] || this.schemas[id];\n if (typeof schOrRef == \"string\") {\n const sch = resolveSchema.call(this, root, schOrRef);\n if (typeof (sch === null || sch === void 0 ? void 0 : sch.schema) !== \"object\")\n return;\n return getJsonPointer.call(this, p, sch);\n }\n if (typeof (schOrRef === null || schOrRef === void 0 ? void 0 : schOrRef.schema) !== \"object\")\n return;\n if (!schOrRef.validate)\n compileSchema.call(this, schOrRef);\n if (id === (0, resolve_1.normalizeId)(ref)) {\n const { schema } = schOrRef;\n const { schemaId } = this.opts;\n const schId = schema[schemaId];\n if (schId)\n baseId = (0, resolve_1.resolveUrl)(this.opts.uriResolver, baseId, schId);\n return new SchemaEnv({ schema, schemaId, root, baseId });\n }\n return getJsonPointer.call(this, p, schOrRef);\n}\nexports.resolveSchema = resolveSchema;\nconst PREVENT_SCOPE_CHANGE = new Set([\n \"properties\",\n \"patternProperties\",\n \"enum\",\n \"dependencies\",\n \"definitions\",\n]);\nfunction getJsonPointer(parsedRef, { baseId, schema, root }) {\n var _a;\n if (((_a = parsedRef.fragment) === null || _a === void 0 ? void 0 : _a[0]) !== \"/\")\n return;\n for (const part of parsedRef.fragment.slice(1).split(\"/\")) {\n if (typeof schema === \"boolean\")\n return;\n const partSchema = schema[(0, util_1.unescapeFragment)(part)];\n if (partSchema === undefined)\n return;\n schema = partSchema;\n // TODO PREVENT_SCOPE_CHANGE could be defined in keyword def?\n const schId = typeof schema === \"object\" && schema[this.opts.schemaId];\n if (!PREVENT_SCOPE_CHANGE.has(part) && schId) {\n baseId = (0, resolve_1.resolveUrl)(this.opts.uriResolver, baseId, schId);\n }\n }\n let env;\n if (typeof schema != \"boolean\" && schema.$ref && !(0, util_1.schemaHasRulesButRef)(schema, this.RULES)) {\n const $ref = (0, resolve_1.resolveUrl)(this.opts.uriResolver, baseId, schema.$ref);\n env = resolveSchema.call(this, root, $ref);\n }\n // even though resolution failed we need to return SchemaEnv to throw exception\n // so that compileAsync loads missing schema.\n const { schemaId } = this.opts;\n env = env || new SchemaEnv({ schema, schemaId, root, baseId });\n if (env.schema !== env.root.schema)\n return env;\n return undefined;\n}\n//# sourceMappingURL=index.js.map","/** @license URI.js v4.4.1 (c) 2011 Gary Court. License: http://github.com/garycourt/uri-js */\n(function (global, factory) {\n\ttypeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :\n\ttypeof define === 'function' && define.amd ? define(['exports'], factory) :\n\t(factory((global.URI = global.URI || {})));\n}(this, (function (exports) { 'use strict';\n\nfunction merge() {\n for (var _len = arguments.length, sets = Array(_len), _key = 0; _key < _len; _key++) {\n sets[_key] = arguments[_key];\n }\n\n if (sets.length > 1) {\n sets[0] = sets[0].slice(0, -1);\n var xl = sets.length - 1;\n for (var x = 1; x < xl; ++x) {\n sets[x] = sets[x].slice(1, -1);\n }\n sets[xl] = sets[xl].slice(1);\n return sets.join('');\n } else {\n return sets[0];\n }\n}\nfunction subexp(str) {\n return \"(?:\" + str + \")\";\n}\nfunction typeOf(o) {\n return o === undefined ? \"undefined\" : o === null ? \"null\" : Object.prototype.toString.call(o).split(\" \").pop().split(\"]\").shift().toLowerCase();\n}\nfunction toUpperCase(str) {\n return str.toUpperCase();\n}\nfunction toArray(obj) {\n return obj !== undefined && obj !== null ? obj instanceof Array ? obj : typeof obj.length !== \"number\" || obj.split || obj.setInterval || obj.call ? [obj] : Array.prototype.slice.call(obj) : [];\n}\nfunction assign(target, source) {\n var obj = target;\n if (source) {\n for (var key in source) {\n obj[key] = source[key];\n }\n }\n return obj;\n}\n\nfunction buildExps(isIRI) {\n var ALPHA$$ = \"[A-Za-z]\",\n CR$ = \"[\\\\x0D]\",\n DIGIT$$ = \"[0-9]\",\n DQUOTE$$ = \"[\\\\x22]\",\n HEXDIG$$ = merge(DIGIT$$, \"[A-Fa-f]\"),\n //case-insensitive\n LF$$ = \"[\\\\x0A]\",\n SP$$ = \"[\\\\x20]\",\n PCT_ENCODED$ = subexp(subexp(\"%[EFef]\" + HEXDIG$$ + \"%\" + HEXDIG$$ + HEXDIG$$ + \"%\" + HEXDIG$$ + HEXDIG$$) + \"|\" + subexp(\"%[89A-Fa-f]\" + HEXDIG$$ + \"%\" + HEXDIG$$ + HEXDIG$$) + \"|\" + subexp(\"%\" + HEXDIG$$ + HEXDIG$$)),\n //expanded\n GEN_DELIMS$$ = \"[\\\\:\\\\/\\\\?\\\\#\\\\[\\\\]\\\\@]\",\n SUB_DELIMS$$ = \"[\\\\!\\\\$\\\\&\\\\'\\\\(\\\\)\\\\*\\\\+\\\\,\\\\;\\\\=]\",\n RESERVED$$ = merge(GEN_DELIMS$$, SUB_DELIMS$$),\n UCSCHAR$$ = isIRI ? \"[\\\\xA0-\\\\u200D\\\\u2010-\\\\u2029\\\\u202F-\\\\uD7FF\\\\uF900-\\\\uFDCF\\\\uFDF0-\\\\uFFEF]\" : \"[]\",\n //subset, excludes bidi control characters\n IPRIVATE$$ = isIRI ? \"[\\\\uE000-\\\\uF8FF]\" : \"[]\",\n //subset\n UNRESERVED$$ = merge(ALPHA$$, DIGIT$$, \"[\\\\-\\\\.\\\\_\\\\~]\", UCSCHAR$$),\n SCHEME$ = subexp(ALPHA$$ + merge(ALPHA$$, DIGIT$$, \"[\\\\+\\\\-\\\\.]\") + \"*\"),\n USERINFO$ = subexp(subexp(PCT_ENCODED$ + \"|\" + merge(UNRESERVED$$, SUB_DELIMS$$, \"[\\\\:]\")) + \"*\"),\n DEC_OCTET$ = subexp(subexp(\"25[0-5]\") + \"|\" + subexp(\"2[0-4]\" + DIGIT$$) + \"|\" + subexp(\"1\" + DIGIT$$ + DIGIT$$) + \"|\" + subexp(\"[1-9]\" + DIGIT$$) + \"|\" + DIGIT$$),\n DEC_OCTET_RELAXED$ = subexp(subexp(\"25[0-5]\") + \"|\" + subexp(\"2[0-4]\" + DIGIT$$) + \"|\" + subexp(\"1\" + DIGIT$$ + DIGIT$$) + \"|\" + subexp(\"0?[1-9]\" + DIGIT$$) + \"|0?0?\" + DIGIT$$),\n //relaxed parsing rules\n IPV4ADDRESS$ = subexp(DEC_OCTET_RELAXED$ + \"\\\\.\" + DEC_OCTET_RELAXED$ + \"\\\\.\" + DEC_OCTET_RELAXED$ + \"\\\\.\" + DEC_OCTET_RELAXED$),\n H16$ = subexp(HEXDIG$$ + \"{1,4}\"),\n LS32$ = subexp(subexp(H16$ + \"\\\\:\" + H16$) + \"|\" + IPV4ADDRESS$),\n IPV6ADDRESS1$ = subexp(subexp(H16$ + \"\\\\:\") + \"{6}\" + LS32$),\n // 6( h16 \":\" ) ls32\n IPV6ADDRESS2$ = subexp(\"\\\\:\\\\:\" + subexp(H16$ + \"\\\\:\") + \"{5}\" + LS32$),\n // \"::\" 5( h16 \":\" ) ls32\n IPV6ADDRESS3$ = subexp(subexp(H16$) + \"?\\\\:\\\\:\" + subexp(H16$ + \"\\\\:\") + \"{4}\" + LS32$),\n //[ h16 ] \"::\" 4( h16 \":\" ) ls32\n IPV6ADDRESS4$ = subexp(subexp(subexp(H16$ + \"\\\\:\") + \"{0,1}\" + H16$) + \"?\\\\:\\\\:\" + subexp(H16$ + \"\\\\:\") + \"{3}\" + LS32$),\n //[ *1( h16 \":\" ) h16 ] \"::\" 3( h16 \":\" ) ls32\n IPV6ADDRESS5$ = subexp(subexp(subexp(H16$ + \"\\\\:\") + \"{0,2}\" + H16$) + \"?\\\\:\\\\:\" + subexp(H16$ + \"\\\\:\") + \"{2}\" + LS32$),\n //[ *2( h16 \":\" ) h16 ] \"::\" 2( h16 \":\" ) ls32\n IPV6ADDRESS6$ = subexp(subexp(subexp(H16$ + \"\\\\:\") + \"{0,3}\" + H16$) + \"?\\\\:\\\\:\" + H16$ + \"\\\\:\" + LS32$),\n //[ *3( h16 \":\" ) h16 ] \"::\" h16 \":\" ls32\n IPV6ADDRESS7$ = subexp(subexp(subexp(H16$ + \"\\\\:\") + \"{0,4}\" + H16$) + \"?\\\\:\\\\:\" + LS32$),\n //[ *4( h16 \":\" ) h16 ] \"::\" ls32\n IPV6ADDRESS8$ = subexp(subexp(subexp(H16$ + \"\\\\:\") + \"{0,5}\" + H16$) + \"?\\\\:\\\\:\" + H16$),\n //[ *5( h16 \":\" ) h16 ] \"::\" h16\n IPV6ADDRESS9$ = subexp(subexp(subexp(H16$ + \"\\\\:\") + \"{0,6}\" + H16$) + \"?\\\\:\\\\:\"),\n //[ *6( h16 \":\" ) h16 ] \"::\"\n IPV6ADDRESS$ = subexp([IPV6ADDRESS1$, IPV6ADDRESS2$, IPV6ADDRESS3$, IPV6ADDRESS4$, IPV6ADDRESS5$, IPV6ADDRESS6$, IPV6ADDRESS7$, IPV6ADDRESS8$, IPV6ADDRESS9$].join(\"|\")),\n ZONEID$ = subexp(subexp(UNRESERVED$$ + \"|\" + PCT_ENCODED$) + \"+\"),\n //RFC 6874\n IPV6ADDRZ$ = subexp(IPV6ADDRESS$ + \"\\\\%25\" + ZONEID$),\n //RFC 6874\n IPV6ADDRZ_RELAXED$ = subexp(IPV6ADDRESS$ + subexp(\"\\\\%25|\\\\%(?!\" + HEXDIG$$ + \"{2})\") + ZONEID$),\n //RFC 6874, with relaxed parsing rules\n IPVFUTURE$ = subexp(\"[vV]\" + HEXDIG$$ + \"+\\\\.\" + merge(UNRESERVED$$, SUB_DELIMS$$, \"[\\\\:]\") + \"+\"),\n IP_LITERAL$ = subexp(\"\\\\[\" + subexp(IPV6ADDRZ_RELAXED$ + \"|\" + IPV6ADDRESS$ + \"|\" + IPVFUTURE$) + \"\\\\]\"),\n //RFC 6874\n REG_NAME$ = subexp(subexp(PCT_ENCODED$ + \"|\" + merge(UNRESERVED$$, SUB_DELIMS$$)) + \"*\"),\n HOST$ = subexp(IP_LITERAL$ + \"|\" + IPV4ADDRESS$ + \"(?!\" + REG_NAME$ + \")\" + \"|\" + REG_NAME$),\n PORT$ = subexp(DIGIT$$ + \"*\"),\n AUTHORITY$ = subexp(subexp(USERINFO$ + \"@\") + \"?\" + HOST$ + subexp(\"\\\\:\" + PORT$) + \"?\"),\n PCHAR$ = subexp(PCT_ENCODED$ + \"|\" + merge(UNRESERVED$$, SUB_DELIMS$$, \"[\\\\:\\\\@]\")),\n SEGMENT$ = subexp(PCHAR$ + \"*\"),\n SEGMENT_NZ$ = subexp(PCHAR$ + \"+\"),\n SEGMENT_NZ_NC$ = subexp(subexp(PCT_ENCODED$ + \"|\" + merge(UNRESERVED$$, SUB_DELIMS$$, \"[\\\\@]\")) + \"+\"),\n PATH_ABEMPTY$ = subexp(subexp(\"\\\\/\" + SEGMENT$) + \"*\"),\n PATH_ABSOLUTE$ = subexp(\"\\\\/\" + subexp(SEGMENT_NZ$ + PATH_ABEMPTY$) + \"?\"),\n //simplified\n PATH_NOSCHEME$ = subexp(SEGMENT_NZ_NC$ + PATH_ABEMPTY$),\n //simplified\n PATH_ROOTLESS$ = subexp(SEGMENT_NZ$ + PATH_ABEMPTY$),\n //simplified\n PATH_EMPTY$ = \"(?!\" + PCHAR$ + \")\",\n PATH$ = subexp(PATH_ABEMPTY$ + \"|\" + PATH_ABSOLUTE$ + \"|\" + PATH_NOSCHEME$ + \"|\" + PATH_ROOTLESS$ + \"|\" + PATH_EMPTY$),\n QUERY$ = subexp(subexp(PCHAR$ + \"|\" + merge(\"[\\\\/\\\\?]\", IPRIVATE$$)) + \"*\"),\n FRAGMENT$ = subexp(subexp(PCHAR$ + \"|[\\\\/\\\\?]\") + \"*\"),\n HIER_PART$ = subexp(subexp(\"\\\\/\\\\/\" + AUTHORITY$ + PATH_ABEMPTY$) + \"|\" + PATH_ABSOLUTE$ + \"|\" + PATH_ROOTLESS$ + \"|\" + PATH_EMPTY$),\n URI$ = subexp(SCHEME$ + \"\\\\:\" + HIER_PART$ + subexp(\"\\\\?\" + QUERY$) + \"?\" + subexp(\"\\\\#\" + FRAGMENT$) + \"?\"),\n RELATIVE_PART$ = subexp(subexp(\"\\\\/\\\\/\" + AUTHORITY$ + PATH_ABEMPTY$) + \"|\" + PATH_ABSOLUTE$ + \"|\" + PATH_NOSCHEME$ + \"|\" + PATH_EMPTY$),\n RELATIVE$ = subexp(RELATIVE_PART$ + subexp(\"\\\\?\" + QUERY$) + \"?\" + subexp(\"\\\\#\" + FRAGMENT$) + \"?\"),\n URI_REFERENCE$ = subexp(URI$ + \"|\" + RELATIVE$),\n ABSOLUTE_URI$ = subexp(SCHEME$ + \"\\\\:\" + HIER_PART$ + subexp(\"\\\\?\" + QUERY$) + \"?\"),\n GENERIC_REF$ = \"^(\" + SCHEME$ + \")\\\\:\" + subexp(subexp(\"\\\\/\\\\/(\" + subexp(\"(\" + USERINFO$ + \")@\") + \"?(\" + HOST$ + \")\" + subexp(\"\\\\:(\" + PORT$ + \")\") + \"?)\") + \"?(\" + PATH_ABEMPTY$ + \"|\" + PATH_ABSOLUTE$ + \"|\" + PATH_ROOTLESS$ + \"|\" + PATH_EMPTY$ + \")\") + subexp(\"\\\\?(\" + QUERY$ + \")\") + \"?\" + subexp(\"\\\\#(\" + FRAGMENT$ + \")\") + \"?$\",\n RELATIVE_REF$ = \"^(){0}\" + subexp(subexp(\"\\\\/\\\\/(\" + subexp(\"(\" + USERINFO$ + \")@\") + \"?(\" + HOST$ + \")\" + subexp(\"\\\\:(\" + PORT$ + \")\") + \"?)\") + \"?(\" + PATH_ABEMPTY$ + \"|\" + PATH_ABSOLUTE$ + \"|\" + PATH_NOSCHEME$ + \"|\" + PATH_EMPTY$ + \")\") + subexp(\"\\\\?(\" + QUERY$ + \")\") + \"?\" + subexp(\"\\\\#(\" + FRAGMENT$ + \")\") + \"?$\",\n ABSOLUTE_REF$ = \"^(\" + SCHEME$ + \")\\\\:\" + subexp(subexp(\"\\\\/\\\\/(\" + subexp(\"(\" + USERINFO$ + \")@\") + \"?(\" + HOST$ + \")\" + subexp(\"\\\\:(\" + PORT$ + \")\") + \"?)\") + \"?(\" + PATH_ABEMPTY$ + \"|\" + PATH_ABSOLUTE$ + \"|\" + PATH_ROOTLESS$ + \"|\" + PATH_EMPTY$ + \")\") + subexp(\"\\\\?(\" + QUERY$ + \")\") + \"?$\",\n SAMEDOC_REF$ = \"^\" + subexp(\"\\\\#(\" + FRAGMENT$ + \")\") + \"?$\",\n AUTHORITY_REF$ = \"^\" + subexp(\"(\" + USERINFO$ + \")@\") + \"?(\" + HOST$ + \")\" + subexp(\"\\\\:(\" + PORT$ + \")\") + \"?$\";\n return {\n NOT_SCHEME: new RegExp(merge(\"[^]\", ALPHA$$, DIGIT$$, \"[\\\\+\\\\-\\\\.]\"), \"g\"),\n NOT_USERINFO: new RegExp(merge(\"[^\\\\%\\\\:]\", UNRESERVED$$, SUB_DELIMS$$), \"g\"),\n NOT_HOST: new RegExp(merge(\"[^\\\\%\\\\[\\\\]\\\\:]\", UNRESERVED$$, SUB_DELIMS$$), \"g\"),\n NOT_PATH: new RegExp(merge(\"[^\\\\%\\\\/\\\\:\\\\@]\", UNRESERVED$$, SUB_DELIMS$$), \"g\"),\n NOT_PATH_NOSCHEME: new RegExp(merge(\"[^\\\\%\\\\/\\\\@]\", UNRESERVED$$, SUB_DELIMS$$), \"g\"),\n NOT_QUERY: new RegExp(merge(\"[^\\\\%]\", UNRESERVED$$, SUB_DELIMS$$, \"[\\\\:\\\\@\\\\/\\\\?]\", IPRIVATE$$), \"g\"),\n NOT_FRAGMENT: new RegExp(merge(\"[^\\\\%]\", UNRESERVED$$, SUB_DELIMS$$, \"[\\\\:\\\\@\\\\/\\\\?]\"), \"g\"),\n ESCAPE: new RegExp(merge(\"[^]\", UNRESERVED$$, SUB_DELIMS$$), \"g\"),\n UNRESERVED: new RegExp(UNRESERVED$$, \"g\"),\n OTHER_CHARS: new RegExp(merge(\"[^\\\\%]\", UNRESERVED$$, RESERVED$$), \"g\"),\n PCT_ENCODED: new RegExp(PCT_ENCODED$, \"g\"),\n IPV4ADDRESS: new RegExp(\"^(\" + IPV4ADDRESS$ + \")$\"),\n IPV6ADDRESS: new RegExp(\"^\\\\[?(\" + IPV6ADDRESS$ + \")\" + subexp(subexp(\"\\\\%25|\\\\%(?!\" + HEXDIG$$ + \"{2})\") + \"(\" + ZONEID$ + \")\") + \"?\\\\]?$\") //RFC 6874, with relaxed parsing rules\n };\n}\nvar URI_PROTOCOL = buildExps(false);\n\nvar IRI_PROTOCOL = buildExps(true);\n\nvar slicedToArray = function () {\n function sliceIterator(arr, i) {\n var _arr = [];\n var _n = true;\n var _d = false;\n var _e = undefined;\n\n try {\n for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"]) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n }\n\n return function (arr, i) {\n if (Array.isArray(arr)) {\n return arr;\n } else if (Symbol.iterator in Object(arr)) {\n return sliceIterator(arr, i);\n } else {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n }\n };\n}();\n\n\n\n\n\n\n\n\n\n\n\n\n\nvar toConsumableArray = function (arr) {\n if (Array.isArray(arr)) {\n for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];\n\n return arr2;\n } else {\n return Array.from(arr);\n }\n};\n\n/** Highest positive signed 32-bit float value */\n\nvar maxInt = 2147483647; // aka. 0x7FFFFFFF or 2^31-1\n\n/** Bootstring parameters */\nvar base = 36;\nvar tMin = 1;\nvar tMax = 26;\nvar skew = 38;\nvar damp = 700;\nvar initialBias = 72;\nvar initialN = 128; // 0x80\nvar delimiter = '-'; // '\\x2D'\n\n/** Regular expressions */\nvar regexPunycode = /^xn--/;\nvar regexNonASCII = /[^\\0-\\x7E]/; // non-ASCII chars\nvar regexSeparators = /[\\x2E\\u3002\\uFF0E\\uFF61]/g; // RFC 3490 separators\n\n/** Error messages */\nvar errors = {\n\t'overflow': 'Overflow: input needs wider integers to process',\n\t'not-basic': 'Illegal input >= 0x80 (not a basic code point)',\n\t'invalid-input': 'Invalid input'\n};\n\n/** Convenience shortcuts */\nvar baseMinusTMin = base - tMin;\nvar floor = Math.floor;\nvar stringFromCharCode = String.fromCharCode;\n\n/*--------------------------------------------------------------------------*/\n\n/**\n * A generic error utility function.\n * @private\n * @param {String} type The error type.\n * @returns {Error} Throws a `RangeError` with the applicable error message.\n */\nfunction error$1(type) {\n\tthrow new RangeError(errors[type]);\n}\n\n/**\n * A generic `Array#map` utility function.\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} callback The function that gets called for every array\n * item.\n * @returns {Array} A new array of values returned by the callback function.\n */\nfunction map(array, fn) {\n\tvar result = [];\n\tvar length = array.length;\n\twhile (length--) {\n\t\tresult[length] = fn(array[length]);\n\t}\n\treturn result;\n}\n\n/**\n * A simple `Array#map`-like wrapper to work with domain name strings or email\n * addresses.\n * @private\n * @param {String} domain The domain name or email address.\n * @param {Function} callback The function that gets called for every\n * character.\n * @returns {Array} A new string of characters returned by the callback\n * function.\n */\nfunction mapDomain(string, fn) {\n\tvar parts = string.split('@');\n\tvar result = '';\n\tif (parts.length > 1) {\n\t\t// In email addresses, only the domain name should be punycoded. Leave\n\t\t// the local part (i.e. everything up to `@`) intact.\n\t\tresult = parts[0] + '@';\n\t\tstring = parts[1];\n\t}\n\t// Avoid `split(regex)` for IE8 compatibility. See #17.\n\tstring = string.replace(regexSeparators, '\\x2E');\n\tvar labels = string.split('.');\n\tvar encoded = map(labels, fn).join('.');\n\treturn result + encoded;\n}\n\n/**\n * Creates an array containing the numeric code points of each Unicode\n * character in the string. While JavaScript uses UCS-2 internally,\n * this function will convert a pair of surrogate halves (each of which\n * UCS-2 exposes as separate characters) into a single code point,\n * matching UTF-16.\n * @see `punycode.ucs2.encode`\n * @see \n * @memberOf punycode.ucs2\n * @name decode\n * @param {String} string The Unicode input string (UCS-2).\n * @returns {Array} The new array of code points.\n */\nfunction ucs2decode(string) {\n\tvar output = [];\n\tvar counter = 0;\n\tvar length = string.length;\n\twhile (counter < length) {\n\t\tvar value = string.charCodeAt(counter++);\n\t\tif (value >= 0xD800 && value <= 0xDBFF && counter < length) {\n\t\t\t// It's a high surrogate, and there is a next character.\n\t\t\tvar extra = string.charCodeAt(counter++);\n\t\t\tif ((extra & 0xFC00) == 0xDC00) {\n\t\t\t\t// Low surrogate.\n\t\t\t\toutput.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n\t\t\t} else {\n\t\t\t\t// It's an unmatched surrogate; only append this code unit, in case the\n\t\t\t\t// next code unit is the high surrogate of a surrogate pair.\n\t\t\t\toutput.push(value);\n\t\t\t\tcounter--;\n\t\t\t}\n\t\t} else {\n\t\t\toutput.push(value);\n\t\t}\n\t}\n\treturn output;\n}\n\n/**\n * Creates a string based on an array of numeric code points.\n * @see `punycode.ucs2.decode`\n * @memberOf punycode.ucs2\n * @name encode\n * @param {Array} codePoints The array of numeric code points.\n * @returns {String} The new Unicode string (UCS-2).\n */\nvar ucs2encode = function ucs2encode(array) {\n\treturn String.fromCodePoint.apply(String, toConsumableArray(array));\n};\n\n/**\n * Converts a basic code point into a digit/integer.\n * @see `digitToBasic()`\n * @private\n * @param {Number} codePoint The basic numeric code point value.\n * @returns {Number} The numeric value of a basic code point (for use in\n * representing integers) in the range `0` to `base - 1`, or `base` if\n * the code point does not represent a value.\n */\nvar basicToDigit = function basicToDigit(codePoint) {\n\tif (codePoint - 0x30 < 0x0A) {\n\t\treturn codePoint - 0x16;\n\t}\n\tif (codePoint - 0x41 < 0x1A) {\n\t\treturn codePoint - 0x41;\n\t}\n\tif (codePoint - 0x61 < 0x1A) {\n\t\treturn codePoint - 0x61;\n\t}\n\treturn base;\n};\n\n/**\n * Converts a digit/integer into a basic code point.\n * @see `basicToDigit()`\n * @private\n * @param {Number} digit The numeric value of a basic code point.\n * @returns {Number} The basic code point whose value (when used for\n * representing integers) is `digit`, which needs to be in the range\n * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is\n * used; else, the lowercase form is used. The behavior is undefined\n * if `flag` is non-zero and `digit` has no uppercase form.\n */\nvar digitToBasic = function digitToBasic(digit, flag) {\n\t// 0..25 map to ASCII a..z or A..Z\n\t// 26..35 map to ASCII 0..9\n\treturn digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5);\n};\n\n/**\n * Bias adaptation function as per section 3.4 of RFC 3492.\n * https://tools.ietf.org/html/rfc3492#section-3.4\n * @private\n */\nvar adapt = function adapt(delta, numPoints, firstTime) {\n\tvar k = 0;\n\tdelta = firstTime ? floor(delta / damp) : delta >> 1;\n\tdelta += floor(delta / numPoints);\n\tfor (; /* no initialization */delta > baseMinusTMin * tMax >> 1; k += base) {\n\t\tdelta = floor(delta / baseMinusTMin);\n\t}\n\treturn floor(k + (baseMinusTMin + 1) * delta / (delta + skew));\n};\n\n/**\n * Converts a Punycode string of ASCII-only symbols to a string of Unicode\n * symbols.\n * @memberOf punycode\n * @param {String} input The Punycode string of ASCII-only symbols.\n * @returns {String} The resulting string of Unicode symbols.\n */\nvar decode = function decode(input) {\n\t// Don't use UCS-2.\n\tvar output = [];\n\tvar inputLength = input.length;\n\tvar i = 0;\n\tvar n = initialN;\n\tvar bias = initialBias;\n\n\t// Handle the basic code points: let `basic` be the number of input code\n\t// points before the last delimiter, or `0` if there is none, then copy\n\t// the first basic code points to the output.\n\n\tvar basic = input.lastIndexOf(delimiter);\n\tif (basic < 0) {\n\t\tbasic = 0;\n\t}\n\n\tfor (var j = 0; j < basic; ++j) {\n\t\t// if it's not a basic code point\n\t\tif (input.charCodeAt(j) >= 0x80) {\n\t\t\terror$1('not-basic');\n\t\t}\n\t\toutput.push(input.charCodeAt(j));\n\t}\n\n\t// Main decoding loop: start just after the last delimiter if any basic code\n\t// points were copied; start at the beginning otherwise.\n\n\tfor (var index = basic > 0 ? basic + 1 : 0; index < inputLength;) /* no final expression */{\n\n\t\t// `index` is the index of the next character to be consumed.\n\t\t// Decode a generalized variable-length integer into `delta`,\n\t\t// which gets added to `i`. The overflow checking is easier\n\t\t// if we increase `i` as we go, then subtract off its starting\n\t\t// value at the end to obtain `delta`.\n\t\tvar oldi = i;\n\t\tfor (var w = 1, k = base;; /* no condition */k += base) {\n\n\t\t\tif (index >= inputLength) {\n\t\t\t\terror$1('invalid-input');\n\t\t\t}\n\n\t\t\tvar digit = basicToDigit(input.charCodeAt(index++));\n\n\t\t\tif (digit >= base || digit > floor((maxInt - i) / w)) {\n\t\t\t\terror$1('overflow');\n\t\t\t}\n\n\t\t\ti += digit * w;\n\t\t\tvar t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias;\n\n\t\t\tif (digit < t) {\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tvar baseMinusT = base - t;\n\t\t\tif (w > floor(maxInt / baseMinusT)) {\n\t\t\t\terror$1('overflow');\n\t\t\t}\n\n\t\t\tw *= baseMinusT;\n\t\t}\n\n\t\tvar out = output.length + 1;\n\t\tbias = adapt(i - oldi, out, oldi == 0);\n\n\t\t// `i` was supposed to wrap around from `out` to `0`,\n\t\t// incrementing `n` each time, so we'll fix that now:\n\t\tif (floor(i / out) > maxInt - n) {\n\t\t\terror$1('overflow');\n\t\t}\n\n\t\tn += floor(i / out);\n\t\ti %= out;\n\n\t\t// Insert `n` at position `i` of the output.\n\t\toutput.splice(i++, 0, n);\n\t}\n\n\treturn String.fromCodePoint.apply(String, output);\n};\n\n/**\n * Converts a string of Unicode symbols (e.g. a domain name label) to a\n * Punycode string of ASCII-only symbols.\n * @memberOf punycode\n * @param {String} input The string of Unicode symbols.\n * @returns {String} The resulting Punycode string of ASCII-only symbols.\n */\nvar encode = function encode(input) {\n\tvar output = [];\n\n\t// Convert the input in UCS-2 to an array of Unicode code points.\n\tinput = ucs2decode(input);\n\n\t// Cache the length.\n\tvar inputLength = input.length;\n\n\t// Initialize the state.\n\tvar n = initialN;\n\tvar delta = 0;\n\tvar bias = initialBias;\n\n\t// Handle the basic code points.\n\tvar _iteratorNormalCompletion = true;\n\tvar _didIteratorError = false;\n\tvar _iteratorError = undefined;\n\n\ttry {\n\t\tfor (var _iterator = input[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {\n\t\t\tvar _currentValue2 = _step.value;\n\n\t\t\tif (_currentValue2 < 0x80) {\n\t\t\t\toutput.push(stringFromCharCode(_currentValue2));\n\t\t\t}\n\t\t}\n\t} catch (err) {\n\t\t_didIteratorError = true;\n\t\t_iteratorError = err;\n\t} finally {\n\t\ttry {\n\t\t\tif (!_iteratorNormalCompletion && _iterator.return) {\n\t\t\t\t_iterator.return();\n\t\t\t}\n\t\t} finally {\n\t\t\tif (_didIteratorError) {\n\t\t\t\tthrow _iteratorError;\n\t\t\t}\n\t\t}\n\t}\n\n\tvar basicLength = output.length;\n\tvar handledCPCount = basicLength;\n\n\t// `handledCPCount` is the number of code points that have been handled;\n\t// `basicLength` is the number of basic code points.\n\n\t// Finish the basic string with a delimiter unless it's empty.\n\tif (basicLength) {\n\t\toutput.push(delimiter);\n\t}\n\n\t// Main encoding loop:\n\twhile (handledCPCount < inputLength) {\n\n\t\t// All non-basic code points < n have been handled already. Find the next\n\t\t// larger one:\n\t\tvar m = maxInt;\n\t\tvar _iteratorNormalCompletion2 = true;\n\t\tvar _didIteratorError2 = false;\n\t\tvar _iteratorError2 = undefined;\n\n\t\ttry {\n\t\t\tfor (var _iterator2 = input[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {\n\t\t\t\tvar currentValue = _step2.value;\n\n\t\t\t\tif (currentValue >= n && currentValue < m) {\n\t\t\t\t\tm = currentValue;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Increase `delta` enough to advance the decoder's state to ,\n\t\t\t// but guard against overflow.\n\t\t} catch (err) {\n\t\t\t_didIteratorError2 = true;\n\t\t\t_iteratorError2 = err;\n\t\t} finally {\n\t\t\ttry {\n\t\t\t\tif (!_iteratorNormalCompletion2 && _iterator2.return) {\n\t\t\t\t\t_iterator2.return();\n\t\t\t\t}\n\t\t\t} finally {\n\t\t\t\tif (_didIteratorError2) {\n\t\t\t\t\tthrow _iteratorError2;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tvar handledCPCountPlusOne = handledCPCount + 1;\n\t\tif (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) {\n\t\t\terror$1('overflow');\n\t\t}\n\n\t\tdelta += (m - n) * handledCPCountPlusOne;\n\t\tn = m;\n\n\t\tvar _iteratorNormalCompletion3 = true;\n\t\tvar _didIteratorError3 = false;\n\t\tvar _iteratorError3 = undefined;\n\n\t\ttry {\n\t\t\tfor (var _iterator3 = input[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) {\n\t\t\t\tvar _currentValue = _step3.value;\n\n\t\t\t\tif (_currentValue < n && ++delta > maxInt) {\n\t\t\t\t\terror$1('overflow');\n\t\t\t\t}\n\t\t\t\tif (_currentValue == n) {\n\t\t\t\t\t// Represent delta as a generalized variable-length integer.\n\t\t\t\t\tvar q = delta;\n\t\t\t\t\tfor (var k = base;; /* no condition */k += base) {\n\t\t\t\t\t\tvar t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias;\n\t\t\t\t\t\tif (q < t) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tvar qMinusT = q - t;\n\t\t\t\t\t\tvar baseMinusT = base - t;\n\t\t\t\t\t\toutput.push(stringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0)));\n\t\t\t\t\t\tq = floor(qMinusT / baseMinusT);\n\t\t\t\t\t}\n\n\t\t\t\t\toutput.push(stringFromCharCode(digitToBasic(q, 0)));\n\t\t\t\t\tbias = adapt(delta, handledCPCountPlusOne, handledCPCount == basicLength);\n\t\t\t\t\tdelta = 0;\n\t\t\t\t\t++handledCPCount;\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (err) {\n\t\t\t_didIteratorError3 = true;\n\t\t\t_iteratorError3 = err;\n\t\t} finally {\n\t\t\ttry {\n\t\t\t\tif (!_iteratorNormalCompletion3 && _iterator3.return) {\n\t\t\t\t\t_iterator3.return();\n\t\t\t\t}\n\t\t\t} finally {\n\t\t\t\tif (_didIteratorError3) {\n\t\t\t\t\tthrow _iteratorError3;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t++delta;\n\t\t++n;\n\t}\n\treturn output.join('');\n};\n\n/**\n * Converts a Punycode string representing a domain name or an email address\n * to Unicode. Only the Punycoded parts of the input will be converted, i.e.\n * it doesn't matter if you call it on a string that has already been\n * converted to Unicode.\n * @memberOf punycode\n * @param {String} input The Punycoded domain name or email address to\n * convert to Unicode.\n * @returns {String} The Unicode representation of the given Punycode\n * string.\n */\nvar toUnicode = function toUnicode(input) {\n\treturn mapDomain(input, function (string) {\n\t\treturn regexPunycode.test(string) ? decode(string.slice(4).toLowerCase()) : string;\n\t});\n};\n\n/**\n * Converts a Unicode string representing a domain name or an email address to\n * Punycode. Only the non-ASCII parts of the domain name will be converted,\n * i.e. it doesn't matter if you call it with a domain that's already in\n * ASCII.\n * @memberOf punycode\n * @param {String} input The domain name or email address to convert, as a\n * Unicode string.\n * @returns {String} The Punycode representation of the given domain name or\n * email address.\n */\nvar toASCII = function toASCII(input) {\n\treturn mapDomain(input, function (string) {\n\t\treturn regexNonASCII.test(string) ? 'xn--' + encode(string) : string;\n\t});\n};\n\n/*--------------------------------------------------------------------------*/\n\n/** Define the public API */\nvar punycode = {\n\t/**\n * A string representing the current Punycode.js version number.\n * @memberOf punycode\n * @type String\n */\n\t'version': '2.1.0',\n\t/**\n * An object of methods to convert from JavaScript's internal character\n * representation (UCS-2) to Unicode code points, and back.\n * @see \n * @memberOf punycode\n * @type Object\n */\n\t'ucs2': {\n\t\t'decode': ucs2decode,\n\t\t'encode': ucs2encode\n\t},\n\t'decode': decode,\n\t'encode': encode,\n\t'toASCII': toASCII,\n\t'toUnicode': toUnicode\n};\n\n/**\n * URI.js\n *\n * @fileoverview An RFC 3986 compliant, scheme extendable URI parsing/validating/resolving library for JavaScript.\n * @author Gary Court\n * @see http://github.com/garycourt/uri-js\n */\n/**\n * Copyright 2011 Gary Court. All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without modification, are\n * permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this list of\n * conditions and the following disclaimer.\n *\n * 2. Redistributions in binary form must reproduce the above copyright notice, this list\n * of conditions and the following disclaimer in the documentation and/or other materials\n * provided with the distribution.\n *\n * THIS SOFTWARE IS PROVIDED BY GARY COURT ``AS IS'' AND ANY EXPRESS OR IMPLIED\n * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GARY COURT OR\n * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR\n * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\n * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF\n * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n *\n * The views and conclusions contained in the software and documentation are those of the\n * authors and should not be interpreted as representing official policies, either expressed\n * or implied, of Gary Court.\n */\nvar SCHEMES = {};\nfunction pctEncChar(chr) {\n var c = chr.charCodeAt(0);\n var e = void 0;\n if (c < 16) e = \"%0\" + c.toString(16).toUpperCase();else if (c < 128) e = \"%\" + c.toString(16).toUpperCase();else if (c < 2048) e = \"%\" + (c >> 6 | 192).toString(16).toUpperCase() + \"%\" + (c & 63 | 128).toString(16).toUpperCase();else e = \"%\" + (c >> 12 | 224).toString(16).toUpperCase() + \"%\" + (c >> 6 & 63 | 128).toString(16).toUpperCase() + \"%\" + (c & 63 | 128).toString(16).toUpperCase();\n return e;\n}\nfunction pctDecChars(str) {\n var newStr = \"\";\n var i = 0;\n var il = str.length;\n while (i < il) {\n var c = parseInt(str.substr(i + 1, 2), 16);\n if (c < 128) {\n newStr += String.fromCharCode(c);\n i += 3;\n } else if (c >= 194 && c < 224) {\n if (il - i >= 6) {\n var c2 = parseInt(str.substr(i + 4, 2), 16);\n newStr += String.fromCharCode((c & 31) << 6 | c2 & 63);\n } else {\n newStr += str.substr(i, 6);\n }\n i += 6;\n } else if (c >= 224) {\n if (il - i >= 9) {\n var _c = parseInt(str.substr(i + 4, 2), 16);\n var c3 = parseInt(str.substr(i + 7, 2), 16);\n newStr += String.fromCharCode((c & 15) << 12 | (_c & 63) << 6 | c3 & 63);\n } else {\n newStr += str.substr(i, 9);\n }\n i += 9;\n } else {\n newStr += str.substr(i, 3);\n i += 3;\n }\n }\n return newStr;\n}\nfunction _normalizeComponentEncoding(components, protocol) {\n function decodeUnreserved(str) {\n var decStr = pctDecChars(str);\n return !decStr.match(protocol.UNRESERVED) ? str : decStr;\n }\n if (components.scheme) components.scheme = String(components.scheme).replace(protocol.PCT_ENCODED, decodeUnreserved).toLowerCase().replace(protocol.NOT_SCHEME, \"\");\n if (components.userinfo !== undefined) components.userinfo = String(components.userinfo).replace(protocol.PCT_ENCODED, decodeUnreserved).replace(protocol.NOT_USERINFO, pctEncChar).replace(protocol.PCT_ENCODED, toUpperCase);\n if (components.host !== undefined) components.host = String(components.host).replace(protocol.PCT_ENCODED, decodeUnreserved).toLowerCase().replace(protocol.NOT_HOST, pctEncChar).replace(protocol.PCT_ENCODED, toUpperCase);\n if (components.path !== undefined) components.path = String(components.path).replace(protocol.PCT_ENCODED, decodeUnreserved).replace(components.scheme ? protocol.NOT_PATH : protocol.NOT_PATH_NOSCHEME, pctEncChar).replace(protocol.PCT_ENCODED, toUpperCase);\n if (components.query !== undefined) components.query = String(components.query).replace(protocol.PCT_ENCODED, decodeUnreserved).replace(protocol.NOT_QUERY, pctEncChar).replace(protocol.PCT_ENCODED, toUpperCase);\n if (components.fragment !== undefined) components.fragment = String(components.fragment).replace(protocol.PCT_ENCODED, decodeUnreserved).replace(protocol.NOT_FRAGMENT, pctEncChar).replace(protocol.PCT_ENCODED, toUpperCase);\n return components;\n}\n\nfunction _stripLeadingZeros(str) {\n return str.replace(/^0*(.*)/, \"$1\") || \"0\";\n}\nfunction _normalizeIPv4(host, protocol) {\n var matches = host.match(protocol.IPV4ADDRESS) || [];\n\n var _matches = slicedToArray(matches, 2),\n address = _matches[1];\n\n if (address) {\n return address.split(\".\").map(_stripLeadingZeros).join(\".\");\n } else {\n return host;\n }\n}\nfunction _normalizeIPv6(host, protocol) {\n var matches = host.match(protocol.IPV6ADDRESS) || [];\n\n var _matches2 = slicedToArray(matches, 3),\n address = _matches2[1],\n zone = _matches2[2];\n\n if (address) {\n var _address$toLowerCase$ = address.toLowerCase().split('::').reverse(),\n _address$toLowerCase$2 = slicedToArray(_address$toLowerCase$, 2),\n last = _address$toLowerCase$2[0],\n first = _address$toLowerCase$2[1];\n\n var firstFields = first ? first.split(\":\").map(_stripLeadingZeros) : [];\n var lastFields = last.split(\":\").map(_stripLeadingZeros);\n var isLastFieldIPv4Address = protocol.IPV4ADDRESS.test(lastFields[lastFields.length - 1]);\n var fieldCount = isLastFieldIPv4Address ? 7 : 8;\n var lastFieldsStart = lastFields.length - fieldCount;\n var fields = Array(fieldCount);\n for (var x = 0; x < fieldCount; ++x) {\n fields[x] = firstFields[x] || lastFields[lastFieldsStart + x] || '';\n }\n if (isLastFieldIPv4Address) {\n fields[fieldCount - 1] = _normalizeIPv4(fields[fieldCount - 1], protocol);\n }\n var allZeroFields = fields.reduce(function (acc, field, index) {\n if (!field || field === \"0\") {\n var lastLongest = acc[acc.length - 1];\n if (lastLongest && lastLongest.index + lastLongest.length === index) {\n lastLongest.length++;\n } else {\n acc.push({ index: index, length: 1 });\n }\n }\n return acc;\n }, []);\n var longestZeroFields = allZeroFields.sort(function (a, b) {\n return b.length - a.length;\n })[0];\n var newHost = void 0;\n if (longestZeroFields && longestZeroFields.length > 1) {\n var newFirst = fields.slice(0, longestZeroFields.index);\n var newLast = fields.slice(longestZeroFields.index + longestZeroFields.length);\n newHost = newFirst.join(\":\") + \"::\" + newLast.join(\":\");\n } else {\n newHost = fields.join(\":\");\n }\n if (zone) {\n newHost += \"%\" + zone;\n }\n return newHost;\n } else {\n return host;\n }\n}\nvar URI_PARSE = /^(?:([^:\\/?#]+):)?(?:\\/\\/((?:([^\\/?#@]*)@)?(\\[[^\\/?#\\]]+\\]|[^\\/?#:]*)(?:\\:(\\d*))?))?([^?#]*)(?:\\?([^#]*))?(?:#((?:.|\\n|\\r)*))?/i;\nvar NO_MATCH_IS_UNDEFINED = \"\".match(/(){0}/)[1] === undefined;\nfunction parse(uriString) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n var components = {};\n var protocol = options.iri !== false ? IRI_PROTOCOL : URI_PROTOCOL;\n if (options.reference === \"suffix\") uriString = (options.scheme ? options.scheme + \":\" : \"\") + \"//\" + uriString;\n var matches = uriString.match(URI_PARSE);\n if (matches) {\n if (NO_MATCH_IS_UNDEFINED) {\n //store each component\n components.scheme = matches[1];\n components.userinfo = matches[3];\n components.host = matches[4];\n components.port = parseInt(matches[5], 10);\n components.path = matches[6] || \"\";\n components.query = matches[7];\n components.fragment = matches[8];\n //fix port number\n if (isNaN(components.port)) {\n components.port = matches[5];\n }\n } else {\n //IE FIX for improper RegExp matching\n //store each component\n components.scheme = matches[1] || undefined;\n components.userinfo = uriString.indexOf(\"@\") !== -1 ? matches[3] : undefined;\n components.host = uriString.indexOf(\"//\") !== -1 ? matches[4] : undefined;\n components.port = parseInt(matches[5], 10);\n components.path = matches[6] || \"\";\n components.query = uriString.indexOf(\"?\") !== -1 ? matches[7] : undefined;\n components.fragment = uriString.indexOf(\"#\") !== -1 ? matches[8] : undefined;\n //fix port number\n if (isNaN(components.port)) {\n components.port = uriString.match(/\\/\\/(?:.|\\n)*\\:(?:\\/|\\?|\\#|$)/) ? matches[4] : undefined;\n }\n }\n if (components.host) {\n //normalize IP hosts\n components.host = _normalizeIPv6(_normalizeIPv4(components.host, protocol), protocol);\n }\n //determine reference type\n if (components.scheme === undefined && components.userinfo === undefined && components.host === undefined && components.port === undefined && !components.path && components.query === undefined) {\n components.reference = \"same-document\";\n } else if (components.scheme === undefined) {\n components.reference = \"relative\";\n } else if (components.fragment === undefined) {\n components.reference = \"absolute\";\n } else {\n components.reference = \"uri\";\n }\n //check for reference errors\n if (options.reference && options.reference !== \"suffix\" && options.reference !== components.reference) {\n components.error = components.error || \"URI is not a \" + options.reference + \" reference.\";\n }\n //find scheme handler\n var schemeHandler = SCHEMES[(options.scheme || components.scheme || \"\").toLowerCase()];\n //check if scheme can't handle IRIs\n if (!options.unicodeSupport && (!schemeHandler || !schemeHandler.unicodeSupport)) {\n //if host component is a domain name\n if (components.host && (options.domainHost || schemeHandler && schemeHandler.domainHost)) {\n //convert Unicode IDN -> ASCII IDN\n try {\n components.host = punycode.toASCII(components.host.replace(protocol.PCT_ENCODED, pctDecChars).toLowerCase());\n } catch (e) {\n components.error = components.error || \"Host's domain name can not be converted to ASCII via punycode: \" + e;\n }\n }\n //convert IRI -> URI\n _normalizeComponentEncoding(components, URI_PROTOCOL);\n } else {\n //normalize encodings\n _normalizeComponentEncoding(components, protocol);\n }\n //perform scheme specific parsing\n if (schemeHandler && schemeHandler.parse) {\n schemeHandler.parse(components, options);\n }\n } else {\n components.error = components.error || \"URI can not be parsed.\";\n }\n return components;\n}\n\nfunction _recomposeAuthority(components, options) {\n var protocol = options.iri !== false ? IRI_PROTOCOL : URI_PROTOCOL;\n var uriTokens = [];\n if (components.userinfo !== undefined) {\n uriTokens.push(components.userinfo);\n uriTokens.push(\"@\");\n }\n if (components.host !== undefined) {\n //normalize IP hosts, add brackets and escape zone separator for IPv6\n uriTokens.push(_normalizeIPv6(_normalizeIPv4(String(components.host), protocol), protocol).replace(protocol.IPV6ADDRESS, function (_, $1, $2) {\n return \"[\" + $1 + ($2 ? \"%25\" + $2 : \"\") + \"]\";\n }));\n }\n if (typeof components.port === \"number\" || typeof components.port === \"string\") {\n uriTokens.push(\":\");\n uriTokens.push(String(components.port));\n }\n return uriTokens.length ? uriTokens.join(\"\") : undefined;\n}\n\nvar RDS1 = /^\\.\\.?\\//;\nvar RDS2 = /^\\/\\.(\\/|$)/;\nvar RDS3 = /^\\/\\.\\.(\\/|$)/;\nvar RDS5 = /^\\/?(?:.|\\n)*?(?=\\/|$)/;\nfunction removeDotSegments(input) {\n var output = [];\n while (input.length) {\n if (input.match(RDS1)) {\n input = input.replace(RDS1, \"\");\n } else if (input.match(RDS2)) {\n input = input.replace(RDS2, \"/\");\n } else if (input.match(RDS3)) {\n input = input.replace(RDS3, \"/\");\n output.pop();\n } else if (input === \".\" || input === \"..\") {\n input = \"\";\n } else {\n var im = input.match(RDS5);\n if (im) {\n var s = im[0];\n input = input.slice(s.length);\n output.push(s);\n } else {\n throw new Error(\"Unexpected dot segment condition\");\n }\n }\n }\n return output.join(\"\");\n}\n\nfunction serialize(components) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n var protocol = options.iri ? IRI_PROTOCOL : URI_PROTOCOL;\n var uriTokens = [];\n //find scheme handler\n var schemeHandler = SCHEMES[(options.scheme || components.scheme || \"\").toLowerCase()];\n //perform scheme specific serialization\n if (schemeHandler && schemeHandler.serialize) schemeHandler.serialize(components, options);\n if (components.host) {\n //if host component is an IPv6 address\n if (protocol.IPV6ADDRESS.test(components.host)) {}\n //TODO: normalize IPv6 address as per RFC 5952\n\n //if host component is a domain name\n else if (options.domainHost || schemeHandler && schemeHandler.domainHost) {\n //convert IDN via punycode\n try {\n components.host = !options.iri ? punycode.toASCII(components.host.replace(protocol.PCT_ENCODED, pctDecChars).toLowerCase()) : punycode.toUnicode(components.host);\n } catch (e) {\n components.error = components.error || \"Host's domain name can not be converted to \" + (!options.iri ? \"ASCII\" : \"Unicode\") + \" via punycode: \" + e;\n }\n }\n }\n //normalize encoding\n _normalizeComponentEncoding(components, protocol);\n if (options.reference !== \"suffix\" && components.scheme) {\n uriTokens.push(components.scheme);\n uriTokens.push(\":\");\n }\n var authority = _recomposeAuthority(components, options);\n if (authority !== undefined) {\n if (options.reference !== \"suffix\") {\n uriTokens.push(\"//\");\n }\n uriTokens.push(authority);\n if (components.path && components.path.charAt(0) !== \"/\") {\n uriTokens.push(\"/\");\n }\n }\n if (components.path !== undefined) {\n var s = components.path;\n if (!options.absolutePath && (!schemeHandler || !schemeHandler.absolutePath)) {\n s = removeDotSegments(s);\n }\n if (authority === undefined) {\n s = s.replace(/^\\/\\//, \"/%2F\"); //don't allow the path to start with \"//\"\n }\n uriTokens.push(s);\n }\n if (components.query !== undefined) {\n uriTokens.push(\"?\");\n uriTokens.push(components.query);\n }\n if (components.fragment !== undefined) {\n uriTokens.push(\"#\");\n uriTokens.push(components.fragment);\n }\n return uriTokens.join(\"\"); //merge tokens into a string\n}\n\nfunction resolveComponents(base, relative) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var skipNormalization = arguments[3];\n\n var target = {};\n if (!skipNormalization) {\n base = parse(serialize(base, options), options); //normalize base components\n relative = parse(serialize(relative, options), options); //normalize relative components\n }\n options = options || {};\n if (!options.tolerant && relative.scheme) {\n target.scheme = relative.scheme;\n //target.authority = relative.authority;\n target.userinfo = relative.userinfo;\n target.host = relative.host;\n target.port = relative.port;\n target.path = removeDotSegments(relative.path || \"\");\n target.query = relative.query;\n } else {\n if (relative.userinfo !== undefined || relative.host !== undefined || relative.port !== undefined) {\n //target.authority = relative.authority;\n target.userinfo = relative.userinfo;\n target.host = relative.host;\n target.port = relative.port;\n target.path = removeDotSegments(relative.path || \"\");\n target.query = relative.query;\n } else {\n if (!relative.path) {\n target.path = base.path;\n if (relative.query !== undefined) {\n target.query = relative.query;\n } else {\n target.query = base.query;\n }\n } else {\n if (relative.path.charAt(0) === \"/\") {\n target.path = removeDotSegments(relative.path);\n } else {\n if ((base.userinfo !== undefined || base.host !== undefined || base.port !== undefined) && !base.path) {\n target.path = \"/\" + relative.path;\n } else if (!base.path) {\n target.path = relative.path;\n } else {\n target.path = base.path.slice(0, base.path.lastIndexOf(\"/\") + 1) + relative.path;\n }\n target.path = removeDotSegments(target.path);\n }\n target.query = relative.query;\n }\n //target.authority = base.authority;\n target.userinfo = base.userinfo;\n target.host = base.host;\n target.port = base.port;\n }\n target.scheme = base.scheme;\n }\n target.fragment = relative.fragment;\n return target;\n}\n\nfunction resolve(baseURI, relativeURI, options) {\n var schemelessOptions = assign({ scheme: 'null' }, options);\n return serialize(resolveComponents(parse(baseURI, schemelessOptions), parse(relativeURI, schemelessOptions), schemelessOptions, true), schemelessOptions);\n}\n\nfunction normalize(uri, options) {\n if (typeof uri === \"string\") {\n uri = serialize(parse(uri, options), options);\n } else if (typeOf(uri) === \"object\") {\n uri = parse(serialize(uri, options), options);\n }\n return uri;\n}\n\nfunction equal(uriA, uriB, options) {\n if (typeof uriA === \"string\") {\n uriA = serialize(parse(uriA, options), options);\n } else if (typeOf(uriA) === \"object\") {\n uriA = serialize(uriA, options);\n }\n if (typeof uriB === \"string\") {\n uriB = serialize(parse(uriB, options), options);\n } else if (typeOf(uriB) === \"object\") {\n uriB = serialize(uriB, options);\n }\n return uriA === uriB;\n}\n\nfunction escapeComponent(str, options) {\n return str && str.toString().replace(!options || !options.iri ? URI_PROTOCOL.ESCAPE : IRI_PROTOCOL.ESCAPE, pctEncChar);\n}\n\nfunction unescapeComponent(str, options) {\n return str && str.toString().replace(!options || !options.iri ? URI_PROTOCOL.PCT_ENCODED : IRI_PROTOCOL.PCT_ENCODED, pctDecChars);\n}\n\nvar handler = {\n scheme: \"http\",\n domainHost: true,\n parse: function parse(components, options) {\n //report missing host\n if (!components.host) {\n components.error = components.error || \"HTTP URIs must have a host.\";\n }\n return components;\n },\n serialize: function serialize(components, options) {\n var secure = String(components.scheme).toLowerCase() === \"https\";\n //normalize the default port\n if (components.port === (secure ? 443 : 80) || components.port === \"\") {\n components.port = undefined;\n }\n //normalize the empty path\n if (!components.path) {\n components.path = \"/\";\n }\n //NOTE: We do not parse query strings for HTTP URIs\n //as WWW Form Url Encoded query strings are part of the HTML4+ spec,\n //and not the HTTP spec.\n return components;\n }\n};\n\nvar handler$1 = {\n scheme: \"https\",\n domainHost: handler.domainHost,\n parse: handler.parse,\n serialize: handler.serialize\n};\n\nfunction isSecure(wsComponents) {\n return typeof wsComponents.secure === 'boolean' ? wsComponents.secure : String(wsComponents.scheme).toLowerCase() === \"wss\";\n}\n//RFC 6455\nvar handler$2 = {\n scheme: \"ws\",\n domainHost: true,\n parse: function parse(components, options) {\n var wsComponents = components;\n //indicate if the secure flag is set\n wsComponents.secure = isSecure(wsComponents);\n //construct resouce name\n wsComponents.resourceName = (wsComponents.path || '/') + (wsComponents.query ? '?' + wsComponents.query : '');\n wsComponents.path = undefined;\n wsComponents.query = undefined;\n return wsComponents;\n },\n serialize: function serialize(wsComponents, options) {\n //normalize the default port\n if (wsComponents.port === (isSecure(wsComponents) ? 443 : 80) || wsComponents.port === \"\") {\n wsComponents.port = undefined;\n }\n //ensure scheme matches secure flag\n if (typeof wsComponents.secure === 'boolean') {\n wsComponents.scheme = wsComponents.secure ? 'wss' : 'ws';\n wsComponents.secure = undefined;\n }\n //reconstruct path from resource name\n if (wsComponents.resourceName) {\n var _wsComponents$resourc = wsComponents.resourceName.split('?'),\n _wsComponents$resourc2 = slicedToArray(_wsComponents$resourc, 2),\n path = _wsComponents$resourc2[0],\n query = _wsComponents$resourc2[1];\n\n wsComponents.path = path && path !== '/' ? path : undefined;\n wsComponents.query = query;\n wsComponents.resourceName = undefined;\n }\n //forbid fragment component\n wsComponents.fragment = undefined;\n return wsComponents;\n }\n};\n\nvar handler$3 = {\n scheme: \"wss\",\n domainHost: handler$2.domainHost,\n parse: handler$2.parse,\n serialize: handler$2.serialize\n};\n\nvar O = {};\nvar isIRI = true;\n//RFC 3986\nvar UNRESERVED$$ = \"[A-Za-z0-9\\\\-\\\\.\\\\_\\\\~\" + (isIRI ? \"\\\\xA0-\\\\u200D\\\\u2010-\\\\u2029\\\\u202F-\\\\uD7FF\\\\uF900-\\\\uFDCF\\\\uFDF0-\\\\uFFEF\" : \"\") + \"]\";\nvar HEXDIG$$ = \"[0-9A-Fa-f]\"; //case-insensitive\nvar PCT_ENCODED$ = subexp(subexp(\"%[EFef]\" + HEXDIG$$ + \"%\" + HEXDIG$$ + HEXDIG$$ + \"%\" + HEXDIG$$ + HEXDIG$$) + \"|\" + subexp(\"%[89A-Fa-f]\" + HEXDIG$$ + \"%\" + HEXDIG$$ + HEXDIG$$) + \"|\" + subexp(\"%\" + HEXDIG$$ + HEXDIG$$)); //expanded\n//RFC 5322, except these symbols as per RFC 6068: @ : / ? # [ ] & ; =\n//const ATEXT$$ = \"[A-Za-z0-9\\\\!\\\\#\\\\$\\\\%\\\\&\\\\'\\\\*\\\\+\\\\-\\\\/\\\\=\\\\?\\\\^\\\\_\\\\`\\\\{\\\\|\\\\}\\\\~]\";\n//const WSP$$ = \"[\\\\x20\\\\x09]\";\n//const OBS_QTEXT$$ = \"[\\\\x01-\\\\x08\\\\x0B\\\\x0C\\\\x0E-\\\\x1F\\\\x7F]\"; //(%d1-8 / %d11-12 / %d14-31 / %d127)\n//const QTEXT$$ = merge(\"[\\\\x21\\\\x23-\\\\x5B\\\\x5D-\\\\x7E]\", OBS_QTEXT$$); //%d33 / %d35-91 / %d93-126 / obs-qtext\n//const VCHAR$$ = \"[\\\\x21-\\\\x7E]\";\n//const WSP$$ = \"[\\\\x20\\\\x09]\";\n//const OBS_QP$ = subexp(\"\\\\\\\\\" + merge(\"[\\\\x00\\\\x0D\\\\x0A]\", OBS_QTEXT$$)); //%d0 / CR / LF / obs-qtext\n//const FWS$ = subexp(subexp(WSP$$ + \"*\" + \"\\\\x0D\\\\x0A\") + \"?\" + WSP$$ + \"+\");\n//const QUOTED_PAIR$ = subexp(subexp(\"\\\\\\\\\" + subexp(VCHAR$$ + \"|\" + WSP$$)) + \"|\" + OBS_QP$);\n//const QUOTED_STRING$ = subexp('\\\\\"' + subexp(FWS$ + \"?\" + QCONTENT$) + \"*\" + FWS$ + \"?\" + '\\\\\"');\nvar ATEXT$$ = \"[A-Za-z0-9\\\\!\\\\$\\\\%\\\\'\\\\*\\\\+\\\\-\\\\^\\\\_\\\\`\\\\{\\\\|\\\\}\\\\~]\";\nvar QTEXT$$ = \"[\\\\!\\\\$\\\\%\\\\'\\\\(\\\\)\\\\*\\\\+\\\\,\\\\-\\\\.0-9\\\\<\\\\>A-Z\\\\x5E-\\\\x7E]\";\nvar VCHAR$$ = merge(QTEXT$$, \"[\\\\\\\"\\\\\\\\]\");\nvar SOME_DELIMS$$ = \"[\\\\!\\\\$\\\\'\\\\(\\\\)\\\\*\\\\+\\\\,\\\\;\\\\:\\\\@]\";\nvar UNRESERVED = new RegExp(UNRESERVED$$, \"g\");\nvar PCT_ENCODED = new RegExp(PCT_ENCODED$, \"g\");\nvar NOT_LOCAL_PART = new RegExp(merge(\"[^]\", ATEXT$$, \"[\\\\.]\", '[\\\\\"]', VCHAR$$), \"g\");\nvar NOT_HFNAME = new RegExp(merge(\"[^]\", UNRESERVED$$, SOME_DELIMS$$), \"g\");\nvar NOT_HFVALUE = NOT_HFNAME;\nfunction decodeUnreserved(str) {\n var decStr = pctDecChars(str);\n return !decStr.match(UNRESERVED) ? str : decStr;\n}\nvar handler$4 = {\n scheme: \"mailto\",\n parse: function parse$$1(components, options) {\n var mailtoComponents = components;\n var to = mailtoComponents.to = mailtoComponents.path ? mailtoComponents.path.split(\",\") : [];\n mailtoComponents.path = undefined;\n if (mailtoComponents.query) {\n var unknownHeaders = false;\n var headers = {};\n var hfields = mailtoComponents.query.split(\"&\");\n for (var x = 0, xl = hfields.length; x < xl; ++x) {\n var hfield = hfields[x].split(\"=\");\n switch (hfield[0]) {\n case \"to\":\n var toAddrs = hfield[1].split(\",\");\n for (var _x = 0, _xl = toAddrs.length; _x < _xl; ++_x) {\n to.push(toAddrs[_x]);\n }\n break;\n case \"subject\":\n mailtoComponents.subject = unescapeComponent(hfield[1], options);\n break;\n case \"body\":\n mailtoComponents.body = unescapeComponent(hfield[1], options);\n break;\n default:\n unknownHeaders = true;\n headers[unescapeComponent(hfield[0], options)] = unescapeComponent(hfield[1], options);\n break;\n }\n }\n if (unknownHeaders) mailtoComponents.headers = headers;\n }\n mailtoComponents.query = undefined;\n for (var _x2 = 0, _xl2 = to.length; _x2 < _xl2; ++_x2) {\n var addr = to[_x2].split(\"@\");\n addr[0] = unescapeComponent(addr[0]);\n if (!options.unicodeSupport) {\n //convert Unicode IDN -> ASCII IDN\n try {\n addr[1] = punycode.toASCII(unescapeComponent(addr[1], options).toLowerCase());\n } catch (e) {\n mailtoComponents.error = mailtoComponents.error || \"Email address's domain name can not be converted to ASCII via punycode: \" + e;\n }\n } else {\n addr[1] = unescapeComponent(addr[1], options).toLowerCase();\n }\n to[_x2] = addr.join(\"@\");\n }\n return mailtoComponents;\n },\n serialize: function serialize$$1(mailtoComponents, options) {\n var components = mailtoComponents;\n var to = toArray(mailtoComponents.to);\n if (to) {\n for (var x = 0, xl = to.length; x < xl; ++x) {\n var toAddr = String(to[x]);\n var atIdx = toAddr.lastIndexOf(\"@\");\n var localPart = toAddr.slice(0, atIdx).replace(PCT_ENCODED, decodeUnreserved).replace(PCT_ENCODED, toUpperCase).replace(NOT_LOCAL_PART, pctEncChar);\n var domain = toAddr.slice(atIdx + 1);\n //convert IDN via punycode\n try {\n domain = !options.iri ? punycode.toASCII(unescapeComponent(domain, options).toLowerCase()) : punycode.toUnicode(domain);\n } catch (e) {\n components.error = components.error || \"Email address's domain name can not be converted to \" + (!options.iri ? \"ASCII\" : \"Unicode\") + \" via punycode: \" + e;\n }\n to[x] = localPart + \"@\" + domain;\n }\n components.path = to.join(\",\");\n }\n var headers = mailtoComponents.headers = mailtoComponents.headers || {};\n if (mailtoComponents.subject) headers[\"subject\"] = mailtoComponents.subject;\n if (mailtoComponents.body) headers[\"body\"] = mailtoComponents.body;\n var fields = [];\n for (var name in headers) {\n if (headers[name] !== O[name]) {\n fields.push(name.replace(PCT_ENCODED, decodeUnreserved).replace(PCT_ENCODED, toUpperCase).replace(NOT_HFNAME, pctEncChar) + \"=\" + headers[name].replace(PCT_ENCODED, decodeUnreserved).replace(PCT_ENCODED, toUpperCase).replace(NOT_HFVALUE, pctEncChar));\n }\n }\n if (fields.length) {\n components.query = fields.join(\"&\");\n }\n return components;\n }\n};\n\nvar URN_PARSE = /^([^\\:]+)\\:(.*)/;\n//RFC 2141\nvar handler$5 = {\n scheme: \"urn\",\n parse: function parse$$1(components, options) {\n var matches = components.path && components.path.match(URN_PARSE);\n var urnComponents = components;\n if (matches) {\n var scheme = options.scheme || urnComponents.scheme || \"urn\";\n var nid = matches[1].toLowerCase();\n var nss = matches[2];\n var urnScheme = scheme + \":\" + (options.nid || nid);\n var schemeHandler = SCHEMES[urnScheme];\n urnComponents.nid = nid;\n urnComponents.nss = nss;\n urnComponents.path = undefined;\n if (schemeHandler) {\n urnComponents = schemeHandler.parse(urnComponents, options);\n }\n } else {\n urnComponents.error = urnComponents.error || \"URN can not be parsed.\";\n }\n return urnComponents;\n },\n serialize: function serialize$$1(urnComponents, options) {\n var scheme = options.scheme || urnComponents.scheme || \"urn\";\n var nid = urnComponents.nid;\n var urnScheme = scheme + \":\" + (options.nid || nid);\n var schemeHandler = SCHEMES[urnScheme];\n if (schemeHandler) {\n urnComponents = schemeHandler.serialize(urnComponents, options);\n }\n var uriComponents = urnComponents;\n var nss = urnComponents.nss;\n uriComponents.path = (nid || options.nid) + \":\" + nss;\n return uriComponents;\n }\n};\n\nvar UUID = /^[0-9A-Fa-f]{8}(?:\\-[0-9A-Fa-f]{4}){3}\\-[0-9A-Fa-f]{12}$/;\n//RFC 4122\nvar handler$6 = {\n scheme: \"urn:uuid\",\n parse: function parse(urnComponents, options) {\n var uuidComponents = urnComponents;\n uuidComponents.uuid = uuidComponents.nss;\n uuidComponents.nss = undefined;\n if (!options.tolerant && (!uuidComponents.uuid || !uuidComponents.uuid.match(UUID))) {\n uuidComponents.error = uuidComponents.error || \"UUID is not valid.\";\n }\n return uuidComponents;\n },\n serialize: function serialize(uuidComponents, options) {\n var urnComponents = uuidComponents;\n //normalize UUID\n urnComponents.nss = (uuidComponents.uuid || \"\").toLowerCase();\n return urnComponents;\n }\n};\n\nSCHEMES[handler.scheme] = handler;\nSCHEMES[handler$1.scheme] = handler$1;\nSCHEMES[handler$2.scheme] = handler$2;\nSCHEMES[handler$3.scheme] = handler$3;\nSCHEMES[handler$4.scheme] = handler$4;\nSCHEMES[handler$5.scheme] = handler$5;\nSCHEMES[handler$6.scheme] = handler$6;\n\nexports.SCHEMES = SCHEMES;\nexports.pctEncChar = pctEncChar;\nexports.pctDecChars = pctDecChars;\nexports.parse = parse;\nexports.removeDotSegments = removeDotSegments;\nexports.serialize = serialize;\nexports.resolveComponents = resolveComponents;\nexports.resolve = resolve;\nexports.normalize = normalize;\nexports.equal = equal;\nexports.escapeComponent = escapeComponent;\nexports.unescapeComponent = unescapeComponent;\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\n})));\n//# sourceMappingURL=uri.all.js.map\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst uri = require(\"uri-js\");\nuri.code = 'require(\"ajv/dist/runtime/uri\").default';\nexports.default = uri;\n//# sourceMappingURL=uri.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.CodeGen = exports.Name = exports.nil = exports.stringify = exports.str = exports._ = exports.KeywordCxt = void 0;\nvar validate_1 = require(\"./compile/validate\");\nObject.defineProperty(exports, \"KeywordCxt\", { enumerable: true, get: function () { return validate_1.KeywordCxt; } });\nvar codegen_1 = require(\"./compile/codegen\");\nObject.defineProperty(exports, \"_\", { enumerable: true, get: function () { return codegen_1._; } });\nObject.defineProperty(exports, \"str\", { enumerable: true, get: function () { return codegen_1.str; } });\nObject.defineProperty(exports, \"stringify\", { enumerable: true, get: function () { return codegen_1.stringify; } });\nObject.defineProperty(exports, \"nil\", { enumerable: true, get: function () { return codegen_1.nil; } });\nObject.defineProperty(exports, \"Name\", { enumerable: true, get: function () { return codegen_1.Name; } });\nObject.defineProperty(exports, \"CodeGen\", { enumerable: true, get: function () { return codegen_1.CodeGen; } });\nconst validation_error_1 = require(\"./runtime/validation_error\");\nconst ref_error_1 = require(\"./compile/ref_error\");\nconst rules_1 = require(\"./compile/rules\");\nconst compile_1 = require(\"./compile\");\nconst codegen_2 = require(\"./compile/codegen\");\nconst resolve_1 = require(\"./compile/resolve\");\nconst dataType_1 = require(\"./compile/validate/dataType\");\nconst util_1 = require(\"./compile/util\");\nconst $dataRefSchema = require(\"./refs/data.json\");\nconst uri_1 = require(\"./runtime/uri\");\nconst defaultRegExp = (str, flags) => new RegExp(str, flags);\ndefaultRegExp.code = \"new RegExp\";\nconst META_IGNORE_OPTIONS = [\"removeAdditional\", \"useDefaults\", \"coerceTypes\"];\nconst EXT_SCOPE_NAMES = new Set([\n \"validate\",\n \"serialize\",\n \"parse\",\n \"wrapper\",\n \"root\",\n \"schema\",\n \"keyword\",\n \"pattern\",\n \"formats\",\n \"validate$data\",\n \"func\",\n \"obj\",\n \"Error\",\n]);\nconst removedOptions = {\n errorDataPath: \"\",\n format: \"`validateFormats: false` can be used instead.\",\n nullable: '\"nullable\" keyword is supported by default.',\n jsonPointers: \"Deprecated jsPropertySyntax can be used instead.\",\n extendRefs: \"Deprecated ignoreKeywordsWithRef can be used instead.\",\n missingRefs: \"Pass empty schema with $id that should be ignored to ajv.addSchema.\",\n processCode: \"Use option `code: {process: (code, schemaEnv: object) => string}`\",\n sourceCode: \"Use option `code: {source: true}`\",\n strictDefaults: \"It is default now, see option `strict`.\",\n strictKeywords: \"It is default now, see option `strict`.\",\n uniqueItems: '\"uniqueItems\" keyword is always validated.',\n unknownFormats: \"Disable strict mode or pass `true` to `ajv.addFormat` (or `formats` option).\",\n cache: \"Map is used as cache, schema object as key.\",\n serialize: \"Map is used as cache, schema object as key.\",\n ajvErrors: \"It is default now.\",\n};\nconst deprecatedOptions = {\n ignoreKeywordsWithRef: \"\",\n jsPropertySyntax: \"\",\n unicode: '\"minLength\"/\"maxLength\" account for unicode characters by default.',\n};\nconst MAX_EXPRESSION = 200;\n// eslint-disable-next-line complexity\nfunction requiredOptions(o) {\n var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0;\n const s = o.strict;\n const _optz = (_a = o.code) === null || _a === void 0 ? void 0 : _a.optimize;\n const optimize = _optz === true || _optz === undefined ? 1 : _optz || 0;\n const regExp = (_c = (_b = o.code) === null || _b === void 0 ? void 0 : _b.regExp) !== null && _c !== void 0 ? _c : defaultRegExp;\n const uriResolver = (_d = o.uriResolver) !== null && _d !== void 0 ? _d : uri_1.default;\n return {\n strictSchema: (_f = (_e = o.strictSchema) !== null && _e !== void 0 ? _e : s) !== null && _f !== void 0 ? _f : true,\n strictNumbers: (_h = (_g = o.strictNumbers) !== null && _g !== void 0 ? _g : s) !== null && _h !== void 0 ? _h : true,\n strictTypes: (_k = (_j = o.strictTypes) !== null && _j !== void 0 ? _j : s) !== null && _k !== void 0 ? _k : \"log\",\n strictTuples: (_m = (_l = o.strictTuples) !== null && _l !== void 0 ? _l : s) !== null && _m !== void 0 ? _m : \"log\",\n strictRequired: (_p = (_o = o.strictRequired) !== null && _o !== void 0 ? _o : s) !== null && _p !== void 0 ? _p : false,\n code: o.code ? { ...o.code, optimize, regExp } : { optimize, regExp },\n loopRequired: (_q = o.loopRequired) !== null && _q !== void 0 ? _q : MAX_EXPRESSION,\n loopEnum: (_r = o.loopEnum) !== null && _r !== void 0 ? _r : MAX_EXPRESSION,\n meta: (_s = o.meta) !== null && _s !== void 0 ? _s : true,\n messages: (_t = o.messages) !== null && _t !== void 0 ? _t : true,\n inlineRefs: (_u = o.inlineRefs) !== null && _u !== void 0 ? _u : true,\n schemaId: (_v = o.schemaId) !== null && _v !== void 0 ? _v : \"$id\",\n addUsedSchema: (_w = o.addUsedSchema) !== null && _w !== void 0 ? _w : true,\n validateSchema: (_x = o.validateSchema) !== null && _x !== void 0 ? _x : true,\n validateFormats: (_y = o.validateFormats) !== null && _y !== void 0 ? _y : true,\n unicodeRegExp: (_z = o.unicodeRegExp) !== null && _z !== void 0 ? _z : true,\n int32range: (_0 = o.int32range) !== null && _0 !== void 0 ? _0 : true,\n uriResolver: uriResolver,\n };\n}\nclass Ajv {\n constructor(opts = {}) {\n this.schemas = {};\n this.refs = {};\n this.formats = {};\n this._compilations = new Set();\n this._loading = {};\n this._cache = new Map();\n opts = this.opts = { ...opts, ...requiredOptions(opts) };\n const { es5, lines } = this.opts.code;\n this.scope = new codegen_2.ValueScope({ scope: {}, prefixes: EXT_SCOPE_NAMES, es5, lines });\n this.logger = getLogger(opts.logger);\n const formatOpt = opts.validateFormats;\n opts.validateFormats = false;\n this.RULES = (0, rules_1.getRules)();\n checkOptions.call(this, removedOptions, opts, \"NOT SUPPORTED\");\n checkOptions.call(this, deprecatedOptions, opts, \"DEPRECATED\", \"warn\");\n this._metaOpts = getMetaSchemaOptions.call(this);\n if (opts.formats)\n addInitialFormats.call(this);\n this._addVocabularies();\n this._addDefaultMetaSchema();\n if (opts.keywords)\n addInitialKeywords.call(this, opts.keywords);\n if (typeof opts.meta == \"object\")\n this.addMetaSchema(opts.meta);\n addInitialSchemas.call(this);\n opts.validateFormats = formatOpt;\n }\n _addVocabularies() {\n this.addKeyword(\"$async\");\n }\n _addDefaultMetaSchema() {\n const { $data, meta, schemaId } = this.opts;\n let _dataRefSchema = $dataRefSchema;\n if (schemaId === \"id\") {\n _dataRefSchema = { ...$dataRefSchema };\n _dataRefSchema.id = _dataRefSchema.$id;\n delete _dataRefSchema.$id;\n }\n if (meta && $data)\n this.addMetaSchema(_dataRefSchema, _dataRefSchema[schemaId], false);\n }\n defaultMeta() {\n const { meta, schemaId } = this.opts;\n return (this.opts.defaultMeta = typeof meta == \"object\" ? meta[schemaId] || meta : undefined);\n }\n validate(schemaKeyRef, // key, ref or schema object\n data // to be validated\n ) {\n let v;\n if (typeof schemaKeyRef == \"string\") {\n v = this.getSchema(schemaKeyRef);\n if (!v)\n throw new Error(`no schema with key or ref \"${schemaKeyRef}\"`);\n }\n else {\n v = this.compile(schemaKeyRef);\n }\n const valid = v(data);\n if (!(\"$async\" in v))\n this.errors = v.errors;\n return valid;\n }\n compile(schema, _meta) {\n const sch = this._addSchema(schema, _meta);\n return (sch.validate || this._compileSchemaEnv(sch));\n }\n compileAsync(schema, meta) {\n if (typeof this.opts.loadSchema != \"function\") {\n throw new Error(\"options.loadSchema should be a function\");\n }\n const { loadSchema } = this.opts;\n return runCompileAsync.call(this, schema, meta);\n async function runCompileAsync(_schema, _meta) {\n await loadMetaSchema.call(this, _schema.$schema);\n const sch = this._addSchema(_schema, _meta);\n return sch.validate || _compileAsync.call(this, sch);\n }\n async function loadMetaSchema($ref) {\n if ($ref && !this.getSchema($ref)) {\n await runCompileAsync.call(this, { $ref }, true);\n }\n }\n async function _compileAsync(sch) {\n try {\n return this._compileSchemaEnv(sch);\n }\n catch (e) {\n if (!(e instanceof ref_error_1.default))\n throw e;\n checkLoaded.call(this, e);\n await loadMissingSchema.call(this, e.missingSchema);\n return _compileAsync.call(this, sch);\n }\n }\n function checkLoaded({ missingSchema: ref, missingRef }) {\n if (this.refs[ref]) {\n throw new Error(`AnySchema ${ref} is loaded but ${missingRef} cannot be resolved`);\n }\n }\n async function loadMissingSchema(ref) {\n const _schema = await _loadSchema.call(this, ref);\n if (!this.refs[ref])\n await loadMetaSchema.call(this, _schema.$schema);\n if (!this.refs[ref])\n this.addSchema(_schema, ref, meta);\n }\n async function _loadSchema(ref) {\n const p = this._loading[ref];\n if (p)\n return p;\n try {\n return await (this._loading[ref] = loadSchema(ref));\n }\n finally {\n delete this._loading[ref];\n }\n }\n }\n // Adds schema to the instance\n addSchema(schema, // If array is passed, `key` will be ignored\n key, // Optional schema key. Can be passed to `validate` method instead of schema object or id/ref. One schema per instance can have empty `id` and `key`.\n _meta, // true if schema is a meta-schema. Used internally, addMetaSchema should be used instead.\n _validateSchema = this.opts.validateSchema // false to skip schema validation. Used internally, option validateSchema should be used instead.\n ) {\n if (Array.isArray(schema)) {\n for (const sch of schema)\n this.addSchema(sch, undefined, _meta, _validateSchema);\n return this;\n }\n let id;\n if (typeof schema === \"object\") {\n const { schemaId } = this.opts;\n id = schema[schemaId];\n if (id !== undefined && typeof id != \"string\") {\n throw new Error(`schema ${schemaId} must be string`);\n }\n }\n key = (0, resolve_1.normalizeId)(key || id);\n this._checkUnique(key);\n this.schemas[key] = this._addSchema(schema, _meta, key, _validateSchema, true);\n return this;\n }\n // Add schema that will be used to validate other schemas\n // options in META_IGNORE_OPTIONS are alway set to false\n addMetaSchema(schema, key, // schema key\n _validateSchema = this.opts.validateSchema // false to skip schema validation, can be used to override validateSchema option for meta-schema\n ) {\n this.addSchema(schema, key, true, _validateSchema);\n return this;\n }\n // Validate schema against its meta-schema\n validateSchema(schema, throwOrLogError) {\n if (typeof schema == \"boolean\")\n return true;\n let $schema;\n $schema = schema.$schema;\n if ($schema !== undefined && typeof $schema != \"string\") {\n throw new Error(\"$schema must be a string\");\n }\n $schema = $schema || this.opts.defaultMeta || this.defaultMeta();\n if (!$schema) {\n this.logger.warn(\"meta-schema not available\");\n this.errors = null;\n return true;\n }\n const valid = this.validate($schema, schema);\n if (!valid && throwOrLogError) {\n const message = \"schema is invalid: \" + this.errorsText();\n if (this.opts.validateSchema === \"log\")\n this.logger.error(message);\n else\n throw new Error(message);\n }\n return valid;\n }\n // Get compiled schema by `key` or `ref`.\n // (`key` that was passed to `addSchema` or full schema reference - `schema.$id` or resolved id)\n getSchema(keyRef) {\n let sch;\n while (typeof (sch = getSchEnv.call(this, keyRef)) == \"string\")\n keyRef = sch;\n if (sch === undefined) {\n const { schemaId } = this.opts;\n const root = new compile_1.SchemaEnv({ schema: {}, schemaId });\n sch = compile_1.resolveSchema.call(this, root, keyRef);\n if (!sch)\n return;\n this.refs[keyRef] = sch;\n }\n return (sch.validate || this._compileSchemaEnv(sch));\n }\n // Remove cached schema(s).\n // If no parameter is passed all schemas but meta-schemas are removed.\n // If RegExp is passed all schemas with key/id matching pattern but meta-schemas are removed.\n // Even if schema is referenced by other schemas it still can be removed as other schemas have local references.\n removeSchema(schemaKeyRef) {\n if (schemaKeyRef instanceof RegExp) {\n this._removeAllSchemas(this.schemas, schemaKeyRef);\n this._removeAllSchemas(this.refs, schemaKeyRef);\n return this;\n }\n switch (typeof schemaKeyRef) {\n case \"undefined\":\n this._removeAllSchemas(this.schemas);\n this._removeAllSchemas(this.refs);\n this._cache.clear();\n return this;\n case \"string\": {\n const sch = getSchEnv.call(this, schemaKeyRef);\n if (typeof sch == \"object\")\n this._cache.delete(sch.schema);\n delete this.schemas[schemaKeyRef];\n delete this.refs[schemaKeyRef];\n return this;\n }\n case \"object\": {\n const cacheKey = schemaKeyRef;\n this._cache.delete(cacheKey);\n let id = schemaKeyRef[this.opts.schemaId];\n if (id) {\n id = (0, resolve_1.normalizeId)(id);\n delete this.schemas[id];\n delete this.refs[id];\n }\n return this;\n }\n default:\n throw new Error(\"ajv.removeSchema: invalid parameter\");\n }\n }\n // add \"vocabulary\" - a collection of keywords\n addVocabulary(definitions) {\n for (const def of definitions)\n this.addKeyword(def);\n return this;\n }\n addKeyword(kwdOrDef, def // deprecated\n ) {\n let keyword;\n if (typeof kwdOrDef == \"string\") {\n keyword = kwdOrDef;\n if (typeof def == \"object\") {\n this.logger.warn(\"these parameters are deprecated, see docs for addKeyword\");\n def.keyword = keyword;\n }\n }\n else if (typeof kwdOrDef == \"object\" && def === undefined) {\n def = kwdOrDef;\n keyword = def.keyword;\n if (Array.isArray(keyword) && !keyword.length) {\n throw new Error(\"addKeywords: keyword must be string or non-empty array\");\n }\n }\n else {\n throw new Error(\"invalid addKeywords parameters\");\n }\n checkKeyword.call(this, keyword, def);\n if (!def) {\n (0, util_1.eachItem)(keyword, (kwd) => addRule.call(this, kwd));\n return this;\n }\n keywordMetaschema.call(this, def);\n const definition = {\n ...def,\n type: (0, dataType_1.getJSONTypes)(def.type),\n schemaType: (0, dataType_1.getJSONTypes)(def.schemaType),\n };\n (0, util_1.eachItem)(keyword, definition.type.length === 0\n ? (k) => addRule.call(this, k, definition)\n : (k) => definition.type.forEach((t) => addRule.call(this, k, definition, t)));\n return this;\n }\n getKeyword(keyword) {\n const rule = this.RULES.all[keyword];\n return typeof rule == \"object\" ? rule.definition : !!rule;\n }\n // Remove keyword\n removeKeyword(keyword) {\n // TODO return type should be Ajv\n const { RULES } = this;\n delete RULES.keywords[keyword];\n delete RULES.all[keyword];\n for (const group of RULES.rules) {\n const i = group.rules.findIndex((rule) => rule.keyword === keyword);\n if (i >= 0)\n group.rules.splice(i, 1);\n }\n return this;\n }\n // Add format\n addFormat(name, format) {\n if (typeof format == \"string\")\n format = new RegExp(format);\n this.formats[name] = format;\n return this;\n }\n errorsText(errors = this.errors, // optional array of validation errors\n { separator = \", \", dataVar = \"data\" } = {} // optional options with properties `separator` and `dataVar`\n ) {\n if (!errors || errors.length === 0)\n return \"No errors\";\n return errors\n .map((e) => `${dataVar}${e.instancePath} ${e.message}`)\n .reduce((text, msg) => text + separator + msg);\n }\n $dataMetaSchema(metaSchema, keywordsJsonPointers) {\n const rules = this.RULES.all;\n metaSchema = JSON.parse(JSON.stringify(metaSchema));\n for (const jsonPointer of keywordsJsonPointers) {\n const segments = jsonPointer.split(\"/\").slice(1); // first segment is an empty string\n let keywords = metaSchema;\n for (const seg of segments)\n keywords = keywords[seg];\n for (const key in rules) {\n const rule = rules[key];\n if (typeof rule != \"object\")\n continue;\n const { $data } = rule.definition;\n const schema = keywords[key];\n if ($data && schema)\n keywords[key] = schemaOrData(schema);\n }\n }\n return metaSchema;\n }\n _removeAllSchemas(schemas, regex) {\n for (const keyRef in schemas) {\n const sch = schemas[keyRef];\n if (!regex || regex.test(keyRef)) {\n if (typeof sch == \"string\") {\n delete schemas[keyRef];\n }\n else if (sch && !sch.meta) {\n this._cache.delete(sch.schema);\n delete schemas[keyRef];\n }\n }\n }\n }\n _addSchema(schema, meta, baseId, validateSchema = this.opts.validateSchema, addSchema = this.opts.addUsedSchema) {\n let id;\n const { schemaId } = this.opts;\n if (typeof schema == \"object\") {\n id = schema[schemaId];\n }\n else {\n if (this.opts.jtd)\n throw new Error(\"schema must be object\");\n else if (typeof schema != \"boolean\")\n throw new Error(\"schema must be object or boolean\");\n }\n let sch = this._cache.get(schema);\n if (sch !== undefined)\n return sch;\n baseId = (0, resolve_1.normalizeId)(id || baseId);\n const localRefs = resolve_1.getSchemaRefs.call(this, schema, baseId);\n sch = new compile_1.SchemaEnv({ schema, schemaId, meta, baseId, localRefs });\n this._cache.set(sch.schema, sch);\n if (addSchema && !baseId.startsWith(\"#\")) {\n // TODO atm it is allowed to overwrite schemas without id (instead of not adding them)\n if (baseId)\n this._checkUnique(baseId);\n this.refs[baseId] = sch;\n }\n if (validateSchema)\n this.validateSchema(schema, true);\n return sch;\n }\n _checkUnique(id) {\n if (this.schemas[id] || this.refs[id]) {\n throw new Error(`schema with key or id \"${id}\" already exists`);\n }\n }\n _compileSchemaEnv(sch) {\n if (sch.meta)\n this._compileMetaSchema(sch);\n else\n compile_1.compileSchema.call(this, sch);\n /* istanbul ignore if */\n if (!sch.validate)\n throw new Error(\"ajv implementation error\");\n return sch.validate;\n }\n _compileMetaSchema(sch) {\n const currentOpts = this.opts;\n this.opts = this._metaOpts;\n try {\n compile_1.compileSchema.call(this, sch);\n }\n finally {\n this.opts = currentOpts;\n }\n }\n}\nexports.default = Ajv;\nAjv.ValidationError = validation_error_1.default;\nAjv.MissingRefError = ref_error_1.default;\nfunction checkOptions(checkOpts, options, msg, log = \"error\") {\n for (const key in checkOpts) {\n const opt = key;\n if (opt in options)\n this.logger[log](`${msg}: option ${key}. ${checkOpts[opt]}`);\n }\n}\nfunction getSchEnv(keyRef) {\n keyRef = (0, resolve_1.normalizeId)(keyRef); // TODO tests fail without this line\n return this.schemas[keyRef] || this.refs[keyRef];\n}\nfunction addInitialSchemas() {\n const optsSchemas = this.opts.schemas;\n if (!optsSchemas)\n return;\n if (Array.isArray(optsSchemas))\n this.addSchema(optsSchemas);\n else\n for (const key in optsSchemas)\n this.addSchema(optsSchemas[key], key);\n}\nfunction addInitialFormats() {\n for (const name in this.opts.formats) {\n const format = this.opts.formats[name];\n if (format)\n this.addFormat(name, format);\n }\n}\nfunction addInitialKeywords(defs) {\n if (Array.isArray(defs)) {\n this.addVocabulary(defs);\n return;\n }\n this.logger.warn(\"keywords option as map is deprecated, pass array\");\n for (const keyword in defs) {\n const def = defs[keyword];\n if (!def.keyword)\n def.keyword = keyword;\n this.addKeyword(def);\n }\n}\nfunction getMetaSchemaOptions() {\n const metaOpts = { ...this.opts };\n for (const opt of META_IGNORE_OPTIONS)\n delete metaOpts[opt];\n return metaOpts;\n}\nconst noLogs = { log() { }, warn() { }, error() { } };\nfunction getLogger(logger) {\n if (logger === false)\n return noLogs;\n if (logger === undefined)\n return console;\n if (logger.log && logger.warn && logger.error)\n return logger;\n throw new Error(\"logger must implement log, warn and error methods\");\n}\nconst KEYWORD_NAME = /^[a-z_$][a-z0-9_$:-]*$/i;\nfunction checkKeyword(keyword, def) {\n const { RULES } = this;\n (0, util_1.eachItem)(keyword, (kwd) => {\n if (RULES.keywords[kwd])\n throw new Error(`Keyword ${kwd} is already defined`);\n if (!KEYWORD_NAME.test(kwd))\n throw new Error(`Keyword ${kwd} has invalid name`);\n });\n if (!def)\n return;\n if (def.$data && !(\"code\" in def || \"validate\" in def)) {\n throw new Error('$data keyword must have \"code\" or \"validate\" function');\n }\n}\nfunction addRule(keyword, definition, dataType) {\n var _a;\n const post = definition === null || definition === void 0 ? void 0 : definition.post;\n if (dataType && post)\n throw new Error('keyword with \"post\" flag cannot have \"type\"');\n const { RULES } = this;\n let ruleGroup = post ? RULES.post : RULES.rules.find(({ type: t }) => t === dataType);\n if (!ruleGroup) {\n ruleGroup = { type: dataType, rules: [] };\n RULES.rules.push(ruleGroup);\n }\n RULES.keywords[keyword] = true;\n if (!definition)\n return;\n const rule = {\n keyword,\n definition: {\n ...definition,\n type: (0, dataType_1.getJSONTypes)(definition.type),\n schemaType: (0, dataType_1.getJSONTypes)(definition.schemaType),\n },\n };\n if (definition.before)\n addBeforeRule.call(this, ruleGroup, rule, definition.before);\n else\n ruleGroup.rules.push(rule);\n RULES.all[keyword] = rule;\n (_a = definition.implements) === null || _a === void 0 ? void 0 : _a.forEach((kwd) => this.addKeyword(kwd));\n}\nfunction addBeforeRule(ruleGroup, rule, before) {\n const i = ruleGroup.rules.findIndex((_rule) => _rule.keyword === before);\n if (i >= 0) {\n ruleGroup.rules.splice(i, 0, rule);\n }\n else {\n ruleGroup.rules.push(rule);\n this.logger.warn(`rule ${before} is not defined`);\n }\n}\nfunction keywordMetaschema(def) {\n let { metaSchema } = def;\n if (metaSchema === undefined)\n return;\n if (def.$data && this.opts.$data)\n metaSchema = schemaOrData(metaSchema);\n def.validateSchema = this.compile(metaSchema, true);\n}\nconst $dataRef = {\n $ref: \"https://raw.githubusercontent.com/ajv-validator/ajv/master/lib/refs/data.json#\",\n};\nfunction schemaOrData(schema) {\n return { anyOf: [schema, $dataRef] };\n}\n//# sourceMappingURL=core.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst def = {\n keyword: \"id\",\n code() {\n throw new Error('NOT SUPPORTED: keyword \"id\", use \"$id\" for schema ID');\n },\n};\nexports.default = def;\n//# sourceMappingURL=id.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.callRef = exports.getValidate = void 0;\nconst ref_error_1 = require(\"../../compile/ref_error\");\nconst code_1 = require(\"../code\");\nconst codegen_1 = require(\"../../compile/codegen\");\nconst names_1 = require(\"../../compile/names\");\nconst compile_1 = require(\"../../compile\");\nconst util_1 = require(\"../../compile/util\");\nconst def = {\n keyword: \"$ref\",\n schemaType: \"string\",\n code(cxt) {\n const { gen, schema: $ref, it } = cxt;\n const { baseId, schemaEnv: env, validateName, opts, self } = it;\n const { root } = env;\n if (($ref === \"#\" || $ref === \"#/\") && baseId === root.baseId)\n return callRootRef();\n const schOrEnv = compile_1.resolveRef.call(self, root, baseId, $ref);\n if (schOrEnv === undefined)\n throw new ref_error_1.default(it.opts.uriResolver, baseId, $ref);\n if (schOrEnv instanceof compile_1.SchemaEnv)\n return callValidate(schOrEnv);\n return inlineRefSchema(schOrEnv);\n function callRootRef() {\n if (env === root)\n return callRef(cxt, validateName, env, env.$async);\n const rootName = gen.scopeValue(\"root\", { ref: root });\n return callRef(cxt, (0, codegen_1._) `${rootName}.validate`, root, root.$async);\n }\n function callValidate(sch) {\n const v = getValidate(cxt, sch);\n callRef(cxt, v, sch, sch.$async);\n }\n function inlineRefSchema(sch) {\n const schName = gen.scopeValue(\"schema\", opts.code.source === true ? { ref: sch, code: (0, codegen_1.stringify)(sch) } : { ref: sch });\n const valid = gen.name(\"valid\");\n const schCxt = cxt.subschema({\n schema: sch,\n dataTypes: [],\n schemaPath: codegen_1.nil,\n topSchemaRef: schName,\n errSchemaPath: $ref,\n }, valid);\n cxt.mergeEvaluated(schCxt);\n cxt.ok(valid);\n }\n },\n};\nfunction getValidate(cxt, sch) {\n const { gen } = cxt;\n return sch.validate\n ? gen.scopeValue(\"validate\", { ref: sch.validate })\n : (0, codegen_1._) `${gen.scopeValue(\"wrapper\", { ref: sch })}.validate`;\n}\nexports.getValidate = getValidate;\nfunction callRef(cxt, v, sch, $async) {\n const { gen, it } = cxt;\n const { allErrors, schemaEnv: env, opts } = it;\n const passCxt = opts.passContext ? names_1.default.this : codegen_1.nil;\n if ($async)\n callAsyncRef();\n else\n callSyncRef();\n function callAsyncRef() {\n if (!env.$async)\n throw new Error(\"async schema referenced by sync schema\");\n const valid = gen.let(\"valid\");\n gen.try(() => {\n gen.code((0, codegen_1._) `await ${(0, code_1.callValidateCode)(cxt, v, passCxt)}`);\n addEvaluatedFrom(v); // TODO will not work with async, it has to be returned with the result\n if (!allErrors)\n gen.assign(valid, true);\n }, (e) => {\n gen.if((0, codegen_1._) `!(${e} instanceof ${it.ValidationError})`, () => gen.throw(e));\n addErrorsFrom(e);\n if (!allErrors)\n gen.assign(valid, false);\n });\n cxt.ok(valid);\n }\n function callSyncRef() {\n cxt.result((0, code_1.callValidateCode)(cxt, v, passCxt), () => addEvaluatedFrom(v), () => addErrorsFrom(v));\n }\n function addErrorsFrom(source) {\n const errs = (0, codegen_1._) `${source}.errors`;\n gen.assign(names_1.default.vErrors, (0, codegen_1._) `${names_1.default.vErrors} === null ? ${errs} : ${names_1.default.vErrors}.concat(${errs})`); // TODO tagged\n gen.assign(names_1.default.errors, (0, codegen_1._) `${names_1.default.vErrors}.length`);\n }\n function addEvaluatedFrom(source) {\n var _a;\n if (!it.opts.unevaluated)\n return;\n const schEvaluated = (_a = sch === null || sch === void 0 ? void 0 : sch.validate) === null || _a === void 0 ? void 0 : _a.evaluated;\n // TODO refactor\n if (it.props !== true) {\n if (schEvaluated && !schEvaluated.dynamicProps) {\n if (schEvaluated.props !== undefined) {\n it.props = util_1.mergeEvaluated.props(gen, schEvaluated.props, it.props);\n }\n }\n else {\n const props = gen.var(\"props\", (0, codegen_1._) `${source}.evaluated.props`);\n it.props = util_1.mergeEvaluated.props(gen, props, it.props, codegen_1.Name);\n }\n }\n if (it.items !== true) {\n if (schEvaluated && !schEvaluated.dynamicItems) {\n if (schEvaluated.items !== undefined) {\n it.items = util_1.mergeEvaluated.items(gen, schEvaluated.items, it.items);\n }\n }\n else {\n const items = gen.var(\"items\", (0, codegen_1._) `${source}.evaluated.items`);\n it.items = util_1.mergeEvaluated.items(gen, items, it.items, codegen_1.Name);\n }\n }\n }\n}\nexports.callRef = callRef;\nexports.default = def;\n//# sourceMappingURL=ref.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst id_1 = require(\"./id\");\nconst ref_1 = require(\"./ref\");\nconst core = [\n \"$schema\",\n \"$id\",\n \"$defs\",\n \"$vocabulary\",\n { keyword: \"$comment\" },\n \"definitions\",\n id_1.default,\n ref_1.default,\n];\nexports.default = core;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst ops = codegen_1.operators;\nconst KWDs = {\n maximum: { okStr: \"<=\", ok: ops.LTE, fail: ops.GT },\n minimum: { okStr: \">=\", ok: ops.GTE, fail: ops.LT },\n exclusiveMaximum: { okStr: \"<\", ok: ops.LT, fail: ops.GTE },\n exclusiveMinimum: { okStr: \">\", ok: ops.GT, fail: ops.LTE },\n};\nconst error = {\n message: ({ keyword, schemaCode }) => (0, codegen_1.str) `must be ${KWDs[keyword].okStr} ${schemaCode}`,\n params: ({ keyword, schemaCode }) => (0, codegen_1._) `{comparison: ${KWDs[keyword].okStr}, limit: ${schemaCode}}`,\n};\nconst def = {\n keyword: Object.keys(KWDs),\n type: \"number\",\n schemaType: \"number\",\n $data: true,\n error,\n code(cxt) {\n const { keyword, data, schemaCode } = cxt;\n cxt.fail$data((0, codegen_1._) `${data} ${KWDs[keyword].fail} ${schemaCode} || isNaN(${data})`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=limitNumber.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst error = {\n message: ({ schemaCode }) => (0, codegen_1.str) `must be multiple of ${schemaCode}`,\n params: ({ schemaCode }) => (0, codegen_1._) `{multipleOf: ${schemaCode}}`,\n};\nconst def = {\n keyword: \"multipleOf\",\n type: \"number\",\n schemaType: \"number\",\n $data: true,\n error,\n code(cxt) {\n const { gen, data, schemaCode, it } = cxt;\n // const bdt = bad$DataType(schemaCode, def.schemaType, $data)\n const prec = it.opts.multipleOfPrecision;\n const res = gen.let(\"res\");\n const invalid = prec\n ? (0, codegen_1._) `Math.abs(Math.round(${res}) - ${res}) > 1e-${prec}`\n : (0, codegen_1._) `${res} !== parseInt(${res})`;\n cxt.fail$data((0, codegen_1._) `(${schemaCode} === 0 || (${res} = ${data}/${schemaCode}, ${invalid}))`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=multipleOf.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n// https://mathiasbynens.be/notes/javascript-encoding\n// https://github.com/bestiejs/punycode.js - punycode.ucs2.decode\nfunction ucs2length(str) {\n const len = str.length;\n let length = 0;\n let pos = 0;\n let value;\n while (pos < len) {\n length++;\n value = str.charCodeAt(pos++);\n if (value >= 0xd800 && value <= 0xdbff && pos < len) {\n // high surrogate, and there is a next character\n value = str.charCodeAt(pos);\n if ((value & 0xfc00) === 0xdc00)\n pos++; // low surrogate\n }\n }\n return length;\n}\nexports.default = ucs2length;\nucs2length.code = 'require(\"ajv/dist/runtime/ucs2length\").default';\n//# sourceMappingURL=ucs2length.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst ucs2length_1 = require(\"../../runtime/ucs2length\");\nconst error = {\n message({ keyword, schemaCode }) {\n const comp = keyword === \"maxLength\" ? \"more\" : \"fewer\";\n return (0, codegen_1.str) `must NOT have ${comp} than ${schemaCode} characters`;\n },\n params: ({ schemaCode }) => (0, codegen_1._) `{limit: ${schemaCode}}`,\n};\nconst def = {\n keyword: [\"maxLength\", \"minLength\"],\n type: \"string\",\n schemaType: \"number\",\n $data: true,\n error,\n code(cxt) {\n const { keyword, data, schemaCode, it } = cxt;\n const op = keyword === \"maxLength\" ? codegen_1.operators.GT : codegen_1.operators.LT;\n const len = it.opts.unicode === false ? (0, codegen_1._) `${data}.length` : (0, codegen_1._) `${(0, util_1.useFunc)(cxt.gen, ucs2length_1.default)}(${data})`;\n cxt.fail$data((0, codegen_1._) `${len} ${op} ${schemaCode}`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=limitLength.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst code_1 = require(\"../code\");\nconst codegen_1 = require(\"../../compile/codegen\");\nconst error = {\n message: ({ schemaCode }) => (0, codegen_1.str) `must match pattern \"${schemaCode}\"`,\n params: ({ schemaCode }) => (0, codegen_1._) `{pattern: ${schemaCode}}`,\n};\nconst def = {\n keyword: \"pattern\",\n type: \"string\",\n schemaType: \"string\",\n $data: true,\n error,\n code(cxt) {\n const { data, $data, schema, schemaCode, it } = cxt;\n // TODO regexp should be wrapped in try/catchs\n const u = it.opts.unicodeRegExp ? \"u\" : \"\";\n const regExp = $data ? (0, codegen_1._) `(new RegExp(${schemaCode}, ${u}))` : (0, code_1.usePattern)(cxt, schema);\n cxt.fail$data((0, codegen_1._) `!${regExp}.test(${data})`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=pattern.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst error = {\n message({ keyword, schemaCode }) {\n const comp = keyword === \"maxProperties\" ? \"more\" : \"fewer\";\n return (0, codegen_1.str) `must NOT have ${comp} than ${schemaCode} properties`;\n },\n params: ({ schemaCode }) => (0, codegen_1._) `{limit: ${schemaCode}}`,\n};\nconst def = {\n keyword: [\"maxProperties\", \"minProperties\"],\n type: \"object\",\n schemaType: \"number\",\n $data: true,\n error,\n code(cxt) {\n const { keyword, data, schemaCode } = cxt;\n const op = keyword === \"maxProperties\" ? codegen_1.operators.GT : codegen_1.operators.LT;\n cxt.fail$data((0, codegen_1._) `Object.keys(${data}).length ${op} ${schemaCode}`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=limitProperties.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst code_1 = require(\"../code\");\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: ({ params: { missingProperty } }) => (0, codegen_1.str) `must have required property '${missingProperty}'`,\n params: ({ params: { missingProperty } }) => (0, codegen_1._) `{missingProperty: ${missingProperty}}`,\n};\nconst def = {\n keyword: \"required\",\n type: \"object\",\n schemaType: \"array\",\n $data: true,\n error,\n code(cxt) {\n const { gen, schema, schemaCode, data, $data, it } = cxt;\n const { opts } = it;\n if (!$data && schema.length === 0)\n return;\n const useLoop = schema.length >= opts.loopRequired;\n if (it.allErrors)\n allErrorsMode();\n else\n exitOnErrorMode();\n if (opts.strictRequired) {\n const props = cxt.parentSchema.properties;\n const { definedProperties } = cxt.it;\n for (const requiredKey of schema) {\n if ((props === null || props === void 0 ? void 0 : props[requiredKey]) === undefined && !definedProperties.has(requiredKey)) {\n const schemaPath = it.schemaEnv.baseId + it.errSchemaPath;\n const msg = `required property \"${requiredKey}\" is not defined at \"${schemaPath}\" (strictRequired)`;\n (0, util_1.checkStrictMode)(it, msg, it.opts.strictRequired);\n }\n }\n }\n function allErrorsMode() {\n if (useLoop || $data) {\n cxt.block$data(codegen_1.nil, loopAllRequired);\n }\n else {\n for (const prop of schema) {\n (0, code_1.checkReportMissingProp)(cxt, prop);\n }\n }\n }\n function exitOnErrorMode() {\n const missing = gen.let(\"missing\");\n if (useLoop || $data) {\n const valid = gen.let(\"valid\", true);\n cxt.block$data(valid, () => loopUntilMissing(missing, valid));\n cxt.ok(valid);\n }\n else {\n gen.if((0, code_1.checkMissingProp)(cxt, schema, missing));\n (0, code_1.reportMissingProp)(cxt, missing);\n gen.else();\n }\n }\n function loopAllRequired() {\n gen.forOf(\"prop\", schemaCode, (prop) => {\n cxt.setParams({ missingProperty: prop });\n gen.if((0, code_1.noPropertyInData)(gen, data, prop, opts.ownProperties), () => cxt.error());\n });\n }\n function loopUntilMissing(missing, valid) {\n cxt.setParams({ missingProperty: missing });\n gen.forOf(missing, schemaCode, () => {\n gen.assign(valid, (0, code_1.propertyInData)(gen, data, missing, opts.ownProperties));\n gen.if((0, codegen_1.not)(valid), () => {\n cxt.error();\n gen.break();\n });\n }, codegen_1.nil);\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=required.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst error = {\n message({ keyword, schemaCode }) {\n const comp = keyword === \"maxItems\" ? \"more\" : \"fewer\";\n return (0, codegen_1.str) `must NOT have ${comp} than ${schemaCode} items`;\n },\n params: ({ schemaCode }) => (0, codegen_1._) `{limit: ${schemaCode}}`,\n};\nconst def = {\n keyword: [\"maxItems\", \"minItems\"],\n type: \"array\",\n schemaType: \"number\",\n $data: true,\n error,\n code(cxt) {\n const { keyword, data, schemaCode } = cxt;\n const op = keyword === \"maxItems\" ? codegen_1.operators.GT : codegen_1.operators.LT;\n cxt.fail$data((0, codegen_1._) `${data}.length ${op} ${schemaCode}`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=limitItems.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n// https://github.com/ajv-validator/ajv/issues/889\nconst equal = require(\"fast-deep-equal\");\nequal.code = 'require(\"ajv/dist/runtime/equal\").default';\nexports.default = equal;\n//# sourceMappingURL=equal.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst dataType_1 = require(\"../../compile/validate/dataType\");\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst equal_1 = require(\"../../runtime/equal\");\nconst error = {\n message: ({ params: { i, j } }) => (0, codegen_1.str) `must NOT have duplicate items (items ## ${j} and ${i} are identical)`,\n params: ({ params: { i, j } }) => (0, codegen_1._) `{i: ${i}, j: ${j}}`,\n};\nconst def = {\n keyword: \"uniqueItems\",\n type: \"array\",\n schemaType: \"boolean\",\n $data: true,\n error,\n code(cxt) {\n const { gen, data, $data, schema, parentSchema, schemaCode, it } = cxt;\n if (!$data && !schema)\n return;\n const valid = gen.let(\"valid\");\n const itemTypes = parentSchema.items ? (0, dataType_1.getSchemaTypes)(parentSchema.items) : [];\n cxt.block$data(valid, validateUniqueItems, (0, codegen_1._) `${schemaCode} === false`);\n cxt.ok(valid);\n function validateUniqueItems() {\n const i = gen.let(\"i\", (0, codegen_1._) `${data}.length`);\n const j = gen.let(\"j\");\n cxt.setParams({ i, j });\n gen.assign(valid, true);\n gen.if((0, codegen_1._) `${i} > 1`, () => (canOptimize() ? loopN : loopN2)(i, j));\n }\n function canOptimize() {\n return itemTypes.length > 0 && !itemTypes.some((t) => t === \"object\" || t === \"array\");\n }\n function loopN(i, j) {\n const item = gen.name(\"item\");\n const wrongType = (0, dataType_1.checkDataTypes)(itemTypes, item, it.opts.strictNumbers, dataType_1.DataType.Wrong);\n const indices = gen.const(\"indices\", (0, codegen_1._) `{}`);\n gen.for((0, codegen_1._) `;${i}--;`, () => {\n gen.let(item, (0, codegen_1._) `${data}[${i}]`);\n gen.if(wrongType, (0, codegen_1._) `continue`);\n if (itemTypes.length > 1)\n gen.if((0, codegen_1._) `typeof ${item} == \"string\"`, (0, codegen_1._) `${item} += \"_\"`);\n gen\n .if((0, codegen_1._) `typeof ${indices}[${item}] == \"number\"`, () => {\n gen.assign(j, (0, codegen_1._) `${indices}[${item}]`);\n cxt.error();\n gen.assign(valid, false).break();\n })\n .code((0, codegen_1._) `${indices}[${item}] = ${i}`);\n });\n }\n function loopN2(i, j) {\n const eql = (0, util_1.useFunc)(gen, equal_1.default);\n const outer = gen.name(\"outer\");\n gen.label(outer).for((0, codegen_1._) `;${i}--;`, () => gen.for((0, codegen_1._) `${j} = ${i}; ${j}--;`, () => gen.if((0, codegen_1._) `${eql}(${data}[${i}], ${data}[${j}])`, () => {\n cxt.error();\n gen.assign(valid, false).break(outer);\n })));\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=uniqueItems.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst equal_1 = require(\"../../runtime/equal\");\nconst error = {\n message: \"must be equal to constant\",\n params: ({ schemaCode }) => (0, codegen_1._) `{allowedValue: ${schemaCode}}`,\n};\nconst def = {\n keyword: \"const\",\n $data: true,\n error,\n code(cxt) {\n const { gen, data, $data, schemaCode, schema } = cxt;\n if ($data || (schema && typeof schema == \"object\")) {\n cxt.fail$data((0, codegen_1._) `!${(0, util_1.useFunc)(gen, equal_1.default)}(${data}, ${schemaCode})`);\n }\n else {\n cxt.fail((0, codegen_1._) `${schema} !== ${data}`);\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=const.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst equal_1 = require(\"../../runtime/equal\");\nconst error = {\n message: \"must be equal to one of the allowed values\",\n params: ({ schemaCode }) => (0, codegen_1._) `{allowedValues: ${schemaCode}}`,\n};\nconst def = {\n keyword: \"enum\",\n schemaType: \"array\",\n $data: true,\n error,\n code(cxt) {\n const { gen, data, $data, schema, schemaCode, it } = cxt;\n if (!$data && schema.length === 0)\n throw new Error(\"enum must have non-empty array\");\n const useLoop = schema.length >= it.opts.loopEnum;\n let eql;\n const getEql = () => (eql !== null && eql !== void 0 ? eql : (eql = (0, util_1.useFunc)(gen, equal_1.default)));\n let valid;\n if (useLoop || $data) {\n valid = gen.let(\"valid\");\n cxt.block$data(valid, loopEnum);\n }\n else {\n /* istanbul ignore if */\n if (!Array.isArray(schema))\n throw new Error(\"ajv implementation error\");\n const vSchema = gen.const(\"vSchema\", schemaCode);\n valid = (0, codegen_1.or)(...schema.map((_x, i) => equalCode(vSchema, i)));\n }\n cxt.pass(valid);\n function loopEnum() {\n gen.assign(valid, false);\n gen.forOf(\"v\", schemaCode, (v) => gen.if((0, codegen_1._) `${getEql()}(${data}, ${v})`, () => gen.assign(valid, true).break()));\n }\n function equalCode(vSchema, i) {\n const sch = schema[i];\n return typeof sch === \"object\" && sch !== null\n ? (0, codegen_1._) `${getEql()}(${data}, ${vSchema}[${i}])`\n : (0, codegen_1._) `${data} === ${sch}`;\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=enum.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst limitNumber_1 = require(\"./limitNumber\");\nconst multipleOf_1 = require(\"./multipleOf\");\nconst limitLength_1 = require(\"./limitLength\");\nconst pattern_1 = require(\"./pattern\");\nconst limitProperties_1 = require(\"./limitProperties\");\nconst required_1 = require(\"./required\");\nconst limitItems_1 = require(\"./limitItems\");\nconst uniqueItems_1 = require(\"./uniqueItems\");\nconst const_1 = require(\"./const\");\nconst enum_1 = require(\"./enum\");\nconst validation = [\n // number\n limitNumber_1.default,\n multipleOf_1.default,\n // string\n limitLength_1.default,\n pattern_1.default,\n // object\n limitProperties_1.default,\n required_1.default,\n // array\n limitItems_1.default,\n uniqueItems_1.default,\n // any\n { keyword: \"type\", schemaType: [\"string\", \"array\"] },\n { keyword: \"nullable\", schemaType: \"boolean\" },\n const_1.default,\n enum_1.default,\n];\nexports.default = validation;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateAdditionalItems = void 0;\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: ({ params: { len } }) => (0, codegen_1.str) `must NOT have more than ${len} items`,\n params: ({ params: { len } }) => (0, codegen_1._) `{limit: ${len}}`,\n};\nconst def = {\n keyword: \"additionalItems\",\n type: \"array\",\n schemaType: [\"boolean\", \"object\"],\n before: \"uniqueItems\",\n error,\n code(cxt) {\n const { parentSchema, it } = cxt;\n const { items } = parentSchema;\n if (!Array.isArray(items)) {\n (0, util_1.checkStrictMode)(it, '\"additionalItems\" is ignored when \"items\" is not an array of schemas');\n return;\n }\n validateAdditionalItems(cxt, items);\n },\n};\nfunction validateAdditionalItems(cxt, items) {\n const { gen, schema, data, keyword, it } = cxt;\n it.items = true;\n const len = gen.const(\"len\", (0, codegen_1._) `${data}.length`);\n if (schema === false) {\n cxt.setParams({ len: items.length });\n cxt.pass((0, codegen_1._) `${len} <= ${items.length}`);\n }\n else if (typeof schema == \"object\" && !(0, util_1.alwaysValidSchema)(it, schema)) {\n const valid = gen.var(\"valid\", (0, codegen_1._) `${len} <= ${items.length}`); // TODO var\n gen.if((0, codegen_1.not)(valid), () => validateItems(valid));\n cxt.ok(valid);\n }\n function validateItems(valid) {\n gen.forRange(\"i\", items.length, len, (i) => {\n cxt.subschema({ keyword, dataProp: i, dataPropType: util_1.Type.Num }, valid);\n if (!it.allErrors)\n gen.if((0, codegen_1.not)(valid), () => gen.break());\n });\n }\n}\nexports.validateAdditionalItems = validateAdditionalItems;\nexports.default = def;\n//# sourceMappingURL=additionalItems.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateTuple = void 0;\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst code_1 = require(\"../code\");\nconst def = {\n keyword: \"items\",\n type: \"array\",\n schemaType: [\"object\", \"array\", \"boolean\"],\n before: \"uniqueItems\",\n code(cxt) {\n const { schema, it } = cxt;\n if (Array.isArray(schema))\n return validateTuple(cxt, \"additionalItems\", schema);\n it.items = true;\n if ((0, util_1.alwaysValidSchema)(it, schema))\n return;\n cxt.ok((0, code_1.validateArray)(cxt));\n },\n};\nfunction validateTuple(cxt, extraItems, schArr = cxt.schema) {\n const { gen, parentSchema, data, keyword, it } = cxt;\n checkStrictTuple(parentSchema);\n if (it.opts.unevaluated && schArr.length && it.items !== true) {\n it.items = util_1.mergeEvaluated.items(gen, schArr.length, it.items);\n }\n const valid = gen.name(\"valid\");\n const len = gen.const(\"len\", (0, codegen_1._) `${data}.length`);\n schArr.forEach((sch, i) => {\n if ((0, util_1.alwaysValidSchema)(it, sch))\n return;\n gen.if((0, codegen_1._) `${len} > ${i}`, () => cxt.subschema({\n keyword,\n schemaProp: i,\n dataProp: i,\n }, valid));\n cxt.ok(valid);\n });\n function checkStrictTuple(sch) {\n const { opts, errSchemaPath } = it;\n const l = schArr.length;\n const fullTuple = l === sch.minItems && (l === sch.maxItems || sch[extraItems] === false);\n if (opts.strictTuples && !fullTuple) {\n const msg = `\"${keyword}\" is ${l}-tuple, but minItems or maxItems/${extraItems} are not specified or different at path \"${errSchemaPath}\"`;\n (0, util_1.checkStrictMode)(it, msg, opts.strictTuples);\n }\n }\n}\nexports.validateTuple = validateTuple;\nexports.default = def;\n//# sourceMappingURL=items.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst items_1 = require(\"./items\");\nconst def = {\n keyword: \"prefixItems\",\n type: \"array\",\n schemaType: [\"array\"],\n before: \"uniqueItems\",\n code: (cxt) => (0, items_1.validateTuple)(cxt, \"items\"),\n};\nexports.default = def;\n//# sourceMappingURL=prefixItems.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst code_1 = require(\"../code\");\nconst additionalItems_1 = require(\"./additionalItems\");\nconst error = {\n message: ({ params: { len } }) => (0, codegen_1.str) `must NOT have more than ${len} items`,\n params: ({ params: { len } }) => (0, codegen_1._) `{limit: ${len}}`,\n};\nconst def = {\n keyword: \"items\",\n type: \"array\",\n schemaType: [\"object\", \"boolean\"],\n before: \"uniqueItems\",\n error,\n code(cxt) {\n const { schema, parentSchema, it } = cxt;\n const { prefixItems } = parentSchema;\n it.items = true;\n if ((0, util_1.alwaysValidSchema)(it, schema))\n return;\n if (prefixItems)\n (0, additionalItems_1.validateAdditionalItems)(cxt, prefixItems);\n else\n cxt.ok((0, code_1.validateArray)(cxt));\n },\n};\nexports.default = def;\n//# sourceMappingURL=items2020.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: ({ params: { min, max } }) => max === undefined\n ? (0, codegen_1.str) `must contain at least ${min} valid item(s)`\n : (0, codegen_1.str) `must contain at least ${min} and no more than ${max} valid item(s)`,\n params: ({ params: { min, max } }) => max === undefined ? (0, codegen_1._) `{minContains: ${min}}` : (0, codegen_1._) `{minContains: ${min}, maxContains: ${max}}`,\n};\nconst def = {\n keyword: \"contains\",\n type: \"array\",\n schemaType: [\"object\", \"boolean\"],\n before: \"uniqueItems\",\n trackErrors: true,\n error,\n code(cxt) {\n const { gen, schema, parentSchema, data, it } = cxt;\n let min;\n let max;\n const { minContains, maxContains } = parentSchema;\n if (it.opts.next) {\n min = minContains === undefined ? 1 : minContains;\n max = maxContains;\n }\n else {\n min = 1;\n }\n const len = gen.const(\"len\", (0, codegen_1._) `${data}.length`);\n cxt.setParams({ min, max });\n if (max === undefined && min === 0) {\n (0, util_1.checkStrictMode)(it, `\"minContains\" == 0 without \"maxContains\": \"contains\" keyword ignored`);\n return;\n }\n if (max !== undefined && min > max) {\n (0, util_1.checkStrictMode)(it, `\"minContains\" > \"maxContains\" is always invalid`);\n cxt.fail();\n return;\n }\n if ((0, util_1.alwaysValidSchema)(it, schema)) {\n let cond = (0, codegen_1._) `${len} >= ${min}`;\n if (max !== undefined)\n cond = (0, codegen_1._) `${cond} && ${len} <= ${max}`;\n cxt.pass(cond);\n return;\n }\n it.items = true;\n const valid = gen.name(\"valid\");\n if (max === undefined && min === 1) {\n validateItems(valid, () => gen.if(valid, () => gen.break()));\n }\n else if (min === 0) {\n gen.let(valid, true);\n if (max !== undefined)\n gen.if((0, codegen_1._) `${data}.length > 0`, validateItemsWithCount);\n }\n else {\n gen.let(valid, false);\n validateItemsWithCount();\n }\n cxt.result(valid, () => cxt.reset());\n function validateItemsWithCount() {\n const schValid = gen.name(\"_valid\");\n const count = gen.let(\"count\", 0);\n validateItems(schValid, () => gen.if(schValid, () => checkLimits(count)));\n }\n function validateItems(_valid, block) {\n gen.forRange(\"i\", 0, len, (i) => {\n cxt.subschema({\n keyword: \"contains\",\n dataProp: i,\n dataPropType: util_1.Type.Num,\n compositeRule: true,\n }, _valid);\n block();\n });\n }\n function checkLimits(count) {\n gen.code((0, codegen_1._) `${count}++`);\n if (max === undefined) {\n gen.if((0, codegen_1._) `${count} >= ${min}`, () => gen.assign(valid, true).break());\n }\n else {\n gen.if((0, codegen_1._) `${count} > ${max}`, () => gen.assign(valid, false).break());\n if (min === 1)\n gen.assign(valid, true);\n else\n gen.if((0, codegen_1._) `${count} >= ${min}`, () => gen.assign(valid, true));\n }\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=contains.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateSchemaDeps = exports.validatePropertyDeps = exports.error = void 0;\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst code_1 = require(\"../code\");\nexports.error = {\n message: ({ params: { property, depsCount, deps } }) => {\n const property_ies = depsCount === 1 ? \"property\" : \"properties\";\n return (0, codegen_1.str) `must have ${property_ies} ${deps} when property ${property} is present`;\n },\n params: ({ params: { property, depsCount, deps, missingProperty } }) => (0, codegen_1._) `{property: ${property},\n missingProperty: ${missingProperty},\n depsCount: ${depsCount},\n deps: ${deps}}`, // TODO change to reference\n};\nconst def = {\n keyword: \"dependencies\",\n type: \"object\",\n schemaType: \"object\",\n error: exports.error,\n code(cxt) {\n const [propDeps, schDeps] = splitDependencies(cxt);\n validatePropertyDeps(cxt, propDeps);\n validateSchemaDeps(cxt, schDeps);\n },\n};\nfunction splitDependencies({ schema }) {\n const propertyDeps = {};\n const schemaDeps = {};\n for (const key in schema) {\n if (key === \"__proto__\")\n continue;\n const deps = Array.isArray(schema[key]) ? propertyDeps : schemaDeps;\n deps[key] = schema[key];\n }\n return [propertyDeps, schemaDeps];\n}\nfunction validatePropertyDeps(cxt, propertyDeps = cxt.schema) {\n const { gen, data, it } = cxt;\n if (Object.keys(propertyDeps).length === 0)\n return;\n const missing = gen.let(\"missing\");\n for (const prop in propertyDeps) {\n const deps = propertyDeps[prop];\n if (deps.length === 0)\n continue;\n const hasProperty = (0, code_1.propertyInData)(gen, data, prop, it.opts.ownProperties);\n cxt.setParams({\n property: prop,\n depsCount: deps.length,\n deps: deps.join(\", \"),\n });\n if (it.allErrors) {\n gen.if(hasProperty, () => {\n for (const depProp of deps) {\n (0, code_1.checkReportMissingProp)(cxt, depProp);\n }\n });\n }\n else {\n gen.if((0, codegen_1._) `${hasProperty} && (${(0, code_1.checkMissingProp)(cxt, deps, missing)})`);\n (0, code_1.reportMissingProp)(cxt, missing);\n gen.else();\n }\n }\n}\nexports.validatePropertyDeps = validatePropertyDeps;\nfunction validateSchemaDeps(cxt, schemaDeps = cxt.schema) {\n const { gen, data, keyword, it } = cxt;\n const valid = gen.name(\"valid\");\n for (const prop in schemaDeps) {\n if ((0, util_1.alwaysValidSchema)(it, schemaDeps[prop]))\n continue;\n gen.if((0, code_1.propertyInData)(gen, data, prop, it.opts.ownProperties), () => {\n const schCxt = cxt.subschema({ keyword, schemaProp: prop }, valid);\n cxt.mergeValidEvaluated(schCxt, valid);\n }, () => gen.var(valid, true) // TODO var\n );\n cxt.ok(valid);\n }\n}\nexports.validateSchemaDeps = validateSchemaDeps;\nexports.default = def;\n//# sourceMappingURL=dependencies.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: \"property name must be valid\",\n params: ({ params }) => (0, codegen_1._) `{propertyName: ${params.propertyName}}`,\n};\nconst def = {\n keyword: \"propertyNames\",\n type: \"object\",\n schemaType: [\"object\", \"boolean\"],\n error,\n code(cxt) {\n const { gen, schema, data, it } = cxt;\n if ((0, util_1.alwaysValidSchema)(it, schema))\n return;\n const valid = gen.name(\"valid\");\n gen.forIn(\"key\", data, (key) => {\n cxt.setParams({ propertyName: key });\n cxt.subschema({\n keyword: \"propertyNames\",\n data: key,\n dataTypes: [\"string\"],\n propertyName: key,\n compositeRule: true,\n }, valid);\n gen.if((0, codegen_1.not)(valid), () => {\n cxt.error(true);\n if (!it.allErrors)\n gen.break();\n });\n });\n cxt.ok(valid);\n },\n};\nexports.default = def;\n//# sourceMappingURL=propertyNames.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst code_1 = require(\"../code\");\nconst codegen_1 = require(\"../../compile/codegen\");\nconst names_1 = require(\"../../compile/names\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: \"must NOT have additional properties\",\n params: ({ params }) => (0, codegen_1._) `{additionalProperty: ${params.additionalProperty}}`,\n};\nconst def = {\n keyword: \"additionalProperties\",\n type: [\"object\"],\n schemaType: [\"boolean\", \"object\"],\n allowUndefined: true,\n trackErrors: true,\n error,\n code(cxt) {\n const { gen, schema, parentSchema, data, errsCount, it } = cxt;\n /* istanbul ignore if */\n if (!errsCount)\n throw new Error(\"ajv implementation error\");\n const { allErrors, opts } = it;\n it.props = true;\n if (opts.removeAdditional !== \"all\" && (0, util_1.alwaysValidSchema)(it, schema))\n return;\n const props = (0, code_1.allSchemaProperties)(parentSchema.properties);\n const patProps = (0, code_1.allSchemaProperties)(parentSchema.patternProperties);\n checkAdditionalProperties();\n cxt.ok((0, codegen_1._) `${errsCount} === ${names_1.default.errors}`);\n function checkAdditionalProperties() {\n gen.forIn(\"key\", data, (key) => {\n if (!props.length && !patProps.length)\n additionalPropertyCode(key);\n else\n gen.if(isAdditional(key), () => additionalPropertyCode(key));\n });\n }\n function isAdditional(key) {\n let definedProp;\n if (props.length > 8) {\n // TODO maybe an option instead of hard-coded 8?\n const propsSchema = (0, util_1.schemaRefOrVal)(it, parentSchema.properties, \"properties\");\n definedProp = (0, code_1.isOwnProperty)(gen, propsSchema, key);\n }\n else if (props.length) {\n definedProp = (0, codegen_1.or)(...props.map((p) => (0, codegen_1._) `${key} === ${p}`));\n }\n else {\n definedProp = codegen_1.nil;\n }\n if (patProps.length) {\n definedProp = (0, codegen_1.or)(definedProp, ...patProps.map((p) => (0, codegen_1._) `${(0, code_1.usePattern)(cxt, p)}.test(${key})`));\n }\n return (0, codegen_1.not)(definedProp);\n }\n function deleteAdditional(key) {\n gen.code((0, codegen_1._) `delete ${data}[${key}]`);\n }\n function additionalPropertyCode(key) {\n if (opts.removeAdditional === \"all\" || (opts.removeAdditional && schema === false)) {\n deleteAdditional(key);\n return;\n }\n if (schema === false) {\n cxt.setParams({ additionalProperty: key });\n cxt.error();\n if (!allErrors)\n gen.break();\n return;\n }\n if (typeof schema == \"object\" && !(0, util_1.alwaysValidSchema)(it, schema)) {\n const valid = gen.name(\"valid\");\n if (opts.removeAdditional === \"failing\") {\n applyAdditionalSchema(key, valid, false);\n gen.if((0, codegen_1.not)(valid), () => {\n cxt.reset();\n deleteAdditional(key);\n });\n }\n else {\n applyAdditionalSchema(key, valid);\n if (!allErrors)\n gen.if((0, codegen_1.not)(valid), () => gen.break());\n }\n }\n }\n function applyAdditionalSchema(key, valid, errors) {\n const subschema = {\n keyword: \"additionalProperties\",\n dataProp: key,\n dataPropType: util_1.Type.Str,\n };\n if (errors === false) {\n Object.assign(subschema, {\n compositeRule: true,\n createErrors: false,\n allErrors: false,\n });\n }\n cxt.subschema(subschema, valid);\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=additionalProperties.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst validate_1 = require(\"../../compile/validate\");\nconst code_1 = require(\"../code\");\nconst util_1 = require(\"../../compile/util\");\nconst additionalProperties_1 = require(\"./additionalProperties\");\nconst def = {\n keyword: \"properties\",\n type: \"object\",\n schemaType: \"object\",\n code(cxt) {\n const { gen, schema, parentSchema, data, it } = cxt;\n if (it.opts.removeAdditional === \"all\" && parentSchema.additionalProperties === undefined) {\n additionalProperties_1.default.code(new validate_1.KeywordCxt(it, additionalProperties_1.default, \"additionalProperties\"));\n }\n const allProps = (0, code_1.allSchemaProperties)(schema);\n for (const prop of allProps) {\n it.definedProperties.add(prop);\n }\n if (it.opts.unevaluated && allProps.length && it.props !== true) {\n it.props = util_1.mergeEvaluated.props(gen, (0, util_1.toHash)(allProps), it.props);\n }\n const properties = allProps.filter((p) => !(0, util_1.alwaysValidSchema)(it, schema[p]));\n if (properties.length === 0)\n return;\n const valid = gen.name(\"valid\");\n for (const prop of properties) {\n if (hasDefault(prop)) {\n applyPropertySchema(prop);\n }\n else {\n gen.if((0, code_1.propertyInData)(gen, data, prop, it.opts.ownProperties));\n applyPropertySchema(prop);\n if (!it.allErrors)\n gen.else().var(valid, true);\n gen.endIf();\n }\n cxt.it.definedProperties.add(prop);\n cxt.ok(valid);\n }\n function hasDefault(prop) {\n return it.opts.useDefaults && !it.compositeRule && schema[prop].default !== undefined;\n }\n function applyPropertySchema(prop) {\n cxt.subschema({\n keyword: \"properties\",\n schemaProp: prop,\n dataProp: prop,\n }, valid);\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=properties.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst code_1 = require(\"../code\");\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst util_2 = require(\"../../compile/util\");\nconst def = {\n keyword: \"patternProperties\",\n type: \"object\",\n schemaType: \"object\",\n code(cxt) {\n const { gen, schema, data, parentSchema, it } = cxt;\n const { opts } = it;\n const patterns = (0, code_1.allSchemaProperties)(schema);\n const alwaysValidPatterns = patterns.filter((p) => (0, util_1.alwaysValidSchema)(it, schema[p]));\n if (patterns.length === 0 ||\n (alwaysValidPatterns.length === patterns.length &&\n (!it.opts.unevaluated || it.props === true))) {\n return;\n }\n const checkProperties = opts.strictSchema && !opts.allowMatchingProperties && parentSchema.properties;\n const valid = gen.name(\"valid\");\n if (it.props !== true && !(it.props instanceof codegen_1.Name)) {\n it.props = (0, util_2.evaluatedPropsToName)(gen, it.props);\n }\n const { props } = it;\n validatePatternProperties();\n function validatePatternProperties() {\n for (const pat of patterns) {\n if (checkProperties)\n checkMatchingProperties(pat);\n if (it.allErrors) {\n validateProperties(pat);\n }\n else {\n gen.var(valid, true); // TODO var\n validateProperties(pat);\n gen.if(valid);\n }\n }\n }\n function checkMatchingProperties(pat) {\n for (const prop in checkProperties) {\n if (new RegExp(pat).test(prop)) {\n (0, util_1.checkStrictMode)(it, `property ${prop} matches pattern ${pat} (use allowMatchingProperties)`);\n }\n }\n }\n function validateProperties(pat) {\n gen.forIn(\"key\", data, (key) => {\n gen.if((0, codegen_1._) `${(0, code_1.usePattern)(cxt, pat)}.test(${key})`, () => {\n const alwaysValid = alwaysValidPatterns.includes(pat);\n if (!alwaysValid) {\n cxt.subschema({\n keyword: \"patternProperties\",\n schemaProp: pat,\n dataProp: key,\n dataPropType: util_2.Type.Str,\n }, valid);\n }\n if (it.opts.unevaluated && props !== true) {\n gen.assign((0, codegen_1._) `${props}[${key}]`, true);\n }\n else if (!alwaysValid && !it.allErrors) {\n // can short-circuit if `unevaluatedProperties` is not supported (opts.next === false)\n // or if all properties were evaluated (props === true)\n gen.if((0, codegen_1.not)(valid), () => gen.break());\n }\n });\n });\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=patternProperties.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst util_1 = require(\"../../compile/util\");\nconst def = {\n keyword: \"not\",\n schemaType: [\"object\", \"boolean\"],\n trackErrors: true,\n code(cxt) {\n const { gen, schema, it } = cxt;\n if ((0, util_1.alwaysValidSchema)(it, schema)) {\n cxt.fail();\n return;\n }\n const valid = gen.name(\"valid\");\n cxt.subschema({\n keyword: \"not\",\n compositeRule: true,\n createErrors: false,\n allErrors: false,\n }, valid);\n cxt.failResult(valid, () => cxt.reset(), () => cxt.error());\n },\n error: { message: \"must NOT be valid\" },\n};\nexports.default = def;\n//# sourceMappingURL=not.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst code_1 = require(\"../code\");\nconst def = {\n keyword: \"anyOf\",\n schemaType: \"array\",\n trackErrors: true,\n code: code_1.validateUnion,\n error: { message: \"must match a schema in anyOf\" },\n};\nexports.default = def;\n//# sourceMappingURL=anyOf.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: \"must match exactly one schema in oneOf\",\n params: ({ params }) => (0, codegen_1._) `{passingSchemas: ${params.passing}}`,\n};\nconst def = {\n keyword: \"oneOf\",\n schemaType: \"array\",\n trackErrors: true,\n error,\n code(cxt) {\n const { gen, schema, parentSchema, it } = cxt;\n /* istanbul ignore if */\n if (!Array.isArray(schema))\n throw new Error(\"ajv implementation error\");\n if (it.opts.discriminator && parentSchema.discriminator)\n return;\n const schArr = schema;\n const valid = gen.let(\"valid\", false);\n const passing = gen.let(\"passing\", null);\n const schValid = gen.name(\"_valid\");\n cxt.setParams({ passing });\n // TODO possibly fail straight away (with warning or exception) if there are two empty always valid schemas\n gen.block(validateOneOf);\n cxt.result(valid, () => cxt.reset(), () => cxt.error(true));\n function validateOneOf() {\n schArr.forEach((sch, i) => {\n let schCxt;\n if ((0, util_1.alwaysValidSchema)(it, sch)) {\n gen.var(schValid, true);\n }\n else {\n schCxt = cxt.subschema({\n keyword: \"oneOf\",\n schemaProp: i,\n compositeRule: true,\n }, schValid);\n }\n if (i > 0) {\n gen\n .if((0, codegen_1._) `${schValid} && ${valid}`)\n .assign(valid, false)\n .assign(passing, (0, codegen_1._) `[${passing}, ${i}]`)\n .else();\n }\n gen.if(schValid, () => {\n gen.assign(valid, true);\n gen.assign(passing, i);\n if (schCxt)\n cxt.mergeEvaluated(schCxt, codegen_1.Name);\n });\n });\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=oneOf.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst util_1 = require(\"../../compile/util\");\nconst def = {\n keyword: \"allOf\",\n schemaType: \"array\",\n code(cxt) {\n const { gen, schema, it } = cxt;\n /* istanbul ignore if */\n if (!Array.isArray(schema))\n throw new Error(\"ajv implementation error\");\n const valid = gen.name(\"valid\");\n schema.forEach((sch, i) => {\n if ((0, util_1.alwaysValidSchema)(it, sch))\n return;\n const schCxt = cxt.subschema({ keyword: \"allOf\", schemaProp: i }, valid);\n cxt.ok(valid);\n cxt.mergeEvaluated(schCxt);\n });\n },\n};\nexports.default = def;\n//# sourceMappingURL=allOf.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: ({ params }) => (0, codegen_1.str) `must match \"${params.ifClause}\" schema`,\n params: ({ params }) => (0, codegen_1._) `{failingKeyword: ${params.ifClause}}`,\n};\nconst def = {\n keyword: \"if\",\n schemaType: [\"object\", \"boolean\"],\n trackErrors: true,\n error,\n code(cxt) {\n const { gen, parentSchema, it } = cxt;\n if (parentSchema.then === undefined && parentSchema.else === undefined) {\n (0, util_1.checkStrictMode)(it, '\"if\" without \"then\" and \"else\" is ignored');\n }\n const hasThen = hasSchema(it, \"then\");\n const hasElse = hasSchema(it, \"else\");\n if (!hasThen && !hasElse)\n return;\n const valid = gen.let(\"valid\", true);\n const schValid = gen.name(\"_valid\");\n validateIf();\n cxt.reset();\n if (hasThen && hasElse) {\n const ifClause = gen.let(\"ifClause\");\n cxt.setParams({ ifClause });\n gen.if(schValid, validateClause(\"then\", ifClause), validateClause(\"else\", ifClause));\n }\n else if (hasThen) {\n gen.if(schValid, validateClause(\"then\"));\n }\n else {\n gen.if((0, codegen_1.not)(schValid), validateClause(\"else\"));\n }\n cxt.pass(valid, () => cxt.error(true));\n function validateIf() {\n const schCxt = cxt.subschema({\n keyword: \"if\",\n compositeRule: true,\n createErrors: false,\n allErrors: false,\n }, schValid);\n cxt.mergeEvaluated(schCxt);\n }\n function validateClause(keyword, ifClause) {\n return () => {\n const schCxt = cxt.subschema({ keyword }, schValid);\n gen.assign(valid, schValid);\n cxt.mergeValidEvaluated(schCxt, valid);\n if (ifClause)\n gen.assign(ifClause, (0, codegen_1._) `${keyword}`);\n else\n cxt.setParams({ ifClause: keyword });\n };\n }\n },\n};\nfunction hasSchema(it, keyword) {\n const schema = it.schema[keyword];\n return schema !== undefined && !(0, util_1.alwaysValidSchema)(it, schema);\n}\nexports.default = def;\n//# sourceMappingURL=if.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst util_1 = require(\"../../compile/util\");\nconst def = {\n keyword: [\"then\", \"else\"],\n schemaType: [\"object\", \"boolean\"],\n code({ keyword, parentSchema, it }) {\n if (parentSchema.if === undefined)\n (0, util_1.checkStrictMode)(it, `\"${keyword}\" without \"if\" is ignored`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=thenElse.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst additionalItems_1 = require(\"./additionalItems\");\nconst prefixItems_1 = require(\"./prefixItems\");\nconst items_1 = require(\"./items\");\nconst items2020_1 = require(\"./items2020\");\nconst contains_1 = require(\"./contains\");\nconst dependencies_1 = require(\"./dependencies\");\nconst propertyNames_1 = require(\"./propertyNames\");\nconst additionalProperties_1 = require(\"./additionalProperties\");\nconst properties_1 = require(\"./properties\");\nconst patternProperties_1 = require(\"./patternProperties\");\nconst not_1 = require(\"./not\");\nconst anyOf_1 = require(\"./anyOf\");\nconst oneOf_1 = require(\"./oneOf\");\nconst allOf_1 = require(\"./allOf\");\nconst if_1 = require(\"./if\");\nconst thenElse_1 = require(\"./thenElse\");\nfunction getApplicator(draft2020 = false) {\n const applicator = [\n // any\n not_1.default,\n anyOf_1.default,\n oneOf_1.default,\n allOf_1.default,\n if_1.default,\n thenElse_1.default,\n // object\n propertyNames_1.default,\n additionalProperties_1.default,\n dependencies_1.default,\n properties_1.default,\n patternProperties_1.default,\n ];\n // array\n if (draft2020)\n applicator.push(prefixItems_1.default, items2020_1.default);\n else\n applicator.push(additionalItems_1.default, items_1.default);\n applicator.push(contains_1.default);\n return applicator;\n}\nexports.default = getApplicator;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst error = {\n message: ({ schemaCode }) => (0, codegen_1.str) `must match format \"${schemaCode}\"`,\n params: ({ schemaCode }) => (0, codegen_1._) `{format: ${schemaCode}}`,\n};\nconst def = {\n keyword: \"format\",\n type: [\"number\", \"string\"],\n schemaType: \"string\",\n $data: true,\n error,\n code(cxt, ruleType) {\n const { gen, data, $data, schema, schemaCode, it } = cxt;\n const { opts, errSchemaPath, schemaEnv, self } = it;\n if (!opts.validateFormats)\n return;\n if ($data)\n validate$DataFormat();\n else\n validateFormat();\n function validate$DataFormat() {\n const fmts = gen.scopeValue(\"formats\", {\n ref: self.formats,\n code: opts.code.formats,\n });\n const fDef = gen.const(\"fDef\", (0, codegen_1._) `${fmts}[${schemaCode}]`);\n const fType = gen.let(\"fType\");\n const format = gen.let(\"format\");\n // TODO simplify\n gen.if((0, codegen_1._) `typeof ${fDef} == \"object\" && !(${fDef} instanceof RegExp)`, () => gen.assign(fType, (0, codegen_1._) `${fDef}.type || \"string\"`).assign(format, (0, codegen_1._) `${fDef}.validate`), () => gen.assign(fType, (0, codegen_1._) `\"string\"`).assign(format, fDef));\n cxt.fail$data((0, codegen_1.or)(unknownFmt(), invalidFmt()));\n function unknownFmt() {\n if (opts.strictSchema === false)\n return codegen_1.nil;\n return (0, codegen_1._) `${schemaCode} && !${format}`;\n }\n function invalidFmt() {\n const callFormat = schemaEnv.$async\n ? (0, codegen_1._) `(${fDef}.async ? await ${format}(${data}) : ${format}(${data}))`\n : (0, codegen_1._) `${format}(${data})`;\n const validData = (0, codegen_1._) `(typeof ${format} == \"function\" ? ${callFormat} : ${format}.test(${data}))`;\n return (0, codegen_1._) `${format} && ${format} !== true && ${fType} === ${ruleType} && !${validData}`;\n }\n }\n function validateFormat() {\n const formatDef = self.formats[schema];\n if (!formatDef) {\n unknownFormat();\n return;\n }\n if (formatDef === true)\n return;\n const [fmtType, format, fmtRef] = getFormat(formatDef);\n if (fmtType === ruleType)\n cxt.pass(validCondition());\n function unknownFormat() {\n if (opts.strictSchema === false) {\n self.logger.warn(unknownMsg());\n return;\n }\n throw new Error(unknownMsg());\n function unknownMsg() {\n return `unknown format \"${schema}\" ignored in schema at path \"${errSchemaPath}\"`;\n }\n }\n function getFormat(fmtDef) {\n const code = fmtDef instanceof RegExp\n ? (0, codegen_1.regexpCode)(fmtDef)\n : opts.code.formats\n ? (0, codegen_1._) `${opts.code.formats}${(0, codegen_1.getProperty)(schema)}`\n : undefined;\n const fmt = gen.scopeValue(\"formats\", { key: schema, ref: fmtDef, code });\n if (typeof fmtDef == \"object\" && !(fmtDef instanceof RegExp)) {\n return [fmtDef.type || \"string\", fmtDef.validate, (0, codegen_1._) `${fmt}.validate`];\n }\n return [\"string\", fmtDef, fmt];\n }\n function validCondition() {\n if (typeof formatDef == \"object\" && !(formatDef instanceof RegExp) && formatDef.async) {\n if (!schemaEnv.$async)\n throw new Error(\"async format in sync schema\");\n return (0, codegen_1._) `await ${fmtRef}(${data})`;\n }\n return typeof format == \"function\" ? (0, codegen_1._) `${fmtRef}(${data})` : (0, codegen_1._) `${fmtRef}.test(${data})`;\n }\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=format.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst format_1 = require(\"./format\");\nconst format = [format_1.default];\nexports.default = format;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.contentVocabulary = exports.metadataVocabulary = void 0;\nexports.metadataVocabulary = [\n \"title\",\n \"description\",\n \"default\",\n \"deprecated\",\n \"readOnly\",\n \"writeOnly\",\n \"examples\",\n];\nexports.contentVocabulary = [\n \"contentMediaType\",\n \"contentEncoding\",\n \"contentSchema\",\n];\n//# sourceMappingURL=metadata.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst core_1 = require(\"./core\");\nconst validation_1 = require(\"./validation\");\nconst applicator_1 = require(\"./applicator\");\nconst format_1 = require(\"./format\");\nconst metadata_1 = require(\"./metadata\");\nconst draft7Vocabularies = [\n core_1.default,\n validation_1.default,\n (0, applicator_1.default)(),\n format_1.default,\n metadata_1.metadataVocabulary,\n metadata_1.contentVocabulary,\n];\nexports.default = draft7Vocabularies;\n//# sourceMappingURL=draft7.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.DiscrError = void 0;\nvar DiscrError;\n(function (DiscrError) {\n DiscrError[\"Tag\"] = \"tag\";\n DiscrError[\"Mapping\"] = \"mapping\";\n})(DiscrError = exports.DiscrError || (exports.DiscrError = {}));\n//# sourceMappingURL=types.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst types_1 = require(\"../discriminator/types\");\nconst compile_1 = require(\"../../compile\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: ({ params: { discrError, tagName } }) => discrError === types_1.DiscrError.Tag\n ? `tag \"${tagName}\" must be string`\n : `value of tag \"${tagName}\" must be in oneOf`,\n params: ({ params: { discrError, tag, tagName } }) => (0, codegen_1._) `{error: ${discrError}, tag: ${tagName}, tagValue: ${tag}}`,\n};\nconst def = {\n keyword: \"discriminator\",\n type: \"object\",\n schemaType: \"object\",\n error,\n code(cxt) {\n const { gen, data, schema, parentSchema, it } = cxt;\n const { oneOf } = parentSchema;\n if (!it.opts.discriminator) {\n throw new Error(\"discriminator: requires discriminator option\");\n }\n const tagName = schema.propertyName;\n if (typeof tagName != \"string\")\n throw new Error(\"discriminator: requires propertyName\");\n if (schema.mapping)\n throw new Error(\"discriminator: mapping is not supported\");\n if (!oneOf)\n throw new Error(\"discriminator: requires oneOf keyword\");\n const valid = gen.let(\"valid\", false);\n const tag = gen.const(\"tag\", (0, codegen_1._) `${data}${(0, codegen_1.getProperty)(tagName)}`);\n gen.if((0, codegen_1._) `typeof ${tag} == \"string\"`, () => validateMapping(), () => cxt.error(false, { discrError: types_1.DiscrError.Tag, tag, tagName }));\n cxt.ok(valid);\n function validateMapping() {\n const mapping = getMapping();\n gen.if(false);\n for (const tagValue in mapping) {\n gen.elseIf((0, codegen_1._) `${tag} === ${tagValue}`);\n gen.assign(valid, applyTagSchema(mapping[tagValue]));\n }\n gen.else();\n cxt.error(false, { discrError: types_1.DiscrError.Mapping, tag, tagName });\n gen.endIf();\n }\n function applyTagSchema(schemaProp) {\n const _valid = gen.name(\"valid\");\n const schCxt = cxt.subschema({ keyword: \"oneOf\", schemaProp }, _valid);\n cxt.mergeEvaluated(schCxt, codegen_1.Name);\n return _valid;\n }\n function getMapping() {\n var _a;\n const oneOfMapping = {};\n const topRequired = hasRequired(parentSchema);\n let tagRequired = true;\n for (let i = 0; i < oneOf.length; i++) {\n let sch = oneOf[i];\n if ((sch === null || sch === void 0 ? void 0 : sch.$ref) && !(0, util_1.schemaHasRulesButRef)(sch, it.self.RULES)) {\n sch = compile_1.resolveRef.call(it.self, it.schemaEnv.root, it.baseId, sch === null || sch === void 0 ? void 0 : sch.$ref);\n if (sch instanceof compile_1.SchemaEnv)\n sch = sch.schema;\n }\n const propSch = (_a = sch === null || sch === void 0 ? void 0 : sch.properties) === null || _a === void 0 ? void 0 : _a[tagName];\n if (typeof propSch != \"object\") {\n throw new Error(`discriminator: oneOf subschemas (or referenced schemas) must have \"properties/${tagName}\"`);\n }\n tagRequired = tagRequired && (topRequired || hasRequired(sch));\n addMappings(propSch, i);\n }\n if (!tagRequired)\n throw new Error(`discriminator: \"${tagName}\" must be required`);\n return oneOfMapping;\n function hasRequired({ required }) {\n return Array.isArray(required) && required.includes(tagName);\n }\n function addMappings(sch, i) {\n if (sch.const) {\n addMapping(sch.const, i);\n }\n else if (sch.enum) {\n for (const tagValue of sch.enum) {\n addMapping(tagValue, i);\n }\n }\n else {\n throw new Error(`discriminator: \"properties/${tagName}\" must have \"const\" or \"enum\"`);\n }\n }\n function addMapping(tagValue, i) {\n if (typeof tagValue != \"string\" || tagValue in oneOfMapping) {\n throw new Error(`discriminator: \"${tagName}\" values must be unique strings`);\n }\n oneOfMapping[tagValue] = i;\n }\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.MissingRefError = exports.ValidationError = exports.CodeGen = exports.Name = exports.nil = exports.stringify = exports.str = exports._ = exports.KeywordCxt = void 0;\nconst core_1 = require(\"./core\");\nconst draft7_1 = require(\"./vocabularies/draft7\");\nconst discriminator_1 = require(\"./vocabularies/discriminator\");\nconst draft7MetaSchema = require(\"./refs/json-schema-draft-07.json\");\nconst META_SUPPORT_DATA = [\"/properties\"];\nconst META_SCHEMA_ID = \"http://json-schema.org/draft-07/schema\";\nclass Ajv extends core_1.default {\n _addVocabularies() {\n super._addVocabularies();\n draft7_1.default.forEach((v) => this.addVocabulary(v));\n if (this.opts.discriminator)\n this.addKeyword(discriminator_1.default);\n }\n _addDefaultMetaSchema() {\n super._addDefaultMetaSchema();\n if (!this.opts.meta)\n return;\n const metaSchema = this.opts.$data\n ? this.$dataMetaSchema(draft7MetaSchema, META_SUPPORT_DATA)\n : draft7MetaSchema;\n this.addMetaSchema(metaSchema, META_SCHEMA_ID, false);\n this.refs[\"http://json-schema.org/schema\"] = META_SCHEMA_ID;\n }\n defaultMeta() {\n return (this.opts.defaultMeta =\n super.defaultMeta() || (this.getSchema(META_SCHEMA_ID) ? META_SCHEMA_ID : undefined));\n }\n}\nmodule.exports = exports = Ajv;\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.default = Ajv;\nvar validate_1 = require(\"./compile/validate\");\nObject.defineProperty(exports, \"KeywordCxt\", { enumerable: true, get: function () { return validate_1.KeywordCxt; } });\nvar codegen_1 = require(\"./compile/codegen\");\nObject.defineProperty(exports, \"_\", { enumerable: true, get: function () { return codegen_1._; } });\nObject.defineProperty(exports, \"str\", { enumerable: true, get: function () { return codegen_1.str; } });\nObject.defineProperty(exports, \"stringify\", { enumerable: true, get: function () { return codegen_1.stringify; } });\nObject.defineProperty(exports, \"nil\", { enumerable: true, get: function () { return codegen_1.nil; } });\nObject.defineProperty(exports, \"Name\", { enumerable: true, get: function () { return codegen_1.Name; } });\nObject.defineProperty(exports, \"CodeGen\", { enumerable: true, get: function () { return codegen_1.CodeGen; } });\nvar validation_error_1 = require(\"./runtime/validation_error\");\nObject.defineProperty(exports, \"ValidationError\", { enumerable: true, get: function () { return validation_error_1.default; } });\nvar ref_error_1 = require(\"./compile/ref_error\");\nObject.defineProperty(exports, \"MissingRefError\", { enumerable: true, get: function () { return ref_error_1.default; } });\n//# sourceMappingURL=ajv.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.formatNames = exports.fastFormats = exports.fullFormats = void 0;\nfunction fmtDef(validate, compare) {\n return { validate, compare };\n}\nexports.fullFormats = {\n // date: http://tools.ietf.org/html/rfc3339#section-5.6\n date: fmtDef(date, compareDate),\n // date-time: http://tools.ietf.org/html/rfc3339#section-5.6\n time: fmtDef(time, compareTime),\n \"date-time\": fmtDef(date_time, compareDateTime),\n // duration: https://tools.ietf.org/html/rfc3339#appendix-A\n duration: /^P(?!$)((\\d+Y)?(\\d+M)?(\\d+D)?(T(?=\\d)(\\d+H)?(\\d+M)?(\\d+S)?)?|(\\d+W)?)$/,\n uri,\n \"uri-reference\": /^(?:[a-z][a-z0-9+\\-.]*:)?(?:\\/?\\/(?:(?:[a-z0-9\\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\\d|[01]?\\d\\d?)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d\\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|[Vv][0-9a-f]+\\.[a-z0-9\\-._~!$&'()*+,;=:]+)\\]|(?:(?:25[0-5]|2[0-4]\\d|[01]?\\d\\d?)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d\\d?)|(?:[a-z0-9\\-._~!$&'\"()*+,;=]|%[0-9a-f]{2})*)(?::\\d*)?(?:\\/(?:[a-z0-9\\-._~!$&'\"()*+,;=:@]|%[0-9a-f]{2})*)*|\\/(?:(?:[a-z0-9\\-._~!$&'\"()*+,;=:@]|%[0-9a-f]{2})+(?:\\/(?:[a-z0-9\\-._~!$&'\"()*+,;=:@]|%[0-9a-f]{2})*)*)?|(?:[a-z0-9\\-._~!$&'\"()*+,;=:@]|%[0-9a-f]{2})+(?:\\/(?:[a-z0-9\\-._~!$&'\"()*+,;=:@]|%[0-9a-f]{2})*)*)?(?:\\?(?:[a-z0-9\\-._~!$&'\"()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\\-._~!$&'\"()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i,\n // uri-template: https://tools.ietf.org/html/rfc6570\n \"uri-template\": /^(?:(?:[^\\x00-\\x20\"'<>%\\\\^`{|}]|%[0-9a-f]{2})|\\{[+#./;?&=,!@|]?(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\\*)?(?:,(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\\*)?)*\\})*$/i,\n // For the source: https://gist.github.com/dperini/729294\n // For test cases: https://mathiasbynens.be/demo/url-regex\n url: /^(?:https?|ftp):\\/\\/(?:\\S+(?::\\S*)?@)?(?:(?!(?:10|127)(?:\\.\\d{1,3}){3})(?!(?:169\\.254|192\\.168)(?:\\.\\d{1,3}){2})(?!172\\.(?:1[6-9]|2\\d|3[0-1])(?:\\.\\d{1,3}){2})(?:[1-9]\\d?|1\\d\\d|2[01]\\d|22[0-3])(?:\\.(?:1?\\d{1,2}|2[0-4]\\d|25[0-5])){2}(?:\\.(?:[1-9]\\d?|1\\d\\d|2[0-4]\\d|25[0-4]))|(?:(?:[a-z0-9\\u{00a1}-\\u{ffff}]+-)*[a-z0-9\\u{00a1}-\\u{ffff}]+)(?:\\.(?:[a-z0-9\\u{00a1}-\\u{ffff}]+-)*[a-z0-9\\u{00a1}-\\u{ffff}]+)*(?:\\.(?:[a-z\\u{00a1}-\\u{ffff}]{2,})))(?::\\d{2,5})?(?:\\/[^\\s]*)?$/iu,\n email: /^[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?$/i,\n hostname: /^(?=.{1,253}\\.?$)[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\\.[a-z0-9](?:[-0-9a-z]{0,61}[0-9a-z])?)*\\.?$/i,\n // optimized https://www.safaribooksonline.com/library/view/regular-expressions-cookbook/9780596802837/ch07s16.html\n ipv4: /^(?:(?:25[0-5]|2[0-4]\\d|[01]?\\d\\d?)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d\\d?)$/,\n ipv6: /^((([0-9a-f]{1,4}:){7}([0-9a-f]{1,4}|:))|(([0-9a-f]{1,4}:){6}(:[0-9a-f]{1,4}|((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3})|:))|(([0-9a-f]{1,4}:){5}(((:[0-9a-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3})|:))|(([0-9a-f]{1,4}:){4}(((:[0-9a-f]{1,4}){1,3})|((:[0-9a-f]{1,4})?:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:))|(([0-9a-f]{1,4}:){3}(((:[0-9a-f]{1,4}){1,4})|((:[0-9a-f]{1,4}){0,2}:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:))|(([0-9a-f]{1,4}:){2}(((:[0-9a-f]{1,4}){1,5})|((:[0-9a-f]{1,4}){0,3}:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:))|(([0-9a-f]{1,4}:){1}(((:[0-9a-f]{1,4}){1,6})|((:[0-9a-f]{1,4}){0,4}:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:))|(:(((:[0-9a-f]{1,4}){1,7})|((:[0-9a-f]{1,4}){0,5}:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:)))$/i,\n regex,\n // uuid: http://tools.ietf.org/html/rfc4122\n uuid: /^(?:urn:uuid:)?[0-9a-f]{8}-(?:[0-9a-f]{4}-){3}[0-9a-f]{12}$/i,\n // JSON-pointer: https://tools.ietf.org/html/rfc6901\n // uri fragment: https://tools.ietf.org/html/rfc3986#appendix-A\n \"json-pointer\": /^(?:\\/(?:[^~/]|~0|~1)*)*$/,\n \"json-pointer-uri-fragment\": /^#(?:\\/(?:[a-z0-9_\\-.!$&'()*+,;:=@]|%[0-9a-f]{2}|~0|~1)*)*$/i,\n // relative JSON-pointer: http://tools.ietf.org/html/draft-luff-relative-json-pointer-00\n \"relative-json-pointer\": /^(?:0|[1-9][0-9]*)(?:#|(?:\\/(?:[^~/]|~0|~1)*)*)$/,\n // the following formats are used by the openapi specification: https://spec.openapis.org/oas/v3.0.0#data-types\n // byte: https://github.com/miguelmota/is-base64\n byte,\n // signed 32 bit integer\n int32: { type: \"number\", validate: validateInt32 },\n // signed 64 bit integer\n int64: { type: \"number\", validate: validateInt64 },\n // C-type float\n float: { type: \"number\", validate: validateNumber },\n // C-type double\n double: { type: \"number\", validate: validateNumber },\n // hint to the UI to hide input strings\n password: true,\n // unchecked string payload\n binary: true,\n};\nexports.fastFormats = {\n ...exports.fullFormats,\n date: fmtDef(/^\\d\\d\\d\\d-[0-1]\\d-[0-3]\\d$/, compareDate),\n time: fmtDef(/^(?:[0-2]\\d:[0-5]\\d:[0-5]\\d|23:59:60)(?:\\.\\d+)?(?:z|[+-]\\d\\d(?::?\\d\\d)?)?$/i, compareTime),\n \"date-time\": fmtDef(/^\\d\\d\\d\\d-[0-1]\\d-[0-3]\\d[t\\s](?:[0-2]\\d:[0-5]\\d:[0-5]\\d|23:59:60)(?:\\.\\d+)?(?:z|[+-]\\d\\d(?::?\\d\\d)?)$/i, compareDateTime),\n // uri: https://github.com/mafintosh/is-my-json-valid/blob/master/formats.js\n uri: /^(?:[a-z][a-z0-9+\\-.]*:)(?:\\/?\\/)?[^\\s]*$/i,\n \"uri-reference\": /^(?:(?:[a-z][a-z0-9+\\-.]*:)?\\/?\\/)?(?:[^\\\\\\s#][^\\s#]*)?(?:#[^\\\\\\s]*)?$/i,\n // email (sources from jsen validator):\n // http://stackoverflow.com/questions/201323/using-a-regular-expression-to-validate-an-email-address#answer-8829363\n // http://www.w3.org/TR/html5/forms.html#valid-e-mail-address (search for 'wilful violation')\n email: /^[a-z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\\.[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?)*$/i,\n};\nexports.formatNames = Object.keys(exports.fullFormats);\nfunction isLeapYear(year) {\n // https://tools.ietf.org/html/rfc3339#appendix-C\n return year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0);\n}\nconst DATE = /^(\\d\\d\\d\\d)-(\\d\\d)-(\\d\\d)$/;\nconst DAYS = [0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\nfunction date(str) {\n // full-date from http://tools.ietf.org/html/rfc3339#section-5.6\n const matches = DATE.exec(str);\n if (!matches)\n return false;\n const year = +matches[1];\n const month = +matches[2];\n const day = +matches[3];\n return (month >= 1 &&\n month <= 12 &&\n day >= 1 &&\n day <= (month === 2 && isLeapYear(year) ? 29 : DAYS[month]));\n}\nfunction compareDate(d1, d2) {\n if (!(d1 && d2))\n return undefined;\n if (d1 > d2)\n return 1;\n if (d1 < d2)\n return -1;\n return 0;\n}\nconst TIME = /^(\\d\\d):(\\d\\d):(\\d\\d)(\\.\\d+)?(z|[+-]\\d\\d(?::?\\d\\d)?)?$/i;\nfunction time(str, withTimeZone) {\n const matches = TIME.exec(str);\n if (!matches)\n return false;\n const hour = +matches[1];\n const minute = +matches[2];\n const second = +matches[3];\n const timeZone = matches[5];\n return (((hour <= 23 && minute <= 59 && second <= 59) ||\n (hour === 23 && minute === 59 && second === 60)) &&\n (!withTimeZone || timeZone !== \"\"));\n}\nfunction compareTime(t1, t2) {\n if (!(t1 && t2))\n return undefined;\n const a1 = TIME.exec(t1);\n const a2 = TIME.exec(t2);\n if (!(a1 && a2))\n return undefined;\n t1 = a1[1] + a1[2] + a1[3] + (a1[4] || \"\");\n t2 = a2[1] + a2[2] + a2[3] + (a2[4] || \"\");\n if (t1 > t2)\n return 1;\n if (t1 < t2)\n return -1;\n return 0;\n}\nconst DATE_TIME_SEPARATOR = /t|\\s/i;\nfunction date_time(str) {\n // http://tools.ietf.org/html/rfc3339#section-5.6\n const dateTime = str.split(DATE_TIME_SEPARATOR);\n return dateTime.length === 2 && date(dateTime[0]) && time(dateTime[1], true);\n}\nfunction compareDateTime(dt1, dt2) {\n if (!(dt1 && dt2))\n return undefined;\n const [d1, t1] = dt1.split(DATE_TIME_SEPARATOR);\n const [d2, t2] = dt2.split(DATE_TIME_SEPARATOR);\n const res = compareDate(d1, d2);\n if (res === undefined)\n return undefined;\n return res || compareTime(t1, t2);\n}\nconst NOT_URI_FRAGMENT = /\\/|:/;\nconst URI = /^(?:[a-z][a-z0-9+\\-.]*:)(?:\\/?\\/(?:(?:[a-z0-9\\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\\d|[01]?\\d\\d?)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d\\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|[Vv][0-9a-f]+\\.[a-z0-9\\-._~!$&'()*+,;=:]+)\\]|(?:(?:25[0-5]|2[0-4]\\d|[01]?\\d\\d?)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d\\d?)|(?:[a-z0-9\\-._~!$&'()*+,;=]|%[0-9a-f]{2})*)(?::\\d*)?(?:\\/(?:[a-z0-9\\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*|\\/(?:(?:[a-z0-9\\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\\/(?:[a-z0-9\\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)?|(?:[a-z0-9\\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\\/(?:[a-z0-9\\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)(?:\\?(?:[a-z0-9\\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i;\nfunction uri(str) {\n // http://jmrware.com/articles/2009/uri_regexp/URI_regex.html + optional protocol + required \".\"\n return NOT_URI_FRAGMENT.test(str) && URI.test(str);\n}\nconst BYTE = /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/gm;\nfunction byte(str) {\n BYTE.lastIndex = 0;\n return BYTE.test(str);\n}\nconst MIN_INT32 = -(2 ** 31);\nconst MAX_INT32 = 2 ** 31 - 1;\nfunction validateInt32(value) {\n return Number.isInteger(value) && value <= MAX_INT32 && value >= MIN_INT32;\n}\nfunction validateInt64(value) {\n // JSON and javascript max Int is 2**53, so any int that passes isInteger is valid for Int64\n return Number.isInteger(value);\n}\nfunction validateNumber() {\n return true;\n}\nconst Z_ANCHOR = /[^\\\\]\\\\Z/;\nfunction regex(str) {\n if (Z_ANCHOR.test(str))\n return false;\n try {\n new RegExp(str);\n return true;\n }\n catch (e) {\n return false;\n }\n}\n//# sourceMappingURL=formats.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.regexpCode = exports.getEsmExportName = exports.getProperty = exports.safeStringify = exports.stringify = exports.strConcat = exports.addCodeArg = exports.str = exports._ = exports.nil = exports._Code = exports.Name = exports.IDENTIFIER = exports._CodeOrName = void 0;\nclass _CodeOrName {\n}\nexports._CodeOrName = _CodeOrName;\nexports.IDENTIFIER = /^[a-z$_][a-z$_0-9]*$/i;\nclass Name extends _CodeOrName {\n constructor(s) {\n super();\n if (!exports.IDENTIFIER.test(s))\n throw new Error(\"CodeGen: name must be a valid identifier\");\n this.str = s;\n }\n toString() {\n return this.str;\n }\n emptyStr() {\n return false;\n }\n get names() {\n return { [this.str]: 1 };\n }\n}\nexports.Name = Name;\nclass _Code extends _CodeOrName {\n constructor(code) {\n super();\n this._items = typeof code === \"string\" ? [code] : code;\n }\n toString() {\n return this.str;\n }\n emptyStr() {\n if (this._items.length > 1)\n return false;\n const item = this._items[0];\n return item === \"\" || item === '\"\"';\n }\n get str() {\n var _a;\n return ((_a = this._str) !== null && _a !== void 0 ? _a : (this._str = this._items.reduce((s, c) => `${s}${c}`, \"\")));\n }\n get names() {\n var _a;\n return ((_a = this._names) !== null && _a !== void 0 ? _a : (this._names = this._items.reduce((names, c) => {\n if (c instanceof Name)\n names[c.str] = (names[c.str] || 0) + 1;\n return names;\n }, {})));\n }\n}\nexports._Code = _Code;\nexports.nil = new _Code(\"\");\nfunction _(strs, ...args) {\n const code = [strs[0]];\n let i = 0;\n while (i < args.length) {\n addCodeArg(code, args[i]);\n code.push(strs[++i]);\n }\n return new _Code(code);\n}\nexports._ = _;\nconst plus = new _Code(\"+\");\nfunction str(strs, ...args) {\n const expr = [safeStringify(strs[0])];\n let i = 0;\n while (i < args.length) {\n expr.push(plus);\n addCodeArg(expr, args[i]);\n expr.push(plus, safeStringify(strs[++i]));\n }\n optimize(expr);\n return new _Code(expr);\n}\nexports.str = str;\nfunction addCodeArg(code, arg) {\n if (arg instanceof _Code)\n code.push(...arg._items);\n else if (arg instanceof Name)\n code.push(arg);\n else\n code.push(interpolate(arg));\n}\nexports.addCodeArg = addCodeArg;\nfunction optimize(expr) {\n let i = 1;\n while (i < expr.length - 1) {\n if (expr[i] === plus) {\n const res = mergeExprItems(expr[i - 1], expr[i + 1]);\n if (res !== undefined) {\n expr.splice(i - 1, 3, res);\n continue;\n }\n expr[i++] = \"+\";\n }\n i++;\n }\n}\nfunction mergeExprItems(a, b) {\n if (b === '\"\"')\n return a;\n if (a === '\"\"')\n return b;\n if (typeof a == \"string\") {\n if (b instanceof Name || a[a.length - 1] !== '\"')\n return;\n if (typeof b != \"string\")\n return `${a.slice(0, -1)}${b}\"`;\n if (b[0] === '\"')\n return a.slice(0, -1) + b.slice(1);\n return;\n }\n if (typeof b == \"string\" && b[0] === '\"' && !(a instanceof Name))\n return `\"${a}${b.slice(1)}`;\n return;\n}\nfunction strConcat(c1, c2) {\n return c2.emptyStr() ? c1 : c1.emptyStr() ? c2 : str `${c1}${c2}`;\n}\nexports.strConcat = strConcat;\n// TODO do not allow arrays here\nfunction interpolate(x) {\n return typeof x == \"number\" || typeof x == \"boolean\" || x === null\n ? x\n : safeStringify(Array.isArray(x) ? x.join(\",\") : x);\n}\nfunction stringify(x) {\n return new _Code(safeStringify(x));\n}\nexports.stringify = stringify;\nfunction safeStringify(x) {\n return JSON.stringify(x)\n .replace(/\\u2028/g, \"\\\\u2028\")\n .replace(/\\u2029/g, \"\\\\u2029\");\n}\nexports.safeStringify = safeStringify;\nfunction getProperty(key) {\n return typeof key == \"string\" && exports.IDENTIFIER.test(key) ? new _Code(`.${key}`) : _ `[${key}]`;\n}\nexports.getProperty = getProperty;\n//Does best effort to format the name properly\nfunction getEsmExportName(key) {\n if (typeof key == \"string\" && exports.IDENTIFIER.test(key)) {\n return new _Code(`${key}`);\n }\n throw new Error(`CodeGen: invalid export name: ${key}, use explicit $id name mapping`);\n}\nexports.getEsmExportName = getEsmExportName;\nfunction regexpCode(rx) {\n return new _Code(rx.toString());\n}\nexports.regexpCode = regexpCode;\n//# sourceMappingURL=code.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ValueScope = exports.ValueScopeName = exports.Scope = exports.varKinds = exports.UsedValueState = void 0;\nconst code_1 = require(\"./code\");\nclass ValueError extends Error {\n constructor(name) {\n super(`CodeGen: \"code\" for ${name} not defined`);\n this.value = name.value;\n }\n}\nvar UsedValueState;\n(function (UsedValueState) {\n UsedValueState[UsedValueState[\"Started\"] = 0] = \"Started\";\n UsedValueState[UsedValueState[\"Completed\"] = 1] = \"Completed\";\n})(UsedValueState = exports.UsedValueState || (exports.UsedValueState = {}));\nexports.varKinds = {\n const: new code_1.Name(\"const\"),\n let: new code_1.Name(\"let\"),\n var: new code_1.Name(\"var\"),\n};\nclass Scope {\n constructor({ prefixes, parent } = {}) {\n this._names = {};\n this._prefixes = prefixes;\n this._parent = parent;\n }\n toName(nameOrPrefix) {\n return nameOrPrefix instanceof code_1.Name ? nameOrPrefix : this.name(nameOrPrefix);\n }\n name(prefix) {\n return new code_1.Name(this._newName(prefix));\n }\n _newName(prefix) {\n const ng = this._names[prefix] || this._nameGroup(prefix);\n return `${prefix}${ng.index++}`;\n }\n _nameGroup(prefix) {\n var _a, _b;\n if (((_b = (_a = this._parent) === null || _a === void 0 ? void 0 : _a._prefixes) === null || _b === void 0 ? void 0 : _b.has(prefix)) || (this._prefixes && !this._prefixes.has(prefix))) {\n throw new Error(`CodeGen: prefix \"${prefix}\" is not allowed in this scope`);\n }\n return (this._names[prefix] = { prefix, index: 0 });\n }\n}\nexports.Scope = Scope;\nclass ValueScopeName extends code_1.Name {\n constructor(prefix, nameStr) {\n super(nameStr);\n this.prefix = prefix;\n }\n setValue(value, { property, itemIndex }) {\n this.value = value;\n this.scopePath = (0, code_1._) `.${new code_1.Name(property)}[${itemIndex}]`;\n }\n}\nexports.ValueScopeName = ValueScopeName;\nconst line = (0, code_1._) `\\n`;\nclass ValueScope extends Scope {\n constructor(opts) {\n super(opts);\n this._values = {};\n this._scope = opts.scope;\n this.opts = { ...opts, _n: opts.lines ? line : code_1.nil };\n }\n get() {\n return this._scope;\n }\n name(prefix) {\n return new ValueScopeName(prefix, this._newName(prefix));\n }\n value(nameOrPrefix, value) {\n var _a;\n if (value.ref === undefined)\n throw new Error(\"CodeGen: ref must be passed in value\");\n const name = this.toName(nameOrPrefix);\n const { prefix } = name;\n const valueKey = (_a = value.key) !== null && _a !== void 0 ? _a : value.ref;\n let vs = this._values[prefix];\n if (vs) {\n const _name = vs.get(valueKey);\n if (_name)\n return _name;\n }\n else {\n vs = this._values[prefix] = new Map();\n }\n vs.set(valueKey, name);\n const s = this._scope[prefix] || (this._scope[prefix] = []);\n const itemIndex = s.length;\n s[itemIndex] = value.ref;\n name.setValue(value, { property: prefix, itemIndex });\n return name;\n }\n getValue(prefix, keyOrRef) {\n const vs = this._values[prefix];\n if (!vs)\n return;\n return vs.get(keyOrRef);\n }\n scopeRefs(scopeName, values = this._values) {\n return this._reduceValues(values, (name) => {\n if (name.scopePath === undefined)\n throw new Error(`CodeGen: name \"${name}\" has no value`);\n return (0, code_1._) `${scopeName}${name.scopePath}`;\n });\n }\n scopeCode(values = this._values, usedValues, getCode) {\n return this._reduceValues(values, (name) => {\n if (name.value === undefined)\n throw new Error(`CodeGen: name \"${name}\" has no value`);\n return name.value.code;\n }, usedValues, getCode);\n }\n _reduceValues(values, valueCode, usedValues = {}, getCode) {\n let code = code_1.nil;\n for (const prefix in values) {\n const vs = values[prefix];\n if (!vs)\n continue;\n const nameSet = (usedValues[prefix] = usedValues[prefix] || new Map());\n vs.forEach((name) => {\n if (nameSet.has(name))\n return;\n nameSet.set(name, UsedValueState.Started);\n let c = valueCode(name);\n if (c) {\n const def = this.opts.es5 ? exports.varKinds.var : exports.varKinds.const;\n code = (0, code_1._) `${code}${def} ${name} = ${c};${this.opts._n}`;\n }\n else if ((c = getCode === null || getCode === void 0 ? void 0 : getCode(name))) {\n code = (0, code_1._) `${code}${c}${this.opts._n}`;\n }\n else {\n throw new ValueError(name);\n }\n nameSet.set(name, UsedValueState.Completed);\n });\n }\n return code;\n }\n}\nexports.ValueScope = ValueScope;\n//# sourceMappingURL=scope.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.or = exports.and = exports.not = exports.CodeGen = exports.operators = exports.varKinds = exports.ValueScopeName = exports.ValueScope = exports.Scope = exports.Name = exports.regexpCode = exports.stringify = exports.getProperty = exports.nil = exports.strConcat = exports.str = exports._ = void 0;\nconst code_1 = require(\"./code\");\nconst scope_1 = require(\"./scope\");\nvar code_2 = require(\"./code\");\nObject.defineProperty(exports, \"_\", { enumerable: true, get: function () { return code_2._; } });\nObject.defineProperty(exports, \"str\", { enumerable: true, get: function () { return code_2.str; } });\nObject.defineProperty(exports, \"strConcat\", { enumerable: true, get: function () { return code_2.strConcat; } });\nObject.defineProperty(exports, \"nil\", { enumerable: true, get: function () { return code_2.nil; } });\nObject.defineProperty(exports, \"getProperty\", { enumerable: true, get: function () { return code_2.getProperty; } });\nObject.defineProperty(exports, \"stringify\", { enumerable: true, get: function () { return code_2.stringify; } });\nObject.defineProperty(exports, \"regexpCode\", { enumerable: true, get: function () { return code_2.regexpCode; } });\nObject.defineProperty(exports, \"Name\", { enumerable: true, get: function () { return code_2.Name; } });\nvar scope_2 = require(\"./scope\");\nObject.defineProperty(exports, \"Scope\", { enumerable: true, get: function () { return scope_2.Scope; } });\nObject.defineProperty(exports, \"ValueScope\", { enumerable: true, get: function () { return scope_2.ValueScope; } });\nObject.defineProperty(exports, \"ValueScopeName\", { enumerable: true, get: function () { return scope_2.ValueScopeName; } });\nObject.defineProperty(exports, \"varKinds\", { enumerable: true, get: function () { return scope_2.varKinds; } });\nexports.operators = {\n GT: new code_1._Code(\">\"),\n GTE: new code_1._Code(\">=\"),\n LT: new code_1._Code(\"<\"),\n LTE: new code_1._Code(\"<=\"),\n EQ: new code_1._Code(\"===\"),\n NEQ: new code_1._Code(\"!==\"),\n NOT: new code_1._Code(\"!\"),\n OR: new code_1._Code(\"||\"),\n AND: new code_1._Code(\"&&\"),\n ADD: new code_1._Code(\"+\"),\n};\nclass Node {\n optimizeNodes() {\n return this;\n }\n optimizeNames(_names, _constants) {\n return this;\n }\n}\nclass Def extends Node {\n constructor(varKind, name, rhs) {\n super();\n this.varKind = varKind;\n this.name = name;\n this.rhs = rhs;\n }\n render({ es5, _n }) {\n const varKind = es5 ? scope_1.varKinds.var : this.varKind;\n const rhs = this.rhs === undefined ? \"\" : ` = ${this.rhs}`;\n return `${varKind} ${this.name}${rhs};` + _n;\n }\n optimizeNames(names, constants) {\n if (!names[this.name.str])\n return;\n if (this.rhs)\n this.rhs = optimizeExpr(this.rhs, names, constants);\n return this;\n }\n get names() {\n return this.rhs instanceof code_1._CodeOrName ? this.rhs.names : {};\n }\n}\nclass Assign extends Node {\n constructor(lhs, rhs, sideEffects) {\n super();\n this.lhs = lhs;\n this.rhs = rhs;\n this.sideEffects = sideEffects;\n }\n render({ _n }) {\n return `${this.lhs} = ${this.rhs};` + _n;\n }\n optimizeNames(names, constants) {\n if (this.lhs instanceof code_1.Name && !names[this.lhs.str] && !this.sideEffects)\n return;\n this.rhs = optimizeExpr(this.rhs, names, constants);\n return this;\n }\n get names() {\n const names = this.lhs instanceof code_1.Name ? {} : { ...this.lhs.names };\n return addExprNames(names, this.rhs);\n }\n}\nclass AssignOp extends Assign {\n constructor(lhs, op, rhs, sideEffects) {\n super(lhs, rhs, sideEffects);\n this.op = op;\n }\n render({ _n }) {\n return `${this.lhs} ${this.op}= ${this.rhs};` + _n;\n }\n}\nclass Label extends Node {\n constructor(label) {\n super();\n this.label = label;\n this.names = {};\n }\n render({ _n }) {\n return `${this.label}:` + _n;\n }\n}\nclass Break extends Node {\n constructor(label) {\n super();\n this.label = label;\n this.names = {};\n }\n render({ _n }) {\n const label = this.label ? ` ${this.label}` : \"\";\n return `break${label};` + _n;\n }\n}\nclass Throw extends Node {\n constructor(error) {\n super();\n this.error = error;\n }\n render({ _n }) {\n return `throw ${this.error};` + _n;\n }\n get names() {\n return this.error.names;\n }\n}\nclass AnyCode extends Node {\n constructor(code) {\n super();\n this.code = code;\n }\n render({ _n }) {\n return `${this.code};` + _n;\n }\n optimizeNodes() {\n return `${this.code}` ? this : undefined;\n }\n optimizeNames(names, constants) {\n this.code = optimizeExpr(this.code, names, constants);\n return this;\n }\n get names() {\n return this.code instanceof code_1._CodeOrName ? this.code.names : {};\n }\n}\nclass ParentNode extends Node {\n constructor(nodes = []) {\n super();\n this.nodes = nodes;\n }\n render(opts) {\n return this.nodes.reduce((code, n) => code + n.render(opts), \"\");\n }\n optimizeNodes() {\n const { nodes } = this;\n let i = nodes.length;\n while (i--) {\n const n = nodes[i].optimizeNodes();\n if (Array.isArray(n))\n nodes.splice(i, 1, ...n);\n else if (n)\n nodes[i] = n;\n else\n nodes.splice(i, 1);\n }\n return nodes.length > 0 ? this : undefined;\n }\n optimizeNames(names, constants) {\n const { nodes } = this;\n let i = nodes.length;\n while (i--) {\n // iterating backwards improves 1-pass optimization\n const n = nodes[i];\n if (n.optimizeNames(names, constants))\n continue;\n subtractNames(names, n.names);\n nodes.splice(i, 1);\n }\n return nodes.length > 0 ? this : undefined;\n }\n get names() {\n return this.nodes.reduce((names, n) => addNames(names, n.names), {});\n }\n}\nclass BlockNode extends ParentNode {\n render(opts) {\n return \"{\" + opts._n + super.render(opts) + \"}\" + opts._n;\n }\n}\nclass Root extends ParentNode {\n}\nclass Else extends BlockNode {\n}\nElse.kind = \"else\";\nclass If extends BlockNode {\n constructor(condition, nodes) {\n super(nodes);\n this.condition = condition;\n }\n render(opts) {\n let code = `if(${this.condition})` + super.render(opts);\n if (this.else)\n code += \"else \" + this.else.render(opts);\n return code;\n }\n optimizeNodes() {\n super.optimizeNodes();\n const cond = this.condition;\n if (cond === true)\n return this.nodes; // else is ignored here\n let e = this.else;\n if (e) {\n const ns = e.optimizeNodes();\n e = this.else = Array.isArray(ns) ? new Else(ns) : ns;\n }\n if (e) {\n if (cond === false)\n return e instanceof If ? e : e.nodes;\n if (this.nodes.length)\n return this;\n return new If(not(cond), e instanceof If ? [e] : e.nodes);\n }\n if (cond === false || !this.nodes.length)\n return undefined;\n return this;\n }\n optimizeNames(names, constants) {\n var _a;\n this.else = (_a = this.else) === null || _a === void 0 ? void 0 : _a.optimizeNames(names, constants);\n if (!(super.optimizeNames(names, constants) || this.else))\n return;\n this.condition = optimizeExpr(this.condition, names, constants);\n return this;\n }\n get names() {\n const names = super.names;\n addExprNames(names, this.condition);\n if (this.else)\n addNames(names, this.else.names);\n return names;\n }\n}\nIf.kind = \"if\";\nclass For extends BlockNode {\n}\nFor.kind = \"for\";\nclass ForLoop extends For {\n constructor(iteration) {\n super();\n this.iteration = iteration;\n }\n render(opts) {\n return `for(${this.iteration})` + super.render(opts);\n }\n optimizeNames(names, constants) {\n if (!super.optimizeNames(names, constants))\n return;\n this.iteration = optimizeExpr(this.iteration, names, constants);\n return this;\n }\n get names() {\n return addNames(super.names, this.iteration.names);\n }\n}\nclass ForRange extends For {\n constructor(varKind, name, from, to) {\n super();\n this.varKind = varKind;\n this.name = name;\n this.from = from;\n this.to = to;\n }\n render(opts) {\n const varKind = opts.es5 ? scope_1.varKinds.var : this.varKind;\n const { name, from, to } = this;\n return `for(${varKind} ${name}=${from}; ${name}<${to}; ${name}++)` + super.render(opts);\n }\n get names() {\n const names = addExprNames(super.names, this.from);\n return addExprNames(names, this.to);\n }\n}\nclass ForIter extends For {\n constructor(loop, varKind, name, iterable) {\n super();\n this.loop = loop;\n this.varKind = varKind;\n this.name = name;\n this.iterable = iterable;\n }\n render(opts) {\n return `for(${this.varKind} ${this.name} ${this.loop} ${this.iterable})` + super.render(opts);\n }\n optimizeNames(names, constants) {\n if (!super.optimizeNames(names, constants))\n return;\n this.iterable = optimizeExpr(this.iterable, names, constants);\n return this;\n }\n get names() {\n return addNames(super.names, this.iterable.names);\n }\n}\nclass Func extends BlockNode {\n constructor(name, args, async) {\n super();\n this.name = name;\n this.args = args;\n this.async = async;\n }\n render(opts) {\n const _async = this.async ? \"async \" : \"\";\n return `${_async}function ${this.name}(${this.args})` + super.render(opts);\n }\n}\nFunc.kind = \"func\";\nclass Return extends ParentNode {\n render(opts) {\n return \"return \" + super.render(opts);\n }\n}\nReturn.kind = \"return\";\nclass Try extends BlockNode {\n render(opts) {\n let code = \"try\" + super.render(opts);\n if (this.catch)\n code += this.catch.render(opts);\n if (this.finally)\n code += this.finally.render(opts);\n return code;\n }\n optimizeNodes() {\n var _a, _b;\n super.optimizeNodes();\n (_a = this.catch) === null || _a === void 0 ? void 0 : _a.optimizeNodes();\n (_b = this.finally) === null || _b === void 0 ? void 0 : _b.optimizeNodes();\n return this;\n }\n optimizeNames(names, constants) {\n var _a, _b;\n super.optimizeNames(names, constants);\n (_a = this.catch) === null || _a === void 0 ? void 0 : _a.optimizeNames(names, constants);\n (_b = this.finally) === null || _b === void 0 ? void 0 : _b.optimizeNames(names, constants);\n return this;\n }\n get names() {\n const names = super.names;\n if (this.catch)\n addNames(names, this.catch.names);\n if (this.finally)\n addNames(names, this.finally.names);\n return names;\n }\n}\nclass Catch extends BlockNode {\n constructor(error) {\n super();\n this.error = error;\n }\n render(opts) {\n return `catch(${this.error})` + super.render(opts);\n }\n}\nCatch.kind = \"catch\";\nclass Finally extends BlockNode {\n render(opts) {\n return \"finally\" + super.render(opts);\n }\n}\nFinally.kind = \"finally\";\nclass CodeGen {\n constructor(extScope, opts = {}) {\n this._values = {};\n this._blockStarts = [];\n this._constants = {};\n this.opts = { ...opts, _n: opts.lines ? \"\\n\" : \"\" };\n this._extScope = extScope;\n this._scope = new scope_1.Scope({ parent: extScope });\n this._nodes = [new Root()];\n }\n toString() {\n return this._root.render(this.opts);\n }\n // returns unique name in the internal scope\n name(prefix) {\n return this._scope.name(prefix);\n }\n // reserves unique name in the external scope\n scopeName(prefix) {\n return this._extScope.name(prefix);\n }\n // reserves unique name in the external scope and assigns value to it\n scopeValue(prefixOrName, value) {\n const name = this._extScope.value(prefixOrName, value);\n const vs = this._values[name.prefix] || (this._values[name.prefix] = new Set());\n vs.add(name);\n return name;\n }\n getScopeValue(prefix, keyOrRef) {\n return this._extScope.getValue(prefix, keyOrRef);\n }\n // return code that assigns values in the external scope to the names that are used internally\n // (same names that were returned by gen.scopeName or gen.scopeValue)\n scopeRefs(scopeName) {\n return this._extScope.scopeRefs(scopeName, this._values);\n }\n scopeCode() {\n return this._extScope.scopeCode(this._values);\n }\n _def(varKind, nameOrPrefix, rhs, constant) {\n const name = this._scope.toName(nameOrPrefix);\n if (rhs !== undefined && constant)\n this._constants[name.str] = rhs;\n this._leafNode(new Def(varKind, name, rhs));\n return name;\n }\n // `const` declaration (`var` in es5 mode)\n const(nameOrPrefix, rhs, _constant) {\n return this._def(scope_1.varKinds.const, nameOrPrefix, rhs, _constant);\n }\n // `let` declaration with optional assignment (`var` in es5 mode)\n let(nameOrPrefix, rhs, _constant) {\n return this._def(scope_1.varKinds.let, nameOrPrefix, rhs, _constant);\n }\n // `var` declaration with optional assignment\n var(nameOrPrefix, rhs, _constant) {\n return this._def(scope_1.varKinds.var, nameOrPrefix, rhs, _constant);\n }\n // assignment code\n assign(lhs, rhs, sideEffects) {\n return this._leafNode(new Assign(lhs, rhs, sideEffects));\n }\n // `+=` code\n add(lhs, rhs) {\n return this._leafNode(new AssignOp(lhs, exports.operators.ADD, rhs));\n }\n // appends passed SafeExpr to code or executes Block\n code(c) {\n if (typeof c == \"function\")\n c();\n else if (c !== code_1.nil)\n this._leafNode(new AnyCode(c));\n return this;\n }\n // returns code for object literal for the passed argument list of key-value pairs\n object(...keyValues) {\n const code = [\"{\"];\n for (const [key, value] of keyValues) {\n if (code.length > 1)\n code.push(\",\");\n code.push(key);\n if (key !== value || this.opts.es5) {\n code.push(\":\");\n (0, code_1.addCodeArg)(code, value);\n }\n }\n code.push(\"}\");\n return new code_1._Code(code);\n }\n // `if` clause (or statement if `thenBody` and, optionally, `elseBody` are passed)\n if(condition, thenBody, elseBody) {\n this._blockNode(new If(condition));\n if (thenBody && elseBody) {\n this.code(thenBody).else().code(elseBody).endIf();\n }\n else if (thenBody) {\n this.code(thenBody).endIf();\n }\n else if (elseBody) {\n throw new Error('CodeGen: \"else\" body without \"then\" body');\n }\n return this;\n }\n // `else if` clause - invalid without `if` or after `else` clauses\n elseIf(condition) {\n return this._elseNode(new If(condition));\n }\n // `else` clause - only valid after `if` or `else if` clauses\n else() {\n return this._elseNode(new Else());\n }\n // end `if` statement (needed if gen.if was used only with condition)\n endIf() {\n return this._endBlockNode(If, Else);\n }\n _for(node, forBody) {\n this._blockNode(node);\n if (forBody)\n this.code(forBody).endFor();\n return this;\n }\n // a generic `for` clause (or statement if `forBody` is passed)\n for(iteration, forBody) {\n return this._for(new ForLoop(iteration), forBody);\n }\n // `for` statement for a range of values\n forRange(nameOrPrefix, from, to, forBody, varKind = this.opts.es5 ? scope_1.varKinds.var : scope_1.varKinds.let) {\n const name = this._scope.toName(nameOrPrefix);\n return this._for(new ForRange(varKind, name, from, to), () => forBody(name));\n }\n // `for-of` statement (in es5 mode replace with a normal for loop)\n forOf(nameOrPrefix, iterable, forBody, varKind = scope_1.varKinds.const) {\n const name = this._scope.toName(nameOrPrefix);\n if (this.opts.es5) {\n const arr = iterable instanceof code_1.Name ? iterable : this.var(\"_arr\", iterable);\n return this.forRange(\"_i\", 0, (0, code_1._) `${arr}.length`, (i) => {\n this.var(name, (0, code_1._) `${arr}[${i}]`);\n forBody(name);\n });\n }\n return this._for(new ForIter(\"of\", varKind, name, iterable), () => forBody(name));\n }\n // `for-in` statement.\n // With option `ownProperties` replaced with a `for-of` loop for object keys\n forIn(nameOrPrefix, obj, forBody, varKind = this.opts.es5 ? scope_1.varKinds.var : scope_1.varKinds.const) {\n if (this.opts.ownProperties) {\n return this.forOf(nameOrPrefix, (0, code_1._) `Object.keys(${obj})`, forBody);\n }\n const name = this._scope.toName(nameOrPrefix);\n return this._for(new ForIter(\"in\", varKind, name, obj), () => forBody(name));\n }\n // end `for` loop\n endFor() {\n return this._endBlockNode(For);\n }\n // `label` statement\n label(label) {\n return this._leafNode(new Label(label));\n }\n // `break` statement\n break(label) {\n return this._leafNode(new Break(label));\n }\n // `return` statement\n return(value) {\n const node = new Return();\n this._blockNode(node);\n this.code(value);\n if (node.nodes.length !== 1)\n throw new Error('CodeGen: \"return\" should have one node');\n return this._endBlockNode(Return);\n }\n // `try` statement\n try(tryBody, catchCode, finallyCode) {\n if (!catchCode && !finallyCode)\n throw new Error('CodeGen: \"try\" without \"catch\" and \"finally\"');\n const node = new Try();\n this._blockNode(node);\n this.code(tryBody);\n if (catchCode) {\n const error = this.name(\"e\");\n this._currNode = node.catch = new Catch(error);\n catchCode(error);\n }\n if (finallyCode) {\n this._currNode = node.finally = new Finally();\n this.code(finallyCode);\n }\n return this._endBlockNode(Catch, Finally);\n }\n // `throw` statement\n throw(error) {\n return this._leafNode(new Throw(error));\n }\n // start self-balancing block\n block(body, nodeCount) {\n this._blockStarts.push(this._nodes.length);\n if (body)\n this.code(body).endBlock(nodeCount);\n return this;\n }\n // end the current self-balancing block\n endBlock(nodeCount) {\n const len = this._blockStarts.pop();\n if (len === undefined)\n throw new Error(\"CodeGen: not in self-balancing block\");\n const toClose = this._nodes.length - len;\n if (toClose < 0 || (nodeCount !== undefined && toClose !== nodeCount)) {\n throw new Error(`CodeGen: wrong number of nodes: ${toClose} vs ${nodeCount} expected`);\n }\n this._nodes.length = len;\n return this;\n }\n // `function` heading (or definition if funcBody is passed)\n func(name, args = code_1.nil, async, funcBody) {\n this._blockNode(new Func(name, args, async));\n if (funcBody)\n this.code(funcBody).endFunc();\n return this;\n }\n // end function definition\n endFunc() {\n return this._endBlockNode(Func);\n }\n optimize(n = 1) {\n while (n-- > 0) {\n this._root.optimizeNodes();\n this._root.optimizeNames(this._root.names, this._constants);\n }\n }\n _leafNode(node) {\n this._currNode.nodes.push(node);\n return this;\n }\n _blockNode(node) {\n this._currNode.nodes.push(node);\n this._nodes.push(node);\n }\n _endBlockNode(N1, N2) {\n const n = this._currNode;\n if (n instanceof N1 || (N2 && n instanceof N2)) {\n this._nodes.pop();\n return this;\n }\n throw new Error(`CodeGen: not in block \"${N2 ? `${N1.kind}/${N2.kind}` : N1.kind}\"`);\n }\n _elseNode(node) {\n const n = this._currNode;\n if (!(n instanceof If)) {\n throw new Error('CodeGen: \"else\" without \"if\"');\n }\n this._currNode = n.else = node;\n return this;\n }\n get _root() {\n return this._nodes[0];\n }\n get _currNode() {\n const ns = this._nodes;\n return ns[ns.length - 1];\n }\n set _currNode(node) {\n const ns = this._nodes;\n ns[ns.length - 1] = node;\n }\n}\nexports.CodeGen = CodeGen;\nfunction addNames(names, from) {\n for (const n in from)\n names[n] = (names[n] || 0) + (from[n] || 0);\n return names;\n}\nfunction addExprNames(names, from) {\n return from instanceof code_1._CodeOrName ? addNames(names, from.names) : names;\n}\nfunction optimizeExpr(expr, names, constants) {\n if (expr instanceof code_1.Name)\n return replaceName(expr);\n if (!canOptimize(expr))\n return expr;\n return new code_1._Code(expr._items.reduce((items, c) => {\n if (c instanceof code_1.Name)\n c = replaceName(c);\n if (c instanceof code_1._Code)\n items.push(...c._items);\n else\n items.push(c);\n return items;\n }, []));\n function replaceName(n) {\n const c = constants[n.str];\n if (c === undefined || names[n.str] !== 1)\n return n;\n delete names[n.str];\n return c;\n }\n function canOptimize(e) {\n return (e instanceof code_1._Code &&\n e._items.some((c) => c instanceof code_1.Name && names[c.str] === 1 && constants[c.str] !== undefined));\n }\n}\nfunction subtractNames(names, from) {\n for (const n in from)\n names[n] = (names[n] || 0) - (from[n] || 0);\n}\nfunction not(x) {\n return typeof x == \"boolean\" || typeof x == \"number\" || x === null ? !x : (0, code_1._) `!${par(x)}`;\n}\nexports.not = not;\nconst andCode = mappend(exports.operators.AND);\n// boolean AND (&&) expression with the passed arguments\nfunction and(...args) {\n return args.reduce(andCode);\n}\nexports.and = and;\nconst orCode = mappend(exports.operators.OR);\n// boolean OR (||) expression with the passed arguments\nfunction or(...args) {\n return args.reduce(orCode);\n}\nexports.or = or;\nfunction mappend(op) {\n return (x, y) => (x === code_1.nil ? y : y === code_1.nil ? x : (0, code_1._) `${par(x)} ${op} ${par(y)}`);\n}\nfunction par(x) {\n return x instanceof code_1.Name ? x : (0, code_1._) `(${x})`;\n}\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.checkStrictMode = exports.getErrorPath = exports.Type = exports.useFunc = exports.setEvaluated = exports.evaluatedPropsToName = exports.mergeEvaluated = exports.eachItem = exports.unescapeJsonPointer = exports.escapeJsonPointer = exports.escapeFragment = exports.unescapeFragment = exports.schemaRefOrVal = exports.schemaHasRulesButRef = exports.schemaHasRules = exports.checkUnknownRules = exports.alwaysValidSchema = exports.toHash = void 0;\nconst codegen_1 = require(\"./codegen\");\nconst code_1 = require(\"./codegen/code\");\n// TODO refactor to use Set\nfunction toHash(arr) {\n const hash = {};\n for (const item of arr)\n hash[item] = true;\n return hash;\n}\nexports.toHash = toHash;\nfunction alwaysValidSchema(it, schema) {\n if (typeof schema == \"boolean\")\n return schema;\n if (Object.keys(schema).length === 0)\n return true;\n checkUnknownRules(it, schema);\n return !schemaHasRules(schema, it.self.RULES.all);\n}\nexports.alwaysValidSchema = alwaysValidSchema;\nfunction checkUnknownRules(it, schema = it.schema) {\n const { opts, self } = it;\n if (!opts.strictSchema)\n return;\n if (typeof schema === \"boolean\")\n return;\n const rules = self.RULES.keywords;\n for (const key in schema) {\n if (!rules[key])\n checkStrictMode(it, `unknown keyword: \"${key}\"`);\n }\n}\nexports.checkUnknownRules = checkUnknownRules;\nfunction schemaHasRules(schema, rules) {\n if (typeof schema == \"boolean\")\n return !schema;\n for (const key in schema)\n if (rules[key])\n return true;\n return false;\n}\nexports.schemaHasRules = schemaHasRules;\nfunction schemaHasRulesButRef(schema, RULES) {\n if (typeof schema == \"boolean\")\n return !schema;\n for (const key in schema)\n if (key !== \"$ref\" && RULES.all[key])\n return true;\n return false;\n}\nexports.schemaHasRulesButRef = schemaHasRulesButRef;\nfunction schemaRefOrVal({ topSchemaRef, schemaPath }, schema, keyword, $data) {\n if (!$data) {\n if (typeof schema == \"number\" || typeof schema == \"boolean\")\n return schema;\n if (typeof schema == \"string\")\n return (0, codegen_1._) `${schema}`;\n }\n return (0, codegen_1._) `${topSchemaRef}${schemaPath}${(0, codegen_1.getProperty)(keyword)}`;\n}\nexports.schemaRefOrVal = schemaRefOrVal;\nfunction unescapeFragment(str) {\n return unescapeJsonPointer(decodeURIComponent(str));\n}\nexports.unescapeFragment = unescapeFragment;\nfunction escapeFragment(str) {\n return encodeURIComponent(escapeJsonPointer(str));\n}\nexports.escapeFragment = escapeFragment;\nfunction escapeJsonPointer(str) {\n if (typeof str == \"number\")\n return `${str}`;\n return str.replace(/~/g, \"~0\").replace(/\\//g, \"~1\");\n}\nexports.escapeJsonPointer = escapeJsonPointer;\nfunction unescapeJsonPointer(str) {\n return str.replace(/~1/g, \"/\").replace(/~0/g, \"~\");\n}\nexports.unescapeJsonPointer = unescapeJsonPointer;\nfunction eachItem(xs, f) {\n if (Array.isArray(xs)) {\n for (const x of xs)\n f(x);\n }\n else {\n f(xs);\n }\n}\nexports.eachItem = eachItem;\nfunction makeMergeEvaluated({ mergeNames, mergeToName, mergeValues, resultToName, }) {\n return (gen, from, to, toName) => {\n const res = to === undefined\n ? from\n : to instanceof codegen_1.Name\n ? (from instanceof codegen_1.Name ? mergeNames(gen, from, to) : mergeToName(gen, from, to), to)\n : from instanceof codegen_1.Name\n ? (mergeToName(gen, to, from), from)\n : mergeValues(from, to);\n return toName === codegen_1.Name && !(res instanceof codegen_1.Name) ? resultToName(gen, res) : res;\n };\n}\nexports.mergeEvaluated = {\n props: makeMergeEvaluated({\n mergeNames: (gen, from, to) => gen.if((0, codegen_1._) `${to} !== true && ${from} !== undefined`, () => {\n gen.if((0, codegen_1._) `${from} === true`, () => gen.assign(to, true), () => gen.assign(to, (0, codegen_1._) `${to} || {}`).code((0, codegen_1._) `Object.assign(${to}, ${from})`));\n }),\n mergeToName: (gen, from, to) => gen.if((0, codegen_1._) `${to} !== true`, () => {\n if (from === true) {\n gen.assign(to, true);\n }\n else {\n gen.assign(to, (0, codegen_1._) `${to} || {}`);\n setEvaluated(gen, to, from);\n }\n }),\n mergeValues: (from, to) => (from === true ? true : { ...from, ...to }),\n resultToName: evaluatedPropsToName,\n }),\n items: makeMergeEvaluated({\n mergeNames: (gen, from, to) => gen.if((0, codegen_1._) `${to} !== true && ${from} !== undefined`, () => gen.assign(to, (0, codegen_1._) `${from} === true ? true : ${to} > ${from} ? ${to} : ${from}`)),\n mergeToName: (gen, from, to) => gen.if((0, codegen_1._) `${to} !== true`, () => gen.assign(to, from === true ? true : (0, codegen_1._) `${to} > ${from} ? ${to} : ${from}`)),\n mergeValues: (from, to) => (from === true ? true : Math.max(from, to)),\n resultToName: (gen, items) => gen.var(\"items\", items),\n }),\n};\nfunction evaluatedPropsToName(gen, ps) {\n if (ps === true)\n return gen.var(\"props\", true);\n const props = gen.var(\"props\", (0, codegen_1._) `{}`);\n if (ps !== undefined)\n setEvaluated(gen, props, ps);\n return props;\n}\nexports.evaluatedPropsToName = evaluatedPropsToName;\nfunction setEvaluated(gen, props, ps) {\n Object.keys(ps).forEach((p) => gen.assign((0, codegen_1._) `${props}${(0, codegen_1.getProperty)(p)}`, true));\n}\nexports.setEvaluated = setEvaluated;\nconst snippets = {};\nfunction useFunc(gen, f) {\n return gen.scopeValue(\"func\", {\n ref: f,\n code: snippets[f.code] || (snippets[f.code] = new code_1._Code(f.code)),\n });\n}\nexports.useFunc = useFunc;\nvar Type;\n(function (Type) {\n Type[Type[\"Num\"] = 0] = \"Num\";\n Type[Type[\"Str\"] = 1] = \"Str\";\n})(Type = exports.Type || (exports.Type = {}));\nfunction getErrorPath(dataProp, dataPropType, jsPropertySyntax) {\n // let path\n if (dataProp instanceof codegen_1.Name) {\n const isNumber = dataPropType === Type.Num;\n return jsPropertySyntax\n ? isNumber\n ? (0, codegen_1._) `\"[\" + ${dataProp} + \"]\"`\n : (0, codegen_1._) `\"['\" + ${dataProp} + \"']\"`\n : isNumber\n ? (0, codegen_1._) `\"/\" + ${dataProp}`\n : (0, codegen_1._) `\"/\" + ${dataProp}.replace(/~/g, \"~0\").replace(/\\\\//g, \"~1\")`; // TODO maybe use global escapePointer\n }\n return jsPropertySyntax ? (0, codegen_1.getProperty)(dataProp).toString() : \"/\" + escapeJsonPointer(dataProp);\n}\nexports.getErrorPath = getErrorPath;\nfunction checkStrictMode(it, msg, mode = it.opts.strictSchema) {\n if (!mode)\n return;\n msg = `strict mode: ${msg}`;\n if (mode === true)\n throw new Error(msg);\n it.self.logger.warn(msg);\n}\nexports.checkStrictMode = checkStrictMode;\n//# sourceMappingURL=util.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"./codegen\");\nconst names = {\n // validation function arguments\n data: new codegen_1.Name(\"data\"),\n // args passed from referencing schema\n valCxt: new codegen_1.Name(\"valCxt\"),\n instancePath: new codegen_1.Name(\"instancePath\"),\n parentData: new codegen_1.Name(\"parentData\"),\n parentDataProperty: new codegen_1.Name(\"parentDataProperty\"),\n rootData: new codegen_1.Name(\"rootData\"),\n dynamicAnchors: new codegen_1.Name(\"dynamicAnchors\"),\n // function scoped variables\n vErrors: new codegen_1.Name(\"vErrors\"),\n errors: new codegen_1.Name(\"errors\"),\n this: new codegen_1.Name(\"this\"),\n // \"globals\"\n self: new codegen_1.Name(\"self\"),\n scope: new codegen_1.Name(\"scope\"),\n // JTD serialize/parse name for JSON string and position\n json: new codegen_1.Name(\"json\"),\n jsonPos: new codegen_1.Name(\"jsonPos\"),\n jsonLen: new codegen_1.Name(\"jsonLen\"),\n jsonPart: new codegen_1.Name(\"jsonPart\"),\n};\nexports.default = names;\n//# sourceMappingURL=names.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.extendErrors = exports.resetErrorsCount = exports.reportExtraError = exports.reportError = exports.keyword$DataError = exports.keywordError = void 0;\nconst codegen_1 = require(\"./codegen\");\nconst util_1 = require(\"./util\");\nconst names_1 = require(\"./names\");\nexports.keywordError = {\n message: ({ keyword }) => (0, codegen_1.str) `must pass \"${keyword}\" keyword validation`,\n};\nexports.keyword$DataError = {\n message: ({ keyword, schemaType }) => schemaType\n ? (0, codegen_1.str) `\"${keyword}\" keyword must be ${schemaType} ($data)`\n : (0, codegen_1.str) `\"${keyword}\" keyword is invalid ($data)`,\n};\nfunction reportError(cxt, error = exports.keywordError, errorPaths, overrideAllErrors) {\n const { it } = cxt;\n const { gen, compositeRule, allErrors } = it;\n const errObj = errorObjectCode(cxt, error, errorPaths);\n if (overrideAllErrors !== null && overrideAllErrors !== void 0 ? overrideAllErrors : (compositeRule || allErrors)) {\n addError(gen, errObj);\n }\n else {\n returnErrors(it, (0, codegen_1._) `[${errObj}]`);\n }\n}\nexports.reportError = reportError;\nfunction reportExtraError(cxt, error = exports.keywordError, errorPaths) {\n const { it } = cxt;\n const { gen, compositeRule, allErrors } = it;\n const errObj = errorObjectCode(cxt, error, errorPaths);\n addError(gen, errObj);\n if (!(compositeRule || allErrors)) {\n returnErrors(it, names_1.default.vErrors);\n }\n}\nexports.reportExtraError = reportExtraError;\nfunction resetErrorsCount(gen, errsCount) {\n gen.assign(names_1.default.errors, errsCount);\n gen.if((0, codegen_1._) `${names_1.default.vErrors} !== null`, () => gen.if(errsCount, () => gen.assign((0, codegen_1._) `${names_1.default.vErrors}.length`, errsCount), () => gen.assign(names_1.default.vErrors, null)));\n}\nexports.resetErrorsCount = resetErrorsCount;\nfunction extendErrors({ gen, keyword, schemaValue, data, errsCount, it, }) {\n /* istanbul ignore if */\n if (errsCount === undefined)\n throw new Error(\"ajv implementation error\");\n const err = gen.name(\"err\");\n gen.forRange(\"i\", errsCount, names_1.default.errors, (i) => {\n gen.const(err, (0, codegen_1._) `${names_1.default.vErrors}[${i}]`);\n gen.if((0, codegen_1._) `${err}.instancePath === undefined`, () => gen.assign((0, codegen_1._) `${err}.instancePath`, (0, codegen_1.strConcat)(names_1.default.instancePath, it.errorPath)));\n gen.assign((0, codegen_1._) `${err}.schemaPath`, (0, codegen_1.str) `${it.errSchemaPath}/${keyword}`);\n if (it.opts.verbose) {\n gen.assign((0, codegen_1._) `${err}.schema`, schemaValue);\n gen.assign((0, codegen_1._) `${err}.data`, data);\n }\n });\n}\nexports.extendErrors = extendErrors;\nfunction addError(gen, errObj) {\n const err = gen.const(\"err\", errObj);\n gen.if((0, codegen_1._) `${names_1.default.vErrors} === null`, () => gen.assign(names_1.default.vErrors, (0, codegen_1._) `[${err}]`), (0, codegen_1._) `${names_1.default.vErrors}.push(${err})`);\n gen.code((0, codegen_1._) `${names_1.default.errors}++`);\n}\nfunction returnErrors(it, errs) {\n const { gen, validateName, schemaEnv } = it;\n if (schemaEnv.$async) {\n gen.throw((0, codegen_1._) `new ${it.ValidationError}(${errs})`);\n }\n else {\n gen.assign((0, codegen_1._) `${validateName}.errors`, errs);\n gen.return(false);\n }\n}\nconst E = {\n keyword: new codegen_1.Name(\"keyword\"),\n schemaPath: new codegen_1.Name(\"schemaPath\"),\n params: new codegen_1.Name(\"params\"),\n propertyName: new codegen_1.Name(\"propertyName\"),\n message: new codegen_1.Name(\"message\"),\n schema: new codegen_1.Name(\"schema\"),\n parentSchema: new codegen_1.Name(\"parentSchema\"),\n};\nfunction errorObjectCode(cxt, error, errorPaths) {\n const { createErrors } = cxt.it;\n if (createErrors === false)\n return (0, codegen_1._) `{}`;\n return errorObject(cxt, error, errorPaths);\n}\nfunction errorObject(cxt, error, errorPaths = {}) {\n const { gen, it } = cxt;\n const keyValues = [\n errorInstancePath(it, errorPaths),\n errorSchemaPath(cxt, errorPaths),\n ];\n extraErrorProps(cxt, error, keyValues);\n return gen.object(...keyValues);\n}\nfunction errorInstancePath({ errorPath }, { instancePath }) {\n const instPath = instancePath\n ? (0, codegen_1.str) `${errorPath}${(0, util_1.getErrorPath)(instancePath, util_1.Type.Str)}`\n : errorPath;\n return [names_1.default.instancePath, (0, codegen_1.strConcat)(names_1.default.instancePath, instPath)];\n}\nfunction errorSchemaPath({ keyword, it: { errSchemaPath } }, { schemaPath, parentSchema }) {\n let schPath = parentSchema ? errSchemaPath : (0, codegen_1.str) `${errSchemaPath}/${keyword}`;\n if (schemaPath) {\n schPath = (0, codegen_1.str) `${schPath}${(0, util_1.getErrorPath)(schemaPath, util_1.Type.Str)}`;\n }\n return [E.schemaPath, schPath];\n}\nfunction extraErrorProps(cxt, { params, message }, keyValues) {\n const { keyword, data, schemaValue, it } = cxt;\n const { opts, propertyName, topSchemaRef, schemaPath } = it;\n keyValues.push([E.keyword, keyword], [E.params, typeof params == \"function\" ? params(cxt) : params || (0, codegen_1._) `{}`]);\n if (opts.messages) {\n keyValues.push([E.message, typeof message == \"function\" ? message(cxt) : message]);\n }\n if (opts.verbose) {\n keyValues.push([E.schema, schemaValue], [E.parentSchema, (0, codegen_1._) `${topSchemaRef}${schemaPath}`], [names_1.default.data, data]);\n }\n if (propertyName)\n keyValues.push([E.propertyName, propertyName]);\n}\n//# sourceMappingURL=errors.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.boolOrEmptySchema = exports.topBoolOrEmptySchema = void 0;\nconst errors_1 = require(\"../errors\");\nconst codegen_1 = require(\"../codegen\");\nconst names_1 = require(\"../names\");\nconst boolError = {\n message: \"boolean schema is false\",\n};\nfunction topBoolOrEmptySchema(it) {\n const { gen, schema, validateName } = it;\n if (schema === false) {\n falseSchemaError(it, false);\n }\n else if (typeof schema == \"object\" && schema.$async === true) {\n gen.return(names_1.default.data);\n }\n else {\n gen.assign((0, codegen_1._) `${validateName}.errors`, null);\n gen.return(true);\n }\n}\nexports.topBoolOrEmptySchema = topBoolOrEmptySchema;\nfunction boolOrEmptySchema(it, valid) {\n const { gen, schema } = it;\n if (schema === false) {\n gen.var(valid, false); // TODO var\n falseSchemaError(it);\n }\n else {\n gen.var(valid, true); // TODO var\n }\n}\nexports.boolOrEmptySchema = boolOrEmptySchema;\nfunction falseSchemaError(it, overrideAllErrors) {\n const { gen, data } = it;\n // TODO maybe some other interface should be used for non-keyword validation errors...\n const cxt = {\n gen,\n keyword: \"false schema\",\n data,\n schema: false,\n schemaCode: false,\n schemaValue: false,\n params: {},\n it,\n };\n (0, errors_1.reportError)(cxt, boolError, undefined, overrideAllErrors);\n}\n//# sourceMappingURL=boolSchema.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getRules = exports.isJSONType = void 0;\nconst _jsonTypes = [\"string\", \"number\", \"integer\", \"boolean\", \"null\", \"object\", \"array\"];\nconst jsonTypes = new Set(_jsonTypes);\nfunction isJSONType(x) {\n return typeof x == \"string\" && jsonTypes.has(x);\n}\nexports.isJSONType = isJSONType;\nfunction getRules() {\n const groups = {\n number: { type: \"number\", rules: [] },\n string: { type: \"string\", rules: [] },\n array: { type: \"array\", rules: [] },\n object: { type: \"object\", rules: [] },\n };\n return {\n types: { ...groups, integer: true, boolean: true, null: true },\n rules: [{ rules: [] }, groups.number, groups.string, groups.array, groups.object],\n post: { rules: [] },\n all: {},\n keywords: {},\n };\n}\nexports.getRules = getRules;\n//# sourceMappingURL=rules.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.shouldUseRule = exports.shouldUseGroup = exports.schemaHasRulesForType = void 0;\nfunction schemaHasRulesForType({ schema, self }, type) {\n const group = self.RULES.types[type];\n return group && group !== true && shouldUseGroup(schema, group);\n}\nexports.schemaHasRulesForType = schemaHasRulesForType;\nfunction shouldUseGroup(schema, group) {\n return group.rules.some((rule) => shouldUseRule(schema, rule));\n}\nexports.shouldUseGroup = shouldUseGroup;\nfunction shouldUseRule(schema, rule) {\n var _a;\n return (schema[rule.keyword] !== undefined ||\n ((_a = rule.definition.implements) === null || _a === void 0 ? void 0 : _a.some((kwd) => schema[kwd] !== undefined)));\n}\nexports.shouldUseRule = shouldUseRule;\n//# sourceMappingURL=applicability.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.reportTypeError = exports.checkDataTypes = exports.checkDataType = exports.coerceAndCheckDataType = exports.getJSONTypes = exports.getSchemaTypes = exports.DataType = void 0;\nconst rules_1 = require(\"../rules\");\nconst applicability_1 = require(\"./applicability\");\nconst errors_1 = require(\"../errors\");\nconst codegen_1 = require(\"../codegen\");\nconst util_1 = require(\"../util\");\nvar DataType;\n(function (DataType) {\n DataType[DataType[\"Correct\"] = 0] = \"Correct\";\n DataType[DataType[\"Wrong\"] = 1] = \"Wrong\";\n})(DataType = exports.DataType || (exports.DataType = {}));\nfunction getSchemaTypes(schema) {\n const types = getJSONTypes(schema.type);\n const hasNull = types.includes(\"null\");\n if (hasNull) {\n if (schema.nullable === false)\n throw new Error(\"type: null contradicts nullable: false\");\n }\n else {\n if (!types.length && schema.nullable !== undefined) {\n throw new Error('\"nullable\" cannot be used without \"type\"');\n }\n if (schema.nullable === true)\n types.push(\"null\");\n }\n return types;\n}\nexports.getSchemaTypes = getSchemaTypes;\nfunction getJSONTypes(ts) {\n const types = Array.isArray(ts) ? ts : ts ? [ts] : [];\n if (types.every(rules_1.isJSONType))\n return types;\n throw new Error(\"type must be JSONType or JSONType[]: \" + types.join(\",\"));\n}\nexports.getJSONTypes = getJSONTypes;\nfunction coerceAndCheckDataType(it, types) {\n const { gen, data, opts } = it;\n const coerceTo = coerceToTypes(types, opts.coerceTypes);\n const checkTypes = types.length > 0 &&\n !(coerceTo.length === 0 && types.length === 1 && (0, applicability_1.schemaHasRulesForType)(it, types[0]));\n if (checkTypes) {\n const wrongType = checkDataTypes(types, data, opts.strictNumbers, DataType.Wrong);\n gen.if(wrongType, () => {\n if (coerceTo.length)\n coerceData(it, types, coerceTo);\n else\n reportTypeError(it);\n });\n }\n return checkTypes;\n}\nexports.coerceAndCheckDataType = coerceAndCheckDataType;\nconst COERCIBLE = new Set([\"string\", \"number\", \"integer\", \"boolean\", \"null\"]);\nfunction coerceToTypes(types, coerceTypes) {\n return coerceTypes\n ? types.filter((t) => COERCIBLE.has(t) || (coerceTypes === \"array\" && t === \"array\"))\n : [];\n}\nfunction coerceData(it, types, coerceTo) {\n const { gen, data, opts } = it;\n const dataType = gen.let(\"dataType\", (0, codegen_1._) `typeof ${data}`);\n const coerced = gen.let(\"coerced\", (0, codegen_1._) `undefined`);\n if (opts.coerceTypes === \"array\") {\n gen.if((0, codegen_1._) `${dataType} == 'object' && Array.isArray(${data}) && ${data}.length == 1`, () => gen\n .assign(data, (0, codegen_1._) `${data}[0]`)\n .assign(dataType, (0, codegen_1._) `typeof ${data}`)\n .if(checkDataTypes(types, data, opts.strictNumbers), () => gen.assign(coerced, data)));\n }\n gen.if((0, codegen_1._) `${coerced} !== undefined`);\n for (const t of coerceTo) {\n if (COERCIBLE.has(t) || (t === \"array\" && opts.coerceTypes === \"array\")) {\n coerceSpecificType(t);\n }\n }\n gen.else();\n reportTypeError(it);\n gen.endIf();\n gen.if((0, codegen_1._) `${coerced} !== undefined`, () => {\n gen.assign(data, coerced);\n assignParentData(it, coerced);\n });\n function coerceSpecificType(t) {\n switch (t) {\n case \"string\":\n gen\n .elseIf((0, codegen_1._) `${dataType} == \"number\" || ${dataType} == \"boolean\"`)\n .assign(coerced, (0, codegen_1._) `\"\" + ${data}`)\n .elseIf((0, codegen_1._) `${data} === null`)\n .assign(coerced, (0, codegen_1._) `\"\"`);\n return;\n case \"number\":\n gen\n .elseIf((0, codegen_1._) `${dataType} == \"boolean\" || ${data} === null\n || (${dataType} == \"string\" && ${data} && ${data} == +${data})`)\n .assign(coerced, (0, codegen_1._) `+${data}`);\n return;\n case \"integer\":\n gen\n .elseIf((0, codegen_1._) `${dataType} === \"boolean\" || ${data} === null\n || (${dataType} === \"string\" && ${data} && ${data} == +${data} && !(${data} % 1))`)\n .assign(coerced, (0, codegen_1._) `+${data}`);\n return;\n case \"boolean\":\n gen\n .elseIf((0, codegen_1._) `${data} === \"false\" || ${data} === 0 || ${data} === null`)\n .assign(coerced, false)\n .elseIf((0, codegen_1._) `${data} === \"true\" || ${data} === 1`)\n .assign(coerced, true);\n return;\n case \"null\":\n gen.elseIf((0, codegen_1._) `${data} === \"\" || ${data} === 0 || ${data} === false`);\n gen.assign(coerced, null);\n return;\n case \"array\":\n gen\n .elseIf((0, codegen_1._) `${dataType} === \"string\" || ${dataType} === \"number\"\n || ${dataType} === \"boolean\" || ${data} === null`)\n .assign(coerced, (0, codegen_1._) `[${data}]`);\n }\n }\n}\nfunction assignParentData({ gen, parentData, parentDataProperty }, expr) {\n // TODO use gen.property\n gen.if((0, codegen_1._) `${parentData} !== undefined`, () => gen.assign((0, codegen_1._) `${parentData}[${parentDataProperty}]`, expr));\n}\nfunction checkDataType(dataType, data, strictNums, correct = DataType.Correct) {\n const EQ = correct === DataType.Correct ? codegen_1.operators.EQ : codegen_1.operators.NEQ;\n let cond;\n switch (dataType) {\n case \"null\":\n return (0, codegen_1._) `${data} ${EQ} null`;\n case \"array\":\n cond = (0, codegen_1._) `Array.isArray(${data})`;\n break;\n case \"object\":\n cond = (0, codegen_1._) `${data} && typeof ${data} == \"object\" && !Array.isArray(${data})`;\n break;\n case \"integer\":\n cond = numCond((0, codegen_1._) `!(${data} % 1) && !isNaN(${data})`);\n break;\n case \"number\":\n cond = numCond();\n break;\n default:\n return (0, codegen_1._) `typeof ${data} ${EQ} ${dataType}`;\n }\n return correct === DataType.Correct ? cond : (0, codegen_1.not)(cond);\n function numCond(_cond = codegen_1.nil) {\n return (0, codegen_1.and)((0, codegen_1._) `typeof ${data} == \"number\"`, _cond, strictNums ? (0, codegen_1._) `isFinite(${data})` : codegen_1.nil);\n }\n}\nexports.checkDataType = checkDataType;\nfunction checkDataTypes(dataTypes, data, strictNums, correct) {\n if (dataTypes.length === 1) {\n return checkDataType(dataTypes[0], data, strictNums, correct);\n }\n let cond;\n const types = (0, util_1.toHash)(dataTypes);\n if (types.array && types.object) {\n const notObj = (0, codegen_1._) `typeof ${data} != \"object\"`;\n cond = types.null ? notObj : (0, codegen_1._) `!${data} || ${notObj}`;\n delete types.null;\n delete types.array;\n delete types.object;\n }\n else {\n cond = codegen_1.nil;\n }\n if (types.number)\n delete types.integer;\n for (const t in types)\n cond = (0, codegen_1.and)(cond, checkDataType(t, data, strictNums, correct));\n return cond;\n}\nexports.checkDataTypes = checkDataTypes;\nconst typeError = {\n message: ({ schema }) => `must be ${schema}`,\n params: ({ schema, schemaValue }) => typeof schema == \"string\" ? (0, codegen_1._) `{type: ${schema}}` : (0, codegen_1._) `{type: ${schemaValue}}`,\n};\nfunction reportTypeError(it) {\n const cxt = getTypeErrorContext(it);\n (0, errors_1.reportError)(cxt, typeError);\n}\nexports.reportTypeError = reportTypeError;\nfunction getTypeErrorContext(it) {\n const { gen, data, schema } = it;\n const schemaCode = (0, util_1.schemaRefOrVal)(it, schema, \"type\");\n return {\n gen,\n keyword: \"type\",\n data,\n schema: schema.type,\n schemaCode,\n schemaValue: schemaCode,\n parentSchema: schema,\n params: {},\n it,\n };\n}\n//# sourceMappingURL=dataType.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.assignDefaults = void 0;\nconst codegen_1 = require(\"../codegen\");\nconst util_1 = require(\"../util\");\nfunction assignDefaults(it, ty) {\n const { properties, items } = it.schema;\n if (ty === \"object\" && properties) {\n for (const key in properties) {\n assignDefault(it, key, properties[key].default);\n }\n }\n else if (ty === \"array\" && Array.isArray(items)) {\n items.forEach((sch, i) => assignDefault(it, i, sch.default));\n }\n}\nexports.assignDefaults = assignDefaults;\nfunction assignDefault(it, prop, defaultValue) {\n const { gen, compositeRule, data, opts } = it;\n if (defaultValue === undefined)\n return;\n const childData = (0, codegen_1._) `${data}${(0, codegen_1.getProperty)(prop)}`;\n if (compositeRule) {\n (0, util_1.checkStrictMode)(it, `default is ignored for: ${childData}`);\n return;\n }\n let condition = (0, codegen_1._) `${childData} === undefined`;\n if (opts.useDefaults === \"empty\") {\n condition = (0, codegen_1._) `${condition} || ${childData} === null || ${childData} === \"\"`;\n }\n // `${childData} === undefined` +\n // (opts.useDefaults === \"empty\" ? ` || ${childData} === null || ${childData} === \"\"` : \"\")\n gen.if(condition, (0, codegen_1._) `${childData} = ${(0, codegen_1.stringify)(defaultValue)}`);\n}\n//# sourceMappingURL=defaults.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateUnion = exports.validateArray = exports.usePattern = exports.callValidateCode = exports.schemaProperties = exports.allSchemaProperties = exports.noPropertyInData = exports.propertyInData = exports.isOwnProperty = exports.hasPropFunc = exports.reportMissingProp = exports.checkMissingProp = exports.checkReportMissingProp = void 0;\nconst codegen_1 = require(\"../compile/codegen\");\nconst util_1 = require(\"../compile/util\");\nconst names_1 = require(\"../compile/names\");\nconst util_2 = require(\"../compile/util\");\nfunction checkReportMissingProp(cxt, prop) {\n const { gen, data, it } = cxt;\n gen.if(noPropertyInData(gen, data, prop, it.opts.ownProperties), () => {\n cxt.setParams({ missingProperty: (0, codegen_1._) `${prop}` }, true);\n cxt.error();\n });\n}\nexports.checkReportMissingProp = checkReportMissingProp;\nfunction checkMissingProp({ gen, data, it: { opts } }, properties, missing) {\n return (0, codegen_1.or)(...properties.map((prop) => (0, codegen_1.and)(noPropertyInData(gen, data, prop, opts.ownProperties), (0, codegen_1._) `${missing} = ${prop}`)));\n}\nexports.checkMissingProp = checkMissingProp;\nfunction reportMissingProp(cxt, missing) {\n cxt.setParams({ missingProperty: missing }, true);\n cxt.error();\n}\nexports.reportMissingProp = reportMissingProp;\nfunction hasPropFunc(gen) {\n return gen.scopeValue(\"func\", {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n ref: Object.prototype.hasOwnProperty,\n code: (0, codegen_1._) `Object.prototype.hasOwnProperty`,\n });\n}\nexports.hasPropFunc = hasPropFunc;\nfunction isOwnProperty(gen, data, property) {\n return (0, codegen_1._) `${hasPropFunc(gen)}.call(${data}, ${property})`;\n}\nexports.isOwnProperty = isOwnProperty;\nfunction propertyInData(gen, data, property, ownProperties) {\n const cond = (0, codegen_1._) `${data}${(0, codegen_1.getProperty)(property)} !== undefined`;\n return ownProperties ? (0, codegen_1._) `${cond} && ${isOwnProperty(gen, data, property)}` : cond;\n}\nexports.propertyInData = propertyInData;\nfunction noPropertyInData(gen, data, property, ownProperties) {\n const cond = (0, codegen_1._) `${data}${(0, codegen_1.getProperty)(property)} === undefined`;\n return ownProperties ? (0, codegen_1.or)(cond, (0, codegen_1.not)(isOwnProperty(gen, data, property))) : cond;\n}\nexports.noPropertyInData = noPropertyInData;\nfunction allSchemaProperties(schemaMap) {\n return schemaMap ? Object.keys(schemaMap).filter((p) => p !== \"__proto__\") : [];\n}\nexports.allSchemaProperties = allSchemaProperties;\nfunction schemaProperties(it, schemaMap) {\n return allSchemaProperties(schemaMap).filter((p) => !(0, util_1.alwaysValidSchema)(it, schemaMap[p]));\n}\nexports.schemaProperties = schemaProperties;\nfunction callValidateCode({ schemaCode, data, it: { gen, topSchemaRef, schemaPath, errorPath }, it }, func, context, passSchema) {\n const dataAndSchema = passSchema ? (0, codegen_1._) `${schemaCode}, ${data}, ${topSchemaRef}${schemaPath}` : data;\n const valCxt = [\n [names_1.default.instancePath, (0, codegen_1.strConcat)(names_1.default.instancePath, errorPath)],\n [names_1.default.parentData, it.parentData],\n [names_1.default.parentDataProperty, it.parentDataProperty],\n [names_1.default.rootData, names_1.default.rootData],\n ];\n if (it.opts.dynamicRef)\n valCxt.push([names_1.default.dynamicAnchors, names_1.default.dynamicAnchors]);\n const args = (0, codegen_1._) `${dataAndSchema}, ${gen.object(...valCxt)}`;\n return context !== codegen_1.nil ? (0, codegen_1._) `${func}.call(${context}, ${args})` : (0, codegen_1._) `${func}(${args})`;\n}\nexports.callValidateCode = callValidateCode;\nconst newRegExp = (0, codegen_1._) `new RegExp`;\nfunction usePattern({ gen, it: { opts } }, pattern) {\n const u = opts.unicodeRegExp ? \"u\" : \"\";\n const { regExp } = opts.code;\n const rx = regExp(pattern, u);\n return gen.scopeValue(\"pattern\", {\n key: rx.toString(),\n ref: rx,\n code: (0, codegen_1._) `${regExp.code === \"new RegExp\" ? newRegExp : (0, util_2.useFunc)(gen, regExp)}(${pattern}, ${u})`,\n });\n}\nexports.usePattern = usePattern;\nfunction validateArray(cxt) {\n const { gen, data, keyword, it } = cxt;\n const valid = gen.name(\"valid\");\n if (it.allErrors) {\n const validArr = gen.let(\"valid\", true);\n validateItems(() => gen.assign(validArr, false));\n return validArr;\n }\n gen.var(valid, true);\n validateItems(() => gen.break());\n return valid;\n function validateItems(notValid) {\n const len = gen.const(\"len\", (0, codegen_1._) `${data}.length`);\n gen.forRange(\"i\", 0, len, (i) => {\n cxt.subschema({\n keyword,\n dataProp: i,\n dataPropType: util_1.Type.Num,\n }, valid);\n gen.if((0, codegen_1.not)(valid), notValid);\n });\n }\n}\nexports.validateArray = validateArray;\nfunction validateUnion(cxt) {\n const { gen, schema, keyword, it } = cxt;\n /* istanbul ignore if */\n if (!Array.isArray(schema))\n throw new Error(\"ajv implementation error\");\n const alwaysValid = schema.some((sch) => (0, util_1.alwaysValidSchema)(it, sch));\n if (alwaysValid && !it.opts.unevaluated)\n return;\n const valid = gen.let(\"valid\", false);\n const schValid = gen.name(\"_valid\");\n gen.block(() => schema.forEach((_sch, i) => {\n const schCxt = cxt.subschema({\n keyword,\n schemaProp: i,\n compositeRule: true,\n }, schValid);\n gen.assign(valid, (0, codegen_1._) `${valid} || ${schValid}`);\n const merged = cxt.mergeValidEvaluated(schCxt, schValid);\n // can short-circuit if `unevaluatedProperties/Items` not supported (opts.unevaluated !== true)\n // or if all properties and items were evaluated (it.props === true && it.items === true)\n if (!merged)\n gen.if((0, codegen_1.not)(valid));\n }));\n cxt.result(valid, () => cxt.reset(), () => cxt.error(true));\n}\nexports.validateUnion = validateUnion;\n//# sourceMappingURL=code.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateKeywordUsage = exports.validSchemaType = exports.funcKeywordCode = exports.macroKeywordCode = void 0;\nconst codegen_1 = require(\"../codegen\");\nconst names_1 = require(\"../names\");\nconst code_1 = require(\"../../vocabularies/code\");\nconst errors_1 = require(\"../errors\");\nfunction macroKeywordCode(cxt, def) {\n const { gen, keyword, schema, parentSchema, it } = cxt;\n const macroSchema = def.macro.call(it.self, schema, parentSchema, it);\n const schemaRef = useKeyword(gen, keyword, macroSchema);\n if (it.opts.validateSchema !== false)\n it.self.validateSchema(macroSchema, true);\n const valid = gen.name(\"valid\");\n cxt.subschema({\n schema: macroSchema,\n schemaPath: codegen_1.nil,\n errSchemaPath: `${it.errSchemaPath}/${keyword}`,\n topSchemaRef: schemaRef,\n compositeRule: true,\n }, valid);\n cxt.pass(valid, () => cxt.error(true));\n}\nexports.macroKeywordCode = macroKeywordCode;\nfunction funcKeywordCode(cxt, def) {\n var _a;\n const { gen, keyword, schema, parentSchema, $data, it } = cxt;\n checkAsyncKeyword(it, def);\n const validate = !$data && def.compile ? def.compile.call(it.self, schema, parentSchema, it) : def.validate;\n const validateRef = useKeyword(gen, keyword, validate);\n const valid = gen.let(\"valid\");\n cxt.block$data(valid, validateKeyword);\n cxt.ok((_a = def.valid) !== null && _a !== void 0 ? _a : valid);\n function validateKeyword() {\n if (def.errors === false) {\n assignValid();\n if (def.modifying)\n modifyData(cxt);\n reportErrs(() => cxt.error());\n }\n else {\n const ruleErrs = def.async ? validateAsync() : validateSync();\n if (def.modifying)\n modifyData(cxt);\n reportErrs(() => addErrs(cxt, ruleErrs));\n }\n }\n function validateAsync() {\n const ruleErrs = gen.let(\"ruleErrs\", null);\n gen.try(() => assignValid((0, codegen_1._) `await `), (e) => gen.assign(valid, false).if((0, codegen_1._) `${e} instanceof ${it.ValidationError}`, () => gen.assign(ruleErrs, (0, codegen_1._) `${e}.errors`), () => gen.throw(e)));\n return ruleErrs;\n }\n function validateSync() {\n const validateErrs = (0, codegen_1._) `${validateRef}.errors`;\n gen.assign(validateErrs, null);\n assignValid(codegen_1.nil);\n return validateErrs;\n }\n function assignValid(_await = def.async ? (0, codegen_1._) `await ` : codegen_1.nil) {\n const passCxt = it.opts.passContext ? names_1.default.this : names_1.default.self;\n const passSchema = !((\"compile\" in def && !$data) || def.schema === false);\n gen.assign(valid, (0, codegen_1._) `${_await}${(0, code_1.callValidateCode)(cxt, validateRef, passCxt, passSchema)}`, def.modifying);\n }\n function reportErrs(errors) {\n var _a;\n gen.if((0, codegen_1.not)((_a = def.valid) !== null && _a !== void 0 ? _a : valid), errors);\n }\n}\nexports.funcKeywordCode = funcKeywordCode;\nfunction modifyData(cxt) {\n const { gen, data, it } = cxt;\n gen.if(it.parentData, () => gen.assign(data, (0, codegen_1._) `${it.parentData}[${it.parentDataProperty}]`));\n}\nfunction addErrs(cxt, errs) {\n const { gen } = cxt;\n gen.if((0, codegen_1._) `Array.isArray(${errs})`, () => {\n gen\n .assign(names_1.default.vErrors, (0, codegen_1._) `${names_1.default.vErrors} === null ? ${errs} : ${names_1.default.vErrors}.concat(${errs})`)\n .assign(names_1.default.errors, (0, codegen_1._) `${names_1.default.vErrors}.length`);\n (0, errors_1.extendErrors)(cxt);\n }, () => cxt.error());\n}\nfunction checkAsyncKeyword({ schemaEnv }, def) {\n if (def.async && !schemaEnv.$async)\n throw new Error(\"async keyword in sync schema\");\n}\nfunction useKeyword(gen, keyword, result) {\n if (result === undefined)\n throw new Error(`keyword \"${keyword}\" failed to compile`);\n return gen.scopeValue(\"keyword\", typeof result == \"function\" ? { ref: result } : { ref: result, code: (0, codegen_1.stringify)(result) });\n}\nfunction validSchemaType(schema, schemaType, allowUndefined = false) {\n // TODO add tests\n return (!schemaType.length ||\n schemaType.some((st) => st === \"array\"\n ? Array.isArray(schema)\n : st === \"object\"\n ? schema && typeof schema == \"object\" && !Array.isArray(schema)\n : typeof schema == st || (allowUndefined && typeof schema == \"undefined\")));\n}\nexports.validSchemaType = validSchemaType;\nfunction validateKeywordUsage({ schema, opts, self, errSchemaPath }, def, keyword) {\n /* istanbul ignore if */\n if (Array.isArray(def.keyword) ? !def.keyword.includes(keyword) : def.keyword !== keyword) {\n throw new Error(\"ajv implementation error\");\n }\n const deps = def.dependencies;\n if (deps === null || deps === void 0 ? void 0 : deps.some((kwd) => !Object.prototype.hasOwnProperty.call(schema, kwd))) {\n throw new Error(`parent schema must have dependencies of ${keyword}: ${deps.join(\",\")}`);\n }\n if (def.validateSchema) {\n const valid = def.validateSchema(schema[keyword]);\n if (!valid) {\n const msg = `keyword \"${keyword}\" value is invalid at path \"${errSchemaPath}\": ` +\n self.errorsText(def.validateSchema.errors);\n if (opts.validateSchema === \"log\")\n self.logger.error(msg);\n else\n throw new Error(msg);\n }\n }\n}\nexports.validateKeywordUsage = validateKeywordUsage;\n//# sourceMappingURL=keyword.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.extendSubschemaMode = exports.extendSubschemaData = exports.getSubschema = void 0;\nconst codegen_1 = require(\"../codegen\");\nconst util_1 = require(\"../util\");\nfunction getSubschema(it, { keyword, schemaProp, schema, schemaPath, errSchemaPath, topSchemaRef }) {\n if (keyword !== undefined && schema !== undefined) {\n throw new Error('both \"keyword\" and \"schema\" passed, only one allowed');\n }\n if (keyword !== undefined) {\n const sch = it.schema[keyword];\n return schemaProp === undefined\n ? {\n schema: sch,\n schemaPath: (0, codegen_1._) `${it.schemaPath}${(0, codegen_1.getProperty)(keyword)}`,\n errSchemaPath: `${it.errSchemaPath}/${keyword}`,\n }\n : {\n schema: sch[schemaProp],\n schemaPath: (0, codegen_1._) `${it.schemaPath}${(0, codegen_1.getProperty)(keyword)}${(0, codegen_1.getProperty)(schemaProp)}`,\n errSchemaPath: `${it.errSchemaPath}/${keyword}/${(0, util_1.escapeFragment)(schemaProp)}`,\n };\n }\n if (schema !== undefined) {\n if (schemaPath === undefined || errSchemaPath === undefined || topSchemaRef === undefined) {\n throw new Error('\"schemaPath\", \"errSchemaPath\" and \"topSchemaRef\" are required with \"schema\"');\n }\n return {\n schema,\n schemaPath,\n topSchemaRef,\n errSchemaPath,\n };\n }\n throw new Error('either \"keyword\" or \"schema\" must be passed');\n}\nexports.getSubschema = getSubschema;\nfunction extendSubschemaData(subschema, it, { dataProp, dataPropType: dpType, data, dataTypes, propertyName }) {\n if (data !== undefined && dataProp !== undefined) {\n throw new Error('both \"data\" and \"dataProp\" passed, only one allowed');\n }\n const { gen } = it;\n if (dataProp !== undefined) {\n const { errorPath, dataPathArr, opts } = it;\n const nextData = gen.let(\"data\", (0, codegen_1._) `${it.data}${(0, codegen_1.getProperty)(dataProp)}`, true);\n dataContextProps(nextData);\n subschema.errorPath = (0, codegen_1.str) `${errorPath}${(0, util_1.getErrorPath)(dataProp, dpType, opts.jsPropertySyntax)}`;\n subschema.parentDataProperty = (0, codegen_1._) `${dataProp}`;\n subschema.dataPathArr = [...dataPathArr, subschema.parentDataProperty];\n }\n if (data !== undefined) {\n const nextData = data instanceof codegen_1.Name ? data : gen.let(\"data\", data, true); // replaceable if used once?\n dataContextProps(nextData);\n if (propertyName !== undefined)\n subschema.propertyName = propertyName;\n // TODO something is possibly wrong here with not changing parentDataProperty and not appending dataPathArr\n }\n if (dataTypes)\n subschema.dataTypes = dataTypes;\n function dataContextProps(_nextData) {\n subschema.data = _nextData;\n subschema.dataLevel = it.dataLevel + 1;\n subschema.dataTypes = [];\n it.definedProperties = new Set();\n subschema.parentData = it.data;\n subschema.dataNames = [...it.dataNames, _nextData];\n }\n}\nexports.extendSubschemaData = extendSubschemaData;\nfunction extendSubschemaMode(subschema, { jtdDiscriminator, jtdMetadata, compositeRule, createErrors, allErrors }) {\n if (compositeRule !== undefined)\n subschema.compositeRule = compositeRule;\n if (createErrors !== undefined)\n subschema.createErrors = createErrors;\n if (allErrors !== undefined)\n subschema.allErrors = allErrors;\n subschema.jtdDiscriminator = jtdDiscriminator; // not inherited\n subschema.jtdMetadata = jtdMetadata; // not inherited\n}\nexports.extendSubschemaMode = extendSubschemaMode;\n//# sourceMappingURL=subschema.js.map","'use strict';\n\nvar traverse = module.exports = function (schema, opts, cb) {\n // Legacy support for v0.3.1 and earlier.\n if (typeof opts == 'function') {\n cb = opts;\n opts = {};\n }\n\n cb = opts.cb || cb;\n var pre = (typeof cb == 'function') ? cb : cb.pre || function() {};\n var post = cb.post || function() {};\n\n _traverse(opts, pre, post, schema, '', schema);\n};\n\n\ntraverse.keywords = {\n additionalItems: true,\n items: true,\n contains: true,\n additionalProperties: true,\n propertyNames: true,\n not: true,\n if: true,\n then: true,\n else: true\n};\n\ntraverse.arrayKeywords = {\n items: true,\n allOf: true,\n anyOf: true,\n oneOf: true\n};\n\ntraverse.propsKeywords = {\n $defs: true,\n definitions: true,\n properties: true,\n patternProperties: true,\n dependencies: true\n};\n\ntraverse.skipKeywords = {\n default: true,\n enum: true,\n const: true,\n required: true,\n maximum: true,\n minimum: true,\n exclusiveMaximum: true,\n exclusiveMinimum: true,\n multipleOf: true,\n maxLength: true,\n minLength: true,\n pattern: true,\n format: true,\n maxItems: true,\n minItems: true,\n uniqueItems: true,\n maxProperties: true,\n minProperties: true\n};\n\n\nfunction _traverse(opts, pre, post, schema, jsonPtr, rootSchema, parentJsonPtr, parentKeyword, parentSchema, keyIndex) {\n if (schema && typeof schema == 'object' && !Array.isArray(schema)) {\n pre(schema, jsonPtr, rootSchema, parentJsonPtr, parentKeyword, parentSchema, keyIndex);\n for (var key in schema) {\n var sch = schema[key];\n if (Array.isArray(sch)) {\n if (key in traverse.arrayKeywords) {\n for (var i=0; i (count += countKeys(sch)));\n }\n if (count === Infinity)\n return Infinity;\n }\n return count;\n}\nfunction getFullPath(resolver, id = \"\", normalize) {\n if (normalize !== false)\n id = normalizeId(id);\n const p = resolver.parse(id);\n return _getFullPath(resolver, p);\n}\nexports.getFullPath = getFullPath;\nfunction _getFullPath(resolver, p) {\n const serialized = resolver.serialize(p);\n return serialized.split(\"#\")[0] + \"#\";\n}\nexports._getFullPath = _getFullPath;\nconst TRAILING_SLASH_HASH = /#\\/?$/;\nfunction normalizeId(id) {\n return id ? id.replace(TRAILING_SLASH_HASH, \"\") : \"\";\n}\nexports.normalizeId = normalizeId;\nfunction resolveUrl(resolver, baseId, id) {\n id = normalizeId(id);\n return resolver.resolve(baseId, id);\n}\nexports.resolveUrl = resolveUrl;\nconst ANCHOR = /^[a-z_][-a-z0-9._]*$/i;\nfunction getSchemaRefs(schema, baseId) {\n if (typeof schema == \"boolean\")\n return {};\n const { schemaId, uriResolver } = this.opts;\n const schId = normalizeId(schema[schemaId] || baseId);\n const baseIds = { \"\": schId };\n const pathPrefix = getFullPath(uriResolver, schId, false);\n const localRefs = {};\n const schemaRefs = new Set();\n traverse(schema, { allKeys: true }, (sch, jsonPtr, _, parentJsonPtr) => {\n if (parentJsonPtr === undefined)\n return;\n const fullPath = pathPrefix + jsonPtr;\n let baseId = baseIds[parentJsonPtr];\n if (typeof sch[schemaId] == \"string\")\n baseId = addRef.call(this, sch[schemaId]);\n addAnchor.call(this, sch.$anchor);\n addAnchor.call(this, sch.$dynamicAnchor);\n baseIds[jsonPtr] = baseId;\n function addRef(ref) {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n const _resolve = this.opts.uriResolver.resolve;\n ref = normalizeId(baseId ? _resolve(baseId, ref) : ref);\n if (schemaRefs.has(ref))\n throw ambiguos(ref);\n schemaRefs.add(ref);\n let schOrRef = this.refs[ref];\n if (typeof schOrRef == \"string\")\n schOrRef = this.refs[schOrRef];\n if (typeof schOrRef == \"object\") {\n checkAmbiguosRef(sch, schOrRef.schema, ref);\n }\n else if (ref !== normalizeId(fullPath)) {\n if (ref[0] === \"#\") {\n checkAmbiguosRef(sch, localRefs[ref], ref);\n localRefs[ref] = sch;\n }\n else {\n this.refs[ref] = fullPath;\n }\n }\n return ref;\n }\n function addAnchor(anchor) {\n if (typeof anchor == \"string\") {\n if (!ANCHOR.test(anchor))\n throw new Error(`invalid anchor \"${anchor}\"`);\n addRef.call(this, `#${anchor}`);\n }\n }\n });\n return localRefs;\n function checkAmbiguosRef(sch1, sch2, ref) {\n if (sch2 !== undefined && !equal(sch1, sch2))\n throw ambiguos(ref);\n }\n function ambiguos(ref) {\n return new Error(`reference \"${ref}\" resolves to more than one schema`);\n }\n}\nexports.getSchemaRefs = getSchemaRefs;\n//# sourceMappingURL=resolve.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getData = exports.KeywordCxt = exports.validateFunctionCode = void 0;\nconst boolSchema_1 = require(\"./boolSchema\");\nconst dataType_1 = require(\"./dataType\");\nconst applicability_1 = require(\"./applicability\");\nconst dataType_2 = require(\"./dataType\");\nconst defaults_1 = require(\"./defaults\");\nconst keyword_1 = require(\"./keyword\");\nconst subschema_1 = require(\"./subschema\");\nconst codegen_1 = require(\"../codegen\");\nconst names_1 = require(\"../names\");\nconst resolve_1 = require(\"../resolve\");\nconst util_1 = require(\"../util\");\nconst errors_1 = require(\"../errors\");\n// schema compilation - generates validation function, subschemaCode (below) is used for subschemas\nfunction validateFunctionCode(it) {\n if (isSchemaObj(it)) {\n checkKeywords(it);\n if (schemaCxtHasRules(it)) {\n topSchemaObjCode(it);\n return;\n }\n }\n validateFunction(it, () => (0, boolSchema_1.topBoolOrEmptySchema)(it));\n}\nexports.validateFunctionCode = validateFunctionCode;\nfunction validateFunction({ gen, validateName, schema, schemaEnv, opts }, body) {\n if (opts.code.es5) {\n gen.func(validateName, (0, codegen_1._) `${names_1.default.data}, ${names_1.default.valCxt}`, schemaEnv.$async, () => {\n gen.code((0, codegen_1._) `\"use strict\"; ${funcSourceUrl(schema, opts)}`);\n destructureValCxtES5(gen, opts);\n gen.code(body);\n });\n }\n else {\n gen.func(validateName, (0, codegen_1._) `${names_1.default.data}, ${destructureValCxt(opts)}`, schemaEnv.$async, () => gen.code(funcSourceUrl(schema, opts)).code(body));\n }\n}\nfunction destructureValCxt(opts) {\n return (0, codegen_1._) `{${names_1.default.instancePath}=\"\", ${names_1.default.parentData}, ${names_1.default.parentDataProperty}, ${names_1.default.rootData}=${names_1.default.data}${opts.dynamicRef ? (0, codegen_1._) `, ${names_1.default.dynamicAnchors}={}` : codegen_1.nil}}={}`;\n}\nfunction destructureValCxtES5(gen, opts) {\n gen.if(names_1.default.valCxt, () => {\n gen.var(names_1.default.instancePath, (0, codegen_1._) `${names_1.default.valCxt}.${names_1.default.instancePath}`);\n gen.var(names_1.default.parentData, (0, codegen_1._) `${names_1.default.valCxt}.${names_1.default.parentData}`);\n gen.var(names_1.default.parentDataProperty, (0, codegen_1._) `${names_1.default.valCxt}.${names_1.default.parentDataProperty}`);\n gen.var(names_1.default.rootData, (0, codegen_1._) `${names_1.default.valCxt}.${names_1.default.rootData}`);\n if (opts.dynamicRef)\n gen.var(names_1.default.dynamicAnchors, (0, codegen_1._) `${names_1.default.valCxt}.${names_1.default.dynamicAnchors}`);\n }, () => {\n gen.var(names_1.default.instancePath, (0, codegen_1._) `\"\"`);\n gen.var(names_1.default.parentData, (0, codegen_1._) `undefined`);\n gen.var(names_1.default.parentDataProperty, (0, codegen_1._) `undefined`);\n gen.var(names_1.default.rootData, names_1.default.data);\n if (opts.dynamicRef)\n gen.var(names_1.default.dynamicAnchors, (0, codegen_1._) `{}`);\n });\n}\nfunction topSchemaObjCode(it) {\n const { schema, opts, gen } = it;\n validateFunction(it, () => {\n if (opts.$comment && schema.$comment)\n commentKeyword(it);\n checkNoDefault(it);\n gen.let(names_1.default.vErrors, null);\n gen.let(names_1.default.errors, 0);\n if (opts.unevaluated)\n resetEvaluated(it);\n typeAndKeywords(it);\n returnResults(it);\n });\n return;\n}\nfunction resetEvaluated(it) {\n // TODO maybe some hook to execute it in the end to check whether props/items are Name, as in assignEvaluated\n const { gen, validateName } = it;\n it.evaluated = gen.const(\"evaluated\", (0, codegen_1._) `${validateName}.evaluated`);\n gen.if((0, codegen_1._) `${it.evaluated}.dynamicProps`, () => gen.assign((0, codegen_1._) `${it.evaluated}.props`, (0, codegen_1._) `undefined`));\n gen.if((0, codegen_1._) `${it.evaluated}.dynamicItems`, () => gen.assign((0, codegen_1._) `${it.evaluated}.items`, (0, codegen_1._) `undefined`));\n}\nfunction funcSourceUrl(schema, opts) {\n const schId = typeof schema == \"object\" && schema[opts.schemaId];\n return schId && (opts.code.source || opts.code.process) ? (0, codegen_1._) `/*# sourceURL=${schId} */` : codegen_1.nil;\n}\n// schema compilation - this function is used recursively to generate code for sub-schemas\nfunction subschemaCode(it, valid) {\n if (isSchemaObj(it)) {\n checkKeywords(it);\n if (schemaCxtHasRules(it)) {\n subSchemaObjCode(it, valid);\n return;\n }\n }\n (0, boolSchema_1.boolOrEmptySchema)(it, valid);\n}\nfunction schemaCxtHasRules({ schema, self }) {\n if (typeof schema == \"boolean\")\n return !schema;\n for (const key in schema)\n if (self.RULES.all[key])\n return true;\n return false;\n}\nfunction isSchemaObj(it) {\n return typeof it.schema != \"boolean\";\n}\nfunction subSchemaObjCode(it, valid) {\n const { schema, gen, opts } = it;\n if (opts.$comment && schema.$comment)\n commentKeyword(it);\n updateContext(it);\n checkAsyncSchema(it);\n const errsCount = gen.const(\"_errs\", names_1.default.errors);\n typeAndKeywords(it, errsCount);\n // TODO var\n gen.var(valid, (0, codegen_1._) `${errsCount} === ${names_1.default.errors}`);\n}\nfunction checkKeywords(it) {\n (0, util_1.checkUnknownRules)(it);\n checkRefsAndKeywords(it);\n}\nfunction typeAndKeywords(it, errsCount) {\n if (it.opts.jtd)\n return schemaKeywords(it, [], false, errsCount);\n const types = (0, dataType_1.getSchemaTypes)(it.schema);\n const checkedTypes = (0, dataType_1.coerceAndCheckDataType)(it, types);\n schemaKeywords(it, types, !checkedTypes, errsCount);\n}\nfunction checkRefsAndKeywords(it) {\n const { schema, errSchemaPath, opts, self } = it;\n if (schema.$ref && opts.ignoreKeywordsWithRef && (0, util_1.schemaHasRulesButRef)(schema, self.RULES)) {\n self.logger.warn(`$ref: keywords ignored in schema at path \"${errSchemaPath}\"`);\n }\n}\nfunction checkNoDefault(it) {\n const { schema, opts } = it;\n if (schema.default !== undefined && opts.useDefaults && opts.strictSchema) {\n (0, util_1.checkStrictMode)(it, \"default is ignored in the schema root\");\n }\n}\nfunction updateContext(it) {\n const schId = it.schema[it.opts.schemaId];\n if (schId)\n it.baseId = (0, resolve_1.resolveUrl)(it.opts.uriResolver, it.baseId, schId);\n}\nfunction checkAsyncSchema(it) {\n if (it.schema.$async && !it.schemaEnv.$async)\n throw new Error(\"async schema in sync schema\");\n}\nfunction commentKeyword({ gen, schemaEnv, schema, errSchemaPath, opts }) {\n const msg = schema.$comment;\n if (opts.$comment === true) {\n gen.code((0, codegen_1._) `${names_1.default.self}.logger.log(${msg})`);\n }\n else if (typeof opts.$comment == \"function\") {\n const schemaPath = (0, codegen_1.str) `${errSchemaPath}/$comment`;\n const rootName = gen.scopeValue(\"root\", { ref: schemaEnv.root });\n gen.code((0, codegen_1._) `${names_1.default.self}.opts.$comment(${msg}, ${schemaPath}, ${rootName}.schema)`);\n }\n}\nfunction returnResults(it) {\n const { gen, schemaEnv, validateName, ValidationError, opts } = it;\n if (schemaEnv.$async) {\n // TODO assign unevaluated\n gen.if((0, codegen_1._) `${names_1.default.errors} === 0`, () => gen.return(names_1.default.data), () => gen.throw((0, codegen_1._) `new ${ValidationError}(${names_1.default.vErrors})`));\n }\n else {\n gen.assign((0, codegen_1._) `${validateName}.errors`, names_1.default.vErrors);\n if (opts.unevaluated)\n assignEvaluated(it);\n gen.return((0, codegen_1._) `${names_1.default.errors} === 0`);\n }\n}\nfunction assignEvaluated({ gen, evaluated, props, items }) {\n if (props instanceof codegen_1.Name)\n gen.assign((0, codegen_1._) `${evaluated}.props`, props);\n if (items instanceof codegen_1.Name)\n gen.assign((0, codegen_1._) `${evaluated}.items`, items);\n}\nfunction schemaKeywords(it, types, typeErrors, errsCount) {\n const { gen, schema, data, allErrors, opts, self } = it;\n const { RULES } = self;\n if (schema.$ref && (opts.ignoreKeywordsWithRef || !(0, util_1.schemaHasRulesButRef)(schema, RULES))) {\n gen.block(() => keywordCode(it, \"$ref\", RULES.all.$ref.definition)); // TODO typecast\n return;\n }\n if (!opts.jtd)\n checkStrictTypes(it, types);\n gen.block(() => {\n for (const group of RULES.rules)\n groupKeywords(group);\n groupKeywords(RULES.post);\n });\n function groupKeywords(group) {\n if (!(0, applicability_1.shouldUseGroup)(schema, group))\n return;\n if (group.type) {\n gen.if((0, dataType_2.checkDataType)(group.type, data, opts.strictNumbers));\n iterateKeywords(it, group);\n if (types.length === 1 && types[0] === group.type && typeErrors) {\n gen.else();\n (0, dataType_2.reportTypeError)(it);\n }\n gen.endIf();\n }\n else {\n iterateKeywords(it, group);\n }\n // TODO make it \"ok\" call?\n if (!allErrors)\n gen.if((0, codegen_1._) `${names_1.default.errors} === ${errsCount || 0}`);\n }\n}\nfunction iterateKeywords(it, group) {\n const { gen, schema, opts: { useDefaults }, } = it;\n if (useDefaults)\n (0, defaults_1.assignDefaults)(it, group.type);\n gen.block(() => {\n for (const rule of group.rules) {\n if ((0, applicability_1.shouldUseRule)(schema, rule)) {\n keywordCode(it, rule.keyword, rule.definition, group.type);\n }\n }\n });\n}\nfunction checkStrictTypes(it, types) {\n if (it.schemaEnv.meta || !it.opts.strictTypes)\n return;\n checkContextTypes(it, types);\n if (!it.opts.allowUnionTypes)\n checkMultipleTypes(it, types);\n checkKeywordTypes(it, it.dataTypes);\n}\nfunction checkContextTypes(it, types) {\n if (!types.length)\n return;\n if (!it.dataTypes.length) {\n it.dataTypes = types;\n return;\n }\n types.forEach((t) => {\n if (!includesType(it.dataTypes, t)) {\n strictTypesError(it, `type \"${t}\" not allowed by context \"${it.dataTypes.join(\",\")}\"`);\n }\n });\n it.dataTypes = it.dataTypes.filter((t) => includesType(types, t));\n}\nfunction checkMultipleTypes(it, ts) {\n if (ts.length > 1 && !(ts.length === 2 && ts.includes(\"null\"))) {\n strictTypesError(it, \"use allowUnionTypes to allow union type keyword\");\n }\n}\nfunction checkKeywordTypes(it, ts) {\n const rules = it.self.RULES.all;\n for (const keyword in rules) {\n const rule = rules[keyword];\n if (typeof rule == \"object\" && (0, applicability_1.shouldUseRule)(it.schema, rule)) {\n const { type } = rule.definition;\n if (type.length && !type.some((t) => hasApplicableType(ts, t))) {\n strictTypesError(it, `missing type \"${type.join(\",\")}\" for keyword \"${keyword}\"`);\n }\n }\n }\n}\nfunction hasApplicableType(schTs, kwdT) {\n return schTs.includes(kwdT) || (kwdT === \"number\" && schTs.includes(\"integer\"));\n}\nfunction includesType(ts, t) {\n return ts.includes(t) || (t === \"integer\" && ts.includes(\"number\"));\n}\nfunction strictTypesError(it, msg) {\n const schemaPath = it.schemaEnv.baseId + it.errSchemaPath;\n msg += ` at \"${schemaPath}\" (strictTypes)`;\n (0, util_1.checkStrictMode)(it, msg, it.opts.strictTypes);\n}\nclass KeywordCxt {\n constructor(it, def, keyword) {\n (0, keyword_1.validateKeywordUsage)(it, def, keyword);\n this.gen = it.gen;\n this.allErrors = it.allErrors;\n this.keyword = keyword;\n this.data = it.data;\n this.schema = it.schema[keyword];\n this.$data = def.$data && it.opts.$data && this.schema && this.schema.$data;\n this.schemaValue = (0, util_1.schemaRefOrVal)(it, this.schema, keyword, this.$data);\n this.schemaType = def.schemaType;\n this.parentSchema = it.schema;\n this.params = {};\n this.it = it;\n this.def = def;\n if (this.$data) {\n this.schemaCode = it.gen.const(\"vSchema\", getData(this.$data, it));\n }\n else {\n this.schemaCode = this.schemaValue;\n if (!(0, keyword_1.validSchemaType)(this.schema, def.schemaType, def.allowUndefined)) {\n throw new Error(`${keyword} value must be ${JSON.stringify(def.schemaType)}`);\n }\n }\n if (\"code\" in def ? def.trackErrors : def.errors !== false) {\n this.errsCount = it.gen.const(\"_errs\", names_1.default.errors);\n }\n }\n result(condition, successAction, failAction) {\n this.failResult((0, codegen_1.not)(condition), successAction, failAction);\n }\n failResult(condition, successAction, failAction) {\n this.gen.if(condition);\n if (failAction)\n failAction();\n else\n this.error();\n if (successAction) {\n this.gen.else();\n successAction();\n if (this.allErrors)\n this.gen.endIf();\n }\n else {\n if (this.allErrors)\n this.gen.endIf();\n else\n this.gen.else();\n }\n }\n pass(condition, failAction) {\n this.failResult((0, codegen_1.not)(condition), undefined, failAction);\n }\n fail(condition) {\n if (condition === undefined) {\n this.error();\n if (!this.allErrors)\n this.gen.if(false); // this branch will be removed by gen.optimize\n return;\n }\n this.gen.if(condition);\n this.error();\n if (this.allErrors)\n this.gen.endIf();\n else\n this.gen.else();\n }\n fail$data(condition) {\n if (!this.$data)\n return this.fail(condition);\n const { schemaCode } = this;\n this.fail((0, codegen_1._) `${schemaCode} !== undefined && (${(0, codegen_1.or)(this.invalid$data(), condition)})`);\n }\n error(append, errorParams, errorPaths) {\n if (errorParams) {\n this.setParams(errorParams);\n this._error(append, errorPaths);\n this.setParams({});\n return;\n }\n this._error(append, errorPaths);\n }\n _error(append, errorPaths) {\n ;\n (append ? errors_1.reportExtraError : errors_1.reportError)(this, this.def.error, errorPaths);\n }\n $dataError() {\n (0, errors_1.reportError)(this, this.def.$dataError || errors_1.keyword$DataError);\n }\n reset() {\n if (this.errsCount === undefined)\n throw new Error('add \"trackErrors\" to keyword definition');\n (0, errors_1.resetErrorsCount)(this.gen, this.errsCount);\n }\n ok(cond) {\n if (!this.allErrors)\n this.gen.if(cond);\n }\n setParams(obj, assign) {\n if (assign)\n Object.assign(this.params, obj);\n else\n this.params = obj;\n }\n block$data(valid, codeBlock, $dataValid = codegen_1.nil) {\n this.gen.block(() => {\n this.check$data(valid, $dataValid);\n codeBlock();\n });\n }\n check$data(valid = codegen_1.nil, $dataValid = codegen_1.nil) {\n if (!this.$data)\n return;\n const { gen, schemaCode, schemaType, def } = this;\n gen.if((0, codegen_1.or)((0, codegen_1._) `${schemaCode} === undefined`, $dataValid));\n if (valid !== codegen_1.nil)\n gen.assign(valid, true);\n if (schemaType.length || def.validateSchema) {\n gen.elseIf(this.invalid$data());\n this.$dataError();\n if (valid !== codegen_1.nil)\n gen.assign(valid, false);\n }\n gen.else();\n }\n invalid$data() {\n const { gen, schemaCode, schemaType, def, it } = this;\n return (0, codegen_1.or)(wrong$DataType(), invalid$DataSchema());\n function wrong$DataType() {\n if (schemaType.length) {\n /* istanbul ignore if */\n if (!(schemaCode instanceof codegen_1.Name))\n throw new Error(\"ajv implementation error\");\n const st = Array.isArray(schemaType) ? schemaType : [schemaType];\n return (0, codegen_1._) `${(0, dataType_2.checkDataTypes)(st, schemaCode, it.opts.strictNumbers, dataType_2.DataType.Wrong)}`;\n }\n return codegen_1.nil;\n }\n function invalid$DataSchema() {\n if (def.validateSchema) {\n const validateSchemaRef = gen.scopeValue(\"validate$data\", { ref: def.validateSchema }); // TODO value.code for standalone\n return (0, codegen_1._) `!${validateSchemaRef}(${schemaCode})`;\n }\n return codegen_1.nil;\n }\n }\n subschema(appl, valid) {\n const subschema = (0, subschema_1.getSubschema)(this.it, appl);\n (0, subschema_1.extendSubschemaData)(subschema, this.it, appl);\n (0, subschema_1.extendSubschemaMode)(subschema, appl);\n const nextContext = { ...this.it, ...subschema, items: undefined, props: undefined };\n subschemaCode(nextContext, valid);\n return nextContext;\n }\n mergeEvaluated(schemaCxt, toName) {\n const { it, gen } = this;\n if (!it.opts.unevaluated)\n return;\n if (it.props !== true && schemaCxt.props !== undefined) {\n it.props = util_1.mergeEvaluated.props(gen, schemaCxt.props, it.props, toName);\n }\n if (it.items !== true && schemaCxt.items !== undefined) {\n it.items = util_1.mergeEvaluated.items(gen, schemaCxt.items, it.items, toName);\n }\n }\n mergeValidEvaluated(schemaCxt, valid) {\n const { it, gen } = this;\n if (it.opts.unevaluated && (it.props !== true || it.items !== true)) {\n gen.if(valid, () => this.mergeEvaluated(schemaCxt, codegen_1.Name));\n return true;\n }\n }\n}\nexports.KeywordCxt = KeywordCxt;\nfunction keywordCode(it, keyword, def, ruleType) {\n const cxt = new KeywordCxt(it, def, keyword);\n if (\"code\" in def) {\n def.code(cxt, ruleType);\n }\n else if (cxt.$data && def.validate) {\n (0, keyword_1.funcKeywordCode)(cxt, def);\n }\n else if (\"macro\" in def) {\n (0, keyword_1.macroKeywordCode)(cxt, def);\n }\n else if (def.compile || def.validate) {\n (0, keyword_1.funcKeywordCode)(cxt, def);\n }\n}\nconst JSON_POINTER = /^\\/(?:[^~]|~0|~1)*$/;\nconst RELATIVE_JSON_POINTER = /^([0-9]+)(#|\\/(?:[^~]|~0|~1)*)?$/;\nfunction getData($data, { dataLevel, dataNames, dataPathArr }) {\n let jsonPointer;\n let data;\n if ($data === \"\")\n return names_1.default.rootData;\n if ($data[0] === \"/\") {\n if (!JSON_POINTER.test($data))\n throw new Error(`Invalid JSON-pointer: ${$data}`);\n jsonPointer = $data;\n data = names_1.default.rootData;\n }\n else {\n const matches = RELATIVE_JSON_POINTER.exec($data);\n if (!matches)\n throw new Error(`Invalid JSON-pointer: ${$data}`);\n const up = +matches[1];\n jsonPointer = matches[2];\n if (jsonPointer === \"#\") {\n if (up >= dataLevel)\n throw new Error(errorMsg(\"property/index\", up));\n return dataPathArr[dataLevel - up];\n }\n if (up > dataLevel)\n throw new Error(errorMsg(\"data\", up));\n data = dataNames[dataLevel - up];\n if (!jsonPointer)\n return data;\n }\n let expr = data;\n const segments = jsonPointer.split(\"/\");\n for (const segment of segments) {\n if (segment) {\n data = (0, codegen_1._) `${data}${(0, codegen_1.getProperty)((0, util_1.unescapeJsonPointer)(segment))}`;\n expr = (0, codegen_1._) `${expr} && ${data}`;\n }\n }\n return expr;\n function errorMsg(pointerType, up) {\n return `Cannot access ${pointerType} ${up} levels up, current level is ${dataLevel}`;\n }\n}\nexports.getData = getData;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nclass ValidationError extends Error {\n constructor(errors) {\n super(\"validation failed\");\n this.errors = errors;\n this.ajv = this.validation = true;\n }\n}\nexports.default = ValidationError;\n//# sourceMappingURL=validation_error.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst resolve_1 = require(\"./resolve\");\nclass MissingRefError extends Error {\n constructor(resolver, baseId, ref, msg) {\n super(msg || `can't resolve reference ${ref} from id ${baseId}`);\n this.missingRef = (0, resolve_1.resolveUrl)(resolver, baseId, ref);\n this.missingSchema = (0, resolve_1.normalizeId)((0, resolve_1.getFullPath)(resolver, this.missingRef));\n }\n}\nexports.default = MissingRefError;\n//# sourceMappingURL=ref_error.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.resolveSchema = exports.getCompilingSchema = exports.resolveRef = exports.compileSchema = exports.SchemaEnv = void 0;\nconst codegen_1 = require(\"./codegen\");\nconst validation_error_1 = require(\"../runtime/validation_error\");\nconst names_1 = require(\"./names\");\nconst resolve_1 = require(\"./resolve\");\nconst util_1 = require(\"./util\");\nconst validate_1 = require(\"./validate\");\nclass SchemaEnv {\n constructor(env) {\n var _a;\n this.refs = {};\n this.dynamicAnchors = {};\n let schema;\n if (typeof env.schema == \"object\")\n schema = env.schema;\n this.schema = env.schema;\n this.schemaId = env.schemaId;\n this.root = env.root || this;\n this.baseId = (_a = env.baseId) !== null && _a !== void 0 ? _a : (0, resolve_1.normalizeId)(schema === null || schema === void 0 ? void 0 : schema[env.schemaId || \"$id\"]);\n this.schemaPath = env.schemaPath;\n this.localRefs = env.localRefs;\n this.meta = env.meta;\n this.$async = schema === null || schema === void 0 ? void 0 : schema.$async;\n this.refs = {};\n }\n}\nexports.SchemaEnv = SchemaEnv;\n// let codeSize = 0\n// let nodeCount = 0\n// Compiles schema in SchemaEnv\nfunction compileSchema(sch) {\n // TODO refactor - remove compilations\n const _sch = getCompilingSchema.call(this, sch);\n if (_sch)\n return _sch;\n const rootId = (0, resolve_1.getFullPath)(this.opts.uriResolver, sch.root.baseId); // TODO if getFullPath removed 1 tests fails\n const { es5, lines } = this.opts.code;\n const { ownProperties } = this.opts;\n const gen = new codegen_1.CodeGen(this.scope, { es5, lines, ownProperties });\n let _ValidationError;\n if (sch.$async) {\n _ValidationError = gen.scopeValue(\"Error\", {\n ref: validation_error_1.default,\n code: (0, codegen_1._) `require(\"ajv/dist/runtime/validation_error\").default`,\n });\n }\n const validateName = gen.scopeName(\"validate\");\n sch.validateName = validateName;\n const schemaCxt = {\n gen,\n allErrors: this.opts.allErrors,\n data: names_1.default.data,\n parentData: names_1.default.parentData,\n parentDataProperty: names_1.default.parentDataProperty,\n dataNames: [names_1.default.data],\n dataPathArr: [codegen_1.nil],\n dataLevel: 0,\n dataTypes: [],\n definedProperties: new Set(),\n topSchemaRef: gen.scopeValue(\"schema\", this.opts.code.source === true\n ? { ref: sch.schema, code: (0, codegen_1.stringify)(sch.schema) }\n : { ref: sch.schema }),\n validateName,\n ValidationError: _ValidationError,\n schema: sch.schema,\n schemaEnv: sch,\n rootId,\n baseId: sch.baseId || rootId,\n schemaPath: codegen_1.nil,\n errSchemaPath: sch.schemaPath || (this.opts.jtd ? \"\" : \"#\"),\n errorPath: (0, codegen_1._) `\"\"`,\n opts: this.opts,\n self: this,\n };\n let sourceCode;\n try {\n this._compilations.add(sch);\n (0, validate_1.validateFunctionCode)(schemaCxt);\n gen.optimize(this.opts.code.optimize);\n // gen.optimize(1)\n const validateCode = gen.toString();\n sourceCode = `${gen.scopeRefs(names_1.default.scope)}return ${validateCode}`;\n // console.log((codeSize += sourceCode.length), (nodeCount += gen.nodeCount))\n if (this.opts.code.process)\n sourceCode = this.opts.code.process(sourceCode, sch);\n // console.log(\"\\n\\n\\n *** \\n\", sourceCode)\n const makeValidate = new Function(`${names_1.default.self}`, `${names_1.default.scope}`, sourceCode);\n const validate = makeValidate(this, this.scope.get());\n this.scope.value(validateName, { ref: validate });\n validate.errors = null;\n validate.schema = sch.schema;\n validate.schemaEnv = sch;\n if (sch.$async)\n validate.$async = true;\n if (this.opts.code.source === true) {\n validate.source = { validateName, validateCode, scopeValues: gen._values };\n }\n if (this.opts.unevaluated) {\n const { props, items } = schemaCxt;\n validate.evaluated = {\n props: props instanceof codegen_1.Name ? undefined : props,\n items: items instanceof codegen_1.Name ? undefined : items,\n dynamicProps: props instanceof codegen_1.Name,\n dynamicItems: items instanceof codegen_1.Name,\n };\n if (validate.source)\n validate.source.evaluated = (0, codegen_1.stringify)(validate.evaluated);\n }\n sch.validate = validate;\n return sch;\n }\n catch (e) {\n delete sch.validate;\n delete sch.validateName;\n if (sourceCode)\n this.logger.error(\"Error compiling schema, function code:\", sourceCode);\n // console.log(\"\\n\\n\\n *** \\n\", sourceCode, this.opts)\n throw e;\n }\n finally {\n this._compilations.delete(sch);\n }\n}\nexports.compileSchema = compileSchema;\nfunction resolveRef(root, baseId, ref) {\n var _a;\n ref = (0, resolve_1.resolveUrl)(this.opts.uriResolver, baseId, ref);\n const schOrFunc = root.refs[ref];\n if (schOrFunc)\n return schOrFunc;\n let _sch = resolve.call(this, root, ref);\n if (_sch === undefined) {\n const schema = (_a = root.localRefs) === null || _a === void 0 ? void 0 : _a[ref]; // TODO maybe localRefs should hold SchemaEnv\n const { schemaId } = this.opts;\n if (schema)\n _sch = new SchemaEnv({ schema, schemaId, root, baseId });\n }\n if (_sch === undefined)\n return;\n return (root.refs[ref] = inlineOrCompile.call(this, _sch));\n}\nexports.resolveRef = resolveRef;\nfunction inlineOrCompile(sch) {\n if ((0, resolve_1.inlineRef)(sch.schema, this.opts.inlineRefs))\n return sch.schema;\n return sch.validate ? sch : compileSchema.call(this, sch);\n}\n// Index of schema compilation in the currently compiled list\nfunction getCompilingSchema(schEnv) {\n for (const sch of this._compilations) {\n if (sameSchemaEnv(sch, schEnv))\n return sch;\n }\n}\nexports.getCompilingSchema = getCompilingSchema;\nfunction sameSchemaEnv(s1, s2) {\n return s1.schema === s2.schema && s1.root === s2.root && s1.baseId === s2.baseId;\n}\n// resolve and compile the references ($ref)\n// TODO returns AnySchemaObject (if the schema can be inlined) or validation function\nfunction resolve(root, // information about the root schema for the current schema\nref // reference to resolve\n) {\n let sch;\n while (typeof (sch = this.refs[ref]) == \"string\")\n ref = sch;\n return sch || this.schemas[ref] || resolveSchema.call(this, root, ref);\n}\n// Resolve schema, its root and baseId\nfunction resolveSchema(root, // root object with properties schema, refs TODO below SchemaEnv is assigned to it\nref // reference to resolve\n) {\n const p = this.opts.uriResolver.parse(ref);\n const refPath = (0, resolve_1._getFullPath)(this.opts.uriResolver, p);\n let baseId = (0, resolve_1.getFullPath)(this.opts.uriResolver, root.baseId, undefined);\n // TODO `Object.keys(root.schema).length > 0` should not be needed - but removing breaks 2 tests\n if (Object.keys(root.schema).length > 0 && refPath === baseId) {\n return getJsonPointer.call(this, p, root);\n }\n const id = (0, resolve_1.normalizeId)(refPath);\n const schOrRef = this.refs[id] || this.schemas[id];\n if (typeof schOrRef == \"string\") {\n const sch = resolveSchema.call(this, root, schOrRef);\n if (typeof (sch === null || sch === void 0 ? void 0 : sch.schema) !== \"object\")\n return;\n return getJsonPointer.call(this, p, sch);\n }\n if (typeof (schOrRef === null || schOrRef === void 0 ? void 0 : schOrRef.schema) !== \"object\")\n return;\n if (!schOrRef.validate)\n compileSchema.call(this, schOrRef);\n if (id === (0, resolve_1.normalizeId)(ref)) {\n const { schema } = schOrRef;\n const { schemaId } = this.opts;\n const schId = schema[schemaId];\n if (schId)\n baseId = (0, resolve_1.resolveUrl)(this.opts.uriResolver, baseId, schId);\n return new SchemaEnv({ schema, schemaId, root, baseId });\n }\n return getJsonPointer.call(this, p, schOrRef);\n}\nexports.resolveSchema = resolveSchema;\nconst PREVENT_SCOPE_CHANGE = new Set([\n \"properties\",\n \"patternProperties\",\n \"enum\",\n \"dependencies\",\n \"definitions\",\n]);\nfunction getJsonPointer(parsedRef, { baseId, schema, root }) {\n var _a;\n if (((_a = parsedRef.fragment) === null || _a === void 0 ? void 0 : _a[0]) !== \"/\")\n return;\n for (const part of parsedRef.fragment.slice(1).split(\"/\")) {\n if (typeof schema === \"boolean\")\n return;\n const partSchema = schema[(0, util_1.unescapeFragment)(part)];\n if (partSchema === undefined)\n return;\n schema = partSchema;\n // TODO PREVENT_SCOPE_CHANGE could be defined in keyword def?\n const schId = typeof schema === \"object\" && schema[this.opts.schemaId];\n if (!PREVENT_SCOPE_CHANGE.has(part) && schId) {\n baseId = (0, resolve_1.resolveUrl)(this.opts.uriResolver, baseId, schId);\n }\n }\n let env;\n if (typeof schema != \"boolean\" && schema.$ref && !(0, util_1.schemaHasRulesButRef)(schema, this.RULES)) {\n const $ref = (0, resolve_1.resolveUrl)(this.opts.uriResolver, baseId, schema.$ref);\n env = resolveSchema.call(this, root, $ref);\n }\n // even though resolution failed we need to return SchemaEnv to throw exception\n // so that compileAsync loads missing schema.\n const { schemaId } = this.opts;\n env = env || new SchemaEnv({ schema, schemaId, root, baseId });\n if (env.schema !== env.root.schema)\n return env;\n return undefined;\n}\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst uri = require(\"uri-js\");\nuri.code = 'require(\"ajv/dist/runtime/uri\").default';\nexports.default = uri;\n//# sourceMappingURL=uri.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.CodeGen = exports.Name = exports.nil = exports.stringify = exports.str = exports._ = exports.KeywordCxt = void 0;\nvar validate_1 = require(\"./compile/validate\");\nObject.defineProperty(exports, \"KeywordCxt\", { enumerable: true, get: function () { return validate_1.KeywordCxt; } });\nvar codegen_1 = require(\"./compile/codegen\");\nObject.defineProperty(exports, \"_\", { enumerable: true, get: function () { return codegen_1._; } });\nObject.defineProperty(exports, \"str\", { enumerable: true, get: function () { return codegen_1.str; } });\nObject.defineProperty(exports, \"stringify\", { enumerable: true, get: function () { return codegen_1.stringify; } });\nObject.defineProperty(exports, \"nil\", { enumerable: true, get: function () { return codegen_1.nil; } });\nObject.defineProperty(exports, \"Name\", { enumerable: true, get: function () { return codegen_1.Name; } });\nObject.defineProperty(exports, \"CodeGen\", { enumerable: true, get: function () { return codegen_1.CodeGen; } });\nconst validation_error_1 = require(\"./runtime/validation_error\");\nconst ref_error_1 = require(\"./compile/ref_error\");\nconst rules_1 = require(\"./compile/rules\");\nconst compile_1 = require(\"./compile\");\nconst codegen_2 = require(\"./compile/codegen\");\nconst resolve_1 = require(\"./compile/resolve\");\nconst dataType_1 = require(\"./compile/validate/dataType\");\nconst util_1 = require(\"./compile/util\");\nconst $dataRefSchema = require(\"./refs/data.json\");\nconst uri_1 = require(\"./runtime/uri\");\nconst defaultRegExp = (str, flags) => new RegExp(str, flags);\ndefaultRegExp.code = \"new RegExp\";\nconst META_IGNORE_OPTIONS = [\"removeAdditional\", \"useDefaults\", \"coerceTypes\"];\nconst EXT_SCOPE_NAMES = new Set([\n \"validate\",\n \"serialize\",\n \"parse\",\n \"wrapper\",\n \"root\",\n \"schema\",\n \"keyword\",\n \"pattern\",\n \"formats\",\n \"validate$data\",\n \"func\",\n \"obj\",\n \"Error\",\n]);\nconst removedOptions = {\n errorDataPath: \"\",\n format: \"`validateFormats: false` can be used instead.\",\n nullable: '\"nullable\" keyword is supported by default.',\n jsonPointers: \"Deprecated jsPropertySyntax can be used instead.\",\n extendRefs: \"Deprecated ignoreKeywordsWithRef can be used instead.\",\n missingRefs: \"Pass empty schema with $id that should be ignored to ajv.addSchema.\",\n processCode: \"Use option `code: {process: (code, schemaEnv: object) => string}`\",\n sourceCode: \"Use option `code: {source: true}`\",\n strictDefaults: \"It is default now, see option `strict`.\",\n strictKeywords: \"It is default now, see option `strict`.\",\n uniqueItems: '\"uniqueItems\" keyword is always validated.',\n unknownFormats: \"Disable strict mode or pass `true` to `ajv.addFormat` (or `formats` option).\",\n cache: \"Map is used as cache, schema object as key.\",\n serialize: \"Map is used as cache, schema object as key.\",\n ajvErrors: \"It is default now.\",\n};\nconst deprecatedOptions = {\n ignoreKeywordsWithRef: \"\",\n jsPropertySyntax: \"\",\n unicode: '\"minLength\"/\"maxLength\" account for unicode characters by default.',\n};\nconst MAX_EXPRESSION = 200;\n// eslint-disable-next-line complexity\nfunction requiredOptions(o) {\n var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0;\n const s = o.strict;\n const _optz = (_a = o.code) === null || _a === void 0 ? void 0 : _a.optimize;\n const optimize = _optz === true || _optz === undefined ? 1 : _optz || 0;\n const regExp = (_c = (_b = o.code) === null || _b === void 0 ? void 0 : _b.regExp) !== null && _c !== void 0 ? _c : defaultRegExp;\n const uriResolver = (_d = o.uriResolver) !== null && _d !== void 0 ? _d : uri_1.default;\n return {\n strictSchema: (_f = (_e = o.strictSchema) !== null && _e !== void 0 ? _e : s) !== null && _f !== void 0 ? _f : true,\n strictNumbers: (_h = (_g = o.strictNumbers) !== null && _g !== void 0 ? _g : s) !== null && _h !== void 0 ? _h : true,\n strictTypes: (_k = (_j = o.strictTypes) !== null && _j !== void 0 ? _j : s) !== null && _k !== void 0 ? _k : \"log\",\n strictTuples: (_m = (_l = o.strictTuples) !== null && _l !== void 0 ? _l : s) !== null && _m !== void 0 ? _m : \"log\",\n strictRequired: (_p = (_o = o.strictRequired) !== null && _o !== void 0 ? _o : s) !== null && _p !== void 0 ? _p : false,\n code: o.code ? { ...o.code, optimize, regExp } : { optimize, regExp },\n loopRequired: (_q = o.loopRequired) !== null && _q !== void 0 ? _q : MAX_EXPRESSION,\n loopEnum: (_r = o.loopEnum) !== null && _r !== void 0 ? _r : MAX_EXPRESSION,\n meta: (_s = o.meta) !== null && _s !== void 0 ? _s : true,\n messages: (_t = o.messages) !== null && _t !== void 0 ? _t : true,\n inlineRefs: (_u = o.inlineRefs) !== null && _u !== void 0 ? _u : true,\n schemaId: (_v = o.schemaId) !== null && _v !== void 0 ? _v : \"$id\",\n addUsedSchema: (_w = o.addUsedSchema) !== null && _w !== void 0 ? _w : true,\n validateSchema: (_x = o.validateSchema) !== null && _x !== void 0 ? _x : true,\n validateFormats: (_y = o.validateFormats) !== null && _y !== void 0 ? _y : true,\n unicodeRegExp: (_z = o.unicodeRegExp) !== null && _z !== void 0 ? _z : true,\n int32range: (_0 = o.int32range) !== null && _0 !== void 0 ? _0 : true,\n uriResolver: uriResolver,\n };\n}\nclass Ajv {\n constructor(opts = {}) {\n this.schemas = {};\n this.refs = {};\n this.formats = {};\n this._compilations = new Set();\n this._loading = {};\n this._cache = new Map();\n opts = this.opts = { ...opts, ...requiredOptions(opts) };\n const { es5, lines } = this.opts.code;\n this.scope = new codegen_2.ValueScope({ scope: {}, prefixes: EXT_SCOPE_NAMES, es5, lines });\n this.logger = getLogger(opts.logger);\n const formatOpt = opts.validateFormats;\n opts.validateFormats = false;\n this.RULES = (0, rules_1.getRules)();\n checkOptions.call(this, removedOptions, opts, \"NOT SUPPORTED\");\n checkOptions.call(this, deprecatedOptions, opts, \"DEPRECATED\", \"warn\");\n this._metaOpts = getMetaSchemaOptions.call(this);\n if (opts.formats)\n addInitialFormats.call(this);\n this._addVocabularies();\n this._addDefaultMetaSchema();\n if (opts.keywords)\n addInitialKeywords.call(this, opts.keywords);\n if (typeof opts.meta == \"object\")\n this.addMetaSchema(opts.meta);\n addInitialSchemas.call(this);\n opts.validateFormats = formatOpt;\n }\n _addVocabularies() {\n this.addKeyword(\"$async\");\n }\n _addDefaultMetaSchema() {\n const { $data, meta, schemaId } = this.opts;\n let _dataRefSchema = $dataRefSchema;\n if (schemaId === \"id\") {\n _dataRefSchema = { ...$dataRefSchema };\n _dataRefSchema.id = _dataRefSchema.$id;\n delete _dataRefSchema.$id;\n }\n if (meta && $data)\n this.addMetaSchema(_dataRefSchema, _dataRefSchema[schemaId], false);\n }\n defaultMeta() {\n const { meta, schemaId } = this.opts;\n return (this.opts.defaultMeta = typeof meta == \"object\" ? meta[schemaId] || meta : undefined);\n }\n validate(schemaKeyRef, // key, ref or schema object\n data // to be validated\n ) {\n let v;\n if (typeof schemaKeyRef == \"string\") {\n v = this.getSchema(schemaKeyRef);\n if (!v)\n throw new Error(`no schema with key or ref \"${schemaKeyRef}\"`);\n }\n else {\n v = this.compile(schemaKeyRef);\n }\n const valid = v(data);\n if (!(\"$async\" in v))\n this.errors = v.errors;\n return valid;\n }\n compile(schema, _meta) {\n const sch = this._addSchema(schema, _meta);\n return (sch.validate || this._compileSchemaEnv(sch));\n }\n compileAsync(schema, meta) {\n if (typeof this.opts.loadSchema != \"function\") {\n throw new Error(\"options.loadSchema should be a function\");\n }\n const { loadSchema } = this.opts;\n return runCompileAsync.call(this, schema, meta);\n async function runCompileAsync(_schema, _meta) {\n await loadMetaSchema.call(this, _schema.$schema);\n const sch = this._addSchema(_schema, _meta);\n return sch.validate || _compileAsync.call(this, sch);\n }\n async function loadMetaSchema($ref) {\n if ($ref && !this.getSchema($ref)) {\n await runCompileAsync.call(this, { $ref }, true);\n }\n }\n async function _compileAsync(sch) {\n try {\n return this._compileSchemaEnv(sch);\n }\n catch (e) {\n if (!(e instanceof ref_error_1.default))\n throw e;\n checkLoaded.call(this, e);\n await loadMissingSchema.call(this, e.missingSchema);\n return _compileAsync.call(this, sch);\n }\n }\n function checkLoaded({ missingSchema: ref, missingRef }) {\n if (this.refs[ref]) {\n throw new Error(`AnySchema ${ref} is loaded but ${missingRef} cannot be resolved`);\n }\n }\n async function loadMissingSchema(ref) {\n const _schema = await _loadSchema.call(this, ref);\n if (!this.refs[ref])\n await loadMetaSchema.call(this, _schema.$schema);\n if (!this.refs[ref])\n this.addSchema(_schema, ref, meta);\n }\n async function _loadSchema(ref) {\n const p = this._loading[ref];\n if (p)\n return p;\n try {\n return await (this._loading[ref] = loadSchema(ref));\n }\n finally {\n delete this._loading[ref];\n }\n }\n }\n // Adds schema to the instance\n addSchema(schema, // If array is passed, `key` will be ignored\n key, // Optional schema key. Can be passed to `validate` method instead of schema object or id/ref. One schema per instance can have empty `id` and `key`.\n _meta, // true if schema is a meta-schema. Used internally, addMetaSchema should be used instead.\n _validateSchema = this.opts.validateSchema // false to skip schema validation. Used internally, option validateSchema should be used instead.\n ) {\n if (Array.isArray(schema)) {\n for (const sch of schema)\n this.addSchema(sch, undefined, _meta, _validateSchema);\n return this;\n }\n let id;\n if (typeof schema === \"object\") {\n const { schemaId } = this.opts;\n id = schema[schemaId];\n if (id !== undefined && typeof id != \"string\") {\n throw new Error(`schema ${schemaId} must be string`);\n }\n }\n key = (0, resolve_1.normalizeId)(key || id);\n this._checkUnique(key);\n this.schemas[key] = this._addSchema(schema, _meta, key, _validateSchema, true);\n return this;\n }\n // Add schema that will be used to validate other schemas\n // options in META_IGNORE_OPTIONS are alway set to false\n addMetaSchema(schema, key, // schema key\n _validateSchema = this.opts.validateSchema // false to skip schema validation, can be used to override validateSchema option for meta-schema\n ) {\n this.addSchema(schema, key, true, _validateSchema);\n return this;\n }\n // Validate schema against its meta-schema\n validateSchema(schema, throwOrLogError) {\n if (typeof schema == \"boolean\")\n return true;\n let $schema;\n $schema = schema.$schema;\n if ($schema !== undefined && typeof $schema != \"string\") {\n throw new Error(\"$schema must be a string\");\n }\n $schema = $schema || this.opts.defaultMeta || this.defaultMeta();\n if (!$schema) {\n this.logger.warn(\"meta-schema not available\");\n this.errors = null;\n return true;\n }\n const valid = this.validate($schema, schema);\n if (!valid && throwOrLogError) {\n const message = \"schema is invalid: \" + this.errorsText();\n if (this.opts.validateSchema === \"log\")\n this.logger.error(message);\n else\n throw new Error(message);\n }\n return valid;\n }\n // Get compiled schema by `key` or `ref`.\n // (`key` that was passed to `addSchema` or full schema reference - `schema.$id` or resolved id)\n getSchema(keyRef) {\n let sch;\n while (typeof (sch = getSchEnv.call(this, keyRef)) == \"string\")\n keyRef = sch;\n if (sch === undefined) {\n const { schemaId } = this.opts;\n const root = new compile_1.SchemaEnv({ schema: {}, schemaId });\n sch = compile_1.resolveSchema.call(this, root, keyRef);\n if (!sch)\n return;\n this.refs[keyRef] = sch;\n }\n return (sch.validate || this._compileSchemaEnv(sch));\n }\n // Remove cached schema(s).\n // If no parameter is passed all schemas but meta-schemas are removed.\n // If RegExp is passed all schemas with key/id matching pattern but meta-schemas are removed.\n // Even if schema is referenced by other schemas it still can be removed as other schemas have local references.\n removeSchema(schemaKeyRef) {\n if (schemaKeyRef instanceof RegExp) {\n this._removeAllSchemas(this.schemas, schemaKeyRef);\n this._removeAllSchemas(this.refs, schemaKeyRef);\n return this;\n }\n switch (typeof schemaKeyRef) {\n case \"undefined\":\n this._removeAllSchemas(this.schemas);\n this._removeAllSchemas(this.refs);\n this._cache.clear();\n return this;\n case \"string\": {\n const sch = getSchEnv.call(this, schemaKeyRef);\n if (typeof sch == \"object\")\n this._cache.delete(sch.schema);\n delete this.schemas[schemaKeyRef];\n delete this.refs[schemaKeyRef];\n return this;\n }\n case \"object\": {\n const cacheKey = schemaKeyRef;\n this._cache.delete(cacheKey);\n let id = schemaKeyRef[this.opts.schemaId];\n if (id) {\n id = (0, resolve_1.normalizeId)(id);\n delete this.schemas[id];\n delete this.refs[id];\n }\n return this;\n }\n default:\n throw new Error(\"ajv.removeSchema: invalid parameter\");\n }\n }\n // add \"vocabulary\" - a collection of keywords\n addVocabulary(definitions) {\n for (const def of definitions)\n this.addKeyword(def);\n return this;\n }\n addKeyword(kwdOrDef, def // deprecated\n ) {\n let keyword;\n if (typeof kwdOrDef == \"string\") {\n keyword = kwdOrDef;\n if (typeof def == \"object\") {\n this.logger.warn(\"these parameters are deprecated, see docs for addKeyword\");\n def.keyword = keyword;\n }\n }\n else if (typeof kwdOrDef == \"object\" && def === undefined) {\n def = kwdOrDef;\n keyword = def.keyword;\n if (Array.isArray(keyword) && !keyword.length) {\n throw new Error(\"addKeywords: keyword must be string or non-empty array\");\n }\n }\n else {\n throw new Error(\"invalid addKeywords parameters\");\n }\n checkKeyword.call(this, keyword, def);\n if (!def) {\n (0, util_1.eachItem)(keyword, (kwd) => addRule.call(this, kwd));\n return this;\n }\n keywordMetaschema.call(this, def);\n const definition = {\n ...def,\n type: (0, dataType_1.getJSONTypes)(def.type),\n schemaType: (0, dataType_1.getJSONTypes)(def.schemaType),\n };\n (0, util_1.eachItem)(keyword, definition.type.length === 0\n ? (k) => addRule.call(this, k, definition)\n : (k) => definition.type.forEach((t) => addRule.call(this, k, definition, t)));\n return this;\n }\n getKeyword(keyword) {\n const rule = this.RULES.all[keyword];\n return typeof rule == \"object\" ? rule.definition : !!rule;\n }\n // Remove keyword\n removeKeyword(keyword) {\n // TODO return type should be Ajv\n const { RULES } = this;\n delete RULES.keywords[keyword];\n delete RULES.all[keyword];\n for (const group of RULES.rules) {\n const i = group.rules.findIndex((rule) => rule.keyword === keyword);\n if (i >= 0)\n group.rules.splice(i, 1);\n }\n return this;\n }\n // Add format\n addFormat(name, format) {\n if (typeof format == \"string\")\n format = new RegExp(format);\n this.formats[name] = format;\n return this;\n }\n errorsText(errors = this.errors, // optional array of validation errors\n { separator = \", \", dataVar = \"data\" } = {} // optional options with properties `separator` and `dataVar`\n ) {\n if (!errors || errors.length === 0)\n return \"No errors\";\n return errors\n .map((e) => `${dataVar}${e.instancePath} ${e.message}`)\n .reduce((text, msg) => text + separator + msg);\n }\n $dataMetaSchema(metaSchema, keywordsJsonPointers) {\n const rules = this.RULES.all;\n metaSchema = JSON.parse(JSON.stringify(metaSchema));\n for (const jsonPointer of keywordsJsonPointers) {\n const segments = jsonPointer.split(\"/\").slice(1); // first segment is an empty string\n let keywords = metaSchema;\n for (const seg of segments)\n keywords = keywords[seg];\n for (const key in rules) {\n const rule = rules[key];\n if (typeof rule != \"object\")\n continue;\n const { $data } = rule.definition;\n const schema = keywords[key];\n if ($data && schema)\n keywords[key] = schemaOrData(schema);\n }\n }\n return metaSchema;\n }\n _removeAllSchemas(schemas, regex) {\n for (const keyRef in schemas) {\n const sch = schemas[keyRef];\n if (!regex || regex.test(keyRef)) {\n if (typeof sch == \"string\") {\n delete schemas[keyRef];\n }\n else if (sch && !sch.meta) {\n this._cache.delete(sch.schema);\n delete schemas[keyRef];\n }\n }\n }\n }\n _addSchema(schema, meta, baseId, validateSchema = this.opts.validateSchema, addSchema = this.opts.addUsedSchema) {\n let id;\n const { schemaId } = this.opts;\n if (typeof schema == \"object\") {\n id = schema[schemaId];\n }\n else {\n if (this.opts.jtd)\n throw new Error(\"schema must be object\");\n else if (typeof schema != \"boolean\")\n throw new Error(\"schema must be object or boolean\");\n }\n let sch = this._cache.get(schema);\n if (sch !== undefined)\n return sch;\n baseId = (0, resolve_1.normalizeId)(id || baseId);\n const localRefs = resolve_1.getSchemaRefs.call(this, schema, baseId);\n sch = new compile_1.SchemaEnv({ schema, schemaId, meta, baseId, localRefs });\n this._cache.set(sch.schema, sch);\n if (addSchema && !baseId.startsWith(\"#\")) {\n // TODO atm it is allowed to overwrite schemas without id (instead of not adding them)\n if (baseId)\n this._checkUnique(baseId);\n this.refs[baseId] = sch;\n }\n if (validateSchema)\n this.validateSchema(schema, true);\n return sch;\n }\n _checkUnique(id) {\n if (this.schemas[id] || this.refs[id]) {\n throw new Error(`schema with key or id \"${id}\" already exists`);\n }\n }\n _compileSchemaEnv(sch) {\n if (sch.meta)\n this._compileMetaSchema(sch);\n else\n compile_1.compileSchema.call(this, sch);\n /* istanbul ignore if */\n if (!sch.validate)\n throw new Error(\"ajv implementation error\");\n return sch.validate;\n }\n _compileMetaSchema(sch) {\n const currentOpts = this.opts;\n this.opts = this._metaOpts;\n try {\n compile_1.compileSchema.call(this, sch);\n }\n finally {\n this.opts = currentOpts;\n }\n }\n}\nexports.default = Ajv;\nAjv.ValidationError = validation_error_1.default;\nAjv.MissingRefError = ref_error_1.default;\nfunction checkOptions(checkOpts, options, msg, log = \"error\") {\n for (const key in checkOpts) {\n const opt = key;\n if (opt in options)\n this.logger[log](`${msg}: option ${key}. ${checkOpts[opt]}`);\n }\n}\nfunction getSchEnv(keyRef) {\n keyRef = (0, resolve_1.normalizeId)(keyRef); // TODO tests fail without this line\n return this.schemas[keyRef] || this.refs[keyRef];\n}\nfunction addInitialSchemas() {\n const optsSchemas = this.opts.schemas;\n if (!optsSchemas)\n return;\n if (Array.isArray(optsSchemas))\n this.addSchema(optsSchemas);\n else\n for (const key in optsSchemas)\n this.addSchema(optsSchemas[key], key);\n}\nfunction addInitialFormats() {\n for (const name in this.opts.formats) {\n const format = this.opts.formats[name];\n if (format)\n this.addFormat(name, format);\n }\n}\nfunction addInitialKeywords(defs) {\n if (Array.isArray(defs)) {\n this.addVocabulary(defs);\n return;\n }\n this.logger.warn(\"keywords option as map is deprecated, pass array\");\n for (const keyword in defs) {\n const def = defs[keyword];\n if (!def.keyword)\n def.keyword = keyword;\n this.addKeyword(def);\n }\n}\nfunction getMetaSchemaOptions() {\n const metaOpts = { ...this.opts };\n for (const opt of META_IGNORE_OPTIONS)\n delete metaOpts[opt];\n return metaOpts;\n}\nconst noLogs = { log() { }, warn() { }, error() { } };\nfunction getLogger(logger) {\n if (logger === false)\n return noLogs;\n if (logger === undefined)\n return console;\n if (logger.log && logger.warn && logger.error)\n return logger;\n throw new Error(\"logger must implement log, warn and error methods\");\n}\nconst KEYWORD_NAME = /^[a-z_$][a-z0-9_$:-]*$/i;\nfunction checkKeyword(keyword, def) {\n const { RULES } = this;\n (0, util_1.eachItem)(keyword, (kwd) => {\n if (RULES.keywords[kwd])\n throw new Error(`Keyword ${kwd} is already defined`);\n if (!KEYWORD_NAME.test(kwd))\n throw new Error(`Keyword ${kwd} has invalid name`);\n });\n if (!def)\n return;\n if (def.$data && !(\"code\" in def || \"validate\" in def)) {\n throw new Error('$data keyword must have \"code\" or \"validate\" function');\n }\n}\nfunction addRule(keyword, definition, dataType) {\n var _a;\n const post = definition === null || definition === void 0 ? void 0 : definition.post;\n if (dataType && post)\n throw new Error('keyword with \"post\" flag cannot have \"type\"');\n const { RULES } = this;\n let ruleGroup = post ? RULES.post : RULES.rules.find(({ type: t }) => t === dataType);\n if (!ruleGroup) {\n ruleGroup = { type: dataType, rules: [] };\n RULES.rules.push(ruleGroup);\n }\n RULES.keywords[keyword] = true;\n if (!definition)\n return;\n const rule = {\n keyword,\n definition: {\n ...definition,\n type: (0, dataType_1.getJSONTypes)(definition.type),\n schemaType: (0, dataType_1.getJSONTypes)(definition.schemaType),\n },\n };\n if (definition.before)\n addBeforeRule.call(this, ruleGroup, rule, definition.before);\n else\n ruleGroup.rules.push(rule);\n RULES.all[keyword] = rule;\n (_a = definition.implements) === null || _a === void 0 ? void 0 : _a.forEach((kwd) => this.addKeyword(kwd));\n}\nfunction addBeforeRule(ruleGroup, rule, before) {\n const i = ruleGroup.rules.findIndex((_rule) => _rule.keyword === before);\n if (i >= 0) {\n ruleGroup.rules.splice(i, 0, rule);\n }\n else {\n ruleGroup.rules.push(rule);\n this.logger.warn(`rule ${before} is not defined`);\n }\n}\nfunction keywordMetaschema(def) {\n let { metaSchema } = def;\n if (metaSchema === undefined)\n return;\n if (def.$data && this.opts.$data)\n metaSchema = schemaOrData(metaSchema);\n def.validateSchema = this.compile(metaSchema, true);\n}\nconst $dataRef = {\n $ref: \"https://raw.githubusercontent.com/ajv-validator/ajv/master/lib/refs/data.json#\",\n};\nfunction schemaOrData(schema) {\n return { anyOf: [schema, $dataRef] };\n}\n//# sourceMappingURL=core.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst def = {\n keyword: \"id\",\n code() {\n throw new Error('NOT SUPPORTED: keyword \"id\", use \"$id\" for schema ID');\n },\n};\nexports.default = def;\n//# sourceMappingURL=id.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.callRef = exports.getValidate = void 0;\nconst ref_error_1 = require(\"../../compile/ref_error\");\nconst code_1 = require(\"../code\");\nconst codegen_1 = require(\"../../compile/codegen\");\nconst names_1 = require(\"../../compile/names\");\nconst compile_1 = require(\"../../compile\");\nconst util_1 = require(\"../../compile/util\");\nconst def = {\n keyword: \"$ref\",\n schemaType: \"string\",\n code(cxt) {\n const { gen, schema: $ref, it } = cxt;\n const { baseId, schemaEnv: env, validateName, opts, self } = it;\n const { root } = env;\n if (($ref === \"#\" || $ref === \"#/\") && baseId === root.baseId)\n return callRootRef();\n const schOrEnv = compile_1.resolveRef.call(self, root, baseId, $ref);\n if (schOrEnv === undefined)\n throw new ref_error_1.default(it.opts.uriResolver, baseId, $ref);\n if (schOrEnv instanceof compile_1.SchemaEnv)\n return callValidate(schOrEnv);\n return inlineRefSchema(schOrEnv);\n function callRootRef() {\n if (env === root)\n return callRef(cxt, validateName, env, env.$async);\n const rootName = gen.scopeValue(\"root\", { ref: root });\n return callRef(cxt, (0, codegen_1._) `${rootName}.validate`, root, root.$async);\n }\n function callValidate(sch) {\n const v = getValidate(cxt, sch);\n callRef(cxt, v, sch, sch.$async);\n }\n function inlineRefSchema(sch) {\n const schName = gen.scopeValue(\"schema\", opts.code.source === true ? { ref: sch, code: (0, codegen_1.stringify)(sch) } : { ref: sch });\n const valid = gen.name(\"valid\");\n const schCxt = cxt.subschema({\n schema: sch,\n dataTypes: [],\n schemaPath: codegen_1.nil,\n topSchemaRef: schName,\n errSchemaPath: $ref,\n }, valid);\n cxt.mergeEvaluated(schCxt);\n cxt.ok(valid);\n }\n },\n};\nfunction getValidate(cxt, sch) {\n const { gen } = cxt;\n return sch.validate\n ? gen.scopeValue(\"validate\", { ref: sch.validate })\n : (0, codegen_1._) `${gen.scopeValue(\"wrapper\", { ref: sch })}.validate`;\n}\nexports.getValidate = getValidate;\nfunction callRef(cxt, v, sch, $async) {\n const { gen, it } = cxt;\n const { allErrors, schemaEnv: env, opts } = it;\n const passCxt = opts.passContext ? names_1.default.this : codegen_1.nil;\n if ($async)\n callAsyncRef();\n else\n callSyncRef();\n function callAsyncRef() {\n if (!env.$async)\n throw new Error(\"async schema referenced by sync schema\");\n const valid = gen.let(\"valid\");\n gen.try(() => {\n gen.code((0, codegen_1._) `await ${(0, code_1.callValidateCode)(cxt, v, passCxt)}`);\n addEvaluatedFrom(v); // TODO will not work with async, it has to be returned with the result\n if (!allErrors)\n gen.assign(valid, true);\n }, (e) => {\n gen.if((0, codegen_1._) `!(${e} instanceof ${it.ValidationError})`, () => gen.throw(e));\n addErrorsFrom(e);\n if (!allErrors)\n gen.assign(valid, false);\n });\n cxt.ok(valid);\n }\n function callSyncRef() {\n cxt.result((0, code_1.callValidateCode)(cxt, v, passCxt), () => addEvaluatedFrom(v), () => addErrorsFrom(v));\n }\n function addErrorsFrom(source) {\n const errs = (0, codegen_1._) `${source}.errors`;\n gen.assign(names_1.default.vErrors, (0, codegen_1._) `${names_1.default.vErrors} === null ? ${errs} : ${names_1.default.vErrors}.concat(${errs})`); // TODO tagged\n gen.assign(names_1.default.errors, (0, codegen_1._) `${names_1.default.vErrors}.length`);\n }\n function addEvaluatedFrom(source) {\n var _a;\n if (!it.opts.unevaluated)\n return;\n const schEvaluated = (_a = sch === null || sch === void 0 ? void 0 : sch.validate) === null || _a === void 0 ? void 0 : _a.evaluated;\n // TODO refactor\n if (it.props !== true) {\n if (schEvaluated && !schEvaluated.dynamicProps) {\n if (schEvaluated.props !== undefined) {\n it.props = util_1.mergeEvaluated.props(gen, schEvaluated.props, it.props);\n }\n }\n else {\n const props = gen.var(\"props\", (0, codegen_1._) `${source}.evaluated.props`);\n it.props = util_1.mergeEvaluated.props(gen, props, it.props, codegen_1.Name);\n }\n }\n if (it.items !== true) {\n if (schEvaluated && !schEvaluated.dynamicItems) {\n if (schEvaluated.items !== undefined) {\n it.items = util_1.mergeEvaluated.items(gen, schEvaluated.items, it.items);\n }\n }\n else {\n const items = gen.var(\"items\", (0, codegen_1._) `${source}.evaluated.items`);\n it.items = util_1.mergeEvaluated.items(gen, items, it.items, codegen_1.Name);\n }\n }\n }\n}\nexports.callRef = callRef;\nexports.default = def;\n//# sourceMappingURL=ref.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst id_1 = require(\"./id\");\nconst ref_1 = require(\"./ref\");\nconst core = [\n \"$schema\",\n \"$id\",\n \"$defs\",\n \"$vocabulary\",\n { keyword: \"$comment\" },\n \"definitions\",\n id_1.default,\n ref_1.default,\n];\nexports.default = core;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst ops = codegen_1.operators;\nconst KWDs = {\n maximum: { okStr: \"<=\", ok: ops.LTE, fail: ops.GT },\n minimum: { okStr: \">=\", ok: ops.GTE, fail: ops.LT },\n exclusiveMaximum: { okStr: \"<\", ok: ops.LT, fail: ops.GTE },\n exclusiveMinimum: { okStr: \">\", ok: ops.GT, fail: ops.LTE },\n};\nconst error = {\n message: ({ keyword, schemaCode }) => (0, codegen_1.str) `must be ${KWDs[keyword].okStr} ${schemaCode}`,\n params: ({ keyword, schemaCode }) => (0, codegen_1._) `{comparison: ${KWDs[keyword].okStr}, limit: ${schemaCode}}`,\n};\nconst def = {\n keyword: Object.keys(KWDs),\n type: \"number\",\n schemaType: \"number\",\n $data: true,\n error,\n code(cxt) {\n const { keyword, data, schemaCode } = cxt;\n cxt.fail$data((0, codegen_1._) `${data} ${KWDs[keyword].fail} ${schemaCode} || isNaN(${data})`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=limitNumber.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst error = {\n message: ({ schemaCode }) => (0, codegen_1.str) `must be multiple of ${schemaCode}`,\n params: ({ schemaCode }) => (0, codegen_1._) `{multipleOf: ${schemaCode}}`,\n};\nconst def = {\n keyword: \"multipleOf\",\n type: \"number\",\n schemaType: \"number\",\n $data: true,\n error,\n code(cxt) {\n const { gen, data, schemaCode, it } = cxt;\n // const bdt = bad$DataType(schemaCode, def.schemaType, $data)\n const prec = it.opts.multipleOfPrecision;\n const res = gen.let(\"res\");\n const invalid = prec\n ? (0, codegen_1._) `Math.abs(Math.round(${res}) - ${res}) > 1e-${prec}`\n : (0, codegen_1._) `${res} !== parseInt(${res})`;\n cxt.fail$data((0, codegen_1._) `(${schemaCode} === 0 || (${res} = ${data}/${schemaCode}, ${invalid}))`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=multipleOf.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n// https://mathiasbynens.be/notes/javascript-encoding\n// https://github.com/bestiejs/punycode.js - punycode.ucs2.decode\nfunction ucs2length(str) {\n const len = str.length;\n let length = 0;\n let pos = 0;\n let value;\n while (pos < len) {\n length++;\n value = str.charCodeAt(pos++);\n if (value >= 0xd800 && value <= 0xdbff && pos < len) {\n // high surrogate, and there is a next character\n value = str.charCodeAt(pos);\n if ((value & 0xfc00) === 0xdc00)\n pos++; // low surrogate\n }\n }\n return length;\n}\nexports.default = ucs2length;\nucs2length.code = 'require(\"ajv/dist/runtime/ucs2length\").default';\n//# sourceMappingURL=ucs2length.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst ucs2length_1 = require(\"../../runtime/ucs2length\");\nconst error = {\n message({ keyword, schemaCode }) {\n const comp = keyword === \"maxLength\" ? \"more\" : \"fewer\";\n return (0, codegen_1.str) `must NOT have ${comp} than ${schemaCode} characters`;\n },\n params: ({ schemaCode }) => (0, codegen_1._) `{limit: ${schemaCode}}`,\n};\nconst def = {\n keyword: [\"maxLength\", \"minLength\"],\n type: \"string\",\n schemaType: \"number\",\n $data: true,\n error,\n code(cxt) {\n const { keyword, data, schemaCode, it } = cxt;\n const op = keyword === \"maxLength\" ? codegen_1.operators.GT : codegen_1.operators.LT;\n const len = it.opts.unicode === false ? (0, codegen_1._) `${data}.length` : (0, codegen_1._) `${(0, util_1.useFunc)(cxt.gen, ucs2length_1.default)}(${data})`;\n cxt.fail$data((0, codegen_1._) `${len} ${op} ${schemaCode}`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=limitLength.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst code_1 = require(\"../code\");\nconst codegen_1 = require(\"../../compile/codegen\");\nconst error = {\n message: ({ schemaCode }) => (0, codegen_1.str) `must match pattern \"${schemaCode}\"`,\n params: ({ schemaCode }) => (0, codegen_1._) `{pattern: ${schemaCode}}`,\n};\nconst def = {\n keyword: \"pattern\",\n type: \"string\",\n schemaType: \"string\",\n $data: true,\n error,\n code(cxt) {\n const { data, $data, schema, schemaCode, it } = cxt;\n // TODO regexp should be wrapped in try/catchs\n const u = it.opts.unicodeRegExp ? \"u\" : \"\";\n const regExp = $data ? (0, codegen_1._) `(new RegExp(${schemaCode}, ${u}))` : (0, code_1.usePattern)(cxt, schema);\n cxt.fail$data((0, codegen_1._) `!${regExp}.test(${data})`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=pattern.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst error = {\n message({ keyword, schemaCode }) {\n const comp = keyword === \"maxProperties\" ? \"more\" : \"fewer\";\n return (0, codegen_1.str) `must NOT have ${comp} than ${schemaCode} properties`;\n },\n params: ({ schemaCode }) => (0, codegen_1._) `{limit: ${schemaCode}}`,\n};\nconst def = {\n keyword: [\"maxProperties\", \"minProperties\"],\n type: \"object\",\n schemaType: \"number\",\n $data: true,\n error,\n code(cxt) {\n const { keyword, data, schemaCode } = cxt;\n const op = keyword === \"maxProperties\" ? codegen_1.operators.GT : codegen_1.operators.LT;\n cxt.fail$data((0, codegen_1._) `Object.keys(${data}).length ${op} ${schemaCode}`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=limitProperties.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst code_1 = require(\"../code\");\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: ({ params: { missingProperty } }) => (0, codegen_1.str) `must have required property '${missingProperty}'`,\n params: ({ params: { missingProperty } }) => (0, codegen_1._) `{missingProperty: ${missingProperty}}`,\n};\nconst def = {\n keyword: \"required\",\n type: \"object\",\n schemaType: \"array\",\n $data: true,\n error,\n code(cxt) {\n const { gen, schema, schemaCode, data, $data, it } = cxt;\n const { opts } = it;\n if (!$data && schema.length === 0)\n return;\n const useLoop = schema.length >= opts.loopRequired;\n if (it.allErrors)\n allErrorsMode();\n else\n exitOnErrorMode();\n if (opts.strictRequired) {\n const props = cxt.parentSchema.properties;\n const { definedProperties } = cxt.it;\n for (const requiredKey of schema) {\n if ((props === null || props === void 0 ? void 0 : props[requiredKey]) === undefined && !definedProperties.has(requiredKey)) {\n const schemaPath = it.schemaEnv.baseId + it.errSchemaPath;\n const msg = `required property \"${requiredKey}\" is not defined at \"${schemaPath}\" (strictRequired)`;\n (0, util_1.checkStrictMode)(it, msg, it.opts.strictRequired);\n }\n }\n }\n function allErrorsMode() {\n if (useLoop || $data) {\n cxt.block$data(codegen_1.nil, loopAllRequired);\n }\n else {\n for (const prop of schema) {\n (0, code_1.checkReportMissingProp)(cxt, prop);\n }\n }\n }\n function exitOnErrorMode() {\n const missing = gen.let(\"missing\");\n if (useLoop || $data) {\n const valid = gen.let(\"valid\", true);\n cxt.block$data(valid, () => loopUntilMissing(missing, valid));\n cxt.ok(valid);\n }\n else {\n gen.if((0, code_1.checkMissingProp)(cxt, schema, missing));\n (0, code_1.reportMissingProp)(cxt, missing);\n gen.else();\n }\n }\n function loopAllRequired() {\n gen.forOf(\"prop\", schemaCode, (prop) => {\n cxt.setParams({ missingProperty: prop });\n gen.if((0, code_1.noPropertyInData)(gen, data, prop, opts.ownProperties), () => cxt.error());\n });\n }\n function loopUntilMissing(missing, valid) {\n cxt.setParams({ missingProperty: missing });\n gen.forOf(missing, schemaCode, () => {\n gen.assign(valid, (0, code_1.propertyInData)(gen, data, missing, opts.ownProperties));\n gen.if((0, codegen_1.not)(valid), () => {\n cxt.error();\n gen.break();\n });\n }, codegen_1.nil);\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=required.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst error = {\n message({ keyword, schemaCode }) {\n const comp = keyword === \"maxItems\" ? \"more\" : \"fewer\";\n return (0, codegen_1.str) `must NOT have ${comp} than ${schemaCode} items`;\n },\n params: ({ schemaCode }) => (0, codegen_1._) `{limit: ${schemaCode}}`,\n};\nconst def = {\n keyword: [\"maxItems\", \"minItems\"],\n type: \"array\",\n schemaType: \"number\",\n $data: true,\n error,\n code(cxt) {\n const { keyword, data, schemaCode } = cxt;\n const op = keyword === \"maxItems\" ? codegen_1.operators.GT : codegen_1.operators.LT;\n cxt.fail$data((0, codegen_1._) `${data}.length ${op} ${schemaCode}`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=limitItems.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n// https://github.com/ajv-validator/ajv/issues/889\nconst equal = require(\"fast-deep-equal\");\nequal.code = 'require(\"ajv/dist/runtime/equal\").default';\nexports.default = equal;\n//# sourceMappingURL=equal.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst dataType_1 = require(\"../../compile/validate/dataType\");\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst equal_1 = require(\"../../runtime/equal\");\nconst error = {\n message: ({ params: { i, j } }) => (0, codegen_1.str) `must NOT have duplicate items (items ## ${j} and ${i} are identical)`,\n params: ({ params: { i, j } }) => (0, codegen_1._) `{i: ${i}, j: ${j}}`,\n};\nconst def = {\n keyword: \"uniqueItems\",\n type: \"array\",\n schemaType: \"boolean\",\n $data: true,\n error,\n code(cxt) {\n const { gen, data, $data, schema, parentSchema, schemaCode, it } = cxt;\n if (!$data && !schema)\n return;\n const valid = gen.let(\"valid\");\n const itemTypes = parentSchema.items ? (0, dataType_1.getSchemaTypes)(parentSchema.items) : [];\n cxt.block$data(valid, validateUniqueItems, (0, codegen_1._) `${schemaCode} === false`);\n cxt.ok(valid);\n function validateUniqueItems() {\n const i = gen.let(\"i\", (0, codegen_1._) `${data}.length`);\n const j = gen.let(\"j\");\n cxt.setParams({ i, j });\n gen.assign(valid, true);\n gen.if((0, codegen_1._) `${i} > 1`, () => (canOptimize() ? loopN : loopN2)(i, j));\n }\n function canOptimize() {\n return itemTypes.length > 0 && !itemTypes.some((t) => t === \"object\" || t === \"array\");\n }\n function loopN(i, j) {\n const item = gen.name(\"item\");\n const wrongType = (0, dataType_1.checkDataTypes)(itemTypes, item, it.opts.strictNumbers, dataType_1.DataType.Wrong);\n const indices = gen.const(\"indices\", (0, codegen_1._) `{}`);\n gen.for((0, codegen_1._) `;${i}--;`, () => {\n gen.let(item, (0, codegen_1._) `${data}[${i}]`);\n gen.if(wrongType, (0, codegen_1._) `continue`);\n if (itemTypes.length > 1)\n gen.if((0, codegen_1._) `typeof ${item} == \"string\"`, (0, codegen_1._) `${item} += \"_\"`);\n gen\n .if((0, codegen_1._) `typeof ${indices}[${item}] == \"number\"`, () => {\n gen.assign(j, (0, codegen_1._) `${indices}[${item}]`);\n cxt.error();\n gen.assign(valid, false).break();\n })\n .code((0, codegen_1._) `${indices}[${item}] = ${i}`);\n });\n }\n function loopN2(i, j) {\n const eql = (0, util_1.useFunc)(gen, equal_1.default);\n const outer = gen.name(\"outer\");\n gen.label(outer).for((0, codegen_1._) `;${i}--;`, () => gen.for((0, codegen_1._) `${j} = ${i}; ${j}--;`, () => gen.if((0, codegen_1._) `${eql}(${data}[${i}], ${data}[${j}])`, () => {\n cxt.error();\n gen.assign(valid, false).break(outer);\n })));\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=uniqueItems.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst equal_1 = require(\"../../runtime/equal\");\nconst error = {\n message: \"must be equal to constant\",\n params: ({ schemaCode }) => (0, codegen_1._) `{allowedValue: ${schemaCode}}`,\n};\nconst def = {\n keyword: \"const\",\n $data: true,\n error,\n code(cxt) {\n const { gen, data, $data, schemaCode, schema } = cxt;\n if ($data || (schema && typeof schema == \"object\")) {\n cxt.fail$data((0, codegen_1._) `!${(0, util_1.useFunc)(gen, equal_1.default)}(${data}, ${schemaCode})`);\n }\n else {\n cxt.fail((0, codegen_1._) `${schema} !== ${data}`);\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=const.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst equal_1 = require(\"../../runtime/equal\");\nconst error = {\n message: \"must be equal to one of the allowed values\",\n params: ({ schemaCode }) => (0, codegen_1._) `{allowedValues: ${schemaCode}}`,\n};\nconst def = {\n keyword: \"enum\",\n schemaType: \"array\",\n $data: true,\n error,\n code(cxt) {\n const { gen, data, $data, schema, schemaCode, it } = cxt;\n if (!$data && schema.length === 0)\n throw new Error(\"enum must have non-empty array\");\n const useLoop = schema.length >= it.opts.loopEnum;\n let eql;\n const getEql = () => (eql !== null && eql !== void 0 ? eql : (eql = (0, util_1.useFunc)(gen, equal_1.default)));\n let valid;\n if (useLoop || $data) {\n valid = gen.let(\"valid\");\n cxt.block$data(valid, loopEnum);\n }\n else {\n /* istanbul ignore if */\n if (!Array.isArray(schema))\n throw new Error(\"ajv implementation error\");\n const vSchema = gen.const(\"vSchema\", schemaCode);\n valid = (0, codegen_1.or)(...schema.map((_x, i) => equalCode(vSchema, i)));\n }\n cxt.pass(valid);\n function loopEnum() {\n gen.assign(valid, false);\n gen.forOf(\"v\", schemaCode, (v) => gen.if((0, codegen_1._) `${getEql()}(${data}, ${v})`, () => gen.assign(valid, true).break()));\n }\n function equalCode(vSchema, i) {\n const sch = schema[i];\n return typeof sch === \"object\" && sch !== null\n ? (0, codegen_1._) `${getEql()}(${data}, ${vSchema}[${i}])`\n : (0, codegen_1._) `${data} === ${sch}`;\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=enum.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst limitNumber_1 = require(\"./limitNumber\");\nconst multipleOf_1 = require(\"./multipleOf\");\nconst limitLength_1 = require(\"./limitLength\");\nconst pattern_1 = require(\"./pattern\");\nconst limitProperties_1 = require(\"./limitProperties\");\nconst required_1 = require(\"./required\");\nconst limitItems_1 = require(\"./limitItems\");\nconst uniqueItems_1 = require(\"./uniqueItems\");\nconst const_1 = require(\"./const\");\nconst enum_1 = require(\"./enum\");\nconst validation = [\n // number\n limitNumber_1.default,\n multipleOf_1.default,\n // string\n limitLength_1.default,\n pattern_1.default,\n // object\n limitProperties_1.default,\n required_1.default,\n // array\n limitItems_1.default,\n uniqueItems_1.default,\n // any\n { keyword: \"type\", schemaType: [\"string\", \"array\"] },\n { keyword: \"nullable\", schemaType: \"boolean\" },\n const_1.default,\n enum_1.default,\n];\nexports.default = validation;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateAdditionalItems = void 0;\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: ({ params: { len } }) => (0, codegen_1.str) `must NOT have more than ${len} items`,\n params: ({ params: { len } }) => (0, codegen_1._) `{limit: ${len}}`,\n};\nconst def = {\n keyword: \"additionalItems\",\n type: \"array\",\n schemaType: [\"boolean\", \"object\"],\n before: \"uniqueItems\",\n error,\n code(cxt) {\n const { parentSchema, it } = cxt;\n const { items } = parentSchema;\n if (!Array.isArray(items)) {\n (0, util_1.checkStrictMode)(it, '\"additionalItems\" is ignored when \"items\" is not an array of schemas');\n return;\n }\n validateAdditionalItems(cxt, items);\n },\n};\nfunction validateAdditionalItems(cxt, items) {\n const { gen, schema, data, keyword, it } = cxt;\n it.items = true;\n const len = gen.const(\"len\", (0, codegen_1._) `${data}.length`);\n if (schema === false) {\n cxt.setParams({ len: items.length });\n cxt.pass((0, codegen_1._) `${len} <= ${items.length}`);\n }\n else if (typeof schema == \"object\" && !(0, util_1.alwaysValidSchema)(it, schema)) {\n const valid = gen.var(\"valid\", (0, codegen_1._) `${len} <= ${items.length}`); // TODO var\n gen.if((0, codegen_1.not)(valid), () => validateItems(valid));\n cxt.ok(valid);\n }\n function validateItems(valid) {\n gen.forRange(\"i\", items.length, len, (i) => {\n cxt.subschema({ keyword, dataProp: i, dataPropType: util_1.Type.Num }, valid);\n if (!it.allErrors)\n gen.if((0, codegen_1.not)(valid), () => gen.break());\n });\n }\n}\nexports.validateAdditionalItems = validateAdditionalItems;\nexports.default = def;\n//# sourceMappingURL=additionalItems.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateTuple = void 0;\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst code_1 = require(\"../code\");\nconst def = {\n keyword: \"items\",\n type: \"array\",\n schemaType: [\"object\", \"array\", \"boolean\"],\n before: \"uniqueItems\",\n code(cxt) {\n const { schema, it } = cxt;\n if (Array.isArray(schema))\n return validateTuple(cxt, \"additionalItems\", schema);\n it.items = true;\n if ((0, util_1.alwaysValidSchema)(it, schema))\n return;\n cxt.ok((0, code_1.validateArray)(cxt));\n },\n};\nfunction validateTuple(cxt, extraItems, schArr = cxt.schema) {\n const { gen, parentSchema, data, keyword, it } = cxt;\n checkStrictTuple(parentSchema);\n if (it.opts.unevaluated && schArr.length && it.items !== true) {\n it.items = util_1.mergeEvaluated.items(gen, schArr.length, it.items);\n }\n const valid = gen.name(\"valid\");\n const len = gen.const(\"len\", (0, codegen_1._) `${data}.length`);\n schArr.forEach((sch, i) => {\n if ((0, util_1.alwaysValidSchema)(it, sch))\n return;\n gen.if((0, codegen_1._) `${len} > ${i}`, () => cxt.subschema({\n keyword,\n schemaProp: i,\n dataProp: i,\n }, valid));\n cxt.ok(valid);\n });\n function checkStrictTuple(sch) {\n const { opts, errSchemaPath } = it;\n const l = schArr.length;\n const fullTuple = l === sch.minItems && (l === sch.maxItems || sch[extraItems] === false);\n if (opts.strictTuples && !fullTuple) {\n const msg = `\"${keyword}\" is ${l}-tuple, but minItems or maxItems/${extraItems} are not specified or different at path \"${errSchemaPath}\"`;\n (0, util_1.checkStrictMode)(it, msg, opts.strictTuples);\n }\n }\n}\nexports.validateTuple = validateTuple;\nexports.default = def;\n//# sourceMappingURL=items.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst items_1 = require(\"./items\");\nconst def = {\n keyword: \"prefixItems\",\n type: \"array\",\n schemaType: [\"array\"],\n before: \"uniqueItems\",\n code: (cxt) => (0, items_1.validateTuple)(cxt, \"items\"),\n};\nexports.default = def;\n//# sourceMappingURL=prefixItems.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst code_1 = require(\"../code\");\nconst additionalItems_1 = require(\"./additionalItems\");\nconst error = {\n message: ({ params: { len } }) => (0, codegen_1.str) `must NOT have more than ${len} items`,\n params: ({ params: { len } }) => (0, codegen_1._) `{limit: ${len}}`,\n};\nconst def = {\n keyword: \"items\",\n type: \"array\",\n schemaType: [\"object\", \"boolean\"],\n before: \"uniqueItems\",\n error,\n code(cxt) {\n const { schema, parentSchema, it } = cxt;\n const { prefixItems } = parentSchema;\n it.items = true;\n if ((0, util_1.alwaysValidSchema)(it, schema))\n return;\n if (prefixItems)\n (0, additionalItems_1.validateAdditionalItems)(cxt, prefixItems);\n else\n cxt.ok((0, code_1.validateArray)(cxt));\n },\n};\nexports.default = def;\n//# sourceMappingURL=items2020.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: ({ params: { min, max } }) => max === undefined\n ? (0, codegen_1.str) `must contain at least ${min} valid item(s)`\n : (0, codegen_1.str) `must contain at least ${min} and no more than ${max} valid item(s)`,\n params: ({ params: { min, max } }) => max === undefined ? (0, codegen_1._) `{minContains: ${min}}` : (0, codegen_1._) `{minContains: ${min}, maxContains: ${max}}`,\n};\nconst def = {\n keyword: \"contains\",\n type: \"array\",\n schemaType: [\"object\", \"boolean\"],\n before: \"uniqueItems\",\n trackErrors: true,\n error,\n code(cxt) {\n const { gen, schema, parentSchema, data, it } = cxt;\n let min;\n let max;\n const { minContains, maxContains } = parentSchema;\n if (it.opts.next) {\n min = minContains === undefined ? 1 : minContains;\n max = maxContains;\n }\n else {\n min = 1;\n }\n const len = gen.const(\"len\", (0, codegen_1._) `${data}.length`);\n cxt.setParams({ min, max });\n if (max === undefined && min === 0) {\n (0, util_1.checkStrictMode)(it, `\"minContains\" == 0 without \"maxContains\": \"contains\" keyword ignored`);\n return;\n }\n if (max !== undefined && min > max) {\n (0, util_1.checkStrictMode)(it, `\"minContains\" > \"maxContains\" is always invalid`);\n cxt.fail();\n return;\n }\n if ((0, util_1.alwaysValidSchema)(it, schema)) {\n let cond = (0, codegen_1._) `${len} >= ${min}`;\n if (max !== undefined)\n cond = (0, codegen_1._) `${cond} && ${len} <= ${max}`;\n cxt.pass(cond);\n return;\n }\n it.items = true;\n const valid = gen.name(\"valid\");\n if (max === undefined && min === 1) {\n validateItems(valid, () => gen.if(valid, () => gen.break()));\n }\n else if (min === 0) {\n gen.let(valid, true);\n if (max !== undefined)\n gen.if((0, codegen_1._) `${data}.length > 0`, validateItemsWithCount);\n }\n else {\n gen.let(valid, false);\n validateItemsWithCount();\n }\n cxt.result(valid, () => cxt.reset());\n function validateItemsWithCount() {\n const schValid = gen.name(\"_valid\");\n const count = gen.let(\"count\", 0);\n validateItems(schValid, () => gen.if(schValid, () => checkLimits(count)));\n }\n function validateItems(_valid, block) {\n gen.forRange(\"i\", 0, len, (i) => {\n cxt.subschema({\n keyword: \"contains\",\n dataProp: i,\n dataPropType: util_1.Type.Num,\n compositeRule: true,\n }, _valid);\n block();\n });\n }\n function checkLimits(count) {\n gen.code((0, codegen_1._) `${count}++`);\n if (max === undefined) {\n gen.if((0, codegen_1._) `${count} >= ${min}`, () => gen.assign(valid, true).break());\n }\n else {\n gen.if((0, codegen_1._) `${count} > ${max}`, () => gen.assign(valid, false).break());\n if (min === 1)\n gen.assign(valid, true);\n else\n gen.if((0, codegen_1._) `${count} >= ${min}`, () => gen.assign(valid, true));\n }\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=contains.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateSchemaDeps = exports.validatePropertyDeps = exports.error = void 0;\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst code_1 = require(\"../code\");\nexports.error = {\n message: ({ params: { property, depsCount, deps } }) => {\n const property_ies = depsCount === 1 ? \"property\" : \"properties\";\n return (0, codegen_1.str) `must have ${property_ies} ${deps} when property ${property} is present`;\n },\n params: ({ params: { property, depsCount, deps, missingProperty } }) => (0, codegen_1._) `{property: ${property},\n missingProperty: ${missingProperty},\n depsCount: ${depsCount},\n deps: ${deps}}`, // TODO change to reference\n};\nconst def = {\n keyword: \"dependencies\",\n type: \"object\",\n schemaType: \"object\",\n error: exports.error,\n code(cxt) {\n const [propDeps, schDeps] = splitDependencies(cxt);\n validatePropertyDeps(cxt, propDeps);\n validateSchemaDeps(cxt, schDeps);\n },\n};\nfunction splitDependencies({ schema }) {\n const propertyDeps = {};\n const schemaDeps = {};\n for (const key in schema) {\n if (key === \"__proto__\")\n continue;\n const deps = Array.isArray(schema[key]) ? propertyDeps : schemaDeps;\n deps[key] = schema[key];\n }\n return [propertyDeps, schemaDeps];\n}\nfunction validatePropertyDeps(cxt, propertyDeps = cxt.schema) {\n const { gen, data, it } = cxt;\n if (Object.keys(propertyDeps).length === 0)\n return;\n const missing = gen.let(\"missing\");\n for (const prop in propertyDeps) {\n const deps = propertyDeps[prop];\n if (deps.length === 0)\n continue;\n const hasProperty = (0, code_1.propertyInData)(gen, data, prop, it.opts.ownProperties);\n cxt.setParams({\n property: prop,\n depsCount: deps.length,\n deps: deps.join(\", \"),\n });\n if (it.allErrors) {\n gen.if(hasProperty, () => {\n for (const depProp of deps) {\n (0, code_1.checkReportMissingProp)(cxt, depProp);\n }\n });\n }\n else {\n gen.if((0, codegen_1._) `${hasProperty} && (${(0, code_1.checkMissingProp)(cxt, deps, missing)})`);\n (0, code_1.reportMissingProp)(cxt, missing);\n gen.else();\n }\n }\n}\nexports.validatePropertyDeps = validatePropertyDeps;\nfunction validateSchemaDeps(cxt, schemaDeps = cxt.schema) {\n const { gen, data, keyword, it } = cxt;\n const valid = gen.name(\"valid\");\n for (const prop in schemaDeps) {\n if ((0, util_1.alwaysValidSchema)(it, schemaDeps[prop]))\n continue;\n gen.if((0, code_1.propertyInData)(gen, data, prop, it.opts.ownProperties), () => {\n const schCxt = cxt.subschema({ keyword, schemaProp: prop }, valid);\n cxt.mergeValidEvaluated(schCxt, valid);\n }, () => gen.var(valid, true) // TODO var\n );\n cxt.ok(valid);\n }\n}\nexports.validateSchemaDeps = validateSchemaDeps;\nexports.default = def;\n//# sourceMappingURL=dependencies.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: \"property name must be valid\",\n params: ({ params }) => (0, codegen_1._) `{propertyName: ${params.propertyName}}`,\n};\nconst def = {\n keyword: \"propertyNames\",\n type: \"object\",\n schemaType: [\"object\", \"boolean\"],\n error,\n code(cxt) {\n const { gen, schema, data, it } = cxt;\n if ((0, util_1.alwaysValidSchema)(it, schema))\n return;\n const valid = gen.name(\"valid\");\n gen.forIn(\"key\", data, (key) => {\n cxt.setParams({ propertyName: key });\n cxt.subschema({\n keyword: \"propertyNames\",\n data: key,\n dataTypes: [\"string\"],\n propertyName: key,\n compositeRule: true,\n }, valid);\n gen.if((0, codegen_1.not)(valid), () => {\n cxt.error(true);\n if (!it.allErrors)\n gen.break();\n });\n });\n cxt.ok(valid);\n },\n};\nexports.default = def;\n//# sourceMappingURL=propertyNames.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst code_1 = require(\"../code\");\nconst codegen_1 = require(\"../../compile/codegen\");\nconst names_1 = require(\"../../compile/names\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: \"must NOT have additional properties\",\n params: ({ params }) => (0, codegen_1._) `{additionalProperty: ${params.additionalProperty}}`,\n};\nconst def = {\n keyword: \"additionalProperties\",\n type: [\"object\"],\n schemaType: [\"boolean\", \"object\"],\n allowUndefined: true,\n trackErrors: true,\n error,\n code(cxt) {\n const { gen, schema, parentSchema, data, errsCount, it } = cxt;\n /* istanbul ignore if */\n if (!errsCount)\n throw new Error(\"ajv implementation error\");\n const { allErrors, opts } = it;\n it.props = true;\n if (opts.removeAdditional !== \"all\" && (0, util_1.alwaysValidSchema)(it, schema))\n return;\n const props = (0, code_1.allSchemaProperties)(parentSchema.properties);\n const patProps = (0, code_1.allSchemaProperties)(parentSchema.patternProperties);\n checkAdditionalProperties();\n cxt.ok((0, codegen_1._) `${errsCount} === ${names_1.default.errors}`);\n function checkAdditionalProperties() {\n gen.forIn(\"key\", data, (key) => {\n if (!props.length && !patProps.length)\n additionalPropertyCode(key);\n else\n gen.if(isAdditional(key), () => additionalPropertyCode(key));\n });\n }\n function isAdditional(key) {\n let definedProp;\n if (props.length > 8) {\n // TODO maybe an option instead of hard-coded 8?\n const propsSchema = (0, util_1.schemaRefOrVal)(it, parentSchema.properties, \"properties\");\n definedProp = (0, code_1.isOwnProperty)(gen, propsSchema, key);\n }\n else if (props.length) {\n definedProp = (0, codegen_1.or)(...props.map((p) => (0, codegen_1._) `${key} === ${p}`));\n }\n else {\n definedProp = codegen_1.nil;\n }\n if (patProps.length) {\n definedProp = (0, codegen_1.or)(definedProp, ...patProps.map((p) => (0, codegen_1._) `${(0, code_1.usePattern)(cxt, p)}.test(${key})`));\n }\n return (0, codegen_1.not)(definedProp);\n }\n function deleteAdditional(key) {\n gen.code((0, codegen_1._) `delete ${data}[${key}]`);\n }\n function additionalPropertyCode(key) {\n if (opts.removeAdditional === \"all\" || (opts.removeAdditional && schema === false)) {\n deleteAdditional(key);\n return;\n }\n if (schema === false) {\n cxt.setParams({ additionalProperty: key });\n cxt.error();\n if (!allErrors)\n gen.break();\n return;\n }\n if (typeof schema == \"object\" && !(0, util_1.alwaysValidSchema)(it, schema)) {\n const valid = gen.name(\"valid\");\n if (opts.removeAdditional === \"failing\") {\n applyAdditionalSchema(key, valid, false);\n gen.if((0, codegen_1.not)(valid), () => {\n cxt.reset();\n deleteAdditional(key);\n });\n }\n else {\n applyAdditionalSchema(key, valid);\n if (!allErrors)\n gen.if((0, codegen_1.not)(valid), () => gen.break());\n }\n }\n }\n function applyAdditionalSchema(key, valid, errors) {\n const subschema = {\n keyword: \"additionalProperties\",\n dataProp: key,\n dataPropType: util_1.Type.Str,\n };\n if (errors === false) {\n Object.assign(subschema, {\n compositeRule: true,\n createErrors: false,\n allErrors: false,\n });\n }\n cxt.subschema(subschema, valid);\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=additionalProperties.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst validate_1 = require(\"../../compile/validate\");\nconst code_1 = require(\"../code\");\nconst util_1 = require(\"../../compile/util\");\nconst additionalProperties_1 = require(\"./additionalProperties\");\nconst def = {\n keyword: \"properties\",\n type: \"object\",\n schemaType: \"object\",\n code(cxt) {\n const { gen, schema, parentSchema, data, it } = cxt;\n if (it.opts.removeAdditional === \"all\" && parentSchema.additionalProperties === undefined) {\n additionalProperties_1.default.code(new validate_1.KeywordCxt(it, additionalProperties_1.default, \"additionalProperties\"));\n }\n const allProps = (0, code_1.allSchemaProperties)(schema);\n for (const prop of allProps) {\n it.definedProperties.add(prop);\n }\n if (it.opts.unevaluated && allProps.length && it.props !== true) {\n it.props = util_1.mergeEvaluated.props(gen, (0, util_1.toHash)(allProps), it.props);\n }\n const properties = allProps.filter((p) => !(0, util_1.alwaysValidSchema)(it, schema[p]));\n if (properties.length === 0)\n return;\n const valid = gen.name(\"valid\");\n for (const prop of properties) {\n if (hasDefault(prop)) {\n applyPropertySchema(prop);\n }\n else {\n gen.if((0, code_1.propertyInData)(gen, data, prop, it.opts.ownProperties));\n applyPropertySchema(prop);\n if (!it.allErrors)\n gen.else().var(valid, true);\n gen.endIf();\n }\n cxt.it.definedProperties.add(prop);\n cxt.ok(valid);\n }\n function hasDefault(prop) {\n return it.opts.useDefaults && !it.compositeRule && schema[prop].default !== undefined;\n }\n function applyPropertySchema(prop) {\n cxt.subschema({\n keyword: \"properties\",\n schemaProp: prop,\n dataProp: prop,\n }, valid);\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=properties.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst code_1 = require(\"../code\");\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst util_2 = require(\"../../compile/util\");\nconst def = {\n keyword: \"patternProperties\",\n type: \"object\",\n schemaType: \"object\",\n code(cxt) {\n const { gen, schema, data, parentSchema, it } = cxt;\n const { opts } = it;\n const patterns = (0, code_1.allSchemaProperties)(schema);\n const alwaysValidPatterns = patterns.filter((p) => (0, util_1.alwaysValidSchema)(it, schema[p]));\n if (patterns.length === 0 ||\n (alwaysValidPatterns.length === patterns.length &&\n (!it.opts.unevaluated || it.props === true))) {\n return;\n }\n const checkProperties = opts.strictSchema && !opts.allowMatchingProperties && parentSchema.properties;\n const valid = gen.name(\"valid\");\n if (it.props !== true && !(it.props instanceof codegen_1.Name)) {\n it.props = (0, util_2.evaluatedPropsToName)(gen, it.props);\n }\n const { props } = it;\n validatePatternProperties();\n function validatePatternProperties() {\n for (const pat of patterns) {\n if (checkProperties)\n checkMatchingProperties(pat);\n if (it.allErrors) {\n validateProperties(pat);\n }\n else {\n gen.var(valid, true); // TODO var\n validateProperties(pat);\n gen.if(valid);\n }\n }\n }\n function checkMatchingProperties(pat) {\n for (const prop in checkProperties) {\n if (new RegExp(pat).test(prop)) {\n (0, util_1.checkStrictMode)(it, `property ${prop} matches pattern ${pat} (use allowMatchingProperties)`);\n }\n }\n }\n function validateProperties(pat) {\n gen.forIn(\"key\", data, (key) => {\n gen.if((0, codegen_1._) `${(0, code_1.usePattern)(cxt, pat)}.test(${key})`, () => {\n const alwaysValid = alwaysValidPatterns.includes(pat);\n if (!alwaysValid) {\n cxt.subschema({\n keyword: \"patternProperties\",\n schemaProp: pat,\n dataProp: key,\n dataPropType: util_2.Type.Str,\n }, valid);\n }\n if (it.opts.unevaluated && props !== true) {\n gen.assign((0, codegen_1._) `${props}[${key}]`, true);\n }\n else if (!alwaysValid && !it.allErrors) {\n // can short-circuit if `unevaluatedProperties` is not supported (opts.next === false)\n // or if all properties were evaluated (props === true)\n gen.if((0, codegen_1.not)(valid), () => gen.break());\n }\n });\n });\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=patternProperties.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst util_1 = require(\"../../compile/util\");\nconst def = {\n keyword: \"not\",\n schemaType: [\"object\", \"boolean\"],\n trackErrors: true,\n code(cxt) {\n const { gen, schema, it } = cxt;\n if ((0, util_1.alwaysValidSchema)(it, schema)) {\n cxt.fail();\n return;\n }\n const valid = gen.name(\"valid\");\n cxt.subschema({\n keyword: \"not\",\n compositeRule: true,\n createErrors: false,\n allErrors: false,\n }, valid);\n cxt.failResult(valid, () => cxt.reset(), () => cxt.error());\n },\n error: { message: \"must NOT be valid\" },\n};\nexports.default = def;\n//# sourceMappingURL=not.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst code_1 = require(\"../code\");\nconst def = {\n keyword: \"anyOf\",\n schemaType: \"array\",\n trackErrors: true,\n code: code_1.validateUnion,\n error: { message: \"must match a schema in anyOf\" },\n};\nexports.default = def;\n//# sourceMappingURL=anyOf.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: \"must match exactly one schema in oneOf\",\n params: ({ params }) => (0, codegen_1._) `{passingSchemas: ${params.passing}}`,\n};\nconst def = {\n keyword: \"oneOf\",\n schemaType: \"array\",\n trackErrors: true,\n error,\n code(cxt) {\n const { gen, schema, parentSchema, it } = cxt;\n /* istanbul ignore if */\n if (!Array.isArray(schema))\n throw new Error(\"ajv implementation error\");\n if (it.opts.discriminator && parentSchema.discriminator)\n return;\n const schArr = schema;\n const valid = gen.let(\"valid\", false);\n const passing = gen.let(\"passing\", null);\n const schValid = gen.name(\"_valid\");\n cxt.setParams({ passing });\n // TODO possibly fail straight away (with warning or exception) if there are two empty always valid schemas\n gen.block(validateOneOf);\n cxt.result(valid, () => cxt.reset(), () => cxt.error(true));\n function validateOneOf() {\n schArr.forEach((sch, i) => {\n let schCxt;\n if ((0, util_1.alwaysValidSchema)(it, sch)) {\n gen.var(schValid, true);\n }\n else {\n schCxt = cxt.subschema({\n keyword: \"oneOf\",\n schemaProp: i,\n compositeRule: true,\n }, schValid);\n }\n if (i > 0) {\n gen\n .if((0, codegen_1._) `${schValid} && ${valid}`)\n .assign(valid, false)\n .assign(passing, (0, codegen_1._) `[${passing}, ${i}]`)\n .else();\n }\n gen.if(schValid, () => {\n gen.assign(valid, true);\n gen.assign(passing, i);\n if (schCxt)\n cxt.mergeEvaluated(schCxt, codegen_1.Name);\n });\n });\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=oneOf.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst util_1 = require(\"../../compile/util\");\nconst def = {\n keyword: \"allOf\",\n schemaType: \"array\",\n code(cxt) {\n const { gen, schema, it } = cxt;\n /* istanbul ignore if */\n if (!Array.isArray(schema))\n throw new Error(\"ajv implementation error\");\n const valid = gen.name(\"valid\");\n schema.forEach((sch, i) => {\n if ((0, util_1.alwaysValidSchema)(it, sch))\n return;\n const schCxt = cxt.subschema({ keyword: \"allOf\", schemaProp: i }, valid);\n cxt.ok(valid);\n cxt.mergeEvaluated(schCxt);\n });\n },\n};\nexports.default = def;\n//# sourceMappingURL=allOf.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: ({ params }) => (0, codegen_1.str) `must match \"${params.ifClause}\" schema`,\n params: ({ params }) => (0, codegen_1._) `{failingKeyword: ${params.ifClause}}`,\n};\nconst def = {\n keyword: \"if\",\n schemaType: [\"object\", \"boolean\"],\n trackErrors: true,\n error,\n code(cxt) {\n const { gen, parentSchema, it } = cxt;\n if (parentSchema.then === undefined && parentSchema.else === undefined) {\n (0, util_1.checkStrictMode)(it, '\"if\" without \"then\" and \"else\" is ignored');\n }\n const hasThen = hasSchema(it, \"then\");\n const hasElse = hasSchema(it, \"else\");\n if (!hasThen && !hasElse)\n return;\n const valid = gen.let(\"valid\", true);\n const schValid = gen.name(\"_valid\");\n validateIf();\n cxt.reset();\n if (hasThen && hasElse) {\n const ifClause = gen.let(\"ifClause\");\n cxt.setParams({ ifClause });\n gen.if(schValid, validateClause(\"then\", ifClause), validateClause(\"else\", ifClause));\n }\n else if (hasThen) {\n gen.if(schValid, validateClause(\"then\"));\n }\n else {\n gen.if((0, codegen_1.not)(schValid), validateClause(\"else\"));\n }\n cxt.pass(valid, () => cxt.error(true));\n function validateIf() {\n const schCxt = cxt.subschema({\n keyword: \"if\",\n compositeRule: true,\n createErrors: false,\n allErrors: false,\n }, schValid);\n cxt.mergeEvaluated(schCxt);\n }\n function validateClause(keyword, ifClause) {\n return () => {\n const schCxt = cxt.subschema({ keyword }, schValid);\n gen.assign(valid, schValid);\n cxt.mergeValidEvaluated(schCxt, valid);\n if (ifClause)\n gen.assign(ifClause, (0, codegen_1._) `${keyword}`);\n else\n cxt.setParams({ ifClause: keyword });\n };\n }\n },\n};\nfunction hasSchema(it, keyword) {\n const schema = it.schema[keyword];\n return schema !== undefined && !(0, util_1.alwaysValidSchema)(it, schema);\n}\nexports.default = def;\n//# sourceMappingURL=if.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst util_1 = require(\"../../compile/util\");\nconst def = {\n keyword: [\"then\", \"else\"],\n schemaType: [\"object\", \"boolean\"],\n code({ keyword, parentSchema, it }) {\n if (parentSchema.if === undefined)\n (0, util_1.checkStrictMode)(it, `\"${keyword}\" without \"if\" is ignored`);\n },\n};\nexports.default = def;\n//# sourceMappingURL=thenElse.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst additionalItems_1 = require(\"./additionalItems\");\nconst prefixItems_1 = require(\"./prefixItems\");\nconst items_1 = require(\"./items\");\nconst items2020_1 = require(\"./items2020\");\nconst contains_1 = require(\"./contains\");\nconst dependencies_1 = require(\"./dependencies\");\nconst propertyNames_1 = require(\"./propertyNames\");\nconst additionalProperties_1 = require(\"./additionalProperties\");\nconst properties_1 = require(\"./properties\");\nconst patternProperties_1 = require(\"./patternProperties\");\nconst not_1 = require(\"./not\");\nconst anyOf_1 = require(\"./anyOf\");\nconst oneOf_1 = require(\"./oneOf\");\nconst allOf_1 = require(\"./allOf\");\nconst if_1 = require(\"./if\");\nconst thenElse_1 = require(\"./thenElse\");\nfunction getApplicator(draft2020 = false) {\n const applicator = [\n // any\n not_1.default,\n anyOf_1.default,\n oneOf_1.default,\n allOf_1.default,\n if_1.default,\n thenElse_1.default,\n // object\n propertyNames_1.default,\n additionalProperties_1.default,\n dependencies_1.default,\n properties_1.default,\n patternProperties_1.default,\n ];\n // array\n if (draft2020)\n applicator.push(prefixItems_1.default, items2020_1.default);\n else\n applicator.push(additionalItems_1.default, items_1.default);\n applicator.push(contains_1.default);\n return applicator;\n}\nexports.default = getApplicator;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst error = {\n message: ({ schemaCode }) => (0, codegen_1.str) `must match format \"${schemaCode}\"`,\n params: ({ schemaCode }) => (0, codegen_1._) `{format: ${schemaCode}}`,\n};\nconst def = {\n keyword: \"format\",\n type: [\"number\", \"string\"],\n schemaType: \"string\",\n $data: true,\n error,\n code(cxt, ruleType) {\n const { gen, data, $data, schema, schemaCode, it } = cxt;\n const { opts, errSchemaPath, schemaEnv, self } = it;\n if (!opts.validateFormats)\n return;\n if ($data)\n validate$DataFormat();\n else\n validateFormat();\n function validate$DataFormat() {\n const fmts = gen.scopeValue(\"formats\", {\n ref: self.formats,\n code: opts.code.formats,\n });\n const fDef = gen.const(\"fDef\", (0, codegen_1._) `${fmts}[${schemaCode}]`);\n const fType = gen.let(\"fType\");\n const format = gen.let(\"format\");\n // TODO simplify\n gen.if((0, codegen_1._) `typeof ${fDef} == \"object\" && !(${fDef} instanceof RegExp)`, () => gen.assign(fType, (0, codegen_1._) `${fDef}.type || \"string\"`).assign(format, (0, codegen_1._) `${fDef}.validate`), () => gen.assign(fType, (0, codegen_1._) `\"string\"`).assign(format, fDef));\n cxt.fail$data((0, codegen_1.or)(unknownFmt(), invalidFmt()));\n function unknownFmt() {\n if (opts.strictSchema === false)\n return codegen_1.nil;\n return (0, codegen_1._) `${schemaCode} && !${format}`;\n }\n function invalidFmt() {\n const callFormat = schemaEnv.$async\n ? (0, codegen_1._) `(${fDef}.async ? await ${format}(${data}) : ${format}(${data}))`\n : (0, codegen_1._) `${format}(${data})`;\n const validData = (0, codegen_1._) `(typeof ${format} == \"function\" ? ${callFormat} : ${format}.test(${data}))`;\n return (0, codegen_1._) `${format} && ${format} !== true && ${fType} === ${ruleType} && !${validData}`;\n }\n }\n function validateFormat() {\n const formatDef = self.formats[schema];\n if (!formatDef) {\n unknownFormat();\n return;\n }\n if (formatDef === true)\n return;\n const [fmtType, format, fmtRef] = getFormat(formatDef);\n if (fmtType === ruleType)\n cxt.pass(validCondition());\n function unknownFormat() {\n if (opts.strictSchema === false) {\n self.logger.warn(unknownMsg());\n return;\n }\n throw new Error(unknownMsg());\n function unknownMsg() {\n return `unknown format \"${schema}\" ignored in schema at path \"${errSchemaPath}\"`;\n }\n }\n function getFormat(fmtDef) {\n const code = fmtDef instanceof RegExp\n ? (0, codegen_1.regexpCode)(fmtDef)\n : opts.code.formats\n ? (0, codegen_1._) `${opts.code.formats}${(0, codegen_1.getProperty)(schema)}`\n : undefined;\n const fmt = gen.scopeValue(\"formats\", { key: schema, ref: fmtDef, code });\n if (typeof fmtDef == \"object\" && !(fmtDef instanceof RegExp)) {\n return [fmtDef.type || \"string\", fmtDef.validate, (0, codegen_1._) `${fmt}.validate`];\n }\n return [\"string\", fmtDef, fmt];\n }\n function validCondition() {\n if (typeof formatDef == \"object\" && !(formatDef instanceof RegExp) && formatDef.async) {\n if (!schemaEnv.$async)\n throw new Error(\"async format in sync schema\");\n return (0, codegen_1._) `await ${fmtRef}(${data})`;\n }\n return typeof format == \"function\" ? (0, codegen_1._) `${fmtRef}(${data})` : (0, codegen_1._) `${fmtRef}.test(${data})`;\n }\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=format.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst format_1 = require(\"./format\");\nconst format = [format_1.default];\nexports.default = format;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.contentVocabulary = exports.metadataVocabulary = void 0;\nexports.metadataVocabulary = [\n \"title\",\n \"description\",\n \"default\",\n \"deprecated\",\n \"readOnly\",\n \"writeOnly\",\n \"examples\",\n];\nexports.contentVocabulary = [\n \"contentMediaType\",\n \"contentEncoding\",\n \"contentSchema\",\n];\n//# sourceMappingURL=metadata.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst core_1 = require(\"./core\");\nconst validation_1 = require(\"./validation\");\nconst applicator_1 = require(\"./applicator\");\nconst format_1 = require(\"./format\");\nconst metadata_1 = require(\"./metadata\");\nconst draft7Vocabularies = [\n core_1.default,\n validation_1.default,\n (0, applicator_1.default)(),\n format_1.default,\n metadata_1.metadataVocabulary,\n metadata_1.contentVocabulary,\n];\nexports.default = draft7Vocabularies;\n//# sourceMappingURL=draft7.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.DiscrError = void 0;\nvar DiscrError;\n(function (DiscrError) {\n DiscrError[\"Tag\"] = \"tag\";\n DiscrError[\"Mapping\"] = \"mapping\";\n})(DiscrError = exports.DiscrError || (exports.DiscrError = {}));\n//# sourceMappingURL=types.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst codegen_1 = require(\"../../compile/codegen\");\nconst types_1 = require(\"../discriminator/types\");\nconst compile_1 = require(\"../../compile\");\nconst util_1 = require(\"../../compile/util\");\nconst error = {\n message: ({ params: { discrError, tagName } }) => discrError === types_1.DiscrError.Tag\n ? `tag \"${tagName}\" must be string`\n : `value of tag \"${tagName}\" must be in oneOf`,\n params: ({ params: { discrError, tag, tagName } }) => (0, codegen_1._) `{error: ${discrError}, tag: ${tagName}, tagValue: ${tag}}`,\n};\nconst def = {\n keyword: \"discriminator\",\n type: \"object\",\n schemaType: \"object\",\n error,\n code(cxt) {\n const { gen, data, schema, parentSchema, it } = cxt;\n const { oneOf } = parentSchema;\n if (!it.opts.discriminator) {\n throw new Error(\"discriminator: requires discriminator option\");\n }\n const tagName = schema.propertyName;\n if (typeof tagName != \"string\")\n throw new Error(\"discriminator: requires propertyName\");\n if (schema.mapping)\n throw new Error(\"discriminator: mapping is not supported\");\n if (!oneOf)\n throw new Error(\"discriminator: requires oneOf keyword\");\n const valid = gen.let(\"valid\", false);\n const tag = gen.const(\"tag\", (0, codegen_1._) `${data}${(0, codegen_1.getProperty)(tagName)}`);\n gen.if((0, codegen_1._) `typeof ${tag} == \"string\"`, () => validateMapping(), () => cxt.error(false, { discrError: types_1.DiscrError.Tag, tag, tagName }));\n cxt.ok(valid);\n function validateMapping() {\n const mapping = getMapping();\n gen.if(false);\n for (const tagValue in mapping) {\n gen.elseIf((0, codegen_1._) `${tag} === ${tagValue}`);\n gen.assign(valid, applyTagSchema(mapping[tagValue]));\n }\n gen.else();\n cxt.error(false, { discrError: types_1.DiscrError.Mapping, tag, tagName });\n gen.endIf();\n }\n function applyTagSchema(schemaProp) {\n const _valid = gen.name(\"valid\");\n const schCxt = cxt.subschema({ keyword: \"oneOf\", schemaProp }, _valid);\n cxt.mergeEvaluated(schCxt, codegen_1.Name);\n return _valid;\n }\n function getMapping() {\n var _a;\n const oneOfMapping = {};\n const topRequired = hasRequired(parentSchema);\n let tagRequired = true;\n for (let i = 0; i < oneOf.length; i++) {\n let sch = oneOf[i];\n if ((sch === null || sch === void 0 ? void 0 : sch.$ref) && !(0, util_1.schemaHasRulesButRef)(sch, it.self.RULES)) {\n sch = compile_1.resolveRef.call(it.self, it.schemaEnv.root, it.baseId, sch === null || sch === void 0 ? void 0 : sch.$ref);\n if (sch instanceof compile_1.SchemaEnv)\n sch = sch.schema;\n }\n const propSch = (_a = sch === null || sch === void 0 ? void 0 : sch.properties) === null || _a === void 0 ? void 0 : _a[tagName];\n if (typeof propSch != \"object\") {\n throw new Error(`discriminator: oneOf subschemas (or referenced schemas) must have \"properties/${tagName}\"`);\n }\n tagRequired = tagRequired && (topRequired || hasRequired(sch));\n addMappings(propSch, i);\n }\n if (!tagRequired)\n throw new Error(`discriminator: \"${tagName}\" must be required`);\n return oneOfMapping;\n function hasRequired({ required }) {\n return Array.isArray(required) && required.includes(tagName);\n }\n function addMappings(sch, i) {\n if (sch.const) {\n addMapping(sch.const, i);\n }\n else if (sch.enum) {\n for (const tagValue of sch.enum) {\n addMapping(tagValue, i);\n }\n }\n else {\n throw new Error(`discriminator: \"properties/${tagName}\" must have \"const\" or \"enum\"`);\n }\n }\n function addMapping(tagValue, i) {\n if (typeof tagValue != \"string\" || tagValue in oneOfMapping) {\n throw new Error(`discriminator: \"${tagName}\" values must be unique strings`);\n }\n oneOfMapping[tagValue] = i;\n }\n }\n },\n};\nexports.default = def;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.CodeGen = exports.Name = exports.nil = exports.stringify = exports.str = exports._ = exports.KeywordCxt = void 0;\nconst core_1 = require(\"./core\");\nconst draft7_1 = require(\"./vocabularies/draft7\");\nconst discriminator_1 = require(\"./vocabularies/discriminator\");\nconst draft7MetaSchema = require(\"./refs/json-schema-draft-07.json\");\nconst META_SUPPORT_DATA = [\"/properties\"];\nconst META_SCHEMA_ID = \"http://json-schema.org/draft-07/schema\";\nclass Ajv extends core_1.default {\n _addVocabularies() {\n super._addVocabularies();\n draft7_1.default.forEach((v) => this.addVocabulary(v));\n if (this.opts.discriminator)\n this.addKeyword(discriminator_1.default);\n }\n _addDefaultMetaSchema() {\n super._addDefaultMetaSchema();\n if (!this.opts.meta)\n return;\n const metaSchema = this.opts.$data\n ? this.$dataMetaSchema(draft7MetaSchema, META_SUPPORT_DATA)\n : draft7MetaSchema;\n this.addMetaSchema(metaSchema, META_SCHEMA_ID, false);\n this.refs[\"http://json-schema.org/schema\"] = META_SCHEMA_ID;\n }\n defaultMeta() {\n return (this.opts.defaultMeta =\n super.defaultMeta() || (this.getSchema(META_SCHEMA_ID) ? META_SCHEMA_ID : undefined));\n }\n}\nmodule.exports = exports = Ajv;\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.default = Ajv;\nvar validate_1 = require(\"./compile/validate\");\nObject.defineProperty(exports, \"KeywordCxt\", { enumerable: true, get: function () { return validate_1.KeywordCxt; } });\nvar codegen_1 = require(\"./compile/codegen\");\nObject.defineProperty(exports, \"_\", { enumerable: true, get: function () { return codegen_1._; } });\nObject.defineProperty(exports, \"str\", { enumerable: true, get: function () { return codegen_1.str; } });\nObject.defineProperty(exports, \"stringify\", { enumerable: true, get: function () { return codegen_1.stringify; } });\nObject.defineProperty(exports, \"nil\", { enumerable: true, get: function () { return codegen_1.nil; } });\nObject.defineProperty(exports, \"Name\", { enumerable: true, get: function () { return codegen_1.Name; } });\nObject.defineProperty(exports, \"CodeGen\", { enumerable: true, get: function () { return codegen_1.CodeGen; } });\n//# sourceMappingURL=ajv.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.formatLimitDefinition = void 0;\nconst ajv_1 = require(\"ajv\");\nconst codegen_1 = require(\"ajv/dist/compile/codegen\");\nconst ops = codegen_1.operators;\nconst KWDs = {\n formatMaximum: { okStr: \"<=\", ok: ops.LTE, fail: ops.GT },\n formatMinimum: { okStr: \">=\", ok: ops.GTE, fail: ops.LT },\n formatExclusiveMaximum: { okStr: \"<\", ok: ops.LT, fail: ops.GTE },\n formatExclusiveMinimum: { okStr: \">\", ok: ops.GT, fail: ops.LTE },\n};\nconst error = {\n message: ({ keyword, schemaCode }) => codegen_1.str `should be ${KWDs[keyword].okStr} ${schemaCode}`,\n params: ({ keyword, schemaCode }) => codegen_1._ `{comparison: ${KWDs[keyword].okStr}, limit: ${schemaCode}}`,\n};\nexports.formatLimitDefinition = {\n keyword: Object.keys(KWDs),\n type: \"string\",\n schemaType: \"string\",\n $data: true,\n error,\n code(cxt) {\n const { gen, data, schemaCode, keyword, it } = cxt;\n const { opts, self } = it;\n if (!opts.validateFormats)\n return;\n const fCxt = new ajv_1.KeywordCxt(it, self.RULES.all.format.definition, \"format\");\n if (fCxt.$data)\n validate$DataFormat();\n else\n validateFormat();\n function validate$DataFormat() {\n const fmts = gen.scopeValue(\"formats\", {\n ref: self.formats,\n code: opts.code.formats,\n });\n const fmt = gen.const(\"fmt\", codegen_1._ `${fmts}[${fCxt.schemaCode}]`);\n cxt.fail$data(codegen_1.or(codegen_1._ `typeof ${fmt} != \"object\"`, codegen_1._ `${fmt} instanceof RegExp`, codegen_1._ `typeof ${fmt}.compare != \"function\"`, compareCode(fmt)));\n }\n function validateFormat() {\n const format = fCxt.schema;\n const fmtDef = self.formats[format];\n if (!fmtDef || fmtDef === true)\n return;\n if (typeof fmtDef != \"object\" ||\n fmtDef instanceof RegExp ||\n typeof fmtDef.compare != \"function\") {\n throw new Error(`\"${keyword}\": format \"${format}\" does not define \"compare\" function`);\n }\n const fmt = gen.scopeValue(\"formats\", {\n key: format,\n ref: fmtDef,\n code: opts.code.formats ? codegen_1._ `${opts.code.formats}${codegen_1.getProperty(format)}` : undefined,\n });\n cxt.fail$data(compareCode(fmt));\n }\n function compareCode(fmt) {\n return codegen_1._ `${fmt}.compare(${data}, ${schemaCode}) ${KWDs[keyword].fail} 0`;\n }\n },\n dependencies: [\"format\"],\n};\nconst formatLimitPlugin = (ajv) => {\n ajv.addKeyword(exports.formatLimitDefinition);\n return ajv;\n};\nexports.default = formatLimitPlugin;\n//# sourceMappingURL=limit.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nconst formats_1 = require(\"./formats\");\nconst limit_1 = require(\"./limit\");\nconst codegen_1 = require(\"ajv/dist/compile/codegen\");\nconst fullName = new codegen_1.Name(\"fullFormats\");\nconst fastName = new codegen_1.Name(\"fastFormats\");\nconst formatsPlugin = (ajv, opts = { keywords: true }) => {\n if (Array.isArray(opts)) {\n addFormats(ajv, opts, formats_1.fullFormats, fullName);\n return ajv;\n }\n const [formats, exportName] = opts.mode === \"fast\" ? [formats_1.fastFormats, fastName] : [formats_1.fullFormats, fullName];\n const list = opts.formats || formats_1.formatNames;\n addFormats(ajv, list, formats, exportName);\n if (opts.keywords)\n limit_1.default(ajv);\n return ajv;\n};\nformatsPlugin.get = (name, mode = \"full\") => {\n const formats = mode === \"fast\" ? formats_1.fastFormats : formats_1.fullFormats;\n const f = formats[name];\n if (!f)\n throw new Error(`Unknown format \"${name}\"`);\n return f;\n};\nfunction addFormats(ajv, list, fs, exportName) {\n var _a;\n var _b;\n (_a = (_b = ajv.opts.code).formats) !== null && _a !== void 0 ? _a : (_b.formats = codegen_1._ `require(\"ajv-formats/dist/formats\").${exportName}`);\n for (const f of list)\n ajv.addFormat(f, fs[f]);\n}\nmodule.exports = exports = formatsPlugin;\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.default = formatsPlugin;\n//# sourceMappingURL=index.js.map","import toPath from 'lodash-es/toPath';\nimport isPlainObject from 'lodash-es/isPlainObject';\nimport clone from 'lodash-es/clone';\nimport { ADDITIONAL_PROPERTY_FLAG, RJSF_ADDITONAL_PROPERTIES_FLAG, ErrorSchemaBuilder, ERRORS_KEY, getUiOptions, PROPERTIES_KEY, getDefaultFormState, mergeValidationData, REF_KEY } from '@rjsf/utils';\nimport get from 'lodash-es/get';\nimport Ajv from 'ajv';\nimport addFormats from 'ajv-formats';\nimport isObject from 'lodash-es/isObject';\n\nfunction _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\n\nvar AJV_CONFIG = {\n allErrors: true,\n multipleOfPrecision: 8,\n strict: false,\n verbose: true\n};\nvar COLOR_FORMAT_REGEX = /^(#?([0-9A-Fa-f]{3}){1,2}\\b|aqua|black|blue|fuchsia|gray|green|lime|maroon|navy|olive|orange|purple|red|silver|teal|white|yellow|(rgb\\(\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*,\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*,\\s*\\b([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\\b\\s*\\))|(rgb\\(\\s*(\\d?\\d%|100%)+\\s*,\\s*(\\d?\\d%|100%)+\\s*,\\s*(\\d?\\d%|100%)+\\s*\\)))$/;\nvar DATA_URL_FORMAT_REGEX = /^data:([a-z]+\\/[a-z0-9-+.]+)?;(?:name=(.*);)?base64,(.*)$/;\n/** Creates an Ajv version 8 implementation object with standard support for the 'color` and `data-url` custom formats.\r\n * If `additionalMetaSchemas` are provided then the Ajv instance is modified to add each of the meta schemas in the\r\n * list. If `customFormats` are provided then those additional formats are added to the list of supported formats. If\r\n * `ajvOptionsOverrides` are provided then they are spread on top of the default `AJV_CONFIG` options when constructing\r\n * the `Ajv` instance. With Ajv v8, the JSON Schema formats are not provided by default, but can be plugged in. By\r\n * default, all formats from the `ajv-formats` library are added. To disable this capability, set the `ajvFormatOptions`\r\n * parameter to `false`. Additionally, you can configure the `ajv-formats` by providing a custom set of\r\n * [format options](https://github.com/ajv-validator/ajv-formats) to the `ajvFormatOptions` parameter.\r\n *\r\n * @param [additionalMetaSchemas] - The list of additional meta schemas that the validator can access\r\n * @param [customFormats] - The set of additional custom formats that the validator will support\r\n * @param [ajvOptionsOverrides={}] - The set of validator config override options\r\n * @param [ajvFormatOptions] - The `ajv-format` options to use when adding formats to `ajv`; pass `false` to disable it\r\n * @param [AjvClass] - The `Ajv` class to use when creating the validator instance\r\n */\nfunction createAjvInstance(additionalMetaSchemas, customFormats, ajvOptionsOverrides, ajvFormatOptions, AjvClass) {\n if (ajvOptionsOverrides === void 0) {\n ajvOptionsOverrides = {};\n }\n if (AjvClass === void 0) {\n AjvClass = Ajv;\n }\n var ajv = new AjvClass(_extends({}, AJV_CONFIG, ajvOptionsOverrides));\n if (ajvFormatOptions) {\n addFormats(ajv, ajvFormatOptions);\n } else if (ajvFormatOptions !== false) {\n addFormats(ajv);\n }\n // add custom formats\n ajv.addFormat('data-url', DATA_URL_FORMAT_REGEX);\n ajv.addFormat('color', COLOR_FORMAT_REGEX);\n // Add RJSF-specific additional properties keywords so Ajv doesn't report errors if strict is enabled.\n ajv.addKeyword(ADDITIONAL_PROPERTY_FLAG);\n ajv.addKeyword(RJSF_ADDITONAL_PROPERTIES_FLAG);\n // add more schemas to validate against\n if (Array.isArray(additionalMetaSchemas)) {\n ajv.addMetaSchema(additionalMetaSchemas);\n }\n // add more custom formats to validate against\n if (isObject(customFormats)) {\n Object.keys(customFormats).forEach(function (formatName) {\n ajv.addFormat(formatName, customFormats[formatName]);\n });\n }\n return ajv;\n}\n\nvar _excluded = [\"instancePath\", \"keyword\", \"params\", \"schemaPath\", \"parentSchema\"];\nvar ROOT_SCHEMA_PREFIX = '__rjsf_rootSchema';\n/** `ValidatorType` implementation that uses the AJV 8 validation mechanism.\r\n */\nvar AJV8Validator = /*#__PURE__*/function () {\n /** The AJV instance to use for all validations\r\n *\r\n * @private\r\n */\n\n /** The Localizer function to use for localizing Ajv errors\r\n *\r\n * @private\r\n */\n\n /** Constructs an `AJV8Validator` instance using the `options`\r\n *\r\n * @param options - The `CustomValidatorOptionsType` options that are used to create the AJV instance\r\n * @param [localizer] - If provided, is used to localize a list of Ajv `ErrorObject`s\r\n */\n function AJV8Validator(options, localizer) {\n this.ajv = void 0;\n this.localizer = void 0;\n var additionalMetaSchemas = options.additionalMetaSchemas,\n customFormats = options.customFormats,\n ajvOptionsOverrides = options.ajvOptionsOverrides,\n ajvFormatOptions = options.ajvFormatOptions,\n AjvClass = options.AjvClass;\n this.ajv = createAjvInstance(additionalMetaSchemas, customFormats, ajvOptionsOverrides, ajvFormatOptions, AjvClass);\n this.localizer = localizer;\n }\n /** Transforms a ajv validation errors list:\r\n * [\r\n * {property: '.level1.level2[2].level3', message: 'err a'},\r\n * {property: '.level1.level2[2].level3', message: 'err b'},\r\n * {property: '.level1.level2[4].level3', message: 'err b'},\r\n * ]\r\n * Into an error tree:\r\n * {\r\n * level1: {\r\n * level2: {\r\n * 2: {level3: {errors: ['err a', 'err b']}},\r\n * 4: {level3: {errors: ['err b']}},\r\n * }\r\n * }\r\n * };\r\n *\r\n * @param errors - The list of RJSFValidationError objects\r\n * @private\r\n */\n var _proto = AJV8Validator.prototype;\n _proto.toErrorSchema = function toErrorSchema(errors) {\n var builder = new ErrorSchemaBuilder();\n if (errors.length) {\n errors.forEach(function (error) {\n var property = error.property,\n message = error.message;\n var path = toPath(property);\n // If the property is at the root (.level1) then toPath creates\n // an empty array element at the first index. Remove it.\n if (path.length > 0 && path[0] === '') {\n path.splice(0, 1);\n }\n if (message) {\n builder.addErrors(message, path);\n }\n });\n }\n return builder.ErrorSchema;\n }\n /** Converts an `errorSchema` into a list of `RJSFValidationErrors`\r\n *\r\n * @param errorSchema - The `ErrorSchema` instance to convert\r\n * @param [fieldPath=[]] - The current field path, defaults to [] if not specified\r\n */;\n _proto.toErrorList = function toErrorList(errorSchema, fieldPath) {\n var _this = this;\n if (fieldPath === void 0) {\n fieldPath = [];\n }\n if (!errorSchema) {\n return [];\n }\n var errorList = [];\n if (ERRORS_KEY in errorSchema) {\n errorList = errorList.concat(errorSchema[ERRORS_KEY].map(function (message) {\n var property = \".\" + fieldPath.join('.');\n return {\n property: property,\n message: message,\n stack: property + \" \" + message\n };\n }));\n }\n return Object.keys(errorSchema).reduce(function (acc, key) {\n if (key !== ERRORS_KEY) {\n var childSchema = errorSchema[key];\n if (isPlainObject(childSchema)) {\n acc = acc.concat(_this.toErrorList(childSchema, [].concat(fieldPath, [key])));\n }\n }\n return acc;\n }, errorList);\n }\n /** Given a `formData` object, recursively creates a `FormValidation` error handling structure around it\r\n *\r\n * @param formData - The form data around which the error handler is created\r\n * @private\r\n */;\n _proto.createErrorHandler = function createErrorHandler(formData) {\n var _this2 = this;\n var handler = {\n // We store the list of errors for this node in a property named __errors\n // to avoid name collision with a possible sub schema field named\n // 'errors' (see `utils.toErrorSchema`).\n __errors: [],\n addError: function addError(message) {\n this.__errors.push(message);\n }\n };\n if (Array.isArray(formData)) {\n return formData.reduce(function (acc, value, key) {\n var _extends2;\n return _extends({}, acc, (_extends2 = {}, _extends2[key] = _this2.createErrorHandler(value), _extends2));\n }, handler);\n }\n if (isPlainObject(formData)) {\n var formObject = formData;\n return Object.keys(formObject).reduce(function (acc, key) {\n var _extends3;\n return _extends({}, acc, (_extends3 = {}, _extends3[key] = _this2.createErrorHandler(formObject[key]), _extends3));\n }, handler);\n }\n return handler;\n }\n /** Unwraps the `errorHandler` structure into the associated `ErrorSchema`, stripping the `addError` functions from it\r\n *\r\n * @param errorHandler - The `FormValidation` error handling structure\r\n * @private\r\n */;\n _proto.unwrapErrorHandler = function unwrapErrorHandler(errorHandler) {\n var _this3 = this;\n return Object.keys(errorHandler).reduce(function (acc, key) {\n if (key === 'addError') {\n return acc;\n } else {\n var _extends5;\n var childSchema = errorHandler[key];\n if (isPlainObject(childSchema)) {\n var _extends4;\n return _extends({}, acc, (_extends4 = {}, _extends4[key] = _this3.unwrapErrorHandler(childSchema), _extends4));\n }\n return _extends({}, acc, (_extends5 = {}, _extends5[key] = childSchema, _extends5));\n }\n }, {});\n }\n /** Transforming the error output from ajv to format used by @rjsf/utils.\r\n * At some point, components should be updated to support ajv.\r\n *\r\n * @param errors - The list of AJV errors to convert to `RJSFValidationErrors`\r\n * @protected\r\n */;\n _proto.transformRJSFValidationErrors = function transformRJSFValidationErrors(errors, uiSchema) {\n if (errors === void 0) {\n errors = [];\n }\n return errors.map(function (e) {\n var instancePath = e.instancePath,\n keyword = e.keyword,\n params = e.params,\n schemaPath = e.schemaPath,\n parentSchema = e.parentSchema,\n rest = _objectWithoutPropertiesLoose(e, _excluded);\n var _rest$message = rest.message,\n message = _rest$message === void 0 ? '' : _rest$message;\n var property = instancePath.replace(/\\//g, '.');\n var stack = (property + \" \" + message).trim();\n if ('missingProperty' in params) {\n property = property ? property + \".\" + params.missingProperty : params.missingProperty;\n var currentProperty = params.missingProperty;\n var uiSchemaTitle = getUiOptions(get(uiSchema, \"\" + property.replace(/^\\./, ''))).title;\n if (uiSchemaTitle) {\n message = message.replace(currentProperty, uiSchemaTitle);\n } else {\n var parentSchemaTitle = get(parentSchema, [PROPERTIES_KEY, currentProperty, 'title']);\n if (parentSchemaTitle) {\n message = message.replace(currentProperty, parentSchemaTitle);\n }\n }\n stack = message;\n } else {\n var _uiSchemaTitle = getUiOptions(get(uiSchema, \"\" + property.replace(/^\\./, ''))).title;\n if (_uiSchemaTitle) {\n stack = (\"'\" + _uiSchemaTitle + \"' \" + message).trim();\n } else {\n var _parentSchemaTitle = parentSchema === null || parentSchema === void 0 ? void 0 : parentSchema.title;\n if (_parentSchemaTitle) {\n stack = (\"'\" + _parentSchemaTitle + \"' \" + message).trim();\n }\n }\n }\n // put data in expected format\n return {\n name: keyword,\n property: property,\n message: message,\n params: params,\n stack: stack,\n schemaPath: schemaPath\n };\n });\n }\n /** Runs the pure validation of the `schema` and `formData` without any of the RJSF functionality. Provided for use\r\n * by the playground. Returns the `errors` from the validation\r\n *\r\n * @param schema - The schema against which to validate the form data * @param schema\r\n * @param formData - The form data to validate\r\n */;\n _proto.rawValidation = function rawValidation(schema, formData) {\n var compilationError = undefined;\n var compiledValidator;\n if (schema['$id']) {\n compiledValidator = this.ajv.getSchema(schema['$id']);\n }\n try {\n if (compiledValidator === undefined) {\n compiledValidator = this.ajv.compile(schema);\n }\n compiledValidator(formData);\n } catch (err) {\n compilationError = err;\n }\n var errors;\n if (compiledValidator) {\n if (typeof this.localizer === 'function') {\n this.localizer(compiledValidator.errors);\n }\n errors = compiledValidator.errors || undefined;\n // Clear errors to prevent persistent errors, see #1104\n compiledValidator.errors = null;\n }\n return {\n errors: errors,\n validationError: compilationError\n };\n }\n /** This function processes the `formData` with an optional user contributed `customValidate` function, which receives\r\n * the form data and a `errorHandler` function that will be used to add custom validation errors for each field. Also\r\n * supports a `transformErrors` function that will take the raw AJV validation errors, prior to custom validation and\r\n * transform them in what ever way it chooses.\r\n *\r\n * @param formData - The form data to validate\r\n * @param schema - The schema against which to validate the form data\r\n * @param [customValidate] - An optional function that is used to perform custom validation\r\n * @param [transformErrors] - An optional function that is used to transform errors after AJV validation\r\n * @param [uiSchema] - An optional uiSchema that is passed to `transformErrors` and `customValidate`\r\n */;\n _proto.validateFormData = function validateFormData(formData, schema, customValidate, transformErrors, uiSchema) {\n var rawErrors = this.rawValidation(schema, formData);\n var invalidSchemaError = rawErrors.validationError;\n var errors = this.transformRJSFValidationErrors(rawErrors.errors, uiSchema);\n if (invalidSchemaError) {\n errors = [].concat(errors, [{\n stack: invalidSchemaError.message\n }]);\n }\n if (typeof transformErrors === 'function') {\n errors = transformErrors(errors, uiSchema);\n }\n var errorSchema = this.toErrorSchema(errors);\n if (invalidSchemaError) {\n errorSchema = _extends({}, errorSchema, {\n $schema: {\n __errors: [invalidSchemaError.message]\n }\n });\n }\n if (typeof customValidate !== 'function') {\n return {\n errors: errors,\n errorSchema: errorSchema\n };\n }\n // Include form data with undefined values, which is required for custom validation.\n var newFormData = getDefaultFormState(this, schema, formData, schema, true);\n var errorHandler = customValidate(newFormData, this.createErrorHandler(newFormData), uiSchema);\n var userErrorSchema = this.unwrapErrorHandler(errorHandler);\n return mergeValidationData(this, {\n errors: errors,\n errorSchema: errorSchema\n }, userErrorSchema);\n }\n /** Takes a `node` object and transforms any contained `$ref` node variables with a prefix, recursively calling\r\n * `withIdRefPrefix` for any other elements.\r\n *\r\n * @param node - The object node to which a ROOT_SCHEMA_PREFIX is added when a REF_KEY is part of it\r\n * @private\r\n */;\n _proto.withIdRefPrefixObject = function withIdRefPrefixObject(node) {\n for (var key in node) {\n var realObj = node;\n var value = realObj[key];\n if (key === REF_KEY && typeof value === 'string' && value.startsWith('#')) {\n realObj[key] = ROOT_SCHEMA_PREFIX + value;\n } else {\n realObj[key] = this.withIdRefPrefix(value);\n }\n }\n return node;\n }\n /** Takes a `node` object list and transforms any contained `$ref` node variables with a prefix, recursively calling\r\n * `withIdRefPrefix` for any other elements.\r\n *\r\n * @param node - The list of object nodes to which a ROOT_SCHEMA_PREFIX is added when a REF_KEY is part of it\r\n * @private\r\n */;\n _proto.withIdRefPrefixArray = function withIdRefPrefixArray(node) {\n for (var i = 0; i < node.length; i++) {\n node[i] = this.withIdRefPrefix(node[i]);\n }\n return node;\n }\n /** Validates data against a schema, returning true if the data is valid, or\r\n * false otherwise. If the schema is invalid, then this function will return\r\n * false.\r\n *\r\n * @param schema - The schema against which to validate the form data\r\n * @param formData - The form data to validate\r\n * @param rootSchema - The root schema used to provide $ref resolutions\r\n */;\n _proto.isValid = function isValid(schema, formData, rootSchema) {\n var _rootSchema$$id;\n var rootSchemaId = (_rootSchema$$id = rootSchema['$id']) != null ? _rootSchema$$id : ROOT_SCHEMA_PREFIX;\n try {\n // add the rootSchema ROOT_SCHEMA_PREFIX as id.\n // then rewrite the schema ref's to point to the rootSchema\n // this accounts for the case where schema have references to models\n // that lives in the rootSchema but not in the schema in question.\n if (this.ajv.getSchema(rootSchemaId) === undefined) {\n this.ajv.addSchema(rootSchema, rootSchemaId);\n }\n var schemaWithIdRefPrefix = this.withIdRefPrefix(schema);\n var compiledValidator;\n if (schemaWithIdRefPrefix['$id']) {\n compiledValidator = this.ajv.getSchema(schemaWithIdRefPrefix['$id']);\n }\n if (compiledValidator === undefined) {\n compiledValidator = this.ajv.compile(schemaWithIdRefPrefix);\n }\n var result = compiledValidator(formData);\n return result;\n } catch (e) {\n console.warn('Error encountered compiling schema:', e);\n return false;\n } finally {\n // TODO: A function should be called if the root schema changes so we don't have to remove and recompile the schema every run.\n // make sure we remove the rootSchema from the global ajv instance\n this.ajv.removeSchema(rootSchemaId);\n }\n }\n /** Recursively prefixes all $ref's in a schema with `ROOT_SCHEMA_PREFIX`\r\n * This is used in isValid to make references to the rootSchema\r\n *\r\n * @param schemaNode - The object node to which a ROOT_SCHEMA_PREFIX is added when a REF_KEY is part of it\r\n * @protected\r\n */;\n _proto.withIdRefPrefix = function withIdRefPrefix(schemaNode) {\n if (Array.isArray(schemaNode)) {\n return this.withIdRefPrefixArray([].concat(schemaNode));\n }\n if (isPlainObject(schemaNode)) {\n return this.withIdRefPrefixObject(clone(schemaNode));\n }\n return schemaNode;\n };\n return AJV8Validator;\n}();\n\n/** Creates and returns a customized implementation of the `ValidatorType` with the given customization `options` if\r\n * provided.\r\n *\r\n * @param [options={}] - The `CustomValidatorOptionsType` options that are used to create the `ValidatorType` instance\r\n * @param [localizer] - If provided, is used to localize a list of Ajv `ErrorObject`s\r\n */\nfunction customizeValidator(options, localizer) {\n if (options === void 0) {\n options = {};\n }\n return new AJV8Validator(options, localizer);\n}\n\nvar index = /*#__PURE__*/customizeValidator();\n\nexport { customizeValidator, index as default };\n//# sourceMappingURL=validator-ajv8.esm.js.map\n","import { urlAlphabet } from './url-alphabet/index.js'\nlet random = bytes => crypto.getRandomValues(new Uint8Array(bytes))\nlet customRandom = (alphabet, defaultSize, getRandom) => {\n let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1\n let step = -~((1.6 * mask * defaultSize) / alphabet.length)\n return (size = defaultSize) => {\n let id = ''\n while (true) {\n let bytes = getRandom(step)\n let j = step\n while (j--) {\n id += alphabet[bytes[j] & mask] || ''\n if (id.length === size) return id\n }\n }\n }\n}\nlet customAlphabet = (alphabet, size = 21) =>\n customRandom(alphabet, size, random)\nlet nanoid = (size = 21) =>\n crypto.getRandomValues(new Uint8Array(size)).reduce((id, byte) => {\n byte &= 63\n if (byte < 36) {\n id += byte.toString(36)\n } else if (byte < 62) {\n id += (byte - 26).toString(36).toUpperCase()\n } else if (byte > 62) {\n id += '-'\n } else {\n id += '_'\n }\n return id\n }, '')\nexport { nanoid, customAlphabet, customRandom, urlAlphabet, random }\n","import*as t from\"react\";function n(){return n=Object.assign||function(t){for(var n=1;n(t[n.toLowerCase()]=n,t),{for:\"htmlFor\"}),o={amp:\"&\",apos:\"'\",gt:\">\",lt:\"<\",nbsp:\" \",quot:\"“\"},c=[\"style\",\"script\"],a=/([-A-Z0-9_:]+)(?:\\s*=\\s*(?:(?:\"((?:\\\\.|[^\"])*)\")|(?:'((?:\\\\.|[^'])*)')|(?:\\{((?:\\\\.|{[^}]*?}|[^}])*)\\})))?/gi,_=/mailto:/i,u=/\\n{2,}$/,i=/^( *>[^\\n]+(\\n[^\\n]+)*\\n*)+\\n{2,}/,l=/^ *> ?/gm,s=/^ {2,}\\n/,f=/^(?:( *[-*_])){3,} *(?:\\n *)+\\n/,d=/^\\s*(`{3,}|~{3,}) *(\\S+)?([^\\n]*?)?\\n([\\s\\S]+?)\\s*\\1 *(?:\\n *)*\\n?/,p=/^(?: {4}[^\\n]+\\n*)+(?:\\n *)+\\n?/,m=/^(`+)\\s*([\\s\\S]*?[^`])\\s*\\1(?!`)/,g=/^(?:\\n *)*\\n/,y=/\\r\\n?/g,h=/^\\[\\^([^\\]]+)](:.*)\\n/,k=/^\\[\\^([^\\]]+)]/,x=/\\f/g,b=/^\\s*?\\[(x|\\s)\\]/,v=/^ *(#{1,6}) *([^\\n]+?)(?: +#*)?(?:\\n *)*(?:\\n|$)/,$=/^([^\\n]+)\\n *(=|-){3,} *(?:\\n *)+\\n/,S=/^ *(?!<[a-z][^ >/]* ?\\/>)<([a-z][^ >/]*) ?([^>]*)\\/{0}>\\n?(\\s*(?:<\\1[^>]*?>[\\s\\S]*?<\\/\\1>|(?!<\\1)[\\s\\S])*?)<\\/\\1>\\n*/i,z=/&([a-zA-Z]+);/g,w=/^)/,A=/^(data|aria|x)-[a-z_][a-z\\d_.-]*$/,E=/^ *<([a-z][a-z0-9:]*)(?:\\s+((?:<.*?>|[^>])*))?\\/?>(?!<\\/\\1>)(\\s*\\n)?/i,L=/^\\{.*\\}$/,M=/^(https?:\\/\\/[^\\s<]+[^<.,:;\"')\\]\\s])/,I=/^<([^ >]+@[^ >]+)>/,O=/^<([^ >]+:\\/[^ >]+)>/,B=/-([a-z])?/gi,R=/^(.*\\|?.*)\\n *(\\|? *[-:]+ *\\|[-| :]*)\\n((?:.*\\|.*\\n)*)\\n?/,T=/^\\[([^\\]]*)\\]:\\s+]+)>?\\s*(\"([^\"]*)\")?/,j=/^!\\[([^\\]]*)\\] ?\\[([^\\]]*)\\]/,C=/^\\[([^\\]]*)\\] ?\\[([^\\]]*)\\]/,D=/(\\[|\\])/g,N=/(\\n|^[-*]\\s|^#|^ {2,}|^-{2,}|^>\\s)/,Z=/\\t/g,F=/^ *\\| */,P=/(^ *\\||\\| *$)/g,G=/ *$/,H=/^ *:-+: *$/,q=/^ *:-+ *$/,U=/^ *-+: *$/,V=/^([*_])\\1((?:\\[.*?\\][([].*?[)\\]]|<.*?>(?:.*?<.*?>)?|`.*?`|~+.*?~+|.)*?)\\1\\1(?!\\1)/,W=/^([*_])((?:\\[.*?\\][([].*?[)\\]]|<.*?>(?:.*?<.*?>)?|`.*?`|~+.*?~+|.)*?)\\1(?!\\1|\\w)/,Q=/^==((?:\\[.*?\\]|<.*?>(?:.*?<.*?>)?|`.*?`|.)*?)==/,X=/^~~((?:\\[.*?\\]|<.*?>(?:.*?<.*?>)?|`.*?`|.)*?)~~/,J=/^\\\\([^0-9A-Za-z\\s])/,K=/^[\\s\\S]+?(?=[^0-9A-Z\\s\\u00c0-\\uffff&;.()'\"]|\\d+\\.|\\n\\n| {2,}\\n|\\w+:\\S|$)/i,Y=/^\\n+/,tt=/^([ \\t]*)/,nt=/\\\\([^\\\\])/g,et=/ *\\n+$/,rt=/(?:^|\\n)( *)$/,ot=\"(?:\\\\d+\\\\.)\",ct=\"(?:[*+-])\";function at(t){return\"( *)(\"+(1===t?ot:ct)+\") +\"}const _t=at(1),ut=at(2);function it(t){return new RegExp(\"^\"+(1===t?_t:ut))}const lt=it(1),st=it(2);function ft(t){return new RegExp(\"^\"+(1===t?_t:ut)+\"[^\\\\n]*(?:\\\\n(?!\\\\1\"+(1===t?ot:ct)+\" )[^\\\\n]*)*(\\\\n|$)\",\"gm\")}const dt=ft(1),pt=ft(2);function mt(t){const n=1===t?ot:ct;return new RegExp(\"^( *)(\"+n+\") [\\\\s\\\\S]+?(?:\\\\n{2,}(?! )(?!\\\\1\"+n+\" (?!\"+n+\" ))\\\\n*|\\\\s*\\\\n*$)\")}const gt=mt(1),yt=mt(2);function ht(t,n){const e=1===n,r=e?gt:yt,o=e?dt:pt,c=e?lt:st;return{t(t,n,e){const o=rt.exec(e);return o&&(n.o||!n._&&!n.u)?r.exec(t=o[1]+t):null},i:Gt.HIGH,l(t,n,r){const a=e?+t[2]:void 0,_=t[0].replace(u,\"\\n\").match(o);let i=!1;return{p:_.map(function(t,e){const o=c.exec(t)[0].length,a=new RegExp(\"^ {1,\"+o+\"}\",\"gm\"),u=t.replace(a,\"\").replace(c,\"\"),l=e===_.length-1,s=-1!==u.indexOf(\"\\n\\n\")||l&&i;i=s;const f=r._,d=r.o;let p;r.o=!0,s?(r._=!1,p=u.replace(et,\"\\n\\n\")):(r._=!0,p=u.replace(et,\"\"));const m=n(p,r);return r._=f,r.o=d,m}),m:e,g:a}},h:(n,e,r)=>t(n.m?\"ol\":\"ul\",{key:r.k,start:n.g},n.p.map(function(n,o){return t(\"li\",{key:o},e(n,r))}))}}const kt=/^\\[([^\\]]*)]\\( *((?:\\([^)]*\\)|[^() ])*) *\"?([^)\"]*)?\"?\\)/,xt=/^!\\[([^\\]]*)]\\( *((?:\\([^)]*\\)|[^() ])*) *\"?([^)\"]*)?\"?\\)/,bt=[i,d,p,v,$,w,R,dt,gt,pt,yt],vt=[...bt,/^[^\\n]+(?: \\n|\\n{2,})/,S,E];function $t(t){return t.replace(/[ÀÁÂÃÄÅàáâãäåæÆ]/g,\"a\").replace(/[çÇ]/g,\"c\").replace(/[ðÐ]/g,\"d\").replace(/[ÈÉÊËéèêë]/g,\"e\").replace(/[ÏïÎîÍíÌì]/g,\"i\").replace(/[Ññ]/g,\"n\").replace(/[øØœŒÕõÔôÓóÒò]/g,\"o\").replace(/[ÜüÛûÚúÙù]/g,\"u\").replace(/[ŸÿÝý]/g,\"y\").replace(/[^a-z0-9- ]/gi,\"\").replace(/ /gi,\"-\").toLowerCase()}function St(t){return U.test(t)?\"right\":H.test(t)?\"center\":q.test(t)?\"left\":null}function zt(t,n,e){const r=e.v;e.v=!0;const o=n(t.trim(),e);e.v=r;let c=[[]];return o.forEach(function(t,n){\"tableSeparator\"===t.type?0!==n&&n!==o.length-1&&c.push([]):(\"text\"!==t.type||null!=o[n+1]&&\"tableSeparator\"!==o[n+1].type||(t.$=t.$.replace(G,\"\")),c[c.length-1].push(t))}),c}function wt(t,n,e){e._=!0;const r=zt(t[1],n,e),o=t[2].replace(P,\"\").split(\"|\").map(St),c=function(t,n,e){return t.trim().split(\"\\n\").map(function(t){return zt(t,n,e)})}(t[3],n,e);return e._=!1,{S:o,A:c,L:r,type:\"table\"}}function At(t,n){return null==t.S[n]?{}:{textAlign:t.S[n]}}function Et(t){return function(n,e){return e._?t.exec(n):null}}function Lt(t){return function(n,e){return e._||e.u?t.exec(n):null}}function Mt(t){return function(n,e){return e._||e.u?null:t.exec(n)}}function It(t){return function(n){return t.exec(n)}}function Ot(t,n,e){if(n._||n.u)return null;if(e&&!e.endsWith(\"\\n\"))return null;let r=\"\";t.split(\"\\n\").every(t=>!bt.some(n=>n.test(t))&&(r+=t+\"\\n\",t.trim()));const o=r.trimEnd();return\"\"==o?null:[r,o]}function Bt(t){try{if(decodeURIComponent(t).replace(/[^A-Za-z0-9/:]/g,\"\").match(/^\\s*(javascript|vbscript|data(?!:image)):/i))return null}catch(t){return null}return t}function Rt(t){return t.replace(nt,\"$1\")}function Tt(t,n,e){const r=e._||!1,o=e.u||!1;e._=!0,e.u=!0;const c=t(n,e);return e._=r,e.u=o,c}function jt(t,n,e){const r=e._||!1,o=e.u||!1;e._=!1,e.u=!0;const c=t(n,e);return e._=r,e.u=o,c}function Ct(t,n,e){return e._=!1,t(n+\"\\n\\n\",e)}const Dt=(t,n,e)=>({$:Tt(n,t[1],e)});function Nt(){return{}}function Zt(){return null}function Ft(...t){return t.filter(Boolean).join(\" \")}function Pt(t,n,e){let r=t;const o=n.split(\".\");for(;o.length&&(r=r[o[0]],void 0!==r);)o.shift();return r||e}var Gt;function Ht(e,u={}){u.overrides=u.overrides||{},u.slugify=u.slugify||$t,u.namedCodesToUnicode=u.namedCodesToUnicode?n({},o,u.namedCodesToUnicode):o;const P=u.createElement||t.createElement;function G(t,e,...r){const o=Pt(u.overrides,`${t}.props`,{});return P(function(t,n){const e=Pt(n,t);return e?\"function\"==typeof e||\"object\"==typeof e&&\"render\"in e?e:Pt(n,`${t}.component`,t):t}(t,u.overrides),n({},e,o,{className:Ft(null==e?void 0:e.className,o.className)||void 0}),...r)}function H(n){let e=!1;u.forceInline?e=!0:u.forceBlock||(e=!1===N.test(n));const r=ot(rt(e?n:`${n.trimEnd().replace(Y,\"\")}\\n\\n`,{_:e}));for(;\"string\"==typeof r[r.length-1]&&!r[r.length-1].trim();)r.pop();if(null===u.wrapper)return r;const o=u.wrapper||(e?\"span\":\"div\");let c;if(r.length>1||u.forceWrapper)c=r;else{if(1===r.length)return c=r[0],\"string\"==typeof c?G(\"span\",{key:\"outer\"},c):c;c=null}return t.createElement(o,{key:\"outer\"},c)}function q(n){const e=n.match(a);return e?e.reduce(function(n,e,o){const c=e.indexOf(\"=\");if(-1!==c){const a=function(t){return-1!==t.indexOf(\"-\")&&null===t.match(A)&&(t=t.replace(B,function(t,n){return n.toUpperCase()})),t}(e.slice(0,c)).trim(),_=function(t){const n=t[0];return('\"'===n||\"'\"===n)&&t.length>=2&&t[t.length-1]===n?t.slice(1,-1):t}(e.slice(c+1).trim()),u=r[a]||a,i=n[u]=function(t,n){return\"style\"===t?n.split(/;\\s?/).reduce(function(t,n){const e=n.slice(0,n.indexOf(\":\"));return t[e.replace(/(-[a-z])/g,t=>t[1].toUpperCase())]=n.slice(e.length+1).trim(),t},{}):\"href\"===t?Bt(n):(n.match(L)&&(n=n.slice(1,n.length-1)),\"true\"===n||\"false\"!==n&&n)}(a,_);\"string\"==typeof i&&(S.test(i)||E.test(i))&&(n[u]=t.cloneElement(H(i.trim()),{key:o}))}else\"style\"!==e&&(n[r[e]||e]=!0);return n},{}):null}const U=[],nt={},et={blockQuote:{t:Mt(i),i:Gt.HIGH,l:(t,n,e)=>({$:n(t[0].replace(l,\"\"),e)}),h:(t,n,e)=>G(\"blockquote\",{key:e.k},n(t.$,e))},breakLine:{t:It(s),i:Gt.HIGH,l:Nt,h:(t,n,e)=>G(\"br\",{key:e.k})},breakThematic:{t:Mt(f),i:Gt.HIGH,l:Nt,h:(t,n,e)=>G(\"hr\",{key:e.k})},codeBlock:{t:Mt(p),i:Gt.MAX,l:t=>({$:t[0].replace(/^ {4}/gm,\"\").replace(/\\n+$/,\"\"),M:void 0}),h:(t,e,r)=>G(\"pre\",{key:r.k},G(\"code\",n({},t.I,{className:t.M?`lang-${t.M}`:\"\"}),t.$))},codeFenced:{t:Mt(d),i:Gt.MAX,l:t=>({I:q(t[3]||\"\"),$:t[4],M:t[2]||void 0,type:\"codeBlock\"})},codeInline:{t:Lt(m),i:Gt.LOW,l:t=>({$:t[2]}),h:(t,n,e)=>G(\"code\",{key:e.k},t.$)},footnote:{t:Mt(h),i:Gt.MAX,l:t=>(U.push({O:t[2],B:t[1]}),{}),h:Zt},footnoteReference:{t:Et(k),i:Gt.HIGH,l:t=>({$:t[1],R:`#${u.slugify(t[1])}`}),h:(t,n,e)=>G(\"a\",{key:e.k,href:Bt(t.R)},G(\"sup\",{key:e.k},t.$))},gfmTask:{t:Et(b),i:Gt.HIGH,l:t=>({T:\"x\"===t[1].toLowerCase()}),h:(t,n,e)=>G(\"input\",{checked:t.T,key:e.k,readOnly:!0,type:\"checkbox\"})},heading:{t:Mt(v),i:Gt.HIGH,l:(t,n,e)=>({$:Tt(n,t[2],e),j:u.slugify(t[2]),C:t[1].length}),h:(t,n,e)=>G(`h${t.C}`,{id:t.j,key:e.k},n(t.$,e))},headingSetext:{t:Mt($),i:Gt.MAX,l:(t,n,e)=>({$:Tt(n,t[1],e),C:\"=\"===t[2]?1:2,type:\"heading\"})},htmlComment:{t:It(w),i:Gt.HIGH,l:()=>({}),h:Zt},image:{t:Lt(xt),i:Gt.HIGH,l:t=>({D:t[1],R:Rt(t[2]),N:t[3]}),h:(t,n,e)=>G(\"img\",{key:e.k,alt:t.D||void 0,title:t.N||void 0,src:Bt(t.R)})},link:{t:Et(kt),i:Gt.LOW,l:(t,n,e)=>({$:jt(n,t[1],e),R:Rt(t[2]),N:t[3]}),h:(t,n,e)=>G(\"a\",{key:e.k,href:Bt(t.R),title:t.N},n(t.$,e))},linkAngleBraceStyleDetector:{t:Et(O),i:Gt.MAX,l:t=>({$:[{$:t[1],type:\"text\"}],R:t[1],type:\"link\"})},linkBareUrlDetector:{t:(t,n)=>n.Z?null:Et(M)(t,n),i:Gt.MAX,l:t=>({$:[{$:t[1],type:\"text\"}],R:t[1],N:void 0,type:\"link\"})},linkMailtoDetector:{t:Et(I),i:Gt.MAX,l(t){let n=t[1],e=t[1];return _.test(e)||(e=\"mailto:\"+e),{$:[{$:n.replace(\"mailto:\",\"\"),type:\"text\"}],R:e,type:\"link\"}}},orderedList:ht(G,1),unorderedList:ht(G,2),newlineCoalescer:{t:Mt(g),i:Gt.LOW,l:Nt,h:()=>\"\\n\"},paragraph:{t:Ot,i:Gt.LOW,l:Dt,h:(t,n,e)=>G(\"p\",{key:e.k},n(t.$,e))},ref:{t:Et(T),i:Gt.MAX,l:t=>(nt[t[1]]={R:t[2],N:t[4]},{}),h:Zt},refImage:{t:Lt(j),i:Gt.MAX,l:t=>({D:t[1]||void 0,F:t[2]}),h:(t,n,e)=>G(\"img\",{key:e.k,alt:t.D,src:Bt(nt[t.F].R),title:nt[t.F].N})},refLink:{t:Et(C),i:Gt.MAX,l:(t,n,e)=>({$:n(t[1],e),P:n(t[0].replace(D,\"\\\\$1\"),e),F:t[2]}),h:(t,n,e)=>nt[t.F]?G(\"a\",{key:e.k,href:Bt(nt[t.F].R),title:nt[t.F].N},n(t.$,e)):G(\"span\",{key:e.k},n(t.P,e))},table:{t:Mt(R),i:Gt.HIGH,l:wt,h:(t,n,e)=>G(\"table\",{key:e.k},G(\"thead\",null,G(\"tr\",null,t.L.map(function(r,o){return G(\"th\",{key:o,style:At(t,o)},n(r,e))}))),G(\"tbody\",null,t.A.map(function(r,o){return G(\"tr\",{key:o},r.map(function(r,o){return G(\"td\",{key:o,style:At(t,o)},n(r,e))}))})))},tableSeparator:{t:function(t,n){return n.v?F.exec(t):null},i:Gt.HIGH,l:function(){return{type:\"tableSeparator\"}},h:()=>\" | \"},text:{t:It(K),i:Gt.MIN,l:t=>({$:t[0].replace(z,(t,n)=>u.namedCodesToUnicode[n]?u.namedCodesToUnicode[n]:t)}),h:t=>t.$},textBolded:{t:Lt(V),i:Gt.MED,l:(t,n,e)=>({$:n(t[2],e)}),h:(t,n,e)=>G(\"strong\",{key:e.k},n(t.$,e))},textEmphasized:{t:Lt(W),i:Gt.LOW,l:(t,n,e)=>({$:n(t[2],e)}),h:(t,n,e)=>G(\"em\",{key:e.k},n(t.$,e))},textEscaped:{t:Lt(J),i:Gt.HIGH,l:t=>({$:t[1],type:\"text\"})},textMarked:{t:Lt(Q),i:Gt.LOW,l:Dt,h:(t,n,e)=>G(\"mark\",{key:e.k},n(t.$,e))},textStrikethroughed:{t:Lt(X),i:Gt.LOW,l:Dt,h:(t,n,e)=>G(\"del\",{key:e.k},n(t.$,e))}};!0!==u.disableParsingRawHTML&&(et.htmlBlock={t:It(S),i:Gt.HIGH,l(t,n,e){const[,r]=t[3].match(tt),o=new RegExp(`^${r}`,\"gm\"),a=t[3].replace(o,\"\"),_=(u=a,vt.some(t=>t.test(u))?Ct:Tt);var u;const i=t[1].toLowerCase(),l=-1!==c.indexOf(i);e.Z=e.Z||\"a\"===i;const s=l?t[3]:_(n,a,e);return e.Z=!1,{I:q(t[2]),$:s,G:l,H:l?i:t[1]}},h:(t,e,r)=>G(t.H,n({key:r.k},t.I),t.G?t.$:e(t.$,r))},et.htmlSelfClosing={t:It(E),i:Gt.HIGH,l:t=>({I:q(t[2]||\"\"),H:t[1]}),h:(t,e,r)=>G(t.H,n({},t.I,{key:r.k}))});const rt=function(t){let n=Object.keys(t);function e(r,o){let c=[],a=\"\";for(;r;){let _=0;for(;_{let{children:r,options:o}=n,c=function(t,n){if(null==t)return{};var e,r,o={},c=Object.keys(t);for(r=0;r=0||(o[e]=t[e]);return o}(n,e);return t.cloneElement(Ht(r,o),c)};export{Ht as compiler};\n//# sourceMappingURL=index.modern.js.map\n","import { jsx, jsxs, Fragment } from 'react/jsx-runtime';\nimport { Component, useState, useCallback, useEffect, useReducer, useMemo, createRef, forwardRef } from 'react';\nimport { isFixedItems, allowAdditionalItems, getUiOptions, ITEMS_KEY, getTemplate, TranslatableString, isCustomWidget, getWidget, optionsList, deepEquals, ERRORS_KEY, asNumber, REF_KEY, orderProperties, PROPERTIES_KEY, ADDITIONAL_PROPERTY_FLAG, ANY_OF_KEY, ONE_OF_KEY, mergeObjects, UI_OPTIONS_KEY, descriptionId, getSchemaType, ID_KEY, hasWidget, titleId, getInputProps, examplesId, ariaDescribedByIds, getSubmitButtonOptions, errorId, helpId, canExpand, parseDateString, toDateString, pad, schemaRequiresTrueValue, labelValue, enumOptionsValueForIndex, enumOptionsIsSelected, optionId, enumOptionsSelectValue, enumOptionsDeselectValue, utcToLocal, localToUTC, dataURItoBlob, enumOptionsIndexForValue, englishStringTranslator, createSchemaUtils, shouldRender, UI_GLOBAL_OPTIONS_KEY, isObject as isObject$1, RJSF_ADDITONAL_PROPERTIES_FLAG, NAME_KEY } from '@rjsf/utils';\nimport get from 'lodash-es/get';\nimport isEmpty from 'lodash-es/isEmpty';\nimport _pick from 'lodash-es/pick';\nimport _toPath from 'lodash-es/toPath';\nimport cloneDeep from 'lodash-es/cloneDeep';\nimport isObject from 'lodash-es/isObject';\nimport set from 'lodash-es/set';\nimport { nanoid } from 'nanoid';\nimport omit from 'lodash-es/omit';\nimport Markdown from 'markdown-to-jsx';\nimport has from 'lodash-es/has';\nimport unset from 'lodash-es/unset';\n\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nfunction _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n _setPrototypeOf(subClass, superClass);\n}\nfunction _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\nfunction _toPrimitive(input, hint) {\n if (typeof input !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (typeof res !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nfunction _toPropertyKey(arg) {\n var key = _toPrimitive(arg, \"string\");\n return typeof key === \"symbol\" ? key : String(key);\n}\n\nvar _excluded$9 = [\"widget\", \"title\"],\n _excluded2 = [\"widget\", \"title\"],\n _excluded3 = [\"widget\", \"title\"];\n/** Used to generate a unique ID for an element in a row */\nfunction generateRowId() {\n return nanoid();\n}\n/** Converts the `formData` into `KeyedFormDataType` data, using the `generateRowId()` function to create the key\r\n *\r\n * @param formData - The data for the form\r\n * @returns - The `formData` converted into a `KeyedFormDataType` element\r\n */\nfunction generateKeyedFormData(formData) {\n return !Array.isArray(formData) ? [] : formData.map(function (item) {\n return {\n key: generateRowId(),\n item: item\n };\n });\n}\n/** Converts `KeyedFormDataType` data into the inner `formData`\r\n *\r\n * @param keyedFormData - The `KeyedFormDataType` to be converted\r\n * @returns - The inner `formData` item(s) in the `keyedFormData`\r\n */\nfunction keyedToPlainFormData(keyedFormData) {\n if (Array.isArray(keyedFormData)) {\n return keyedFormData.map(function (keyedItem) {\n return keyedItem.item;\n });\n }\n return [];\n}\n/** The `ArrayField` component is used to render a field in the schema that is of type `array`. It supports both normal\r\n * and fixed array, allowing user to add and remove elements from the array data.\r\n */\nvar ArrayField = /*#__PURE__*/function (_Component) {\n _inheritsLoose(ArrayField, _Component);\n /** Constructs an `ArrayField` from the `props`, generating the initial keyed data from the `formData`\r\n *\r\n * @param props - The `FieldProps` for this template\r\n */\n function ArrayField(props) {\n var _this;\n _this = _Component.call(this, props) || this;\n _this._getNewFormDataRow = function () {\n var _this$props = _this.props,\n schema = _this$props.schema,\n registry = _this$props.registry;\n var schemaUtils = registry.schemaUtils;\n var itemSchema = schema.items;\n if (isFixedItems(schema) && allowAdditionalItems(schema)) {\n itemSchema = schema.additionalItems;\n }\n // Cast this as a T to work around schema utils being for T[] caused by the FieldProps call on the class\n return schemaUtils.getDefaultFormState(itemSchema);\n };\n _this.onAddClick = function (event) {\n _this._handleAddClick(event);\n };\n _this.onAddIndexClick = function (index) {\n return function (event) {\n _this._handleAddClick(event, index);\n };\n };\n _this.onCopyIndexClick = function (index) {\n return function (event) {\n if (event) {\n event.preventDefault();\n }\n var onChange = _this.props.onChange;\n var keyedFormData = _this.state.keyedFormData;\n var newKeyedFormDataRow = {\n key: generateRowId(),\n item: cloneDeep(keyedFormData[index].item)\n };\n var newKeyedFormData = [].concat(keyedFormData);\n if (index !== undefined) {\n newKeyedFormData.splice(index + 1, 0, newKeyedFormDataRow);\n } else {\n newKeyedFormData.push(newKeyedFormDataRow);\n }\n _this.setState({\n keyedFormData: newKeyedFormData,\n updatedKeyedFormData: true\n }, function () {\n return onChange(keyedToPlainFormData(newKeyedFormData));\n });\n };\n };\n _this.onDropIndexClick = function (index) {\n return function (event) {\n if (event) {\n event.preventDefault();\n }\n var _this$props2 = _this.props,\n onChange = _this$props2.onChange,\n errorSchema = _this$props2.errorSchema;\n var keyedFormData = _this.state.keyedFormData;\n // refs #195: revalidate to ensure properly reindexing errors\n var newErrorSchema;\n if (errorSchema) {\n newErrorSchema = {};\n for (var idx in errorSchema) {\n var i = parseInt(idx);\n if (i < index) {\n set(newErrorSchema, [i], errorSchema[idx]);\n } else if (i > index) {\n set(newErrorSchema, [i - 1], errorSchema[idx]);\n }\n }\n }\n var newKeyedFormData = keyedFormData.filter(function (_, i) {\n return i !== index;\n });\n _this.setState({\n keyedFormData: newKeyedFormData,\n updatedKeyedFormData: true\n }, function () {\n return onChange(keyedToPlainFormData(newKeyedFormData), newErrorSchema);\n });\n };\n };\n _this.onReorderClick = function (index, newIndex) {\n return function (event) {\n if (event) {\n event.preventDefault();\n event.currentTarget.blur();\n }\n var _this$props3 = _this.props,\n onChange = _this$props3.onChange,\n errorSchema = _this$props3.errorSchema;\n var newErrorSchema;\n if (errorSchema) {\n newErrorSchema = {};\n for (var idx in errorSchema) {\n var i = parseInt(idx);\n if (i == index) {\n set(newErrorSchema, [newIndex], errorSchema[index]);\n } else if (i == newIndex) {\n set(newErrorSchema, [index], errorSchema[newIndex]);\n } else {\n set(newErrorSchema, [idx], errorSchema[i]);\n }\n }\n }\n var keyedFormData = _this.state.keyedFormData;\n function reOrderArray() {\n // Copy item\n var _newKeyedFormData = keyedFormData.slice();\n // Moves item from index to newIndex\n _newKeyedFormData.splice(index, 1);\n _newKeyedFormData.splice(newIndex, 0, keyedFormData[index]);\n return _newKeyedFormData;\n }\n var newKeyedFormData = reOrderArray();\n _this.setState({\n keyedFormData: newKeyedFormData\n }, function () {\n return onChange(keyedToPlainFormData(newKeyedFormData), newErrorSchema);\n });\n };\n };\n _this.onChangeForIndex = function (index) {\n return function (value, newErrorSchema, id) {\n var _extends2;\n var _this$props4 = _this.props,\n formData = _this$props4.formData,\n onChange = _this$props4.onChange,\n errorSchema = _this$props4.errorSchema;\n var arrayData = Array.isArray(formData) ? formData : [];\n var newFormData = arrayData.map(function (item, i) {\n // We need to treat undefined items as nulls to have validation.\n // See https://github.com/tdegrunt/jsonschema/issues/206\n var jsonValue = typeof value === 'undefined' ? null : value;\n return index === i ? jsonValue : item;\n });\n onChange(newFormData, errorSchema && errorSchema && _extends({}, errorSchema, (_extends2 = {}, _extends2[index] = newErrorSchema, _extends2)), id);\n };\n };\n _this.onSelectChange = function (value) {\n var _this$props5 = _this.props,\n onChange = _this$props5.onChange,\n idSchema = _this$props5.idSchema;\n onChange(value, undefined, idSchema && idSchema.$id);\n };\n var _props$formData = props.formData,\n _formData = _props$formData === void 0 ? [] : _props$formData;\n var _keyedFormData = generateKeyedFormData(_formData);\n _this.state = {\n keyedFormData: _keyedFormData,\n updatedKeyedFormData: false\n };\n return _this;\n }\n /** React lifecycle method that is called when the props are about to change allowing the state to be updated. It\r\n * regenerates the keyed form data and returns it\r\n *\r\n * @param nextProps - The next set of props data\r\n * @param prevState - The previous set of state data\r\n */\n ArrayField.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, prevState) {\n // Don't call getDerivedStateFromProps if keyed formdata was just updated.\n if (prevState.updatedKeyedFormData) {\n return {\n updatedKeyedFormData: false\n };\n }\n var nextFormData = Array.isArray(nextProps.formData) ? nextProps.formData : [];\n var previousKeyedFormData = prevState.keyedFormData || [];\n var newKeyedFormData = nextFormData.length === previousKeyedFormData.length ? previousKeyedFormData.map(function (previousKeyedFormDatum, index) {\n return {\n key: previousKeyedFormDatum.key,\n item: nextFormData[index]\n };\n }) : generateKeyedFormData(nextFormData);\n return {\n keyedFormData: newKeyedFormData\n };\n }\n /** Returns the appropriate title for an item by getting first the title from the schema.items, then falling back to\r\n * the description from the schema.items, and finally the string \"Item\"\r\n */;\n var _proto = ArrayField.prototype;\n /** Determines whether the item described in the schema is always required, which is determined by whether any item\r\n * may be null.\r\n *\r\n * @param itemSchema - The schema for the item\r\n * @return - True if the item schema type does not contain the \"null\" type\r\n */\n _proto.isItemRequired = function isItemRequired(itemSchema) {\n if (Array.isArray(itemSchema.type)) {\n // While we don't yet support composite/nullable jsonschema types, it's\n // future-proof to check for requirement against these.\n return !itemSchema.type.includes('null');\n }\n // All non-null array item types are inherently required by design\n return itemSchema.type !== 'null';\n }\n /** Determines whether more items can be added to the array. If the uiSchema indicates the array doesn't allow adding\r\n * then false is returned. Otherwise, if the schema indicates that there are a maximum number of items and the\r\n * `formData` matches that value, then false is returned, otherwise true is returned.\r\n *\r\n * @param formItems - The list of items in the form\r\n * @returns - True if the item is addable otherwise false\r\n */;\n _proto.canAddItem = function canAddItem(formItems) {\n var _this$props6 = this.props,\n schema = _this$props6.schema,\n uiSchema = _this$props6.uiSchema,\n registry = _this$props6.registry;\n var _getUiOptions = getUiOptions(uiSchema, registry.globalUiOptions),\n addable = _getUiOptions.addable;\n if (addable !== false) {\n // if ui:options.addable was not explicitly set to false, we can add\n // another item if we have not exceeded maxItems yet\n if (schema.maxItems !== undefined) {\n addable = formItems.length < schema.maxItems;\n } else {\n addable = true;\n }\n }\n return addable;\n }\n /** Returns the default form information for an item based on the schema for that item. Deals with the possibility\r\n * that the schema is fixed and allows additional items.\r\n */;\n /** Callback handler for when the user clicks on the add or add at index buttons. Creates a new row of keyed form data\r\n * either at the end of the list (when index is not specified) or inserted at the `index` when it is, adding it into\r\n * the state, and then returning `onChange()` with the plain form data converted from the keyed data\r\n *\r\n * @param event - The event for the click\r\n * @param [index] - The optional index at which to add the new data\r\n */\n _proto._handleAddClick = function _handleAddClick(event, index) {\n if (event) {\n event.preventDefault();\n }\n var onChange = this.props.onChange;\n var keyedFormData = this.state.keyedFormData;\n var newKeyedFormDataRow = {\n key: generateRowId(),\n item: this._getNewFormDataRow()\n };\n var newKeyedFormData = [].concat(keyedFormData);\n if (index !== undefined) {\n newKeyedFormData.splice(index, 0, newKeyedFormDataRow);\n } else {\n newKeyedFormData.push(newKeyedFormDataRow);\n }\n this.setState({\n keyedFormData: newKeyedFormData,\n updatedKeyedFormData: true\n }, function () {\n return onChange(keyedToPlainFormData(newKeyedFormData));\n });\n }\n /** Callback handler for when the user clicks on the add button. Creates a new row of keyed form data at the end of\r\n * the list, adding it into the state, and then returning `onChange()` with the plain form data converted from the\r\n * keyed data\r\n *\r\n * @param event - The event for the click\r\n */;\n /** Renders the `ArrayField` depending on the specific needs of the schema and uischema elements\r\n */\n _proto.render = function render() {\n var _this$props7 = this.props,\n schema = _this$props7.schema,\n uiSchema = _this$props7.uiSchema,\n idSchema = _this$props7.idSchema,\n registry = _this$props7.registry;\n var schemaUtils = registry.schemaUtils,\n translateString = registry.translateString;\n if (!(ITEMS_KEY in schema)) {\n var uiOptions = getUiOptions(uiSchema);\n var UnsupportedFieldTemplate = getTemplate('UnsupportedFieldTemplate', registry, uiOptions);\n return jsx(UnsupportedFieldTemplate, {\n schema: schema,\n idSchema: idSchema,\n reason: translateString(TranslatableString.MissingItems),\n registry: registry\n });\n }\n if (schemaUtils.isMultiSelect(schema)) {\n // If array has enum or uniqueItems set to true, call renderMultiSelect() to render the default multiselect widget or a custom widget, if specified.\n return this.renderMultiSelect();\n }\n if (isCustomWidget(uiSchema)) {\n return this.renderCustomWidget();\n }\n if (isFixedItems(schema)) {\n return this.renderFixedArray();\n }\n if (schemaUtils.isFilesArray(schema, uiSchema)) {\n return this.renderFiles();\n }\n return this.renderNormalArray();\n }\n /** Renders a normal array without any limitations of length\r\n */;\n _proto.renderNormalArray = function renderNormalArray() {\n var _this2 = this;\n var _this$props8 = this.props,\n schema = _this$props8.schema,\n _this$props8$uiSchema = _this$props8.uiSchema,\n uiSchema = _this$props8$uiSchema === void 0 ? {} : _this$props8$uiSchema,\n errorSchema = _this$props8.errorSchema,\n idSchema = _this$props8.idSchema,\n name = _this$props8.name,\n _this$props8$disabled = _this$props8.disabled,\n disabled = _this$props8$disabled === void 0 ? false : _this$props8$disabled,\n _this$props8$readonly = _this$props8.readonly,\n readonly = _this$props8$readonly === void 0 ? false : _this$props8$readonly,\n _this$props8$autofocu = _this$props8.autofocus,\n autofocus = _this$props8$autofocu === void 0 ? false : _this$props8$autofocu,\n _this$props8$required = _this$props8.required,\n required = _this$props8$required === void 0 ? false : _this$props8$required,\n registry = _this$props8.registry,\n onBlur = _this$props8.onBlur,\n onFocus = _this$props8.onFocus,\n idPrefix = _this$props8.idPrefix,\n _this$props8$idSepara = _this$props8.idSeparator,\n idSeparator = _this$props8$idSepara === void 0 ? '_' : _this$props8$idSepara,\n rawErrors = _this$props8.rawErrors;\n var keyedFormData = this.state.keyedFormData;\n var title = schema.title === undefined ? name : schema.title;\n var schemaUtils = registry.schemaUtils,\n formContext = registry.formContext;\n var uiOptions = getUiOptions(uiSchema);\n var _schemaItems = isObject(schema.items) ? schema.items : {};\n var itemsSchema = schemaUtils.retrieveSchema(_schemaItems);\n var formData = keyedToPlainFormData(this.state.keyedFormData);\n var canAdd = this.canAddItem(formData);\n var arrayProps = {\n canAdd: canAdd,\n items: keyedFormData.map(function (keyedItem, index) {\n var key = keyedItem.key,\n item = keyedItem.item;\n // While we are actually dealing with a single item of type T, the types require a T[], so cast\n var itemCast = item;\n var itemSchema = schemaUtils.retrieveSchema(_schemaItems, itemCast);\n var itemErrorSchema = errorSchema ? errorSchema[index] : undefined;\n var itemIdPrefix = idSchema.$id + idSeparator + index;\n var itemIdSchema = schemaUtils.toIdSchema(itemSchema, itemIdPrefix, itemCast, idPrefix, idSeparator);\n return _this2.renderArrayFieldItem({\n key: key,\n index: index,\n name: name && name + \"-\" + index,\n canAdd: canAdd,\n canMoveUp: index > 0,\n canMoveDown: index < formData.length - 1,\n itemSchema: itemSchema,\n itemIdSchema: itemIdSchema,\n itemErrorSchema: itemErrorSchema,\n itemData: itemCast,\n itemUiSchema: uiSchema.items,\n autofocus: autofocus && index === 0,\n onBlur: onBlur,\n onFocus: onFocus,\n rawErrors: rawErrors,\n totalItems: keyedFormData.length\n });\n }),\n className: \"field field-array field-array-of-\" + itemsSchema.type,\n disabled: disabled,\n idSchema: idSchema,\n uiSchema: uiSchema,\n onAddClick: this.onAddClick,\n readonly: readonly,\n required: required,\n schema: schema,\n title: title,\n formContext: formContext,\n formData: formData,\n rawErrors: rawErrors,\n registry: registry\n };\n var Template = getTemplate('ArrayFieldTemplate', registry, uiOptions);\n return jsx(Template, _extends({}, arrayProps));\n }\n /** Renders an array using the custom widget provided by the user in the `uiSchema`\r\n */;\n _proto.renderCustomWidget = function renderCustomWidget() {\n var _ref;\n var _this$props9 = this.props,\n schema = _this$props9.schema,\n idSchema = _this$props9.idSchema,\n uiSchema = _this$props9.uiSchema,\n _this$props9$disabled = _this$props9.disabled,\n disabled = _this$props9$disabled === void 0 ? false : _this$props9$disabled,\n _this$props9$readonly = _this$props9.readonly,\n readonly = _this$props9$readonly === void 0 ? false : _this$props9$readonly,\n _this$props9$autofocu = _this$props9.autofocus,\n autofocus = _this$props9$autofocu === void 0 ? false : _this$props9$autofocu,\n _this$props9$required = _this$props9.required,\n required = _this$props9$required === void 0 ? false : _this$props9$required,\n hideError = _this$props9.hideError,\n placeholder = _this$props9.placeholder,\n onBlur = _this$props9.onBlur,\n onFocus = _this$props9.onFocus,\n _this$props9$formData = _this$props9.formData,\n items = _this$props9$formData === void 0 ? [] : _this$props9$formData,\n registry = _this$props9.registry,\n rawErrors = _this$props9.rawErrors,\n name = _this$props9.name;\n var widgets = registry.widgets,\n formContext = registry.formContext,\n globalUiOptions = registry.globalUiOptions,\n schemaUtils = registry.schemaUtils;\n var _getUiOptions2 = getUiOptions(uiSchema, globalUiOptions),\n widget = _getUiOptions2.widget,\n uiTitle = _getUiOptions2.title,\n options = _objectWithoutPropertiesLoose(_getUiOptions2, _excluded$9);\n var Widget = getWidget(schema, widget, widgets);\n var label = (_ref = uiTitle != null ? uiTitle : schema.title) != null ? _ref : name;\n var displayLabel = schemaUtils.getDisplayLabel(schema, uiSchema, globalUiOptions);\n return jsx(Widget, {\n id: idSchema.$id,\n name: name,\n multiple: true,\n onChange: this.onSelectChange,\n onBlur: onBlur,\n onFocus: onFocus,\n options: options,\n schema: schema,\n uiSchema: uiSchema,\n registry: registry,\n value: items,\n disabled: disabled,\n readonly: readonly,\n hideError: hideError,\n required: required,\n label: label,\n hideLabel: !displayLabel,\n placeholder: placeholder,\n formContext: formContext,\n autofocus: autofocus,\n rawErrors: rawErrors\n });\n }\n /** Renders an array as a set of checkboxes\r\n */;\n _proto.renderMultiSelect = function renderMultiSelect() {\n var _ref2;\n var _this$props10 = this.props,\n schema = _this$props10.schema,\n idSchema = _this$props10.idSchema,\n uiSchema = _this$props10.uiSchema,\n _this$props10$formDat = _this$props10.formData,\n items = _this$props10$formDat === void 0 ? [] : _this$props10$formDat,\n _this$props10$disable = _this$props10.disabled,\n disabled = _this$props10$disable === void 0 ? false : _this$props10$disable,\n _this$props10$readonl = _this$props10.readonly,\n readonly = _this$props10$readonl === void 0 ? false : _this$props10$readonl,\n _this$props10$autofoc = _this$props10.autofocus,\n autofocus = _this$props10$autofoc === void 0 ? false : _this$props10$autofoc,\n _this$props10$require = _this$props10.required,\n required = _this$props10$require === void 0 ? false : _this$props10$require,\n placeholder = _this$props10.placeholder,\n onBlur = _this$props10.onBlur,\n onFocus = _this$props10.onFocus,\n registry = _this$props10.registry,\n rawErrors = _this$props10.rawErrors,\n name = _this$props10.name;\n var widgets = registry.widgets,\n schemaUtils = registry.schemaUtils,\n formContext = registry.formContext,\n globalUiOptions = registry.globalUiOptions;\n var itemsSchema = schemaUtils.retrieveSchema(schema.items, items);\n var enumOptions = optionsList(itemsSchema);\n var _getUiOptions3 = getUiOptions(uiSchema, globalUiOptions),\n _getUiOptions3$widget = _getUiOptions3.widget,\n widget = _getUiOptions3$widget === void 0 ? 'select' : _getUiOptions3$widget,\n uiTitle = _getUiOptions3.title,\n options = _objectWithoutPropertiesLoose(_getUiOptions3, _excluded2);\n var Widget = getWidget(schema, widget, widgets);\n var label = (_ref2 = uiTitle != null ? uiTitle : schema.title) != null ? _ref2 : name;\n var displayLabel = schemaUtils.getDisplayLabel(schema, uiSchema, globalUiOptions);\n return jsx(Widget, {\n id: idSchema.$id,\n name: name,\n multiple: true,\n onChange: this.onSelectChange,\n onBlur: onBlur,\n onFocus: onFocus,\n options: _extends({}, options, {\n enumOptions: enumOptions\n }),\n schema: schema,\n uiSchema: uiSchema,\n registry: registry,\n value: items,\n disabled: disabled,\n readonly: readonly,\n required: required,\n label: label,\n hideLabel: !displayLabel,\n placeholder: placeholder,\n formContext: formContext,\n autofocus: autofocus,\n rawErrors: rawErrors\n });\n }\n /** Renders an array of files using the `FileWidget`\r\n */;\n _proto.renderFiles = function renderFiles() {\n var _ref3;\n var _this$props11 = this.props,\n schema = _this$props11.schema,\n uiSchema = _this$props11.uiSchema,\n idSchema = _this$props11.idSchema,\n name = _this$props11.name,\n _this$props11$disable = _this$props11.disabled,\n disabled = _this$props11$disable === void 0 ? false : _this$props11$disable,\n _this$props11$readonl = _this$props11.readonly,\n readonly = _this$props11$readonl === void 0 ? false : _this$props11$readonl,\n _this$props11$autofoc = _this$props11.autofocus,\n autofocus = _this$props11$autofoc === void 0 ? false : _this$props11$autofoc,\n _this$props11$require = _this$props11.required,\n required = _this$props11$require === void 0 ? false : _this$props11$require,\n onBlur = _this$props11.onBlur,\n onFocus = _this$props11.onFocus,\n registry = _this$props11.registry,\n _this$props11$formDat = _this$props11.formData,\n items = _this$props11$formDat === void 0 ? [] : _this$props11$formDat,\n rawErrors = _this$props11.rawErrors;\n var widgets = registry.widgets,\n formContext = registry.formContext,\n globalUiOptions = registry.globalUiOptions,\n schemaUtils = registry.schemaUtils;\n var _getUiOptions4 = getUiOptions(uiSchema, globalUiOptions),\n _getUiOptions4$widget = _getUiOptions4.widget,\n widget = _getUiOptions4$widget === void 0 ? 'files' : _getUiOptions4$widget,\n uiTitle = _getUiOptions4.title,\n options = _objectWithoutPropertiesLoose(_getUiOptions4, _excluded3);\n var Widget = getWidget(schema, widget, widgets);\n var label = (_ref3 = uiTitle != null ? uiTitle : schema.title) != null ? _ref3 : name;\n var displayLabel = schemaUtils.getDisplayLabel(schema, uiSchema, globalUiOptions);\n return jsx(Widget, {\n options: options,\n id: idSchema.$id,\n name: name,\n multiple: true,\n onChange: this.onSelectChange,\n onBlur: onBlur,\n onFocus: onFocus,\n schema: schema,\n uiSchema: uiSchema,\n value: items,\n disabled: disabled,\n readonly: readonly,\n required: required,\n registry: registry,\n formContext: formContext,\n autofocus: autofocus,\n rawErrors: rawErrors,\n label: label,\n hideLabel: !displayLabel\n });\n }\n /** Renders an array that has a maximum limit of items\r\n */;\n _proto.renderFixedArray = function renderFixedArray() {\n var _this3 = this;\n var _this$props12 = this.props,\n schema = _this$props12.schema,\n _this$props12$uiSchem = _this$props12.uiSchema,\n uiSchema = _this$props12$uiSchem === void 0 ? {} : _this$props12$uiSchem,\n _this$props12$formDat = _this$props12.formData,\n formData = _this$props12$formDat === void 0 ? [] : _this$props12$formDat,\n errorSchema = _this$props12.errorSchema,\n idPrefix = _this$props12.idPrefix,\n _this$props12$idSepar = _this$props12.idSeparator,\n idSeparator = _this$props12$idSepar === void 0 ? '_' : _this$props12$idSepar,\n idSchema = _this$props12.idSchema,\n name = _this$props12.name,\n _this$props12$disable = _this$props12.disabled,\n disabled = _this$props12$disable === void 0 ? false : _this$props12$disable,\n _this$props12$readonl = _this$props12.readonly,\n readonly = _this$props12$readonl === void 0 ? false : _this$props12$readonl,\n _this$props12$autofoc = _this$props12.autofocus,\n autofocus = _this$props12$autofoc === void 0 ? false : _this$props12$autofoc,\n _this$props12$require = _this$props12.required,\n required = _this$props12$require === void 0 ? false : _this$props12$require,\n registry = _this$props12.registry,\n onBlur = _this$props12.onBlur,\n onFocus = _this$props12.onFocus,\n rawErrors = _this$props12.rawErrors;\n var keyedFormData = this.state.keyedFormData;\n var _this$props$formData = this.props.formData,\n items = _this$props$formData === void 0 ? [] : _this$props$formData;\n var title = schema.title || name;\n var uiOptions = getUiOptions(uiSchema);\n var schemaUtils = registry.schemaUtils,\n formContext = registry.formContext;\n var _schemaItems = isObject(schema.items) ? schema.items : [];\n var itemSchemas = _schemaItems.map(function (item, index) {\n return schemaUtils.retrieveSchema(item, formData[index]);\n });\n var additionalSchema = isObject(schema.additionalItems) ? schemaUtils.retrieveSchema(schema.additionalItems, formData) : null;\n if (!items || items.length < itemSchemas.length) {\n // to make sure at least all fixed items are generated\n items = items || [];\n items = items.concat(new Array(itemSchemas.length - items.length));\n }\n // These are the props passed into the render function\n var canAdd = this.canAddItem(items) && !!additionalSchema;\n var arrayProps = {\n canAdd: canAdd,\n className: 'field field-array field-array-fixed-items',\n disabled: disabled,\n idSchema: idSchema,\n formData: formData,\n items: keyedFormData.map(function (keyedItem, index) {\n var key = keyedItem.key,\n item = keyedItem.item;\n // While we are actually dealing with a single item of type T, the types require a T[], so cast\n var itemCast = item;\n var additional = index >= itemSchemas.length;\n var itemSchema = additional && isObject(schema.additionalItems) ? schemaUtils.retrieveSchema(schema.additionalItems, itemCast) : itemSchemas[index];\n var itemIdPrefix = idSchema.$id + idSeparator + index;\n var itemIdSchema = schemaUtils.toIdSchema(itemSchema, itemIdPrefix, itemCast, idPrefix, idSeparator);\n var itemUiSchema = additional ? uiSchema.additionalItems || {} : Array.isArray(uiSchema.items) ? uiSchema.items[index] : uiSchema.items || {};\n var itemErrorSchema = errorSchema ? errorSchema[index] : undefined;\n return _this3.renderArrayFieldItem({\n key: key,\n index: index,\n name: name && name + \"-\" + index,\n canAdd: canAdd,\n canRemove: additional,\n canMoveUp: index >= itemSchemas.length + 1,\n canMoveDown: additional && index < items.length - 1,\n itemSchema: itemSchema,\n itemData: itemCast,\n itemUiSchema: itemUiSchema,\n itemIdSchema: itemIdSchema,\n itemErrorSchema: itemErrorSchema,\n autofocus: autofocus && index === 0,\n onBlur: onBlur,\n onFocus: onFocus,\n rawErrors: rawErrors,\n totalItems: keyedFormData.length\n });\n }),\n onAddClick: this.onAddClick,\n readonly: readonly,\n required: required,\n registry: registry,\n schema: schema,\n uiSchema: uiSchema,\n title: title,\n formContext: formContext,\n rawErrors: rawErrors\n };\n var Template = getTemplate('ArrayFieldTemplate', registry, uiOptions);\n return jsx(Template, _extends({}, arrayProps));\n }\n /** Renders the individual array item using a `SchemaField` along with the additional properties required to be send\r\n * back to the `ArrayFieldItemTemplate`.\r\n *\r\n * @param props - The props for the individual array item to be rendered\r\n */;\n _proto.renderArrayFieldItem = function renderArrayFieldItem(props) {\n var key = props.key,\n index = props.index,\n name = props.name,\n canAdd = props.canAdd,\n _props$canRemove = props.canRemove,\n canRemove = _props$canRemove === void 0 ? true : _props$canRemove,\n canMoveUp = props.canMoveUp,\n canMoveDown = props.canMoveDown,\n itemSchema = props.itemSchema,\n itemData = props.itemData,\n itemUiSchema = props.itemUiSchema,\n itemIdSchema = props.itemIdSchema,\n itemErrorSchema = props.itemErrorSchema,\n autofocus = props.autofocus,\n onBlur = props.onBlur,\n onFocus = props.onFocus,\n rawErrors = props.rawErrors,\n totalItems = props.totalItems;\n var _this$props13 = this.props,\n disabled = _this$props13.disabled,\n hideError = _this$props13.hideError,\n idPrefix = _this$props13.idPrefix,\n idSeparator = _this$props13.idSeparator,\n readonly = _this$props13.readonly,\n uiSchema = _this$props13.uiSchema,\n registry = _this$props13.registry,\n formContext = _this$props13.formContext;\n var _registry$fields = registry.fields,\n ArraySchemaField = _registry$fields.ArraySchemaField,\n SchemaField = _registry$fields.SchemaField,\n globalUiOptions = registry.globalUiOptions;\n var ItemSchemaField = ArraySchemaField || SchemaField;\n var _getUiOptions5 = getUiOptions(uiSchema, globalUiOptions),\n _getUiOptions5$ordera = _getUiOptions5.orderable,\n orderable = _getUiOptions5$ordera === void 0 ? true : _getUiOptions5$ordera,\n _getUiOptions5$remova = _getUiOptions5.removable,\n removable = _getUiOptions5$remova === void 0 ? true : _getUiOptions5$remova,\n _getUiOptions5$copyab = _getUiOptions5.copyable,\n copyable = _getUiOptions5$copyab === void 0 ? false : _getUiOptions5$copyab;\n var has = {\n moveUp: orderable && canMoveUp,\n moveDown: orderable && canMoveDown,\n copy: copyable && canAdd,\n remove: removable && canRemove,\n toolbar: false\n };\n has.toolbar = Object.keys(has).some(function (key) {\n return has[key];\n });\n return {\n children: jsx(ItemSchemaField, {\n name: name,\n index: index,\n schema: itemSchema,\n uiSchema: itemUiSchema,\n formData: itemData,\n formContext: formContext,\n errorSchema: itemErrorSchema,\n idPrefix: idPrefix,\n idSeparator: idSeparator,\n idSchema: itemIdSchema,\n required: this.isItemRequired(itemSchema),\n onChange: this.onChangeForIndex(index),\n onBlur: onBlur,\n onFocus: onFocus,\n registry: registry,\n disabled: disabled,\n readonly: readonly,\n hideError: hideError,\n autofocus: autofocus,\n rawErrors: rawErrors\n }),\n className: 'array-item',\n disabled: disabled,\n canAdd: canAdd,\n hasCopy: has.copy,\n hasToolbar: has.toolbar,\n hasMoveUp: has.moveUp,\n hasMoveDown: has.moveDown,\n hasRemove: has.remove,\n index: index,\n totalItems: totalItems,\n key: key,\n onAddIndexClick: this.onAddIndexClick,\n onCopyIndexClick: this.onCopyIndexClick,\n onDropIndexClick: this.onDropIndexClick,\n onReorderClick: this.onReorderClick,\n readonly: readonly,\n registry: registry,\n schema: itemSchema,\n uiSchema: itemUiSchema\n };\n };\n _createClass(ArrayField, [{\n key: \"itemTitle\",\n get: function get$1() {\n var _this$props14 = this.props,\n schema = _this$props14.schema,\n registry = _this$props14.registry;\n var translateString = registry.translateString;\n return get(schema, [ITEMS_KEY, 'title'], get(schema, [ITEMS_KEY, 'description'], translateString(TranslatableString.ArrayItemTitle)));\n }\n }]);\n return ArrayField;\n}(Component);\n\nvar _excluded$8 = [\"widget\", \"title\", \"label\"];\n/** The `BooleanField` component is used to render a field in the schema is boolean. It constructs `enumOptions` for the\r\n * two boolean values based on the various alternatives in the schema.\r\n *\r\n * @param props - The `FieldProps` for this template\r\n */\nfunction BooleanField(props) {\n var _ref;\n var schema = props.schema,\n name = props.name,\n uiSchema = props.uiSchema,\n idSchema = props.idSchema,\n formData = props.formData,\n registry = props.registry,\n required = props.required,\n disabled = props.disabled,\n readonly = props.readonly,\n autofocus = props.autofocus,\n onChange = props.onChange,\n onFocus = props.onFocus,\n onBlur = props.onBlur,\n rawErrors = props.rawErrors;\n var title = schema.title;\n var widgets = registry.widgets,\n formContext = registry.formContext,\n translateString = registry.translateString,\n globalUiOptions = registry.globalUiOptions;\n var _getUiOptions = getUiOptions(uiSchema, globalUiOptions),\n _getUiOptions$widget = _getUiOptions.widget,\n widget = _getUiOptions$widget === void 0 ? 'checkbox' : _getUiOptions$widget,\n uiTitle = _getUiOptions.title,\n _getUiOptions$label = _getUiOptions.label,\n displayLabel = _getUiOptions$label === void 0 ? true : _getUiOptions$label,\n options = _objectWithoutPropertiesLoose(_getUiOptions, _excluded$8);\n var Widget = getWidget(schema, widget, widgets);\n var yes = translateString(TranslatableString.YesLabel);\n var no = translateString(TranslatableString.NoLabel);\n var enumOptions;\n var label = (_ref = uiTitle != null ? uiTitle : title) != null ? _ref : name;\n if (Array.isArray(schema.oneOf)) {\n enumOptions = optionsList({\n oneOf: schema.oneOf.map(function (option) {\n if (isObject(option)) {\n return _extends({}, option, {\n title: option.title || (option[\"const\"] === true ? yes : no)\n });\n }\n return undefined;\n }).filter(function (o) {\n return o;\n }) // cast away the error that typescript can't grok is fixed\n });\n } else {\n var _schema$enum;\n // We deprecated enumNames in v5. It's intentionally omitted from RSJFSchema type, so we need to cast here.\n var schemaWithEnumNames = schema;\n var enums = (_schema$enum = schema[\"enum\"]) != null ? _schema$enum : [true, false];\n if (!schemaWithEnumNames.enumNames && enums.length === 2 && enums.every(function (v) {\n return typeof v === 'boolean';\n })) {\n enumOptions = [{\n value: enums[0],\n label: enums[0] ? yes : no\n }, {\n value: enums[1],\n label: enums[1] ? yes : no\n }];\n } else {\n enumOptions = optionsList({\n \"enum\": enums,\n // NOTE: enumNames is deprecated, but still supported for now.\n enumNames: schemaWithEnumNames.enumNames\n });\n }\n }\n return jsx(Widget, {\n options: _extends({}, options, {\n enumOptions: enumOptions\n }),\n schema: schema,\n uiSchema: uiSchema,\n id: idSchema.$id,\n name: name,\n onChange: onChange,\n onFocus: onFocus,\n onBlur: onBlur,\n label: label,\n hideLabel: !displayLabel,\n value: formData,\n required: required,\n disabled: disabled,\n readonly: readonly,\n registry: registry,\n formContext: formContext,\n autofocus: autofocus,\n rawErrors: rawErrors\n });\n}\n\nvar _excluded$7 = [\"widget\", \"placeholder\", \"autofocus\", \"autocomplete\", \"title\"];\n/** The `AnyOfField` component is used to render a field in the schema that is an `anyOf`, `allOf` or `oneOf`. It tracks\r\n * the currently selected option and cleans up any irrelevant data in `formData`.\r\n *\r\n * @param props - The `FieldProps` for this template\r\n */\nvar AnyOfField = /*#__PURE__*/function (_Component) {\n _inheritsLoose(AnyOfField, _Component);\n /** Constructs an `AnyOfField` with the given `props` to initialize the initially selected option in state\r\n *\r\n * @param props - The `FieldProps` for this template\r\n */\n function AnyOfField(props) {\n var _this;\n _this = _Component.call(this, props) || this;\n _this.onOptionChange = function (option) {\n var _this$state = _this.state,\n selectedOption = _this$state.selectedOption,\n retrievedOptions = _this$state.retrievedOptions;\n var _this$props = _this.props,\n formData = _this$props.formData,\n onChange = _this$props.onChange,\n registry = _this$props.registry;\n var schemaUtils = registry.schemaUtils;\n var intOption = option !== undefined ? parseInt(option, 10) : -1;\n if (intOption === selectedOption) {\n return;\n }\n var newOption = intOption >= 0 ? retrievedOptions[intOption] : undefined;\n var oldOption = selectedOption >= 0 ? retrievedOptions[selectedOption] : undefined;\n var newFormData = schemaUtils.sanitizeDataForNewSchema(newOption, oldOption, formData);\n if (newFormData && newOption) {\n // Call getDefaultFormState to make sure defaults are populated on change. Pass \"excludeObjectChildren\"\n // so that only the root objects themselves are created without adding undefined children properties\n newFormData = schemaUtils.getDefaultFormState(newOption, newFormData, 'excludeObjectChildren');\n }\n onChange(newFormData, undefined, _this.getFieldId());\n _this.setState({\n selectedOption: intOption\n });\n };\n var _this$props2 = _this.props,\n _formData = _this$props2.formData,\n options = _this$props2.options,\n _schemaUtils = _this$props2.registry.schemaUtils;\n // cache the retrieved options in state in case they have $refs to save doing it later\n var _retrievedOptions = options.map(function (opt) {\n return _schemaUtils.retrieveSchema(opt, _formData);\n });\n _this.state = {\n retrievedOptions: _retrievedOptions,\n selectedOption: _this.getMatchingOption(0, _formData, _retrievedOptions)\n };\n return _this;\n }\n /** React lifecycle method that is called when the props and/or state for this component is updated. It recomputes the\r\n * currently selected option based on the overall `formData`\r\n *\r\n * @param prevProps - The previous `FieldProps` for this template\r\n * @param prevState - The previous `AnyOfFieldState` for this template\r\n */\n var _proto = AnyOfField.prototype;\n _proto.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {\n var _this$props3 = this.props,\n formData = _this$props3.formData,\n options = _this$props3.options,\n idSchema = _this$props3.idSchema;\n var selectedOption = this.state.selectedOption;\n var newState = this.state;\n if (!deepEquals(prevProps.options, options)) {\n var schemaUtils = this.props.registry.schemaUtils;\n // re-cache the retrieved options in state in case they have $refs to save doing it later\n var retrievedOptions = options.map(function (opt) {\n return schemaUtils.retrieveSchema(opt, formData);\n });\n newState = {\n selectedOption: selectedOption,\n retrievedOptions: retrievedOptions\n };\n }\n if (!deepEquals(formData, prevProps.formData) && idSchema.$id === prevProps.idSchema.$id) {\n var _newState = newState,\n _retrievedOptions2 = _newState.retrievedOptions;\n var matchingOption = this.getMatchingOption(selectedOption, formData, _retrievedOptions2);\n if (prevState && matchingOption !== selectedOption) {\n newState = {\n selectedOption: matchingOption,\n retrievedOptions: _retrievedOptions2\n };\n }\n }\n if (newState !== this.state) {\n this.setState(newState);\n }\n }\n /** Determines the best matching option for the given `formData` and `options`.\r\n *\r\n * @param formData - The new formData\r\n * @param options - The list of options to choose from\r\n * @return - The index of the `option` that best matches the `formData`\r\n */;\n _proto.getMatchingOption = function getMatchingOption(selectedOption, formData, options) {\n var schemaUtils = this.props.registry.schemaUtils;\n var option = schemaUtils.getClosestMatchingOption(formData, options, selectedOption);\n if (option > 0) {\n return option;\n }\n // If the form data matches none of the options, use the currently selected\n // option, assuming it's available; otherwise use the first option\n return selectedOption || 0;\n }\n /** Callback handler to remember what the currently selected option is. In addition to that the `formData` is updated\r\n * to remove properties that are not part of the newly selected option schema, and then the updated data is passed to\r\n * the `onChange` handler.\r\n *\r\n * @param option - The new option value being selected\r\n */;\n _proto.getFieldId = function getFieldId() {\n var _this$props4 = this.props,\n idSchema = _this$props4.idSchema,\n schema = _this$props4.schema;\n return \"\" + idSchema.$id + (schema.oneOf ? '__oneof_select' : '__anyof_select');\n }\n /** Renders the `AnyOfField` selector along with a `SchemaField` for the value of the `formData`\r\n */;\n _proto.render = function render() {\n var _this$props5 = this.props,\n name = _this$props5.name,\n baseType = _this$props5.baseType,\n _this$props5$disabled = _this$props5.disabled,\n disabled = _this$props5$disabled === void 0 ? false : _this$props5$disabled,\n _this$props5$errorSch = _this$props5.errorSchema,\n errorSchema = _this$props5$errorSch === void 0 ? {} : _this$props5$errorSch,\n formContext = _this$props5.formContext,\n onBlur = _this$props5.onBlur,\n onFocus = _this$props5.onFocus,\n registry = _this$props5.registry,\n schema = _this$props5.schema,\n uiSchema = _this$props5.uiSchema;\n var widgets = registry.widgets,\n fields = registry.fields,\n translateString = registry.translateString,\n globalUiOptions = registry.globalUiOptions,\n schemaUtils = registry.schemaUtils;\n var _SchemaField = fields.SchemaField;\n var _this$state2 = this.state,\n selectedOption = _this$state2.selectedOption,\n retrievedOptions = _this$state2.retrievedOptions;\n var _getUiOptions = getUiOptions(uiSchema, globalUiOptions),\n _getUiOptions$widget = _getUiOptions.widget,\n widget = _getUiOptions$widget === void 0 ? 'select' : _getUiOptions$widget,\n placeholder = _getUiOptions.placeholder,\n autofocus = _getUiOptions.autofocus,\n autocomplete = _getUiOptions.autocomplete,\n _getUiOptions$title = _getUiOptions.title,\n title = _getUiOptions$title === void 0 ? schema.title : _getUiOptions$title,\n uiOptions = _objectWithoutPropertiesLoose(_getUiOptions, _excluded$7);\n var Widget = getWidget({\n type: 'number'\n }, widget, widgets);\n var rawErrors = get(errorSchema, ERRORS_KEY, []);\n var fieldErrorSchema = omit(errorSchema, [ERRORS_KEY]);\n var displayLabel = schemaUtils.getDisplayLabel(schema, uiSchema, globalUiOptions);\n var option = selectedOption >= 0 ? retrievedOptions[selectedOption] || null : null;\n var optionSchema;\n if (option) {\n // If the subschema doesn't declare a type, infer the type from the\n // parent schema\n optionSchema = option.type ? option : Object.assign({}, option, {\n type: baseType\n });\n }\n var translateEnum = title ? TranslatableString.TitleOptionPrefix : TranslatableString.OptionPrefix;\n var translateParams = title ? [title] : [];\n var enumOptions = retrievedOptions.map(function (opt, index) {\n return {\n label: opt.title || translateString(translateEnum, translateParams.concat(String(index + 1))),\n value: index\n };\n });\n return jsxs(\"div\", {\n className: 'panel panel-default panel-body',\n children: [jsx(\"div\", {\n className: 'form-group',\n children: jsx(Widget, {\n id: this.getFieldId(),\n name: \"\" + name + (schema.oneOf ? '__oneof_select' : '__anyof_select'),\n schema: {\n type: 'number',\n \"default\": 0\n },\n onChange: this.onOptionChange,\n onBlur: onBlur,\n onFocus: onFocus,\n disabled: disabled || isEmpty(enumOptions),\n multiple: false,\n rawErrors: rawErrors,\n errorSchema: fieldErrorSchema,\n value: selectedOption >= 0 ? selectedOption : undefined,\n options: _extends({\n enumOptions: enumOptions\n }, uiOptions),\n registry: registry,\n formContext: formContext,\n placeholder: placeholder,\n autocomplete: autocomplete,\n autofocus: autofocus,\n label: title != null ? title : name,\n hideLabel: !displayLabel\n })\n }), option !== null && jsx(_SchemaField, _extends({}, this.props, {\n schema: optionSchema\n }))]\n });\n };\n return AnyOfField;\n}(Component);\n\n// Matches a string that ends in a . character, optionally followed by a sequence of\n// digits followed by any number of 0 characters up until the end of the line.\n// Ensuring that there is at least one prefixed character is important so that\n// you don't incorrectly match against \"0\".\nvar trailingCharMatcherWithPrefix = /\\.([0-9]*0)*$/;\n// This is used for trimming the trailing 0 and . characters without affecting\n// the rest of the string. Its possible to use one RegEx with groups for this\n// functionality, but it is fairly complex compared to simply defining two\n// different matchers.\nvar trailingCharMatcher = /[0.]0*$/;\n/**\r\n * The NumberField class has some special handling for dealing with trailing\r\n * decimal points and/or zeroes. This logic is designed to allow trailing values\r\n * to be visible in the input element, but not be represented in the\r\n * corresponding form data.\r\n *\r\n * The algorithm is as follows:\r\n *\r\n * 1. When the input value changes the value is cached in the component state\r\n *\r\n * 2. The value is then normalized, removing trailing decimal points and zeros,\r\n * then passed to the \"onChange\" callback\r\n *\r\n * 3. When the component is rendered, the formData value is checked against the\r\n * value cached in the state. If it matches the cached value, the cached\r\n * value is passed to the input instead of the formData value\r\n */\nfunction NumberField(props) {\n var registry = props.registry,\n onChange = props.onChange,\n formData = props.formData,\n initialValue = props.value;\n var _useState = useState(initialValue),\n lastValue = _useState[0],\n setLastValue = _useState[1];\n var StringField = registry.fields.StringField;\n var value = formData;\n /** Handle the change from the `StringField` to properly convert to a number\r\n *\r\n * @param value - The current value for the change occurring\r\n */\n var handleChange = useCallback(function (value) {\n // Cache the original value in component state\n setLastValue(value);\n // Normalize decimals that don't start with a zero character in advance so\n // that the rest of the normalization logic is simpler\n if ((\"\" + value).charAt(0) === '.') {\n value = \"0\" + value;\n }\n // Check that the value is a string (this can happen if the widget used is a\n // ` component for the `core` theme.\r\n * It is used as the template for rendering many of the based widgets that differ by `type` and callbacks only.\r\n * It can be customized/overridden for other themes or individual implementations as needed.\r\n *\r\n * @param props - The `WidgetProps` for this template\r\n */\nfunction BaseInputTemplate(props) {\n var id = props.id,\n value = props.value,\n readonly = props.readonly,\n disabled = props.disabled,\n autofocus = props.autofocus,\n onBlur = props.onBlur,\n onFocus = props.onFocus,\n onChange = props.onChange,\n onChangeOverride = props.onChangeOverride,\n options = props.options,\n schema = props.schema,\n type = props.type,\n rest = _objectWithoutPropertiesLoose(props, _excluded$3);\n // Note: since React 15.2.0 we can't forward unknown element attributes, so we\n // exclude the \"options\" and \"schema\" ones here.\n if (!id) {\n console.log('No id for', props);\n throw new Error(\"no id for props \" + JSON.stringify(props));\n }\n var inputProps = _extends({}, rest, getInputProps(schema, type, options));\n var inputValue;\n if (inputProps.type === 'number' || inputProps.type === 'integer') {\n inputValue = value || value === 0 ? value : '';\n } else {\n inputValue = value == null ? '' : value;\n }\n var _onChange = useCallback(function (_ref) {\n var value = _ref.target.value;\n return onChange(value === '' ? options.emptyValue : value);\n }, [onChange, options]);\n var _onBlur = useCallback(function (_ref2) {\n var value = _ref2.target.value;\n return onBlur(id, value);\n }, [onBlur, id]);\n var _onFocus = useCallback(function (_ref3) {\n var value = _ref3.target.value;\n return onFocus(id, value);\n }, [onFocus, id]);\n return jsxs(Fragment, {\n children: [jsx(\"input\", _extends({\n id: id,\n name: id,\n className: 'form-control',\n readOnly: readonly,\n disabled: disabled,\n autoFocus: autofocus,\n value: inputValue\n }, inputProps, {\n list: schema.examples ? examplesId(id) : undefined,\n onChange: onChangeOverride || _onChange,\n onBlur: _onBlur,\n onFocus: _onFocus,\n \"aria-describedby\": ariaDescribedByIds(id, !!schema.examples)\n })), Array.isArray(schema.examples) && jsx(\"datalist\", {\n id: examplesId(id),\n children: schema.examples.concat(schema[\"default\"] && !schema.examples.includes(schema[\"default\"]) ? [schema[\"default\"]] : []).map(function (example) {\n return jsx(\"option\", {\n value: example\n }, example);\n })\n }, \"datalist_\" + id)]\n });\n}\n\n/** The `SubmitButton` renders a button that represent the `Submit` action on a form\r\n */\nfunction SubmitButton(_ref) {\n var uiSchema = _ref.uiSchema;\n var _getSubmitButtonOptio = getSubmitButtonOptions(uiSchema),\n submitText = _getSubmitButtonOptio.submitText,\n norender = _getSubmitButtonOptio.norender,\n _getSubmitButtonOptio2 = _getSubmitButtonOptio.props,\n submitButtonProps = _getSubmitButtonOptio2 === void 0 ? {} : _getSubmitButtonOptio2;\n if (norender) {\n return null;\n }\n return jsx(\"div\", {\n children: jsx(\"button\", _extends({\n type: 'submit'\n }, submitButtonProps, {\n className: \"btn btn-info \" + (submitButtonProps.className || ''),\n children: submitText\n }))\n });\n}\n\nvar _excluded$2 = [\"iconType\", \"icon\", \"className\", \"uiSchema\", \"registry\"];\nfunction IconButton(props) {\n var _props$iconType = props.iconType,\n iconType = _props$iconType === void 0 ? 'default' : _props$iconType,\n icon = props.icon,\n className = props.className,\n otherProps = _objectWithoutPropertiesLoose(props, _excluded$2);\n return jsx(\"button\", _extends({\n type: 'button',\n className: \"btn btn-\" + iconType + \" \" + className\n }, otherProps, {\n children: jsx(\"i\", {\n className: \"glyphicon glyphicon-\" + icon\n })\n }));\n}\nfunction CopyButton(props) {\n var translateString = props.registry.translateString;\n return jsx(IconButton, _extends({\n title: translateString(TranslatableString.CopyButton),\n className: 'array-item-copy'\n }, props, {\n icon: 'copy'\n }));\n}\nfunction MoveDownButton(props) {\n var translateString = props.registry.translateString;\n return jsx(IconButton, _extends({\n title: translateString(TranslatableString.MoveDownButton),\n className: 'array-item-move-down'\n }, props, {\n icon: 'arrow-down'\n }));\n}\nfunction MoveUpButton(props) {\n var translateString = props.registry.translateString;\n return jsx(IconButton, _extends({\n title: translateString(TranslatableString.MoveUpButton),\n className: 'array-item-move-up'\n }, props, {\n icon: 'arrow-up'\n }));\n}\nfunction RemoveButton(props) {\n var translateString = props.registry.translateString;\n return jsx(IconButton, _extends({\n title: translateString(TranslatableString.RemoveButton),\n className: 'array-item-remove'\n }, props, {\n iconType: 'danger',\n icon: 'remove'\n }));\n}\n\n/** The `AddButton` renders a button that represent the `Add` action on a form\r\n */\nfunction AddButton(_ref) {\n var className = _ref.className,\n onClick = _ref.onClick,\n disabled = _ref.disabled,\n registry = _ref.registry;\n var translateString = registry.translateString;\n return jsx(\"div\", {\n className: 'row',\n children: jsx(\"p\", {\n className: \"col-xs-3 col-xs-offset-9 text-right \" + className,\n children: jsx(IconButton, {\n iconType: 'info',\n icon: 'plus',\n className: 'btn-add col-xs-12',\n title: translateString(TranslatableString.AddButton),\n onClick: onClick,\n disabled: disabled,\n registry: registry\n })\n })\n });\n}\n\nfunction buttonTemplates() {\n return {\n SubmitButton: SubmitButton,\n AddButton: AddButton,\n CopyButton: CopyButton,\n MoveDownButton: MoveDownButton,\n MoveUpButton: MoveUpButton,\n RemoveButton: RemoveButton\n };\n}\n\n/** The `DescriptionField` is the template to use to render the description of a field\r\n *\r\n * @param props - The `DescriptionFieldProps` for this component\r\n */\nfunction DescriptionField(props) {\n var id = props.id,\n description = props.description;\n if (!description) {\n return null;\n }\n if (typeof description === 'string') {\n return jsx(\"p\", {\n id: id,\n className: 'field-description',\n children: description\n });\n } else {\n return jsx(\"div\", {\n id: id,\n className: 'field-description',\n children: description\n });\n }\n}\n\n/** The `ErrorList` component is the template that renders the all the errors associated with the fields in the `Form`\r\n *\r\n * @param props - The `ErrorListProps` for this component\r\n */\nfunction ErrorList(_ref) {\n var errors = _ref.errors,\n registry = _ref.registry;\n var translateString = registry.translateString;\n return jsxs(\"div\", {\n className: 'panel panel-danger errors',\n children: [jsx(\"div\", {\n className: 'panel-heading',\n children: jsx(\"h3\", {\n className: 'panel-title',\n children: translateString(TranslatableString.ErrorsLabel)\n })\n }), jsx(\"ul\", {\n className: 'list-group',\n children: errors.map(function (error, i) {\n return jsx(\"li\", {\n className: 'list-group-item text-danger',\n children: error.stack\n }, i);\n })\n })]\n });\n}\n\nvar REQUIRED_FIELD_SYMBOL$1 = '*';\n/** Renders a label for a field\r\n *\r\n * @param props - The `LabelProps` for this component\r\n */\nfunction Label(props) {\n var label = props.label,\n required = props.required,\n id = props.id;\n if (!label) {\n return null;\n }\n return jsxs(\"label\", {\n className: 'control-label',\n htmlFor: id,\n children: [label, required && jsx(\"span\", {\n className: 'required',\n children: REQUIRED_FIELD_SYMBOL$1\n })]\n });\n}\n\n/** The `FieldTemplate` component is the template used by `SchemaField` to render any field. It renders the field\r\n * content, (label, description, children, errors and help) inside of a `WrapIfAdditional` component.\r\n *\r\n * @param props - The `FieldTemplateProps` for this component\r\n */\nfunction FieldTemplate(props) {\n var id = props.id,\n label = props.label,\n children = props.children,\n errors = props.errors,\n help = props.help,\n description = props.description,\n hidden = props.hidden,\n required = props.required,\n displayLabel = props.displayLabel,\n registry = props.registry,\n uiSchema = props.uiSchema;\n var uiOptions = getUiOptions(uiSchema);\n var WrapIfAdditionalTemplate = getTemplate('WrapIfAdditionalTemplate', registry, uiOptions);\n if (hidden) {\n return jsx(\"div\", {\n className: 'hidden',\n children: children\n });\n }\n return jsxs(WrapIfAdditionalTemplate, _extends({}, props, {\n children: [displayLabel && jsx(Label, {\n label: label,\n required: required,\n id: id\n }), displayLabel && description ? description : null, children, errors, help]\n }));\n}\n\n/** The `FieldErrorTemplate` component renders the errors local to the particular field\r\n *\r\n * @param props - The `FieldErrorProps` for the errors being rendered\r\n */\nfunction FieldErrorTemplate(props) {\n var _props$errors = props.errors,\n errors = _props$errors === void 0 ? [] : _props$errors,\n idSchema = props.idSchema;\n if (errors.length === 0) {\n return null;\n }\n var id = errorId(idSchema);\n return jsx(\"div\", {\n children: jsx(\"ul\", {\n id: id,\n className: 'error-detail bs-callout bs-callout-info',\n children: errors.filter(function (elem) {\n return !!elem;\n }).map(function (error, index) {\n return jsx(\"li\", {\n className: 'text-danger',\n children: error\n }, index);\n })\n })\n });\n}\n\n/** The `FieldHelpTemplate` component renders any help desired for a field\r\n *\r\n * @param props - The `FieldHelpProps` to be rendered\r\n */\nfunction FieldHelpTemplate(props) {\n var idSchema = props.idSchema,\n help = props.help;\n if (!help) {\n return null;\n }\n var id = helpId(idSchema);\n if (typeof help === 'string') {\n return jsx(\"p\", {\n id: id,\n className: 'help-block',\n children: help\n });\n }\n return jsx(\"div\", {\n id: id,\n className: 'help-block',\n children: help\n });\n}\n\n/** The `ObjectFieldTemplate` is the template to use to render all the inner properties of an object along with the\r\n * title and description if available. If the object is expandable, then an `AddButton` is also rendered after all\r\n * the properties.\r\n *\r\n * @param props - The `ObjectFieldTemplateProps` for this component\r\n */\nfunction ObjectFieldTemplate(props) {\n var description = props.description,\n disabled = props.disabled,\n formData = props.formData,\n idSchema = props.idSchema,\n onAddClick = props.onAddClick,\n properties = props.properties,\n readonly = props.readonly,\n registry = props.registry,\n required = props.required,\n schema = props.schema,\n title = props.title,\n uiSchema = props.uiSchema;\n var options = getUiOptions(uiSchema);\n var TitleFieldTemplate = getTemplate('TitleFieldTemplate', registry, options);\n var DescriptionFieldTemplate = getTemplate('DescriptionFieldTemplate', registry, options);\n // Button templates are not overridden in the uiSchema\n var AddButton = registry.templates.ButtonTemplates.AddButton;\n return jsxs(\"fieldset\", {\n id: idSchema.$id,\n children: [title && jsx(TitleFieldTemplate, {\n id: titleId(idSchema),\n title: title,\n required: required,\n schema: schema,\n uiSchema: uiSchema,\n registry: registry\n }), description && jsx(DescriptionFieldTemplate, {\n id: descriptionId(idSchema),\n description: description,\n schema: schema,\n uiSchema: uiSchema,\n registry: registry\n }), properties.map(function (prop) {\n return prop.content;\n }), canExpand(schema, uiSchema, formData) && jsx(AddButton, {\n className: 'object-property-expand',\n onClick: onAddClick(schema),\n disabled: disabled || readonly,\n uiSchema: uiSchema,\n registry: registry\n })]\n });\n}\n\nvar REQUIRED_FIELD_SYMBOL = '*';\n/** The `TitleField` is the template to use to render the title of a field\r\n *\r\n * @param props - The `TitleFieldProps` for this component\r\n */\nfunction TitleField(props) {\n var id = props.id,\n title = props.title,\n required = props.required;\n return jsxs(\"legend\", {\n id: id,\n children: [title, required && jsx(\"span\", {\n className: 'required',\n children: REQUIRED_FIELD_SYMBOL\n })]\n });\n}\n\n/** The `UnsupportedField` component is used to render a field in the schema is one that is not supported by\r\n * react-jsonschema-form.\r\n *\r\n * @param props - The `FieldProps` for this template\r\n */\nfunction UnsupportedField(props) {\n var schema = props.schema,\n idSchema = props.idSchema,\n reason = props.reason,\n registry = props.registry;\n var translateString = registry.translateString;\n var translateEnum = TranslatableString.UnsupportedField;\n var translateParams = [];\n if (idSchema && idSchema.$id) {\n translateEnum = TranslatableString.UnsupportedFieldWithId;\n translateParams.push(idSchema.$id);\n }\n if (reason) {\n translateEnum = translateEnum === TranslatableString.UnsupportedField ? TranslatableString.UnsupportedFieldWithReason : TranslatableString.UnsupportedFieldWithIdAndReason;\n translateParams.push(reason);\n }\n return jsxs(\"div\", {\n className: 'unsupported-field',\n children: [jsx(\"p\", {\n children: jsx(Markdown, {\n children: translateString(translateEnum, translateParams)\n })\n }), schema && jsx(\"pre\", {\n children: JSON.stringify(schema, null, 2)\n })]\n });\n}\n\n/** The `WrapIfAdditional` component is used by the `FieldTemplate` to rename, or remove properties that are\r\n * part of an `additionalProperties` part of a schema.\r\n *\r\n * @param props - The `WrapIfAdditionalProps` for this component\r\n */\nfunction WrapIfAdditionalTemplate(props) {\n var id = props.id,\n classNames = props.classNames,\n style = props.style,\n disabled = props.disabled,\n label = props.label,\n onKeyChange = props.onKeyChange,\n onDropPropertyClick = props.onDropPropertyClick,\n readonly = props.readonly,\n required = props.required,\n schema = props.schema,\n children = props.children,\n uiSchema = props.uiSchema,\n registry = props.registry;\n var templates = registry.templates,\n translateString = registry.translateString;\n // Button templates are not overridden in the uiSchema\n var RemoveButton = templates.ButtonTemplates.RemoveButton;\n var keyLabel = translateString(TranslatableString.KeyLabel, [label]);\n var additional = (ADDITIONAL_PROPERTY_FLAG in schema);\n if (!additional) {\n return jsx(\"div\", {\n className: classNames,\n style: style,\n children: children\n });\n }\n return jsx(\"div\", {\n className: classNames,\n style: style,\n children: jsxs(\"div\", {\n className: 'row',\n children: [jsx(\"div\", {\n className: 'col-xs-5 form-additional',\n children: jsxs(\"div\", {\n className: 'form-group',\n children: [jsx(Label, {\n label: keyLabel,\n required: required,\n id: id + \"-key\"\n }), jsx(\"input\", {\n className: 'form-control',\n type: 'text',\n id: id + \"-key\",\n onBlur: function onBlur(event) {\n return onKeyChange(event.target.value);\n },\n defaultValue: label\n })]\n })\n }), jsx(\"div\", {\n className: 'form-additional form-group col-xs-5',\n children: children\n }), jsx(\"div\", {\n className: 'col-xs-2',\n children: jsx(RemoveButton, {\n className: 'array-item-remove btn-block',\n style: {\n border: '0'\n },\n disabled: disabled || readonly,\n onClick: onDropPropertyClick(label),\n uiSchema: uiSchema,\n registry: registry\n })\n })]\n })\n });\n}\n\nfunction templates() {\n return {\n ArrayFieldDescriptionTemplate: ArrayFieldDescriptionTemplate,\n ArrayFieldItemTemplate: ArrayFieldItemTemplate,\n ArrayFieldTemplate: ArrayFieldTemplate,\n ArrayFieldTitleTemplate: ArrayFieldTitleTemplate,\n ButtonTemplates: buttonTemplates(),\n BaseInputTemplate: BaseInputTemplate,\n DescriptionFieldTemplate: DescriptionField,\n ErrorListTemplate: ErrorList,\n FieldTemplate: FieldTemplate,\n FieldErrorTemplate: FieldErrorTemplate,\n FieldHelpTemplate: FieldHelpTemplate,\n ObjectFieldTemplate: ObjectFieldTemplate,\n TitleFieldTemplate: TitleField,\n UnsupportedFieldTemplate: UnsupportedField,\n WrapIfAdditionalTemplate: WrapIfAdditionalTemplate\n };\n}\n\nfunction rangeOptions(start, stop) {\n var options = [];\n for (var i = start; i <= stop; i++) {\n options.push({\n value: i,\n label: pad(i, 2)\n });\n }\n return options;\n}\nfunction readyForChange(state) {\n return Object.values(state).every(function (value) {\n return value !== -1;\n });\n}\nfunction dateElementProps(state, time, yearsRange) {\n if (yearsRange === void 0) {\n yearsRange = [1900, new Date().getFullYear() + 2];\n }\n var year = state.year,\n month = state.month,\n day = state.day,\n hour = state.hour,\n minute = state.minute,\n second = state.second;\n var data = [{\n type: 'year',\n range: yearsRange,\n value: year\n }, {\n type: 'month',\n range: [1, 12],\n value: month\n }, {\n type: 'day',\n range: [1, 31],\n value: day\n }];\n if (time) {\n data.push({\n type: 'hour',\n range: [0, 23],\n value: hour\n }, {\n type: 'minute',\n range: [0, 59],\n value: minute\n }, {\n type: 'second',\n range: [0, 59],\n value: second\n });\n }\n return data;\n}\nfunction DateElement(_ref) {\n var type = _ref.type,\n range = _ref.range,\n value = _ref.value,\n select = _ref.select,\n rootId = _ref.rootId,\n name = _ref.name,\n disabled = _ref.disabled,\n readonly = _ref.readonly,\n autofocus = _ref.autofocus,\n registry = _ref.registry,\n onBlur = _ref.onBlur,\n onFocus = _ref.onFocus;\n var id = rootId + '_' + type;\n var SelectWidget = registry.widgets.SelectWidget;\n return jsx(SelectWidget, {\n schema: {\n type: 'integer'\n },\n id: id,\n name: name,\n className: 'form-control',\n options: {\n enumOptions: rangeOptions(range[0], range[1])\n },\n placeholder: type,\n value: value,\n disabled: disabled,\n readonly: readonly,\n autofocus: autofocus,\n onChange: function onChange(value) {\n return select(type, value);\n },\n onBlur: onBlur,\n onFocus: onFocus,\n registry: registry,\n label: '',\n \"aria-describedby\": ariaDescribedByIds(rootId)\n });\n}\n/** The `AltDateWidget` is an alternative widget for rendering date properties.\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction AltDateWidget(_ref2) {\n var _ref2$time = _ref2.time,\n time = _ref2$time === void 0 ? false : _ref2$time,\n _ref2$disabled = _ref2.disabled,\n disabled = _ref2$disabled === void 0 ? false : _ref2$disabled,\n _ref2$readonly = _ref2.readonly,\n readonly = _ref2$readonly === void 0 ? false : _ref2$readonly,\n _ref2$autofocus = _ref2.autofocus,\n autofocus = _ref2$autofocus === void 0 ? false : _ref2$autofocus,\n options = _ref2.options,\n id = _ref2.id,\n name = _ref2.name,\n registry = _ref2.registry,\n onBlur = _ref2.onBlur,\n onFocus = _ref2.onFocus,\n onChange = _ref2.onChange,\n value = _ref2.value;\n var translateString = registry.translateString;\n var _useState = useState(value),\n lastValue = _useState[0],\n setLastValue = _useState[1];\n var _useReducer = useReducer(function (state, action) {\n return _extends({}, state, action);\n }, parseDateString(value, time)),\n state = _useReducer[0],\n setState = _useReducer[1];\n useEffect(function () {\n var stateValue = toDateString(state, time);\n if (readyForChange(state) && stateValue !== value) {\n // The user changed the date to a new valid data via the comboboxes, so call onChange\n onChange(stateValue);\n } else if (lastValue !== value) {\n // We got a new value in the props\n setLastValue(value);\n setState(parseDateString(value, time));\n }\n }, [time, value, onChange, state, lastValue]);\n var handleChange = useCallback(function (property, value) {\n var _setState;\n setState((_setState = {}, _setState[property] = value, _setState));\n }, []);\n var handleSetNow = useCallback(function (event) {\n event.preventDefault();\n if (disabled || readonly) {\n return;\n }\n var nextState = parseDateString(new Date().toJSON(), time);\n onChange(toDateString(nextState, time));\n }, [disabled, readonly, time]);\n var handleClear = useCallback(function (event) {\n event.preventDefault();\n if (disabled || readonly) {\n return;\n }\n onChange(undefined);\n }, [disabled, readonly, onChange]);\n return jsxs(\"ul\", {\n className: 'list-inline',\n children: [dateElementProps(state, time, options.yearsRange).map(function (elemProps, i) {\n return jsx(\"li\", {\n className: 'list-inline-item',\n children: jsx(DateElement, _extends({\n rootId: id,\n name: name,\n select: handleChange\n }, elemProps, {\n disabled: disabled,\n readonly: readonly,\n registry: registry,\n onBlur: onBlur,\n onFocus: onFocus,\n autofocus: autofocus && i === 0\n }))\n }, i);\n }), (options.hideNowButton !== 'undefined' ? !options.hideNowButton : true) && jsx(\"li\", {\n className: 'list-inline-item',\n children: jsx(\"a\", {\n href: '#',\n className: 'btn btn-info btn-now',\n onClick: handleSetNow,\n children: translateString(TranslatableString.NowLabel)\n })\n }), (options.hideClearButton !== 'undefined' ? !options.hideClearButton : true) && jsx(\"li\", {\n className: 'list-inline-item',\n children: jsx(\"a\", {\n href: '#',\n className: 'btn btn-warning btn-clear',\n onClick: handleClear,\n children: translateString(TranslatableString.ClearLabel)\n })\n })]\n });\n}\n\nvar _excluded$1 = [\"time\"];\n/** The `AltDateTimeWidget` is an alternative widget for rendering datetime properties.\r\n * It uses the AltDateWidget for rendering, with the `time` prop set to true by default.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction AltDateTimeWidget(_ref) {\n var _ref$time = _ref.time,\n time = _ref$time === void 0 ? true : _ref$time,\n props = _objectWithoutPropertiesLoose(_ref, _excluded$1);\n var AltDateWidget = props.registry.widgets.AltDateWidget;\n return jsx(AltDateWidget, _extends({\n time: time\n }, props));\n}\n\n/** The `CheckBoxWidget` is a widget for rendering boolean properties.\r\n * It is typically used to represent a boolean.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction CheckboxWidget(_ref) {\n var _options$description;\n var schema = _ref.schema,\n uiSchema = _ref.uiSchema,\n options = _ref.options,\n id = _ref.id,\n value = _ref.value,\n disabled = _ref.disabled,\n readonly = _ref.readonly,\n label = _ref.label,\n hideLabel = _ref.hideLabel,\n _ref$autofocus = _ref.autofocus,\n autofocus = _ref$autofocus === void 0 ? false : _ref$autofocus,\n onBlur = _ref.onBlur,\n onFocus = _ref.onFocus,\n onChange = _ref.onChange,\n registry = _ref.registry;\n var DescriptionFieldTemplate = getTemplate('DescriptionFieldTemplate', registry, options);\n // Because an unchecked checkbox will cause html5 validation to fail, only add\n // the \"required\" attribute if the field value must be \"true\", due to the\n // \"const\" or \"enum\" keywords\n var required = schemaRequiresTrueValue(schema);\n var handleChange = useCallback(function (event) {\n return onChange(event.target.checked);\n }, [onChange]);\n var handleBlur = useCallback(function (event) {\n return onBlur(id, event.target.checked);\n }, [onBlur, id]);\n var handleFocus = useCallback(function (event) {\n return onFocus(id, event.target.checked);\n }, [onFocus, id]);\n var description = (_options$description = options.description) != null ? _options$description : schema.description;\n return jsxs(\"div\", {\n className: \"checkbox \" + (disabled || readonly ? 'disabled' : ''),\n children: [!hideLabel && !!description && jsx(DescriptionFieldTemplate, {\n id: descriptionId(id),\n description: description,\n schema: schema,\n uiSchema: uiSchema,\n registry: registry\n }), jsxs(\"label\", {\n children: [jsx(\"input\", {\n type: 'checkbox',\n id: id,\n name: id,\n checked: typeof value === 'undefined' ? false : value,\n required: required,\n disabled: disabled || readonly,\n autoFocus: autofocus,\n onChange: handleChange,\n onBlur: handleBlur,\n onFocus: handleFocus,\n \"aria-describedby\": ariaDescribedByIds(id)\n }), labelValue(jsx(\"span\", {\n children: label\n }), hideLabel)]\n })]\n });\n}\n\n/** The `CheckboxesWidget` is a widget for rendering checkbox groups.\r\n * It is typically used to represent an array of enums.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction CheckboxesWidget(_ref) {\n var id = _ref.id,\n disabled = _ref.disabled,\n _ref$options = _ref.options,\n _ref$options$inline = _ref$options.inline,\n inline = _ref$options$inline === void 0 ? false : _ref$options$inline,\n enumOptions = _ref$options.enumOptions,\n enumDisabled = _ref$options.enumDisabled,\n emptyValue = _ref$options.emptyValue,\n value = _ref.value,\n _ref$autofocus = _ref.autofocus,\n autofocus = _ref$autofocus === void 0 ? false : _ref$autofocus,\n readonly = _ref.readonly,\n onChange = _ref.onChange,\n onBlur = _ref.onBlur,\n onFocus = _ref.onFocus;\n var checkboxesValues = Array.isArray(value) ? value : [value];\n var handleBlur = useCallback(function (_ref2) {\n var value = _ref2.target.value;\n return onBlur(id, enumOptionsValueForIndex(value, enumOptions, emptyValue));\n }, [onBlur, id]);\n var handleFocus = useCallback(function (_ref3) {\n var value = _ref3.target.value;\n return onFocus(id, enumOptionsValueForIndex(value, enumOptions, emptyValue));\n }, [onFocus, id]);\n return jsx(\"div\", {\n className: 'checkboxes',\n id: id,\n children: Array.isArray(enumOptions) && enumOptions.map(function (option, index) {\n var checked = enumOptionsIsSelected(option.value, checkboxesValues);\n var itemDisabled = Array.isArray(enumDisabled) && enumDisabled.indexOf(option.value) !== -1;\n var disabledCls = disabled || itemDisabled || readonly ? 'disabled' : '';\n var handleChange = function handleChange(event) {\n if (event.target.checked) {\n onChange(enumOptionsSelectValue(index, checkboxesValues, enumOptions));\n } else {\n onChange(enumOptionsDeselectValue(index, checkboxesValues, enumOptions));\n }\n };\n var checkbox = jsxs(\"span\", {\n children: [jsx(\"input\", {\n type: 'checkbox',\n id: optionId(id, index),\n name: id,\n checked: checked,\n value: String(index),\n disabled: disabled || itemDisabled || readonly,\n autoFocus: autofocus && index === 0,\n onChange: handleChange,\n onBlur: handleBlur,\n onFocus: handleFocus,\n \"aria-describedby\": ariaDescribedByIds(id)\n }), jsx(\"span\", {\n children: option.label\n })]\n });\n return inline ? jsx(\"label\", {\n className: \"checkbox-inline \" + disabledCls,\n children: checkbox\n }, index) : jsx(\"div\", {\n className: \"checkbox \" + disabledCls,\n children: jsx(\"label\", {\n children: checkbox\n })\n }, index);\n })\n });\n}\n\n/** The `ColorWidget` component uses the `BaseInputTemplate` changing the type to `color` and disables it when it is\r\n * either disabled or readonly.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction ColorWidget(props) {\n var disabled = props.disabled,\n readonly = props.readonly,\n options = props.options,\n registry = props.registry;\n var BaseInputTemplate = getTemplate('BaseInputTemplate', registry, options);\n return jsx(BaseInputTemplate, _extends({\n type: 'color'\n }, props, {\n disabled: disabled || readonly\n }));\n}\n\n/** The `DateWidget` component uses the `BaseInputTemplate` changing the type to `date` and transforms\r\n * the value to undefined when it is falsy during the `onChange` handling.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction DateWidget(props) {\n var onChange = props.onChange,\n options = props.options,\n registry = props.registry;\n var BaseInputTemplate = getTemplate('BaseInputTemplate', registry, options);\n var handleChange = useCallback(function (value) {\n return onChange(value || undefined);\n }, [onChange]);\n return jsx(BaseInputTemplate, _extends({\n type: 'date'\n }, props, {\n onChange: handleChange\n }));\n}\n\n/** The `DateTimeWidget` component uses the `BaseInputTemplate` changing the type to `datetime-local` and transforms\r\n * the value to/from utc using the appropriate utility functions.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction DateTimeWidget(props) {\n var _onChange = props.onChange,\n value = props.value,\n options = props.options,\n registry = props.registry;\n var BaseInputTemplate = getTemplate('BaseInputTemplate', registry, options);\n return jsx(BaseInputTemplate, _extends({\n type: 'datetime-local'\n }, props, {\n value: utcToLocal(value),\n onChange: function onChange(value) {\n return _onChange(localToUTC(value));\n }\n }));\n}\n\n/** The `EmailWidget` component uses the `BaseInputTemplate` changing the type to `email`.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction EmailWidget(props) {\n var options = props.options,\n registry = props.registry;\n var BaseInputTemplate = getTemplate('BaseInputTemplate', registry, options);\n return jsx(BaseInputTemplate, _extends({\n type: 'email'\n }, props));\n}\n\nfunction addNameToDataURL(dataURL, name) {\n if (dataURL === null) {\n return null;\n }\n return dataURL.replace(';base64', \";name=\" + encodeURIComponent(name) + \";base64\");\n}\nfunction processFile(file) {\n var name = file.name,\n size = file.size,\n type = file.type;\n return new Promise(function (resolve, reject) {\n var reader = new window.FileReader();\n reader.onerror = reject;\n reader.onload = function (event) {\n var _event$target;\n if (typeof ((_event$target = event.target) === null || _event$target === void 0 ? void 0 : _event$target.result) === 'string') {\n resolve({\n dataURL: addNameToDataURL(event.target.result, name),\n name: name,\n size: size,\n type: type\n });\n } else {\n resolve({\n dataURL: null,\n name: name,\n size: size,\n type: type\n });\n }\n };\n reader.readAsDataURL(file);\n });\n}\nfunction processFiles(files) {\n return Promise.all(Array.from(files).map(processFile));\n}\nfunction FileInfoPreview(_ref) {\n var fileInfo = _ref.fileInfo,\n registry = _ref.registry;\n var translateString = registry.translateString;\n var dataURL = fileInfo.dataURL,\n type = fileInfo.type,\n name = fileInfo.name;\n if (!dataURL) {\n return null;\n }\n if (type.indexOf('image') !== -1) {\n return jsx(\"img\", {\n src: dataURL,\n style: {\n maxWidth: '100%'\n },\n className: 'file-preview'\n });\n }\n return jsxs(Fragment, {\n children: [' ', jsx(\"a\", {\n download: \"preview-\" + name,\n href: dataURL,\n className: 'file-download',\n children: translateString(TranslatableString.PreviewLabel)\n })]\n });\n}\nfunction FilesInfo(_ref2) {\n var filesInfo = _ref2.filesInfo,\n registry = _ref2.registry,\n preview = _ref2.preview;\n if (filesInfo.length === 0) {\n return null;\n }\n var translateString = registry.translateString;\n return jsx(\"ul\", {\n className: 'file-info',\n children: filesInfo.map(function (fileInfo, key) {\n var name = fileInfo.name,\n size = fileInfo.size,\n type = fileInfo.type;\n return jsxs(\"li\", {\n children: [jsx(Markdown, {\n children: translateString(TranslatableString.FilesInfo, [name, type, String(size)])\n }), preview && jsx(FileInfoPreview, {\n fileInfo: fileInfo,\n registry: registry\n })]\n }, key);\n })\n });\n}\nfunction extractFileInfo(dataURLs) {\n return dataURLs.filter(function (dataURL) {\n return dataURL;\n }).map(function (dataURL) {\n var _dataURItoBlob = dataURItoBlob(dataURL),\n blob = _dataURItoBlob.blob,\n name = _dataURItoBlob.name;\n return {\n dataURL: dataURL,\n name: name,\n size: blob.size,\n type: blob.type\n };\n });\n}\n/**\r\n * The `FileWidget` is a widget for rendering file upload fields.\r\n * It is typically used with a string property with data-url format.\r\n */\nfunction FileWidget(props) {\n var disabled = props.disabled,\n readonly = props.readonly,\n required = props.required,\n multiple = props.multiple,\n onChange = props.onChange,\n value = props.value,\n options = props.options,\n registry = props.registry;\n var BaseInputTemplate = getTemplate('BaseInputTemplate', registry, options);\n var extractedFilesInfo = useMemo(function () {\n return Array.isArray(value) ? extractFileInfo(value) : extractFileInfo([value]);\n }, [value]);\n var _useState = useState(extractedFilesInfo),\n filesInfo = _useState[0],\n setFilesInfo = _useState[1];\n var handleChange = useCallback(function (event) {\n if (!event.target.files) {\n return;\n }\n processFiles(event.target.files).then(function (filesInfoEvent) {\n setFilesInfo(filesInfoEvent);\n var newValue = filesInfoEvent.map(function (fileInfo) {\n return fileInfo.dataURL;\n });\n if (multiple) {\n onChange(newValue);\n } else {\n onChange(newValue[0]);\n }\n });\n }, [multiple, onChange]);\n return jsxs(\"div\", {\n children: [jsx(BaseInputTemplate, _extends({}, props, {\n disabled: disabled || readonly,\n type: 'file',\n required: value ? false : required,\n onChangeOverride: handleChange,\n value: '',\n accept: options.accept ? String(options.accept) : undefined\n })), jsx(FilesInfo, {\n filesInfo: filesInfo,\n registry: registry,\n preview: options.filePreview\n })]\n });\n}\n\n/** The `HiddenWidget` is a widget for rendering a hidden input field.\r\n * It is typically used by setting type to \"hidden\".\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction HiddenWidget(_ref) {\n var id = _ref.id,\n value = _ref.value;\n return jsx(\"input\", {\n type: 'hidden',\n id: id,\n name: id,\n value: typeof value === 'undefined' ? '' : value\n });\n}\n\n/** The `PasswordWidget` component uses the `BaseInputTemplate` changing the type to `password`.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction PasswordWidget(props) {\n var options = props.options,\n registry = props.registry;\n var BaseInputTemplate = getTemplate('BaseInputTemplate', registry, options);\n return jsx(BaseInputTemplate, _extends({\n type: 'password'\n }, props));\n}\n\n/** The `RadioWidget` is a widget for rendering a radio group.\r\n * It is typically used with a string property constrained with enum options.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction RadioWidget(_ref) {\n var options = _ref.options,\n value = _ref.value,\n required = _ref.required,\n disabled = _ref.disabled,\n readonly = _ref.readonly,\n _ref$autofocus = _ref.autofocus,\n autofocus = _ref$autofocus === void 0 ? false : _ref$autofocus,\n onBlur = _ref.onBlur,\n onFocus = _ref.onFocus,\n onChange = _ref.onChange,\n id = _ref.id;\n var enumOptions = options.enumOptions,\n enumDisabled = options.enumDisabled,\n inline = options.inline,\n emptyValue = options.emptyValue;\n var handleBlur = useCallback(function (_ref2) {\n var value = _ref2.target.value;\n return onBlur(id, enumOptionsValueForIndex(value, enumOptions, emptyValue));\n }, [onBlur, id]);\n var handleFocus = useCallback(function (_ref3) {\n var value = _ref3.target.value;\n return onFocus(id, enumOptionsValueForIndex(value, enumOptions, emptyValue));\n }, [onFocus, id]);\n return jsx(\"div\", {\n className: 'field-radio-group',\n id: id,\n children: Array.isArray(enumOptions) && enumOptions.map(function (option, i) {\n var checked = enumOptionsIsSelected(option.value, value);\n var itemDisabled = Array.isArray(enumDisabled) && enumDisabled.indexOf(option.value) !== -1;\n var disabledCls = disabled || itemDisabled || readonly ? 'disabled' : '';\n var handleChange = function handleChange() {\n return onChange(option.value);\n };\n var radio = jsxs(\"span\", {\n children: [jsx(\"input\", {\n type: 'radio',\n id: optionId(id, i),\n checked: checked,\n name: id,\n required: required,\n value: String(i),\n disabled: disabled || itemDisabled || readonly,\n autoFocus: autofocus && i === 0,\n onChange: handleChange,\n onBlur: handleBlur,\n onFocus: handleFocus,\n \"aria-describedby\": ariaDescribedByIds(id)\n }), jsx(\"span\", {\n children: option.label\n })]\n });\n return inline ? jsx(\"label\", {\n className: \"radio-inline \" + disabledCls,\n children: radio\n }, i) : jsx(\"div\", {\n className: \"radio \" + disabledCls,\n children: jsx(\"label\", {\n children: radio\n })\n }, i);\n })\n });\n}\n\n/** The `RangeWidget` component uses the `BaseInputTemplate` changing the type to `range` and wrapping the result\r\n * in a div, with the value along side it.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction RangeWidget(props) {\n var value = props.value,\n BaseInputTemplate = props.registry.templates.BaseInputTemplate;\n return jsxs(\"div\", {\n className: 'field-range-wrapper',\n children: [jsx(BaseInputTemplate, _extends({\n type: 'range'\n }, props)), jsx(\"span\", {\n className: 'range-view',\n children: value\n })]\n });\n}\n\nfunction getValue(event, multiple) {\n if (multiple) {\n return Array.from(event.target.options).slice().filter(function (o) {\n return o.selected;\n }).map(function (o) {\n return o.value;\n });\n }\n return event.target.value;\n}\n/** The `SelectWidget` is a widget for rendering dropdowns.\r\n * It is typically used with string properties constrained with enum options.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction SelectWidget(_ref) {\n var schema = _ref.schema,\n id = _ref.id,\n options = _ref.options,\n value = _ref.value,\n required = _ref.required,\n disabled = _ref.disabled,\n readonly = _ref.readonly,\n _ref$multiple = _ref.multiple,\n multiple = _ref$multiple === void 0 ? false : _ref$multiple,\n _ref$autofocus = _ref.autofocus,\n autofocus = _ref$autofocus === void 0 ? false : _ref$autofocus,\n onChange = _ref.onChange,\n onBlur = _ref.onBlur,\n onFocus = _ref.onFocus,\n placeholder = _ref.placeholder;\n var enumOptions = options.enumOptions,\n enumDisabled = options.enumDisabled,\n optEmptyVal = options.emptyValue;\n var emptyValue = multiple ? [] : '';\n var handleFocus = useCallback(function (event) {\n var newValue = getValue(event, multiple);\n return onFocus(id, enumOptionsValueForIndex(newValue, enumOptions, optEmptyVal));\n }, [onFocus, id, schema, multiple, options]);\n var handleBlur = useCallback(function (event) {\n var newValue = getValue(event, multiple);\n return onBlur(id, enumOptionsValueForIndex(newValue, enumOptions, optEmptyVal));\n }, [onBlur, id, schema, multiple, options]);\n var handleChange = useCallback(function (event) {\n var newValue = getValue(event, multiple);\n return onChange(enumOptionsValueForIndex(newValue, enumOptions, optEmptyVal));\n }, [onChange, schema, multiple, options]);\n var selectedIndexes = enumOptionsIndexForValue(value, enumOptions, multiple);\n return jsxs(\"select\", {\n id: id,\n name: id,\n multiple: multiple,\n className: 'form-control',\n value: typeof selectedIndexes === 'undefined' ? emptyValue : selectedIndexes,\n required: required,\n disabled: disabled || readonly,\n autoFocus: autofocus,\n onBlur: handleBlur,\n onFocus: handleFocus,\n onChange: handleChange,\n \"aria-describedby\": ariaDescribedByIds(id),\n children: [!multiple && schema[\"default\"] === undefined && jsx(\"option\", {\n value: '',\n children: placeholder\n }), Array.isArray(enumOptions) && enumOptions.map(function (_ref2, i) {\n var value = _ref2.value,\n label = _ref2.label;\n var disabled = enumDisabled && enumDisabled.indexOf(value) !== -1;\n return jsx(\"option\", {\n value: String(i),\n disabled: disabled,\n children: label\n }, i);\n })]\n });\n}\n\n/** The `TextareaWidget` is a widget for rendering input fields as textarea.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction TextareaWidget(_ref) {\n var id = _ref.id,\n _ref$options = _ref.options,\n options = _ref$options === void 0 ? {} : _ref$options,\n placeholder = _ref.placeholder,\n value = _ref.value,\n required = _ref.required,\n disabled = _ref.disabled,\n readonly = _ref.readonly,\n _ref$autofocus = _ref.autofocus,\n autofocus = _ref$autofocus === void 0 ? false : _ref$autofocus,\n onChange = _ref.onChange,\n onBlur = _ref.onBlur,\n onFocus = _ref.onFocus;\n var handleChange = useCallback(function (_ref2) {\n var value = _ref2.target.value;\n return onChange(value === '' ? options.emptyValue : value);\n }, [onChange, options.emptyValue]);\n var handleBlur = useCallback(function (_ref3) {\n var value = _ref3.target.value;\n return onBlur(id, value);\n }, [onBlur, id]);\n var handleFocus = useCallback(function (_ref4) {\n var value = _ref4.target.value;\n return onFocus(id, value);\n }, [id, onFocus]);\n return jsx(\"textarea\", {\n id: id,\n name: id,\n className: 'form-control',\n value: value ? value : '',\n placeholder: placeholder,\n required: required,\n disabled: disabled,\n readOnly: readonly,\n autoFocus: autofocus,\n rows: options.rows,\n onBlur: handleBlur,\n onFocus: handleFocus,\n onChange: handleChange,\n \"aria-describedby\": ariaDescribedByIds(id)\n });\n}\nTextareaWidget.defaultProps = {\n autofocus: false,\n options: {}\n};\n\n/** The `TextWidget` component uses the `BaseInputTemplate`.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction TextWidget(props) {\n var options = props.options,\n registry = props.registry;\n var BaseInputTemplate = getTemplate('BaseInputTemplate', registry, options);\n return jsx(BaseInputTemplate, _extends({}, props));\n}\n\n/** The `TimeWidget` component uses the `BaseInputTemplate` changing the type to `time` and transforms\r\n * the value to undefined when it is falsy during the `onChange` handling.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction TimeWidget(props) {\n var onChange = props.onChange,\n options = props.options,\n registry = props.registry;\n var BaseInputTemplate = getTemplate('BaseInputTemplate', registry, options);\n var handleChange = useCallback(function (value) {\n return onChange(value ? value + \":00\" : undefined);\n }, [onChange]);\n return jsx(BaseInputTemplate, _extends({\n type: 'time'\n }, props, {\n onChange: handleChange\n }));\n}\n\n/** The `URLWidget` component uses the `BaseInputTemplate` changing the type to `url`.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction URLWidget(props) {\n var options = props.options,\n registry = props.registry;\n var BaseInputTemplate = getTemplate('BaseInputTemplate', registry, options);\n return jsx(BaseInputTemplate, _extends({\n type: 'url'\n }, props));\n}\n\n/** The `UpDownWidget` component uses the `BaseInputTemplate` changing the type to `number`.\r\n *\r\n * @param props - The `WidgetProps` for this component\r\n */\nfunction UpDownWidget(props) {\n var options = props.options,\n registry = props.registry;\n var BaseInputTemplate = getTemplate('BaseInputTemplate', registry, options);\n return jsx(BaseInputTemplate, _extends({\n type: 'number'\n }, props));\n}\n\nfunction widgets() {\n return {\n AltDateWidget: AltDateWidget,\n AltDateTimeWidget: AltDateTimeWidget,\n CheckboxWidget: CheckboxWidget,\n CheckboxesWidget: CheckboxesWidget,\n ColorWidget: ColorWidget,\n DateWidget: DateWidget,\n DateTimeWidget: DateTimeWidget,\n EmailWidget: EmailWidget,\n FileWidget: FileWidget,\n HiddenWidget: HiddenWidget,\n PasswordWidget: PasswordWidget,\n RadioWidget: RadioWidget,\n RangeWidget: RangeWidget,\n SelectWidget: SelectWidget,\n TextWidget: TextWidget,\n TextareaWidget: TextareaWidget,\n TimeWidget: TimeWidget,\n UpDownWidget: UpDownWidget,\n URLWidget: URLWidget\n };\n}\n\n/** The default registry consists of all the fields, templates and widgets provided in the core implementation,\r\n * plus an empty `rootSchema` and `formContext. We omit schemaUtils here because it cannot be defaulted without a\r\n * rootSchema and validator. It will be added into the computed registry later in the Form.\r\n */\nfunction getDefaultRegistry() {\n return {\n fields: fields(),\n templates: templates(),\n widgets: widgets(),\n rootSchema: {},\n formContext: {},\n translateString: englishStringTranslator\n };\n}\n\n/** The `Form` component renders the outer form and all the fields defined in the `schema` */\nvar Form = /*#__PURE__*/function (_Component) {\n _inheritsLoose(Form, _Component);\n /** The ref used to hold the `form` element, this needs to be `any` because `tagName` or `_internalFormWrapper` can\r\n * provide any possible type here\r\n */\n\n /** Constructs the `Form` from the `props`. Will setup the initial state from the props. It will also call the\r\n * `onChange` handler if the initially provided `formData` is modified to add missing default values as part of the\r\n * state construction.\r\n *\r\n * @param props - The initial props for the `Form`\r\n */\n function Form(props) {\n var _this;\n _this = _Component.call(this, props) || this;\n _this.formElement = void 0;\n _this.getUsedFormData = function (formData, fields) {\n // For the case of a single input form\n if (fields.length === 0 && typeof formData !== 'object') {\n return formData;\n }\n // _pick has incorrect type definition, it works with string[][], because lodash/hasIn supports it\n var data = _pick(formData, fields);\n if (Array.isArray(formData)) {\n return Object.keys(data).map(function (key) {\n return data[key];\n });\n }\n return data;\n };\n _this.getFieldNames = function (pathSchema, formData) {\n var getAllPaths = function getAllPaths(_obj, acc, paths) {\n if (acc === void 0) {\n acc = [];\n }\n if (paths === void 0) {\n paths = [[]];\n }\n Object.keys(_obj).forEach(function (key) {\n if (typeof _obj[key] === 'object') {\n var newPaths = paths.map(function (path) {\n return [].concat(path, [key]);\n });\n // If an object is marked with additionalProperties, all its keys are valid\n if (_obj[key][RJSF_ADDITONAL_PROPERTIES_FLAG] && _obj[key][NAME_KEY] !== '') {\n acc.push(_obj[key][NAME_KEY]);\n } else {\n getAllPaths(_obj[key], acc, newPaths);\n }\n } else if (key === NAME_KEY && _obj[key] !== '') {\n paths.forEach(function (path) {\n var formValue = get(formData, path);\n // adds path to fieldNames if it points to a value\n // or an empty object/array\n if (typeof formValue !== 'object' || isEmpty(formValue)) {\n acc.push(path);\n }\n });\n }\n });\n return acc;\n };\n return getAllPaths(pathSchema);\n };\n _this.onChange = function (formData, newErrorSchema, id) {\n var _this$props = _this.props,\n extraErrors = _this$props.extraErrors,\n omitExtraData = _this$props.omitExtraData,\n liveOmit = _this$props.liveOmit,\n noValidate = _this$props.noValidate,\n liveValidate = _this$props.liveValidate,\n onChange = _this$props.onChange;\n var _this$state = _this.state,\n schemaUtils = _this$state.schemaUtils,\n schema = _this$state.schema;\n if (isObject$1(formData) || Array.isArray(formData)) {\n var newState = _this.getStateFromProps(_this.props, formData);\n formData = newState.formData;\n }\n var mustValidate = !noValidate && liveValidate;\n var state = {\n formData: formData,\n schema: schema\n };\n var newFormData = formData;\n if (omitExtraData === true && liveOmit === true) {\n var retrievedSchema = schemaUtils.retrieveSchema(schema, formData);\n var pathSchema = schemaUtils.toPathSchema(retrievedSchema, '', formData);\n var fieldNames = _this.getFieldNames(pathSchema, formData);\n newFormData = _this.getUsedFormData(formData, fieldNames);\n state = {\n formData: newFormData\n };\n }\n if (mustValidate) {\n var schemaValidation = _this.validate(newFormData);\n var errors = schemaValidation.errors;\n var errorSchema = schemaValidation.errorSchema;\n var schemaValidationErrors = errors;\n var schemaValidationErrorSchema = errorSchema;\n if (extraErrors) {\n var merged = schemaUtils.mergeValidationData(schemaValidation, extraErrors);\n errorSchema = merged.errorSchema;\n errors = merged.errors;\n }\n state = {\n formData: newFormData,\n errors: errors,\n errorSchema: errorSchema,\n schemaValidationErrors: schemaValidationErrors,\n schemaValidationErrorSchema: schemaValidationErrorSchema\n };\n } else if (!noValidate && newErrorSchema) {\n var _errorSchema = extraErrors ? mergeObjects(newErrorSchema, extraErrors, 'preventDuplicates') : newErrorSchema;\n state = {\n formData: newFormData,\n errorSchema: _errorSchema,\n errors: schemaUtils.getValidator().toErrorList(_errorSchema)\n };\n }\n _this.setState(state, function () {\n return onChange && onChange(_extends({}, _this.state, state), id);\n });\n };\n _this.reset = function () {\n var onChange = _this.props.onChange;\n var newState = _this.getStateFromProps(_this.props, undefined);\n var newFormData = newState.formData;\n var state = {\n formData: newFormData,\n errorSchema: {},\n errors: [],\n schemaValidationErrors: [],\n schemaValidationErrorSchema: {}\n };\n _this.setState(state, function () {\n return onChange && onChange(_extends({}, _this.state, state));\n });\n };\n _this.onBlur = function (id, data) {\n var onBlur = _this.props.onBlur;\n if (onBlur) {\n onBlur(id, data);\n }\n };\n _this.onFocus = function (id, data) {\n var onFocus = _this.props.onFocus;\n if (onFocus) {\n onFocus(id, data);\n }\n };\n _this.onSubmit = function (event) {\n event.preventDefault();\n if (event.target !== event.currentTarget) {\n return;\n }\n event.persist();\n var _this$props2 = _this.props,\n omitExtraData = _this$props2.omitExtraData,\n extraErrors = _this$props2.extraErrors,\n noValidate = _this$props2.noValidate,\n onSubmit = _this$props2.onSubmit;\n var newFormData = _this.state.formData;\n var _this$state2 = _this.state,\n schema = _this$state2.schema,\n schemaUtils = _this$state2.schemaUtils;\n if (omitExtraData === true) {\n var retrievedSchema = schemaUtils.retrieveSchema(schema, newFormData);\n var pathSchema = schemaUtils.toPathSchema(retrievedSchema, '', newFormData);\n var fieldNames = _this.getFieldNames(pathSchema, newFormData);\n newFormData = _this.getUsedFormData(newFormData, fieldNames);\n }\n if (noValidate || _this.validateForm()) {\n // There are no errors generated through schema validation.\n // Check for user provided errors and update state accordingly.\n var errorSchema = extraErrors || {};\n var errors = extraErrors ? schemaUtils.getValidator().toErrorList(extraErrors) : [];\n _this.setState({\n formData: newFormData,\n errors: errors,\n errorSchema: errorSchema,\n schemaValidationErrors: [],\n schemaValidationErrorSchema: {}\n }, function () {\n if (onSubmit) {\n onSubmit(_extends({}, _this.state, {\n formData: newFormData,\n status: 'submitted'\n }), event);\n }\n });\n }\n };\n if (!props.validator) {\n throw new Error('A validator is required for Form functionality to work');\n }\n _this.state = _this.getStateFromProps(props, props.formData);\n if (_this.props.onChange && !deepEquals(_this.state.formData, _this.props.formData)) {\n _this.props.onChange(_this.state);\n }\n _this.formElement = /*#__PURE__*/createRef();\n return _this;\n }\n /** React lifecycle method that gets called before new props are provided, updates the state based on new props. It\r\n * will also call the`onChange` handler if the `formData` is modified to add missing default values as part of the\r\n * state construction.\r\n *\r\n * @param nextProps - The new set of props about to be applied to the `Form`\r\n */\n var _proto = Form.prototype;\n _proto.UNSAFE_componentWillReceiveProps = function UNSAFE_componentWillReceiveProps(nextProps) {\n var nextState = this.getStateFromProps(nextProps, nextProps.formData);\n if (!deepEquals(nextState.formData, nextProps.formData) && !deepEquals(nextState.formData, this.state.formData) && nextProps.onChange) {\n nextProps.onChange(nextState);\n }\n this.setState(nextState);\n }\n /** Extracts the updated state from the given `props` and `inputFormData`. As part of this process, the\r\n * `inputFormData` is first processed to add any missing required defaults. After that, the data is run through the\r\n * validation process IF required by the `props`.\r\n *\r\n * @param props - The props passed to the `Form`\r\n * @param inputFormData - The new or current data for the `Form`\r\n * @returns - The new state for the `Form`\r\n */;\n _proto.getStateFromProps = function getStateFromProps(props, inputFormData) {\n var state = this.state || {};\n var schema = 'schema' in props ? props.schema : this.props.schema;\n var uiSchema = ('uiSchema' in props ? props.uiSchema : this.props.uiSchema) || {};\n var edit = typeof inputFormData !== 'undefined';\n var liveValidate = 'liveValidate' in props ? props.liveValidate : this.props.liveValidate;\n var mustValidate = edit && !props.noValidate && liveValidate;\n var rootSchema = schema;\n var schemaUtils = state.schemaUtils;\n if (!schemaUtils || schemaUtils.doesSchemaUtilsDiffer(props.validator, rootSchema)) {\n schemaUtils = createSchemaUtils(props.validator, rootSchema);\n }\n var formData = schemaUtils.getDefaultFormState(schema, inputFormData);\n var retrievedSchema = schemaUtils.retrieveSchema(schema, formData);\n var getCurrentErrors = function getCurrentErrors() {\n if (props.noValidate) {\n return {\n errors: [],\n errorSchema: {}\n };\n } else if (!props.liveValidate) {\n return {\n errors: state.schemaValidationErrors || [],\n errorSchema: state.schemaValidationErrorSchema || {}\n };\n }\n return {\n errors: state.errors || [],\n errorSchema: state.errorSchema || {}\n };\n };\n var errors;\n var errorSchema;\n var schemaValidationErrors = state.schemaValidationErrors;\n var schemaValidationErrorSchema = state.schemaValidationErrorSchema;\n if (mustValidate) {\n var schemaValidation = this.validate(formData, schema, schemaUtils);\n errors = schemaValidation.errors;\n errorSchema = schemaValidation.errorSchema;\n schemaValidationErrors = errors;\n schemaValidationErrorSchema = errorSchema;\n } else {\n var currentErrors = getCurrentErrors();\n errors = currentErrors.errors;\n errorSchema = currentErrors.errorSchema;\n }\n if (props.extraErrors) {\n var merged = schemaUtils.mergeValidationData({\n errorSchema: errorSchema,\n errors: errors\n }, props.extraErrors);\n errorSchema = merged.errorSchema;\n errors = merged.errors;\n }\n var idSchema = schemaUtils.toIdSchema(retrievedSchema, uiSchema['ui:rootFieldId'], formData, props.idPrefix, props.idSeparator);\n var nextState = {\n schemaUtils: schemaUtils,\n schema: schema,\n uiSchema: uiSchema,\n idSchema: idSchema,\n formData: formData,\n edit: edit,\n errors: errors,\n errorSchema: errorSchema,\n schemaValidationErrors: schemaValidationErrors,\n schemaValidationErrorSchema: schemaValidationErrorSchema\n };\n return nextState;\n }\n /** React lifecycle method that is used to determine whether component should be updated.\r\n *\r\n * @param nextProps - The next version of the props\r\n * @param nextState - The next version of the state\r\n * @returns - True if the component should be updated, false otherwise\r\n */;\n _proto.shouldComponentUpdate = function shouldComponentUpdate(nextProps, nextState) {\n return shouldRender(this, nextProps, nextState);\n }\n /** Validates the `formData` against the `schema` using the `altSchemaUtils` (if provided otherwise it uses the\r\n * `schemaUtils` in the state), returning the results.\r\n *\r\n * @param formData - The new form data to validate\r\n * @param schema - The schema used to validate against\r\n * @param altSchemaUtils - The alternate schemaUtils to use for validation\r\n */;\n _proto.validate = function validate(formData, schema, altSchemaUtils) {\n if (schema === void 0) {\n schema = this.props.schema;\n }\n var schemaUtils = altSchemaUtils ? altSchemaUtils : this.state.schemaUtils;\n var _this$props3 = this.props,\n customValidate = _this$props3.customValidate,\n transformErrors = _this$props3.transformErrors,\n uiSchema = _this$props3.uiSchema;\n var resolvedSchema = schemaUtils.retrieveSchema(schema, formData);\n return schemaUtils.getValidator().validateFormData(formData, resolvedSchema, customValidate, transformErrors, uiSchema);\n }\n /** Renders any errors contained in the `state` in using the `ErrorList`, if not disabled by `showErrorList`. */;\n _proto.renderErrors = function renderErrors(registry) {\n var _this$state3 = this.state,\n errors = _this$state3.errors,\n errorSchema = _this$state3.errorSchema,\n schema = _this$state3.schema,\n uiSchema = _this$state3.uiSchema;\n var formContext = this.props.formContext;\n var options = getUiOptions(uiSchema);\n var ErrorListTemplate = getTemplate('ErrorListTemplate', registry, options);\n if (errors && errors.length) {\n return jsx(ErrorListTemplate, {\n errors: errors,\n errorSchema: errorSchema || {},\n schema: schema,\n uiSchema: uiSchema,\n formContext: formContext,\n registry: registry\n });\n }\n return null;\n }\n /** Returns the `formData` with only the elements specified in the `fields` list\r\n *\r\n * @param formData - The data for the `Form`\r\n * @param fields - The fields to keep while filtering\r\n */;\n /** Returns the registry for the form */\n _proto.getRegistry = function getRegistry() {\n var _this$props$templates;\n var _this$props4 = this.props,\n customTranslateString = _this$props4.translateString,\n _this$props4$uiSchema = _this$props4.uiSchema,\n uiSchema = _this$props4$uiSchema === void 0 ? {} : _this$props4$uiSchema;\n var schemaUtils = this.state.schemaUtils;\n var _getDefaultRegistry = getDefaultRegistry(),\n fields = _getDefaultRegistry.fields,\n templates = _getDefaultRegistry.templates,\n widgets = _getDefaultRegistry.widgets,\n formContext = _getDefaultRegistry.formContext,\n translateString = _getDefaultRegistry.translateString;\n return {\n fields: _extends({}, fields, this.props.fields),\n templates: _extends({}, templates, this.props.templates, {\n ButtonTemplates: _extends({}, templates.ButtonTemplates, (_this$props$templates = this.props.templates) === null || _this$props$templates === void 0 ? void 0 : _this$props$templates.ButtonTemplates)\n }),\n widgets: _extends({}, widgets, this.props.widgets),\n rootSchema: this.props.schema,\n formContext: this.props.formContext || formContext,\n schemaUtils: schemaUtils,\n translateString: customTranslateString || translateString,\n globalUiOptions: uiSchema[UI_GLOBAL_OPTIONS_KEY]\n };\n }\n /** Provides a function that can be used to programmatically submit the `Form` */;\n _proto.submit = function submit() {\n if (this.formElement.current) {\n this.formElement.current.dispatchEvent(new CustomEvent('submit', {\n cancelable: true\n }));\n this.formElement.current.requestSubmit();\n }\n }\n /** Attempts to focus on the field associated with the `error`. Uses the `property` field to compute path of the error\r\n * field, then, using the `idPrefix` and `idSeparator` converts that path into an id. Then the input element with that\r\n * id is attempted to be found using the `formElement` ref. If it is located, then it is focused.\r\n *\r\n * @param error - The error on which to focus\r\n */;\n _proto.focusOnError = function focusOnError(error) {\n var _this$props5 = this.props,\n _this$props5$idPrefix = _this$props5.idPrefix,\n idPrefix = _this$props5$idPrefix === void 0 ? 'root' : _this$props5$idPrefix,\n _this$props5$idSepara = _this$props5.idSeparator,\n idSeparator = _this$props5$idSepara === void 0 ? '_' : _this$props5$idSepara;\n var property = error.property;\n var path = _toPath(property);\n if (path[0] === '') {\n // Most of the time the `.foo` property results in the first element being empty, so replace it with the idPrefix\n path[0] = idPrefix;\n } else {\n // Otherwise insert the idPrefix into the first location using unshift\n path.unshift(idPrefix);\n }\n var elementId = path.join(idSeparator);\n var field = this.formElement.current.elements[elementId];\n if (!field) {\n // if not an exact match, try finding an input starting with the element id (like radio buttons or checkboxes)\n field = this.formElement.current.querySelector(\"input[id^=\" + elementId);\n }\n if (field.length) {\n // If we got a list with length > 0\n field = field[0];\n }\n if (field) {\n field.focus();\n }\n }\n /** Programmatically validate the form. If `onError` is provided, then it will be called with the list of errors the\r\n * same way as would happen on form submission.\r\n *\r\n * @returns - True if the form is valid, false otherwise.\r\n */;\n _proto.validateForm = function validateForm() {\n var _this$props6 = this.props,\n extraErrors = _this$props6.extraErrors,\n focusOnFirstError = _this$props6.focusOnFirstError,\n onError = _this$props6.onError;\n var formData = this.state.formData;\n var schemaUtils = this.state.schemaUtils;\n var schemaValidation = this.validate(formData);\n var errors = schemaValidation.errors;\n var errorSchema = schemaValidation.errorSchema;\n var schemaValidationErrors = errors;\n var schemaValidationErrorSchema = errorSchema;\n if (errors.length > 0) {\n if (extraErrors) {\n var merged = schemaUtils.mergeValidationData(schemaValidation, extraErrors);\n errorSchema = merged.errorSchema;\n errors = merged.errors;\n }\n if (focusOnFirstError) {\n this.focusOnError(schemaValidation.errors[0]);\n }\n this.setState({\n errors: errors,\n errorSchema: errorSchema,\n schemaValidationErrors: schemaValidationErrors,\n schemaValidationErrorSchema: schemaValidationErrorSchema\n }, function () {\n if (onError) {\n onError(errors);\n } else {\n console.error('Form validation failed', errors);\n }\n });\n return false;\n }\n return true;\n }\n /** Renders the `Form` fields inside the
| `tagName` or `_internalFormWrapper`, rendering any errors if\r\n * needed along with the submit button or any children of the form.\r\n */;\n _proto.render = function render() {\n var _this$props7 = this.props,\n children = _this$props7.children,\n id = _this$props7.id,\n idPrefix = _this$props7.idPrefix,\n idSeparator = _this$props7.idSeparator,\n _this$props7$classNam = _this$props7.className,\n className = _this$props7$classNam === void 0 ? '' : _this$props7$classNam,\n tagName = _this$props7.tagName,\n name = _this$props7.name,\n method = _this$props7.method,\n target = _this$props7.target,\n action = _this$props7.action,\n autoComplete = _this$props7.autoComplete,\n enctype = _this$props7.enctype,\n acceptcharset = _this$props7.acceptcharset,\n _this$props7$noHtml5V = _this$props7.noHtml5Validate,\n noHtml5Validate = _this$props7$noHtml5V === void 0 ? false : _this$props7$noHtml5V,\n _this$props7$disabled = _this$props7.disabled,\n disabled = _this$props7$disabled === void 0 ? false : _this$props7$disabled,\n _this$props7$readonly = _this$props7.readonly,\n readonly = _this$props7$readonly === void 0 ? false : _this$props7$readonly,\n formContext = _this$props7.formContext,\n _this$props7$showErro = _this$props7.showErrorList,\n showErrorList = _this$props7$showErro === void 0 ? 'top' : _this$props7$showErro,\n _internalFormWrapper = _this$props7._internalFormWrapper;\n var _this$state4 = this.state,\n schema = _this$state4.schema,\n uiSchema = _this$state4.uiSchema,\n formData = _this$state4.formData,\n errorSchema = _this$state4.errorSchema,\n idSchema = _this$state4.idSchema;\n var registry = this.getRegistry();\n var _SchemaField = registry.fields.SchemaField;\n var SubmitButton = registry.templates.ButtonTemplates.SubmitButton;\n // The `semantic-ui` and `material-ui` themes have `_internalFormWrapper`s that take an `as` prop that is the\n // PropTypes.elementType to use for the inner tag, so we'll need to pass `tagName` along if it is provided.\n // NOTE, the `as` prop is native to `semantic-ui` and is emulated in the `material-ui` theme\n var as = _internalFormWrapper ? tagName : undefined;\n var FormTag = _internalFormWrapper || tagName || 'form';\n return jsxs(FormTag, {\n className: className ? className : 'rjsf',\n id: id,\n name: name,\n method: method,\n target: target,\n action: action,\n autoComplete: autoComplete,\n encType: enctype,\n acceptCharset: acceptcharset,\n noValidate: noHtml5Validate,\n onSubmit: this.onSubmit,\n as: as,\n ref: this.formElement,\n children: [showErrorList === 'top' && this.renderErrors(registry), jsx(_SchemaField, {\n name: '',\n schema: schema,\n uiSchema: uiSchema,\n errorSchema: errorSchema,\n idSchema: idSchema,\n idPrefix: idPrefix,\n idSeparator: idSeparator,\n formContext: formContext,\n formData: formData,\n onChange: this.onChange,\n onBlur: this.onBlur,\n onFocus: this.onFocus,\n registry: registry,\n disabled: disabled,\n readonly: readonly\n }), children ? children : jsx(SubmitButton, {\n uiSchema: uiSchema,\n registry: registry\n }), showErrorList === 'bottom' && this.renderErrors(registry)]\n });\n };\n return Form;\n}(Component);\n\nvar _excluded = [\"fields\", \"widgets\", \"templates\"];\n/** A Higher-Order component that creates a wrapper around a `Form` with the overrides from the `WithThemeProps` */\nfunction withTheme(themeProps) {\n return /*#__PURE__*/forwardRef(function (_ref, ref) {\n var _themeProps$templates, _templates;\n var fields = _ref.fields,\n widgets = _ref.widgets,\n templates = _ref.templates,\n directProps = _objectWithoutPropertiesLoose(_ref, _excluded);\n fields = _extends({}, themeProps === null || themeProps === void 0 ? void 0 : themeProps.fields, fields);\n widgets = _extends({}, themeProps === null || themeProps === void 0 ? void 0 : themeProps.widgets, widgets);\n templates = _extends({}, themeProps === null || themeProps === void 0 ? void 0 : themeProps.templates, templates, {\n ButtonTemplates: _extends({}, themeProps === null || themeProps === void 0 ? void 0 : (_themeProps$templates = themeProps.templates) === null || _themeProps$templates === void 0 ? void 0 : _themeProps$templates.ButtonTemplates, (_templates = templates) === null || _templates === void 0 ? void 0 : _templates.ButtonTemplates)\n });\n return jsx(Form, _extends({}, themeProps, directProps, {\n fields: fields,\n widgets: widgets,\n templates: templates,\n ref: ref\n }));\n });\n}\n\nexport { Form as default, getDefaultRegistry, withTheme };\n//# sourceMappingURL=core.esm.js.map\n","// src/index.ts\nimport { useEffect, useLayoutEffect } from \"react\";\nvar useSafeLayoutEffect = Boolean(globalThis == null ? void 0 : globalThis.document) ? useLayoutEffect : useEffect;\nexport {\n useSafeLayoutEffect\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/color-mode-provider.tsx\nimport { useSafeLayoutEffect } from \"@chakra-ui/react-use-safe-layout-effect\";\nimport { useCallback, useEffect, useMemo, useState } from \"react\";\n\n// src/color-mode-context.ts\nimport { createContext, useContext } from \"react\";\nvar ColorModeContext = createContext({});\nColorModeContext.displayName = \"ColorModeContext\";\nfunction useColorMode() {\n const context = useContext(ColorModeContext);\n if (context === void 0) {\n throw new Error(\"useColorMode must be used within a ColorModeProvider\");\n }\n return context;\n}\nfunction useColorModeValue(light, dark) {\n const { colorMode } = useColorMode();\n return colorMode === \"dark\" ? dark : light;\n}\n\n// src/color-mode.utils.ts\nvar classNames = {\n light: \"chakra-ui-light\",\n dark: \"chakra-ui-dark\"\n};\nfunction getColorModeUtils(options = {}) {\n const { preventTransition = true } = options;\n const utils = {\n setDataset: (value) => {\n const cleanup = preventTransition ? utils.preventTransition() : void 0;\n document.documentElement.dataset.theme = value;\n document.documentElement.style.colorScheme = value;\n cleanup == null ? void 0 : cleanup();\n },\n setClassName(dark) {\n document.body.classList.add(dark ? classNames.dark : classNames.light);\n document.body.classList.remove(dark ? classNames.light : classNames.dark);\n },\n query() {\n return window.matchMedia(\"(prefers-color-scheme: dark)\");\n },\n getSystemTheme(fallback) {\n const dark = utils.query().matches ?? fallback === \"dark\";\n return dark ? \"dark\" : \"light\";\n },\n addListener(fn) {\n const mql = utils.query();\n const listener = (e) => {\n fn(e.matches ? \"dark\" : \"light\");\n };\n if (typeof mql.addListener === \"function\")\n mql.addListener(listener);\n else\n mql.addEventListener(\"change\", listener);\n return () => {\n if (typeof mql.removeListener === \"function\")\n mql.removeListener(listener);\n else\n mql.removeEventListener(\"change\", listener);\n };\n },\n preventTransition() {\n const css = document.createElement(\"style\");\n css.appendChild(document.createTextNode(`*{-webkit-transition:none!important;-moz-transition:none!important;-o-transition:none!important;-ms-transition:none!important;transition:none!important}`));\n document.head.appendChild(css);\n return () => {\n ;\n (() => window.getComputedStyle(document.body))();\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n document.head.removeChild(css);\n });\n });\n };\n }\n };\n return utils;\n}\n\n// src/storage-manager.ts\nvar STORAGE_KEY = \"chakra-ui-color-mode\";\nfunction createLocalStorageManager(key) {\n return {\n ssr: false,\n type: \"localStorage\",\n get(init) {\n if (!(globalThis == null ? void 0 : globalThis.document))\n return init;\n let value;\n try {\n value = localStorage.getItem(key) || init;\n } catch (e) {\n }\n return value || init;\n },\n set(value) {\n try {\n localStorage.setItem(key, value);\n } catch (e) {\n }\n }\n };\n}\nvar localStorageManager = createLocalStorageManager(STORAGE_KEY);\nfunction parseCookie(cookie, key) {\n const match = cookie.match(new RegExp(`(^| )${key}=([^;]+)`));\n return match == null ? void 0 : match[2];\n}\nfunction createCookieStorageManager(key, cookie) {\n return {\n ssr: !!cookie,\n type: \"cookie\",\n get(init) {\n if (cookie)\n return parseCookie(cookie, key);\n if (!(globalThis == null ? void 0 : globalThis.document))\n return init;\n return parseCookie(document.cookie, key) || init;\n },\n set(value) {\n document.cookie = `${key}=${value}; max-age=31536000; path=/`;\n }\n };\n}\nvar cookieStorageManager = createCookieStorageManager(STORAGE_KEY);\nvar cookieStorageManagerSSR = (cookie) => createCookieStorageManager(STORAGE_KEY, cookie);\n\n// src/color-mode-provider.tsx\nvar noop = () => {\n};\nfunction getTheme(manager, fallback) {\n return manager.type === \"cookie\" && manager.ssr ? manager.get(fallback) : fallback;\n}\nfunction ColorModeProvider(props) {\n const {\n value,\n children,\n options: {\n useSystemColorMode,\n initialColorMode,\n disableTransitionOnChange\n } = {},\n colorModeManager = localStorageManager\n } = props;\n const defaultColorMode = initialColorMode === \"dark\" ? \"dark\" : \"light\";\n const [colorMode, rawSetColorMode] = useState(() => getTheme(colorModeManager, defaultColorMode));\n const [resolvedColorMode, setResolvedColorMode] = useState(() => getTheme(colorModeManager));\n const { getSystemTheme, setClassName, setDataset, addListener } = useMemo(() => getColorModeUtils({ preventTransition: disableTransitionOnChange }), [disableTransitionOnChange]);\n const resolvedValue = initialColorMode === \"system\" && !colorMode ? resolvedColorMode : colorMode;\n const setColorMode = useCallback((value2) => {\n const resolved = value2 === \"system\" ? getSystemTheme() : value2;\n rawSetColorMode(resolved);\n setClassName(resolved === \"dark\");\n setDataset(resolved);\n colorModeManager.set(resolved);\n }, [colorModeManager, getSystemTheme, setClassName, setDataset]);\n useSafeLayoutEffect(() => {\n if (initialColorMode === \"system\") {\n setResolvedColorMode(getSystemTheme());\n }\n }, []);\n useEffect(() => {\n const managerValue = colorModeManager.get();\n if (managerValue) {\n setColorMode(managerValue);\n return;\n }\n if (initialColorMode === \"system\") {\n setColorMode(\"system\");\n return;\n }\n setColorMode(defaultColorMode);\n }, [colorModeManager, defaultColorMode, initialColorMode, setColorMode]);\n const toggleColorMode = useCallback(() => {\n setColorMode(resolvedValue === \"dark\" ? \"light\" : \"dark\");\n }, [resolvedValue, setColorMode]);\n useEffect(() => {\n if (!useSystemColorMode)\n return;\n return addListener(setColorMode);\n }, [useSystemColorMode, addListener, setColorMode]);\n const context = useMemo(() => ({\n colorMode: value ?? resolvedValue,\n toggleColorMode: value ? noop : toggleColorMode,\n setColorMode: value ? noop : setColorMode,\n forced: value !== void 0\n }), [resolvedValue, toggleColorMode, setColorMode, value]);\n return /* @__PURE__ */ React.createElement(ColorModeContext.Provider, {\n value: context\n }, children);\n}\nColorModeProvider.displayName = \"ColorModeProvider\";\nfunction DarkMode(props) {\n const context = useMemo(() => ({\n colorMode: \"dark\",\n toggleColorMode: noop,\n setColorMode: noop,\n forced: true\n }), []);\n return /* @__PURE__ */ React.createElement(ColorModeContext.Provider, {\n value: context,\n ...props\n });\n}\nDarkMode.displayName = \"DarkMode\";\nfunction LightMode(props) {\n const context = useMemo(() => ({\n colorMode: \"light\",\n toggleColorMode: noop,\n setColorMode: noop,\n forced: true\n }), []);\n return /* @__PURE__ */ React.createElement(ColorModeContext.Provider, {\n value: context,\n ...props\n });\n}\nLightMode.displayName = \"LightMode\";\n\n// src/color-mode-script.tsx\nvar VALID_VALUES = /* @__PURE__ */ new Set([\"dark\", \"light\", \"system\"]);\nfunction normalize(initialColorMode) {\n let value = initialColorMode;\n if (!VALID_VALUES.has(value))\n value = \"light\";\n return value;\n}\nfunction getScriptSrc(props = {}) {\n const {\n initialColorMode = \"light\",\n type = \"localStorage\",\n storageKey: key = \"chakra-ui-color-mode\"\n } = props;\n const init = normalize(initialColorMode);\n const isCookie = type === \"cookie\";\n const cookieScript = `(function(){try{var a=function(o){var l=\"(prefers-color-scheme: dark)\",v=window.matchMedia(l).matches?\"dark\":\"light\",e=o===\"system\"?v:o,d=document.documentElement,m=document.body,i=\"chakra-ui-light\",n=\"chakra-ui-dark\",s=e===\"dark\";return m.classList.add(s?n:i),m.classList.remove(s?i:n),d.style.colorScheme=e,d.dataset.theme=e,e},u=a,h=\"${init}\",r=\"${key}\",t=document.cookie.match(new RegExp(\"(^| )\".concat(r,\"=([^;]+)\"))),c=t?t[2]:null;c?a(c):document.cookie=\"\".concat(r,\"=\").concat(a(h),\"; max-age=31536000; path=/\")}catch(a){}})();\n `;\n const localStorageScript = `(function(){try{var a=function(c){var v=\"(prefers-color-scheme: dark)\",h=window.matchMedia(v).matches?\"dark\":\"light\",r=c===\"system\"?h:c,o=document.documentElement,s=document.body,l=\"chakra-ui-light\",d=\"chakra-ui-dark\",i=r===\"dark\";return s.classList.add(i?d:l),s.classList.remove(i?l:d),o.style.colorScheme=r,o.dataset.theme=r,r},n=a,m=\"${init}\",e=\"${key}\",t=localStorage.getItem(e);t?a(t):localStorage.setItem(e,a(m))}catch(a){}})();\n `;\n const fn = isCookie ? cookieScript : localStorageScript;\n return `!${fn}`.trim();\n}\nfunction ColorModeScript(props = {}) {\n const { nonce } = props;\n return /* @__PURE__ */ React.createElement(\"script\", {\n id: \"chakra-script\",\n nonce,\n dangerouslySetInnerHTML: { __html: getScriptSrc(props) }\n });\n}\nexport {\n ColorModeContext,\n ColorModeProvider,\n ColorModeScript,\n DarkMode,\n LightMode,\n cookieStorageManager,\n cookieStorageManagerSSR,\n createCookieStorageManager,\n createLocalStorageManager,\n getScriptSrc,\n localStorageManager,\n useColorMode,\n useColorModeValue\n};\n","// ../../utilities/shared-utils/src/index.ts\nfunction isObject(value) {\n const type = typeof value;\n return value != null && (type === \"object\" || type === \"function\") && !Array.isArray(value);\n}\nfunction runIfFn(valueOrFn, ...args) {\n return isFunction(valueOrFn) ? valueOrFn(...args) : valueOrFn;\n}\nvar isFunction = (value) => typeof value === \"function\";\n\n// src/utils/create-transform.ts\nvar isImportant = (value) => /!(important)?$/.test(value);\nvar withoutImportant = (value) => typeof value === \"string\" ? value.replace(/!(important)?$/, \"\").trim() : value;\nvar tokenToCSSVar = (scale, value) => (theme) => {\n const valueStr = String(value);\n const important = isImportant(valueStr);\n const valueWithoutImportant = withoutImportant(valueStr);\n const key = scale ? `${scale}.${valueWithoutImportant}` : valueWithoutImportant;\n let transformed = isObject(theme.__cssMap) && key in theme.__cssMap ? theme.__cssMap[key].varRef : value;\n transformed = withoutImportant(transformed);\n return important ? `${transformed} !important` : transformed;\n};\nfunction createTransform(options) {\n const { scale, transform: transform2, compose } = options;\n const fn = (value, theme) => {\n const _value = tokenToCSSVar(scale, value)(theme);\n let result = (transform2 == null ? void 0 : transform2(_value, theme)) ?? _value;\n if (compose) {\n result = compose(result, theme);\n }\n return result;\n };\n return fn;\n}\n\n// src/utils/pipe.ts\nvar pipe = (...fns) => (v) => fns.reduce((a, b) => b(a), v);\n\n// src/utils/prop-config.ts\nfunction toConfig(scale, transform2) {\n return (property) => {\n const result = { property, scale };\n result.transform = createTransform({\n scale,\n transform: transform2\n });\n return result;\n };\n}\nvar getRtl = ({ rtl, ltr }) => (theme) => theme.direction === \"rtl\" ? rtl : ltr;\nfunction logical(options) {\n const { property, scale, transform: transform2 } = options;\n return {\n scale,\n property: getRtl(property),\n transform: scale ? createTransform({\n scale,\n compose: transform2\n }) : transform2\n };\n}\n\n// src/utils/templates.ts\nvar transformTemplate = [\n \"rotate(var(--chakra-rotate, 0))\",\n \"scaleX(var(--chakra-scale-x, 1))\",\n \"scaleY(var(--chakra-scale-y, 1))\",\n \"skewX(var(--chakra-skew-x, 0))\",\n \"skewY(var(--chakra-skew-y, 0))\"\n];\nfunction getTransformTemplate() {\n return [\n \"translateX(var(--chakra-translate-x, 0))\",\n \"translateY(var(--chakra-translate-y, 0))\",\n ...transformTemplate\n ].join(\" \");\n}\nfunction getTransformGpuTemplate() {\n return [\n \"translate3d(var(--chakra-translate-x, 0), var(--chakra-translate-y, 0), 0)\",\n ...transformTemplate\n ].join(\" \");\n}\nvar filterTemplate = {\n \"--chakra-blur\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-brightness\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-contrast\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-grayscale\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-hue-rotate\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-invert\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-saturate\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-sepia\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-drop-shadow\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n filter: [\n \"var(--chakra-blur)\",\n \"var(--chakra-brightness)\",\n \"var(--chakra-contrast)\",\n \"var(--chakra-grayscale)\",\n \"var(--chakra-hue-rotate)\",\n \"var(--chakra-invert)\",\n \"var(--chakra-saturate)\",\n \"var(--chakra-sepia)\",\n \"var(--chakra-drop-shadow)\"\n ].join(\" \")\n};\nvar backdropFilterTemplate = {\n backdropFilter: [\n \"var(--chakra-backdrop-blur)\",\n \"var(--chakra-backdrop-brightness)\",\n \"var(--chakra-backdrop-contrast)\",\n \"var(--chakra-backdrop-grayscale)\",\n \"var(--chakra-backdrop-hue-rotate)\",\n \"var(--chakra-backdrop-invert)\",\n \"var(--chakra-backdrop-opacity)\",\n \"var(--chakra-backdrop-saturate)\",\n \"var(--chakra-backdrop-sepia)\"\n ].join(\" \"),\n \"--chakra-backdrop-blur\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-backdrop-brightness\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-backdrop-contrast\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-backdrop-grayscale\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-backdrop-hue-rotate\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-backdrop-invert\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-backdrop-opacity\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-backdrop-saturate\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-backdrop-sepia\": \"var(--chakra-empty,/*!*/ /*!*/)\"\n};\nfunction getRingTemplate(value) {\n return {\n \"--chakra-ring-offset-shadow\": `var(--chakra-ring-inset) 0 0 0 var(--chakra-ring-offset-width) var(--chakra-ring-offset-color)`,\n \"--chakra-ring-shadow\": `var(--chakra-ring-inset) 0 0 0 calc(var(--chakra-ring-width) + var(--chakra-ring-offset-width)) var(--chakra-ring-color)`,\n \"--chakra-ring-width\": value,\n boxShadow: [\n `var(--chakra-ring-offset-shadow)`,\n `var(--chakra-ring-shadow)`,\n `var(--chakra-shadow, 0 0 #0000)`\n ].join(\", \")\n };\n}\nvar flexDirectionTemplate = {\n \"row-reverse\": {\n space: \"--chakra-space-x-reverse\",\n divide: \"--chakra-divide-x-reverse\"\n },\n \"column-reverse\": {\n space: \"--chakra-space-y-reverse\",\n divide: \"--chakra-divide-y-reverse\"\n }\n};\nvar owlSelector = \"& > :not(style) ~ :not(style)\";\nvar spaceXTemplate = {\n [owlSelector]: {\n marginInlineStart: \"calc(var(--chakra-space-x) * calc(1 - var(--chakra-space-x-reverse)))\",\n marginInlineEnd: \"calc(var(--chakra-space-x) * var(--chakra-space-x-reverse))\"\n }\n};\nvar spaceYTemplate = {\n [owlSelector]: {\n marginTop: \"calc(var(--chakra-space-y) * calc(1 - var(--chakra-space-y-reverse)))\",\n marginBottom: \"calc(var(--chakra-space-y) * var(--chakra-space-y-reverse))\"\n }\n};\n\n// src/utils/parse-gradient.ts\nvar directionMap = {\n \"to-t\": \"to top\",\n \"to-tr\": \"to top right\",\n \"to-r\": \"to right\",\n \"to-br\": \"to bottom right\",\n \"to-b\": \"to bottom\",\n \"to-bl\": \"to bottom left\",\n \"to-l\": \"to left\",\n \"to-tl\": \"to top left\"\n};\nvar valueSet = new Set(Object.values(directionMap));\nvar globalSet = /* @__PURE__ */ new Set([\n \"none\",\n \"-moz-initial\",\n \"inherit\",\n \"initial\",\n \"revert\",\n \"unset\"\n]);\nvar trimSpace = (str) => str.trim();\nfunction parseGradient(value, theme) {\n var _a;\n if (value == null || globalSet.has(value))\n return value;\n const regex = /(?^[a-z-A-Z]+)\\((?(.*))\\)/g;\n const { type, values } = ((_a = regex.exec(value)) == null ? void 0 : _a.groups) ?? {};\n if (!type || !values)\n return value;\n const _type = type.includes(\"-gradient\") ? type : `${type}-gradient`;\n const [maybeDirection, ...stops] = values.split(\",\").map(trimSpace).filter(Boolean);\n if ((stops == null ? void 0 : stops.length) === 0)\n return value;\n const direction = maybeDirection in directionMap ? directionMap[maybeDirection] : maybeDirection;\n stops.unshift(direction);\n const _values = stops.map((stop) => {\n if (valueSet.has(stop))\n return stop;\n const firstStop = stop.indexOf(\" \");\n const [_color, _stop] = firstStop !== -1 ? [stop.substr(0, firstStop), stop.substr(firstStop + 1)] : [stop];\n const _stopOrFunc = isCSSFunction(_stop) ? _stop : _stop && _stop.split(\" \");\n const key = `colors.${_color}`;\n const color2 = key in theme.__cssMap ? theme.__cssMap[key].varRef : _color;\n return _stopOrFunc ? [\n color2,\n ...Array.isArray(_stopOrFunc) ? _stopOrFunc : [_stopOrFunc]\n ].join(\" \") : color2;\n });\n return `${_type}(${_values.join(\", \")})`;\n}\nvar isCSSFunction = (value) => {\n return typeof value === \"string\" && value.includes(\"(\") && value.includes(\")\");\n};\nvar gradientTransform = (value, theme) => parseGradient(value, theme ?? {});\n\n// src/utils/transform-functions.ts\nfunction isCssVar(value) {\n return /^var\\(--.+\\)$/.test(value);\n}\nvar analyzeCSSValue = (value) => {\n const num = parseFloat(value.toString());\n const unit = value.toString().replace(String(num), \"\");\n return { unitless: !unit, value: num, unit };\n};\nvar wrap = (str) => (value) => `${str}(${value})`;\nvar transformFunctions = {\n filter(value) {\n return value !== \"auto\" ? value : filterTemplate;\n },\n backdropFilter(value) {\n return value !== \"auto\" ? value : backdropFilterTemplate;\n },\n ring(value) {\n return getRingTemplate(transformFunctions.px(value));\n },\n bgClip(value) {\n return value === \"text\" ? { color: \"transparent\", backgroundClip: \"text\" } : { backgroundClip: value };\n },\n transform(value) {\n if (value === \"auto\")\n return getTransformTemplate();\n if (value === \"auto-gpu\")\n return getTransformGpuTemplate();\n return value;\n },\n vh(value) {\n return value === \"$100vh\" ? \"var(--chakra-vh)\" : value;\n },\n px(value) {\n if (value == null)\n return value;\n const { unitless } = analyzeCSSValue(value);\n return unitless || typeof value === \"number\" ? `${value}px` : value;\n },\n fraction(value) {\n return !(typeof value === \"number\") || value > 1 ? value : `${value * 100}%`;\n },\n float(value, theme) {\n const map = { left: \"right\", right: \"left\" };\n return theme.direction === \"rtl\" ? map[value] : value;\n },\n degree(value) {\n if (isCssVar(value) || value == null)\n return value;\n const unitless = typeof value === \"string\" && !value.endsWith(\"deg\");\n return typeof value === \"number\" || unitless ? `${value}deg` : value;\n },\n gradient: gradientTransform,\n blur: wrap(\"blur\"),\n opacity: wrap(\"opacity\"),\n brightness: wrap(\"brightness\"),\n contrast: wrap(\"contrast\"),\n dropShadow: wrap(\"drop-shadow\"),\n grayscale: wrap(\"grayscale\"),\n hueRotate: wrap(\"hue-rotate\"),\n invert: wrap(\"invert\"),\n saturate: wrap(\"saturate\"),\n sepia: wrap(\"sepia\"),\n bgImage(value) {\n if (value == null)\n return value;\n const prevent = isCSSFunction(value) || globalSet.has(value);\n return !prevent ? `url(${value})` : value;\n },\n outline(value) {\n const isNoneOrZero = String(value) === \"0\" || String(value) === \"none\";\n return value !== null && isNoneOrZero ? { outline: \"2px solid transparent\", outlineOffset: \"2px\" } : { outline: value };\n },\n flexDirection(value) {\n const { space: space2, divide: divide2 } = flexDirectionTemplate[value] ?? {};\n const result = { flexDirection: value };\n if (space2)\n result[space2] = 1;\n if (divide2)\n result[divide2] = 1;\n return result;\n }\n};\n\n// src/utils/index.ts\nvar t = {\n borderWidths: toConfig(\"borderWidths\"),\n borderStyles: toConfig(\"borderStyles\"),\n colors: toConfig(\"colors\"),\n borders: toConfig(\"borders\"),\n radii: toConfig(\"radii\", transformFunctions.px),\n space: toConfig(\"space\", pipe(transformFunctions.vh, transformFunctions.px)),\n spaceT: toConfig(\"space\", pipe(transformFunctions.vh, transformFunctions.px)),\n degreeT(property) {\n return { property, transform: transformFunctions.degree };\n },\n prop(property, scale, transform2) {\n return {\n property,\n scale,\n ...scale && {\n transform: createTransform({ scale, transform: transform2 })\n }\n };\n },\n propT(property, transform2) {\n return { property, transform: transform2 };\n },\n sizes: toConfig(\"sizes\", pipe(transformFunctions.vh, transformFunctions.px)),\n sizesT: toConfig(\"sizes\", pipe(transformFunctions.vh, transformFunctions.fraction)),\n shadows: toConfig(\"shadows\"),\n logical,\n blur: toConfig(\"blur\", transformFunctions.blur)\n};\n\n// src/config/background.ts\nvar background = {\n background: t.colors(\"background\"),\n backgroundColor: t.colors(\"backgroundColor\"),\n backgroundImage: t.propT(\"backgroundImage\", transformFunctions.bgImage),\n backgroundSize: true,\n backgroundPosition: true,\n backgroundRepeat: true,\n backgroundAttachment: true,\n backgroundClip: { transform: transformFunctions.bgClip },\n bgSize: t.prop(\"backgroundSize\"),\n bgPosition: t.prop(\"backgroundPosition\"),\n bg: t.colors(\"background\"),\n bgColor: t.colors(\"backgroundColor\"),\n bgPos: t.prop(\"backgroundPosition\"),\n bgRepeat: t.prop(\"backgroundRepeat\"),\n bgAttachment: t.prop(\"backgroundAttachment\"),\n bgGradient: t.propT(\"backgroundImage\", transformFunctions.gradient),\n bgClip: { transform: transformFunctions.bgClip }\n};\nObject.assign(background, {\n bgImage: background.backgroundImage,\n bgImg: background.backgroundImage\n});\n\n// src/config/border.ts\nvar border = {\n border: t.borders(\"border\"),\n borderWidth: t.borderWidths(\"borderWidth\"),\n borderStyle: t.borderStyles(\"borderStyle\"),\n borderColor: t.colors(\"borderColor\"),\n borderRadius: t.radii(\"borderRadius\"),\n borderTop: t.borders(\"borderTop\"),\n borderBlockStart: t.borders(\"borderBlockStart\"),\n borderTopLeftRadius: t.radii(\"borderTopLeftRadius\"),\n borderStartStartRadius: t.logical({\n scale: \"radii\",\n property: {\n ltr: \"borderTopLeftRadius\",\n rtl: \"borderTopRightRadius\"\n }\n }),\n borderEndStartRadius: t.logical({\n scale: \"radii\",\n property: {\n ltr: \"borderBottomLeftRadius\",\n rtl: \"borderBottomRightRadius\"\n }\n }),\n borderTopRightRadius: t.radii(\"borderTopRightRadius\"),\n borderStartEndRadius: t.logical({\n scale: \"radii\",\n property: {\n ltr: \"borderTopRightRadius\",\n rtl: \"borderTopLeftRadius\"\n }\n }),\n borderEndEndRadius: t.logical({\n scale: \"radii\",\n property: {\n ltr: \"borderBottomRightRadius\",\n rtl: \"borderBottomLeftRadius\"\n }\n }),\n borderRight: t.borders(\"borderRight\"),\n borderInlineEnd: t.borders(\"borderInlineEnd\"),\n borderBottom: t.borders(\"borderBottom\"),\n borderBlockEnd: t.borders(\"borderBlockEnd\"),\n borderBottomLeftRadius: t.radii(\"borderBottomLeftRadius\"),\n borderBottomRightRadius: t.radii(\"borderBottomRightRadius\"),\n borderLeft: t.borders(\"borderLeft\"),\n borderInlineStart: {\n property: \"borderInlineStart\",\n scale: \"borders\"\n },\n borderInlineStartRadius: t.logical({\n scale: \"radii\",\n property: {\n ltr: [\"borderTopLeftRadius\", \"borderBottomLeftRadius\"],\n rtl: [\"borderTopRightRadius\", \"borderBottomRightRadius\"]\n }\n }),\n borderInlineEndRadius: t.logical({\n scale: \"radii\",\n property: {\n ltr: [\"borderTopRightRadius\", \"borderBottomRightRadius\"],\n rtl: [\"borderTopLeftRadius\", \"borderBottomLeftRadius\"]\n }\n }),\n borderX: t.borders([\"borderLeft\", \"borderRight\"]),\n borderInline: t.borders(\"borderInline\"),\n borderY: t.borders([\"borderTop\", \"borderBottom\"]),\n borderBlock: t.borders(\"borderBlock\"),\n borderTopWidth: t.borderWidths(\"borderTopWidth\"),\n borderBlockStartWidth: t.borderWidths(\"borderBlockStartWidth\"),\n borderTopColor: t.colors(\"borderTopColor\"),\n borderBlockStartColor: t.colors(\"borderBlockStartColor\"),\n borderTopStyle: t.borderStyles(\"borderTopStyle\"),\n borderBlockStartStyle: t.borderStyles(\"borderBlockStartStyle\"),\n borderBottomWidth: t.borderWidths(\"borderBottomWidth\"),\n borderBlockEndWidth: t.borderWidths(\"borderBlockEndWidth\"),\n borderBottomColor: t.colors(\"borderBottomColor\"),\n borderBlockEndColor: t.colors(\"borderBlockEndColor\"),\n borderBottomStyle: t.borderStyles(\"borderBottomStyle\"),\n borderBlockEndStyle: t.borderStyles(\"borderBlockEndStyle\"),\n borderLeftWidth: t.borderWidths(\"borderLeftWidth\"),\n borderInlineStartWidth: t.borderWidths(\"borderInlineStartWidth\"),\n borderLeftColor: t.colors(\"borderLeftColor\"),\n borderInlineStartColor: t.colors(\"borderInlineStartColor\"),\n borderLeftStyle: t.borderStyles(\"borderLeftStyle\"),\n borderInlineStartStyle: t.borderStyles(\"borderInlineStartStyle\"),\n borderRightWidth: t.borderWidths(\"borderRightWidth\"),\n borderInlineEndWidth: t.borderWidths(\"borderInlineEndWidth\"),\n borderRightColor: t.colors(\"borderRightColor\"),\n borderInlineEndColor: t.colors(\"borderInlineEndColor\"),\n borderRightStyle: t.borderStyles(\"borderRightStyle\"),\n borderInlineEndStyle: t.borderStyles(\"borderInlineEndStyle\"),\n borderTopRadius: t.radii([\"borderTopLeftRadius\", \"borderTopRightRadius\"]),\n borderBottomRadius: t.radii([\n \"borderBottomLeftRadius\",\n \"borderBottomRightRadius\"\n ]),\n borderLeftRadius: t.radii([\"borderTopLeftRadius\", \"borderBottomLeftRadius\"]),\n borderRightRadius: t.radii([\n \"borderTopRightRadius\",\n \"borderBottomRightRadius\"\n ])\n};\nObject.assign(border, {\n rounded: border.borderRadius,\n roundedTop: border.borderTopRadius,\n roundedTopLeft: border.borderTopLeftRadius,\n roundedTopRight: border.borderTopRightRadius,\n roundedTopStart: border.borderStartStartRadius,\n roundedTopEnd: border.borderStartEndRadius,\n roundedBottom: border.borderBottomRadius,\n roundedBottomLeft: border.borderBottomLeftRadius,\n roundedBottomRight: border.borderBottomRightRadius,\n roundedBottomStart: border.borderEndStartRadius,\n roundedBottomEnd: border.borderEndEndRadius,\n roundedLeft: border.borderLeftRadius,\n roundedRight: border.borderRightRadius,\n roundedStart: border.borderInlineStartRadius,\n roundedEnd: border.borderInlineEndRadius,\n borderStart: border.borderInlineStart,\n borderEnd: border.borderInlineEnd,\n borderTopStartRadius: border.borderStartStartRadius,\n borderTopEndRadius: border.borderStartEndRadius,\n borderBottomStartRadius: border.borderEndStartRadius,\n borderBottomEndRadius: border.borderEndEndRadius,\n borderStartRadius: border.borderInlineStartRadius,\n borderEndRadius: border.borderInlineEndRadius,\n borderStartWidth: border.borderInlineStartWidth,\n borderEndWidth: border.borderInlineEndWidth,\n borderStartColor: border.borderInlineStartColor,\n borderEndColor: border.borderInlineEndColor,\n borderStartStyle: border.borderInlineStartStyle,\n borderEndStyle: border.borderInlineEndStyle\n});\n\n// src/config/color.ts\nvar color = {\n color: t.colors(\"color\"),\n textColor: t.colors(\"color\"),\n fill: t.colors(\"fill\"),\n stroke: t.colors(\"stroke\")\n};\n\n// src/config/effect.ts\nvar effect = {\n boxShadow: t.shadows(\"boxShadow\"),\n mixBlendMode: true,\n blendMode: t.prop(\"mixBlendMode\"),\n backgroundBlendMode: true,\n bgBlendMode: t.prop(\"backgroundBlendMode\"),\n opacity: true\n};\nObject.assign(effect, {\n shadow: effect.boxShadow\n});\n\n// src/config/filter.ts\nvar filter = {\n filter: { transform: transformFunctions.filter },\n blur: t.blur(\"--chakra-blur\"),\n brightness: t.propT(\"--chakra-brightness\", transformFunctions.brightness),\n contrast: t.propT(\"--chakra-contrast\", transformFunctions.contrast),\n hueRotate: t.degreeT(\"--chakra-hue-rotate\"),\n invert: t.propT(\"--chakra-invert\", transformFunctions.invert),\n saturate: t.propT(\"--chakra-saturate\", transformFunctions.saturate),\n dropShadow: t.propT(\"--chakra-drop-shadow\", transformFunctions.dropShadow),\n backdropFilter: { transform: transformFunctions.backdropFilter },\n backdropBlur: t.blur(\"--chakra-backdrop-blur\"),\n backdropBrightness: t.propT(\"--chakra-backdrop-brightness\", transformFunctions.brightness),\n backdropContrast: t.propT(\"--chakra-backdrop-contrast\", transformFunctions.contrast),\n backdropHueRotate: t.degreeT(\"--chakra-backdrop-hue-rotate\"),\n backdropInvert: t.propT(\"--chakra-backdrop-invert\", transformFunctions.invert),\n backdropSaturate: t.propT(\"--chakra-backdrop-saturate\", transformFunctions.saturate)\n};\n\n// src/config/flexbox.ts\nvar flexbox = {\n alignItems: true,\n alignContent: true,\n justifyItems: true,\n justifyContent: true,\n flexWrap: true,\n flexDirection: { transform: transformFunctions.flexDirection },\n experimental_spaceX: {\n static: spaceXTemplate,\n transform: createTransform({\n scale: \"space\",\n transform: (value) => value !== null ? { \"--chakra-space-x\": value } : null\n })\n },\n experimental_spaceY: {\n static: spaceYTemplate,\n transform: createTransform({\n scale: \"space\",\n transform: (value) => value != null ? { \"--chakra-space-y\": value } : null\n })\n },\n flex: true,\n flexFlow: true,\n flexGrow: true,\n flexShrink: true,\n flexBasis: t.sizes(\"flexBasis\"),\n justifySelf: true,\n alignSelf: true,\n order: true,\n placeItems: true,\n placeContent: true,\n placeSelf: true,\n gap: t.space(\"gap\"),\n rowGap: t.space(\"rowGap\"),\n columnGap: t.space(\"columnGap\")\n};\nObject.assign(flexbox, {\n flexDir: flexbox.flexDirection\n});\n\n// src/config/grid.ts\nvar grid = {\n gridGap: t.space(\"gridGap\"),\n gridColumnGap: t.space(\"gridColumnGap\"),\n gridRowGap: t.space(\"gridRowGap\"),\n gridColumn: true,\n gridRow: true,\n gridAutoFlow: true,\n gridAutoColumns: true,\n gridColumnStart: true,\n gridColumnEnd: true,\n gridRowStart: true,\n gridRowEnd: true,\n gridAutoRows: true,\n gridTemplate: true,\n gridTemplateColumns: true,\n gridTemplateRows: true,\n gridTemplateAreas: true,\n gridArea: true\n};\n\n// src/config/interactivity.ts\nvar interactivity = {\n appearance: true,\n cursor: true,\n resize: true,\n userSelect: true,\n pointerEvents: true,\n outline: { transform: transformFunctions.outline },\n outlineOffset: true,\n outlineColor: t.colors(\"outlineColor\")\n};\n\n// src/config/layout.ts\nvar layout = {\n width: t.sizesT(\"width\"),\n inlineSize: t.sizesT(\"inlineSize\"),\n height: t.sizes(\"height\"),\n blockSize: t.sizes(\"blockSize\"),\n boxSize: t.sizes([\"width\", \"height\"]),\n minWidth: t.sizes(\"minWidth\"),\n minInlineSize: t.sizes(\"minInlineSize\"),\n minHeight: t.sizes(\"minHeight\"),\n minBlockSize: t.sizes(\"minBlockSize\"),\n maxWidth: t.sizes(\"maxWidth\"),\n maxInlineSize: t.sizes(\"maxInlineSize\"),\n maxHeight: t.sizes(\"maxHeight\"),\n maxBlockSize: t.sizes(\"maxBlockSize\"),\n overflow: true,\n overflowX: true,\n overflowY: true,\n overscrollBehavior: true,\n overscrollBehaviorX: true,\n overscrollBehaviorY: true,\n display: true,\n verticalAlign: true,\n boxSizing: true,\n boxDecorationBreak: true,\n float: t.propT(\"float\", transformFunctions.float),\n objectFit: true,\n objectPosition: true,\n visibility: true,\n isolation: true\n};\nObject.assign(layout, {\n w: layout.width,\n h: layout.height,\n minW: layout.minWidth,\n maxW: layout.maxWidth,\n minH: layout.minHeight,\n maxH: layout.maxHeight,\n overscroll: layout.overscrollBehavior,\n overscrollX: layout.overscrollBehaviorX,\n overscrollY: layout.overscrollBehaviorY\n});\n\n// src/config/list.ts\nvar list = {\n listStyleType: true,\n listStylePosition: true,\n listStylePos: t.prop(\"listStylePosition\"),\n listStyleImage: true,\n listStyleImg: t.prop(\"listStyleImage\")\n};\n\n// src/get.ts\nfunction get(obj, path, fallback, index) {\n const key = typeof path === \"string\" ? path.split(\".\") : [path];\n for (index = 0; index < key.length; index += 1) {\n if (!obj)\n break;\n obj = obj[key[index]];\n }\n return obj === void 0 ? fallback : obj;\n}\nvar memoize = (fn) => {\n const cache = /* @__PURE__ */ new WeakMap();\n const memoizedFn = (obj, path, fallback, index) => {\n if (typeof obj === \"undefined\") {\n return fn(obj, path, fallback);\n }\n if (!cache.has(obj)) {\n cache.set(obj, /* @__PURE__ */ new Map());\n }\n const map = cache.get(obj);\n if (map.has(path)) {\n return map.get(path);\n }\n const value = fn(obj, path, fallback, index);\n map.set(path, value);\n return value;\n };\n return memoizedFn;\n};\nvar memoizedGet = memoize(get);\n\n// src/config/others.ts\nvar srOnly = {\n border: \"0px\",\n clip: \"rect(0, 0, 0, 0)\",\n width: \"1px\",\n height: \"1px\",\n margin: \"-1px\",\n padding: \"0px\",\n overflow: \"hidden\",\n whiteSpace: \"nowrap\",\n position: \"absolute\"\n};\nvar srFocusable = {\n position: \"static\",\n width: \"auto\",\n height: \"auto\",\n clip: \"auto\",\n padding: \"0\",\n margin: \"0\",\n overflow: \"visible\",\n whiteSpace: \"normal\"\n};\nvar getWithPriority = (theme, key, styles) => {\n const result = {};\n const obj = memoizedGet(theme, key, {});\n for (const prop in obj) {\n const isInStyles = prop in styles && styles[prop] != null;\n if (!isInStyles)\n result[prop] = obj[prop];\n }\n return result;\n};\nvar others = {\n srOnly: {\n transform(value) {\n if (value === true)\n return srOnly;\n if (value === \"focusable\")\n return srFocusable;\n return {};\n }\n },\n layerStyle: {\n processResult: true,\n transform: (value, theme, styles) => getWithPriority(theme, `layerStyles.${value}`, styles)\n },\n textStyle: {\n processResult: true,\n transform: (value, theme, styles) => getWithPriority(theme, `textStyles.${value}`, styles)\n },\n apply: {\n processResult: true,\n transform: (value, theme, styles) => getWithPriority(theme, value, styles)\n }\n};\n\n// src/config/position.ts\nvar position = {\n position: true,\n pos: t.prop(\"position\"),\n zIndex: t.prop(\"zIndex\", \"zIndices\"),\n inset: t.spaceT(\"inset\"),\n insetX: t.spaceT([\"left\", \"right\"]),\n insetInline: t.spaceT(\"insetInline\"),\n insetY: t.spaceT([\"top\", \"bottom\"]),\n insetBlock: t.spaceT(\"insetBlock\"),\n top: t.spaceT(\"top\"),\n insetBlockStart: t.spaceT(\"insetBlockStart\"),\n bottom: t.spaceT(\"bottom\"),\n insetBlockEnd: t.spaceT(\"insetBlockEnd\"),\n left: t.spaceT(\"left\"),\n insetInlineStart: t.logical({\n scale: \"space\",\n property: { ltr: \"left\", rtl: \"right\" }\n }),\n right: t.spaceT(\"right\"),\n insetInlineEnd: t.logical({\n scale: \"space\",\n property: { ltr: \"right\", rtl: \"left\" }\n })\n};\nObject.assign(position, {\n insetStart: position.insetInlineStart,\n insetEnd: position.insetInlineEnd\n});\n\n// src/config/ring.ts\nvar ring = {\n ring: { transform: transformFunctions.ring },\n ringColor: t.colors(\"--chakra-ring-color\"),\n ringOffset: t.prop(\"--chakra-ring-offset-width\"),\n ringOffsetColor: t.colors(\"--chakra-ring-offset-color\"),\n ringInset: t.prop(\"--chakra-ring-inset\")\n};\n\n// src/config/space.ts\nvar space = {\n margin: t.spaceT(\"margin\"),\n marginTop: t.spaceT(\"marginTop\"),\n marginBlockStart: t.spaceT(\"marginBlockStart\"),\n marginRight: t.spaceT(\"marginRight\"),\n marginInlineEnd: t.spaceT(\"marginInlineEnd\"),\n marginBottom: t.spaceT(\"marginBottom\"),\n marginBlockEnd: t.spaceT(\"marginBlockEnd\"),\n marginLeft: t.spaceT(\"marginLeft\"),\n marginInlineStart: t.spaceT(\"marginInlineStart\"),\n marginX: t.spaceT([\"marginInlineStart\", \"marginInlineEnd\"]),\n marginInline: t.spaceT(\"marginInline\"),\n marginY: t.spaceT([\"marginTop\", \"marginBottom\"]),\n marginBlock: t.spaceT(\"marginBlock\"),\n padding: t.space(\"padding\"),\n paddingTop: t.space(\"paddingTop\"),\n paddingBlockStart: t.space(\"paddingBlockStart\"),\n paddingRight: t.space(\"paddingRight\"),\n paddingBottom: t.space(\"paddingBottom\"),\n paddingBlockEnd: t.space(\"paddingBlockEnd\"),\n paddingLeft: t.space(\"paddingLeft\"),\n paddingInlineStart: t.space(\"paddingInlineStart\"),\n paddingInlineEnd: t.space(\"paddingInlineEnd\"),\n paddingX: t.space([\"paddingInlineStart\", \"paddingInlineEnd\"]),\n paddingInline: t.space(\"paddingInline\"),\n paddingY: t.space([\"paddingTop\", \"paddingBottom\"]),\n paddingBlock: t.space(\"paddingBlock\")\n};\nObject.assign(space, {\n m: space.margin,\n mt: space.marginTop,\n mr: space.marginRight,\n me: space.marginInlineEnd,\n marginEnd: space.marginInlineEnd,\n mb: space.marginBottom,\n ml: space.marginLeft,\n ms: space.marginInlineStart,\n marginStart: space.marginInlineStart,\n mx: space.marginX,\n my: space.marginY,\n p: space.padding,\n pt: space.paddingTop,\n py: space.paddingY,\n px: space.paddingX,\n pb: space.paddingBottom,\n pl: space.paddingLeft,\n ps: space.paddingInlineStart,\n paddingStart: space.paddingInlineStart,\n pr: space.paddingRight,\n pe: space.paddingInlineEnd,\n paddingEnd: space.paddingInlineEnd\n});\n\n// src/config/text-decoration.ts\nvar textDecoration = {\n textDecorationColor: t.colors(\"textDecorationColor\"),\n textDecoration: true,\n textDecor: { property: \"textDecoration\" },\n textDecorationLine: true,\n textDecorationStyle: true,\n textDecorationThickness: true,\n textUnderlineOffset: true,\n textShadow: t.shadows(\"textShadow\")\n};\n\n// src/config/transform.ts\nvar transform = {\n clipPath: true,\n transform: t.propT(\"transform\", transformFunctions.transform),\n transformOrigin: true,\n translateX: t.spaceT(\"--chakra-translate-x\"),\n translateY: t.spaceT(\"--chakra-translate-y\"),\n skewX: t.degreeT(\"--chakra-skew-x\"),\n skewY: t.degreeT(\"--chakra-skew-y\"),\n scaleX: t.prop(\"--chakra-scale-x\"),\n scaleY: t.prop(\"--chakra-scale-y\"),\n scale: t.prop([\"--chakra-scale-x\", \"--chakra-scale-y\"]),\n rotate: t.degreeT(\"--chakra-rotate\")\n};\n\n// src/config/transition.ts\nvar transition = {\n transition: true,\n transitionDelay: true,\n animation: true,\n willChange: true,\n transitionDuration: t.prop(\"transitionDuration\", \"transition.duration\"),\n transitionProperty: t.prop(\"transitionProperty\", \"transition.property\"),\n transitionTimingFunction: t.prop(\"transitionTimingFunction\", \"transition.easing\")\n};\n\n// src/config/typography.ts\nvar typography = {\n fontFamily: t.prop(\"fontFamily\", \"fonts\"),\n fontSize: t.prop(\"fontSize\", \"fontSizes\", transformFunctions.px),\n fontWeight: t.prop(\"fontWeight\", \"fontWeights\"),\n lineHeight: t.prop(\"lineHeight\", \"lineHeights\"),\n letterSpacing: t.prop(\"letterSpacing\", \"letterSpacings\"),\n textAlign: true,\n fontStyle: true,\n wordBreak: true,\n overflowWrap: true,\n textOverflow: true,\n textTransform: true,\n whiteSpace: true,\n noOfLines: {\n static: {\n overflow: \"hidden\",\n textOverflow: \"ellipsis\",\n display: \"-webkit-box\",\n WebkitBoxOrient: \"vertical\",\n WebkitLineClamp: \"var(--chakra-line-clamp)\"\n },\n property: \"--chakra-line-clamp\"\n }\n};\n\n// src/config/scroll.ts\nvar scroll = {\n scrollBehavior: true,\n scrollSnapAlign: true,\n scrollSnapStop: true,\n scrollSnapType: true,\n scrollMargin: t.spaceT(\"scrollMargin\"),\n scrollMarginTop: t.spaceT(\"scrollMarginTop\"),\n scrollMarginBottom: t.spaceT(\"scrollMarginBottom\"),\n scrollMarginLeft: t.spaceT(\"scrollMarginLeft\"),\n scrollMarginRight: t.spaceT(\"scrollMarginRight\"),\n scrollMarginX: t.spaceT([\"scrollMarginLeft\", \"scrollMarginRight\"]),\n scrollMarginY: t.spaceT([\"scrollMarginTop\", \"scrollMarginBottom\"]),\n scrollPadding: t.spaceT(\"scrollPadding\"),\n scrollPaddingTop: t.spaceT(\"scrollPaddingTop\"),\n scrollPaddingBottom: t.spaceT(\"scrollPaddingBottom\"),\n scrollPaddingLeft: t.spaceT(\"scrollPaddingLeft\"),\n scrollPaddingRight: t.spaceT(\"scrollPaddingRight\"),\n scrollPaddingX: t.spaceT([\"scrollPaddingLeft\", \"scrollPaddingRight\"]),\n scrollPaddingY: t.spaceT([\"scrollPaddingTop\", \"scrollPaddingBottom\"])\n};\n\n// src/create-theme-vars/calc.ts\nfunction resolveReference(operand) {\n if (isObject(operand) && operand.reference) {\n return operand.reference;\n }\n return String(operand);\n}\nvar toExpression = (operator, ...operands) => operands.map(resolveReference).join(` ${operator} `).replace(/calc/g, \"\");\nvar add = (...operands) => `calc(${toExpression(\"+\", ...operands)})`;\nvar subtract = (...operands) => `calc(${toExpression(\"-\", ...operands)})`;\nvar multiply = (...operands) => `calc(${toExpression(\"*\", ...operands)})`;\nvar divide = (...operands) => `calc(${toExpression(\"/\", ...operands)})`;\nvar negate = (x) => {\n const value = resolveReference(x);\n if (value != null && !Number.isNaN(parseFloat(value))) {\n return String(value).startsWith(\"-\") ? String(value).slice(1) : `-${value}`;\n }\n return multiply(value, -1);\n};\nvar calc = Object.assign((x) => ({\n add: (...operands) => calc(add(x, ...operands)),\n subtract: (...operands) => calc(subtract(x, ...operands)),\n multiply: (...operands) => calc(multiply(x, ...operands)),\n divide: (...operands) => calc(divide(x, ...operands)),\n negate: () => calc(negate(x)),\n toString: () => x.toString()\n}), {\n add,\n subtract,\n multiply,\n divide,\n negate\n});\n\n// src/create-theme-vars/css-var.ts\nfunction replaceWhiteSpace(value, replaceValue = \"-\") {\n return value.replace(/\\s+/g, replaceValue);\n}\nfunction escape(value) {\n const valueStr = replaceWhiteSpace(value.toString());\n return escapeSymbol(escapeDot(valueStr));\n}\nfunction escapeDot(value) {\n if (value.includes(\"\\\\.\"))\n return value;\n const isDecimal = !Number.isInteger(parseFloat(value.toString()));\n return isDecimal ? value.replace(\".\", `\\\\.`) : value;\n}\nfunction escapeSymbol(value) {\n return value.replace(/[!-,/:-@[-^`{-~]/g, \"\\\\$&\");\n}\nfunction addPrefix(value, prefix = \"\") {\n return [prefix, value].filter(Boolean).join(\"-\");\n}\nfunction toVarReference(name, fallback) {\n return `var(${name}${fallback ? `, ${fallback}` : \"\"})`;\n}\nfunction toVarDefinition(value, prefix = \"\") {\n return escape(`--${addPrefix(value, prefix)}`);\n}\nfunction cssVar(name, fallback, cssVarPrefix) {\n const cssVariable = toVarDefinition(name, cssVarPrefix);\n return {\n variable: cssVariable,\n reference: toVarReference(cssVariable, fallback)\n };\n}\n\n// ../../utilities/breakpoint-utils/src/breakpoint.ts\nfunction getLastItem(array) {\n const length = array == null ? 0 : array.length;\n return length ? array[length - 1] : void 0;\n}\nfunction analyzeCSSValue2(value) {\n const num = parseFloat(value.toString());\n const unit = value.toString().replace(String(num), \"\");\n return { unitless: !unit, value: num, unit };\n}\nfunction px(value) {\n if (value == null)\n return value;\n const { unitless } = analyzeCSSValue2(value);\n return unitless || typeof value === \"number\" ? `${value}px` : value;\n}\nvar sortByBreakpointValue = (a, b) => parseInt(a[1], 10) > parseInt(b[1], 10) ? 1 : -1;\nvar sortBps = (breakpoints) => Object.fromEntries(Object.entries(breakpoints).sort(sortByBreakpointValue));\nfunction normalize(breakpoints) {\n const sorted = sortBps(breakpoints);\n return Object.assign(Object.values(sorted), sorted);\n}\nfunction keys(breakpoints) {\n const value = Object.keys(sortBps(breakpoints));\n return new Set(value);\n}\nfunction subtract2(value) {\n if (!value)\n return value;\n value = px(value) ?? value;\n const factor = value.endsWith(\"px\") ? -1 : -0.0625;\n return typeof value === \"number\" ? `${value + factor}` : value.replace(/(\\d+\\.?\\d*)/u, (m) => `${parseFloat(m) + factor}`);\n}\nfunction toMediaQueryString(min, max) {\n const query = [\"@media screen\"];\n if (min)\n query.push(\"and\", `(min-width: ${px(min)})`);\n if (max)\n query.push(\"and\", `(max-width: ${px(max)})`);\n return query.join(\" \");\n}\nfunction analyzeBreakpoints(breakpoints) {\n if (!breakpoints)\n return null;\n breakpoints.base = breakpoints.base ?? \"0px\";\n const normalized = normalize(breakpoints);\n const queries = Object.entries(breakpoints).sort(sortByBreakpointValue).map(([breakpoint, minW], index, entry) => {\n let [, maxW] = entry[index + 1] ?? [];\n maxW = parseFloat(maxW) > 0 ? subtract2(maxW) : void 0;\n return {\n _minW: subtract2(minW),\n breakpoint,\n minW,\n maxW,\n maxWQuery: toMediaQueryString(null, maxW),\n minWQuery: toMediaQueryString(minW),\n minMaxQuery: toMediaQueryString(minW, maxW)\n };\n });\n const _keys = keys(breakpoints);\n const _keysArr = Array.from(_keys.values());\n return {\n keys: _keys,\n normalized,\n isResponsive(test) {\n const keys2 = Object.keys(test);\n return keys2.length > 0 && keys2.every((key) => _keys.has(key));\n },\n asObject: sortBps(breakpoints),\n asArray: normalize(breakpoints),\n details: queries,\n media: [\n null,\n ...normalized.map((minW) => toMediaQueryString(minW)).slice(1)\n ],\n toArrayValue(test) {\n if (!isObject(test)) {\n throw new Error(\"toArrayValue: value must be an object\");\n }\n const result = _keysArr.map((bp) => test[bp] ?? null);\n while (getLastItem(result) === null) {\n result.pop();\n }\n return result;\n },\n toObjectValue(test) {\n if (!Array.isArray(test)) {\n throw new Error(\"toObjectValue: value must be an array\");\n }\n return test.reduce((acc, value, index) => {\n const key = _keysArr[index];\n if (key != null && value != null)\n acc[key] = value;\n return acc;\n }, {});\n }\n };\n}\n\n// src/pseudos.ts\nvar state = {\n hover: (str, post) => `${str}:hover ${post}, ${str}[data-hover] ${post}`,\n focus: (str, post) => `${str}:focus ${post}, ${str}[data-focus] ${post}`,\n focusVisible: (str, post) => `${str}:focus-visible ${post}`,\n focusWithin: (str, post) => `${str}:focus-within ${post}`,\n active: (str, post) => `${str}:active ${post}, ${str}[data-active] ${post}`,\n disabled: (str, post) => `${str}:disabled ${post}, ${str}[data-disabled] ${post}`,\n invalid: (str, post) => `${str}:invalid ${post}, ${str}[data-invalid] ${post}`,\n checked: (str, post) => `${str}:checked ${post}, ${str}[data-checked] ${post}`,\n indeterminate: (str, post) => `${str}:indeterminate ${post}, ${str}[aria-checked=mixed] ${post}, ${str}[data-indeterminate] ${post}`,\n readOnly: (str, post) => `${str}:read-only ${post}, ${str}[readonly] ${post}, ${str}[data-read-only] ${post}`,\n expanded: (str, post) => `${str}:read-only ${post}, ${str}[aria-expanded=true] ${post}, ${str}[data-expanded] ${post}`,\n placeholderShown: (str, post) => `${str}:placeholder-shown ${post}`\n};\nvar toGroup = (fn) => merge((v) => fn(v, \"&\"), \"[role=group]\", \"[data-group]\", \".group\");\nvar toPeer = (fn) => merge((v) => fn(v, \"~ &\"), \"[data-peer]\", \".peer\");\nvar merge = (fn, ...selectors) => selectors.map(fn).join(\", \");\nvar pseudoSelectors = {\n _hover: \"&:hover, &[data-hover]\",\n _active: \"&:active, &[data-active]\",\n _focus: \"&:focus, &[data-focus]\",\n _highlighted: \"&[data-highlighted]\",\n _focusWithin: \"&:focus-within\",\n _focusVisible: \"&:focus-visible, &[data-focus-visible]\",\n _disabled: \"&:disabled, &[disabled], &[aria-disabled=true], &[data-disabled]\",\n _readOnly: \"&[aria-readonly=true], &[readonly], &[data-readonly]\",\n _before: \"&::before\",\n _after: \"&::after\",\n _empty: \"&:empty\",\n _expanded: \"&[aria-expanded=true], &[data-expanded]\",\n _checked: \"&[aria-checked=true], &[data-checked]\",\n _grabbed: \"&[aria-grabbed=true], &[data-grabbed]\",\n _pressed: \"&[aria-pressed=true], &[data-pressed]\",\n _invalid: \"&[aria-invalid=true], &[data-invalid]\",\n _valid: \"&[data-valid], &[data-state=valid]\",\n _loading: \"&[data-loading], &[aria-busy=true]\",\n _selected: \"&[aria-selected=true], &[data-selected]\",\n _hidden: \"&[hidden], &[data-hidden]\",\n _autofill: \"&:-webkit-autofill\",\n _even: \"&:nth-of-type(even)\",\n _odd: \"&:nth-of-type(odd)\",\n _first: \"&:first-of-type\",\n _last: \"&:last-of-type\",\n _notFirst: \"&:not(:first-of-type)\",\n _notLast: \"&:not(:last-of-type)\",\n _visited: \"&:visited\",\n _activeLink: \"&[aria-current=page]\",\n _activeStep: \"&[aria-current=step]\",\n _indeterminate: \"&:indeterminate, &[aria-checked=mixed], &[data-indeterminate]\",\n _groupHover: toGroup(state.hover),\n _peerHover: toPeer(state.hover),\n _groupFocus: toGroup(state.focus),\n _peerFocus: toPeer(state.focus),\n _groupFocusVisible: toGroup(state.focusVisible),\n _peerFocusVisible: toPeer(state.focusVisible),\n _groupActive: toGroup(state.active),\n _peerActive: toPeer(state.active),\n _groupDisabled: toGroup(state.disabled),\n _peerDisabled: toPeer(state.disabled),\n _groupInvalid: toGroup(state.invalid),\n _peerInvalid: toPeer(state.invalid),\n _groupChecked: toGroup(state.checked),\n _peerChecked: toPeer(state.checked),\n _groupFocusWithin: toGroup(state.focusWithin),\n _peerFocusWithin: toPeer(state.focusWithin),\n _peerPlaceholderShown: toPeer(state.placeholderShown),\n _placeholder: \"&::placeholder\",\n _placeholderShown: \"&:placeholder-shown\",\n _fullScreen: \"&:fullscreen\",\n _selection: \"&::selection\",\n _rtl: \"[dir=rtl] &, &[dir=rtl]\",\n _ltr: \"[dir=ltr] &, &[dir=ltr]\",\n _mediaDark: \"@media (prefers-color-scheme: dark)\",\n _mediaReduceMotion: \"@media (prefers-reduced-motion: reduce)\",\n _dark: \".chakra-ui-dark &:not([data-theme]),[data-theme=dark] &:not([data-theme]),&[data-theme=dark]\",\n _light: \".chakra-ui-light &:not([data-theme]),[data-theme=light] &:not([data-theme]),&[data-theme=light]\"\n};\nvar pseudoPropNames = Object.keys(pseudoSelectors);\n\n// src/create-theme-vars/create-theme-vars.ts\nimport mergeWith from \"lodash.mergewith\";\nfunction tokenToCssVar(token, prefix) {\n return cssVar(String(token).replace(/\\./g, \"-\"), void 0, prefix);\n}\nfunction createThemeVars(flatTokens, options) {\n let cssVars = {};\n const cssMap = {};\n for (const [token, tokenValue] of Object.entries(flatTokens)) {\n const { isSemantic, value } = tokenValue;\n const { variable, reference } = tokenToCssVar(token, options == null ? void 0 : options.cssVarPrefix);\n if (!isSemantic) {\n if (token.startsWith(\"space\")) {\n const keys2 = token.split(\".\");\n const [firstKey, ...referenceKeys] = keys2;\n const negativeLookupKey = `${firstKey}.-${referenceKeys.join(\".\")}`;\n const negativeValue = calc.negate(value);\n const negatedReference = calc.negate(reference);\n cssMap[negativeLookupKey] = {\n value: negativeValue,\n var: variable,\n varRef: negatedReference\n };\n }\n cssVars[variable] = value;\n cssMap[token] = {\n value,\n var: variable,\n varRef: reference\n };\n continue;\n }\n const lookupToken = (maybeToken) => {\n const scale = String(token).split(\".\")[0];\n const withScale = [scale, maybeToken].join(\".\");\n const resolvedTokenValue = flatTokens[withScale];\n if (!resolvedTokenValue)\n return maybeToken;\n const { reference: reference2 } = tokenToCssVar(withScale, options == null ? void 0 : options.cssVarPrefix);\n return reference2;\n };\n const normalizedValue = isObject(value) ? value : { default: value };\n cssVars = mergeWith(cssVars, Object.entries(normalizedValue).reduce((acc, [conditionAlias, conditionValue]) => {\n var _a;\n const maybeReference = lookupToken(conditionValue);\n if (conditionAlias === \"default\") {\n acc[variable] = maybeReference;\n return acc;\n }\n const conditionSelector = ((_a = pseudoSelectors) == null ? void 0 : _a[conditionAlias]) ?? conditionAlias;\n acc[conditionSelector] = { [variable]: maybeReference };\n return acc;\n }, {}));\n cssMap[token] = {\n value: reference,\n var: variable,\n varRef: reference\n };\n }\n return {\n cssVars,\n cssMap\n };\n}\n\n// ../../utilities/object-utils/src/index.ts\nfunction omit(object, keysToOmit = []) {\n const clone = Object.assign({}, object);\n for (const key of keysToOmit) {\n if (key in clone)\n delete clone[key];\n }\n return clone;\n}\nfunction pick(object, keysToPick) {\n const result = {};\n for (const key of keysToPick) {\n if (key in object) {\n result[key] = object[key];\n }\n }\n return result;\n}\n\n// src/create-theme-vars/theme-tokens.ts\nvar tokens = [\n \"colors\",\n \"borders\",\n \"borderWidths\",\n \"borderStyles\",\n \"fonts\",\n \"fontSizes\",\n \"fontWeights\",\n \"letterSpacings\",\n \"lineHeights\",\n \"radii\",\n \"space\",\n \"shadows\",\n \"sizes\",\n \"zIndices\",\n \"transition\",\n \"blur\"\n];\nfunction extractTokens(theme) {\n const _tokens = tokens;\n return pick(theme, _tokens);\n}\nfunction extractSemanticTokens(theme) {\n return theme.semanticTokens;\n}\nfunction omitVars(rawTheme) {\n const { __cssMap, __cssVars, __breakpoints, ...cleanTheme } = rawTheme;\n return cleanTheme;\n}\n\n// src/create-theme-vars/flatten-tokens.ts\nfunction flattenTokens({\n tokens: tokens2,\n semanticTokens\n}) {\n const tokenEntries = Object.entries(flatten(tokens2) ?? {}).map(([token, value]) => {\n const enhancedToken = { isSemantic: false, value };\n return [token, enhancedToken];\n });\n const semanticTokenEntries = Object.entries(flatten(semanticTokens, 1) ?? {}).map(([token, value]) => {\n const enhancedToken = { isSemantic: true, value };\n return [token, enhancedToken];\n });\n return Object.fromEntries([\n ...tokenEntries,\n ...semanticTokenEntries\n ]);\n}\nfunction flatten(target, maxDepth = Infinity) {\n if (!isObject(target) && !Array.isArray(target) || !maxDepth) {\n return target;\n }\n return Object.entries(target).reduce((result, [key, value]) => {\n if (isObject(value) || Array.isArray(value)) {\n Object.entries(flatten(value, maxDepth - 1)).forEach(([childKey, childValue]) => {\n result[`${key}.${childKey}`] = childValue;\n });\n } else {\n result[key] = value;\n }\n return result;\n }, {});\n}\n\n// src/create-theme-vars/to-css-var.ts\nfunction toCSSVar(rawTheme) {\n var _a;\n const theme = omitVars(rawTheme);\n const tokens2 = extractTokens(theme);\n const semanticTokens = extractSemanticTokens(theme);\n const flatTokens = flattenTokens({ tokens: tokens2, semanticTokens });\n const cssVarPrefix = (_a = theme.config) == null ? void 0 : _a.cssVarPrefix;\n const {\n cssMap,\n cssVars\n } = createThemeVars(flatTokens, { cssVarPrefix });\n const defaultCssVars = {\n \"--chakra-ring-inset\": \"var(--chakra-empty,/*!*/ /*!*/)\",\n \"--chakra-ring-offset-width\": \"0px\",\n \"--chakra-ring-offset-color\": \"#fff\",\n \"--chakra-ring-color\": \"rgba(66, 153, 225, 0.6)\",\n \"--chakra-ring-offset-shadow\": \"0 0 #0000\",\n \"--chakra-ring-shadow\": \"0 0 #0000\",\n \"--chakra-space-x-reverse\": \"0\",\n \"--chakra-space-y-reverse\": \"0\"\n };\n Object.assign(theme, {\n __cssVars: { ...defaultCssVars, ...cssVars },\n __cssMap: cssMap,\n __breakpoints: analyzeBreakpoints(theme.breakpoints)\n });\n return theme;\n}\n\n// src/css.ts\nimport mergeWith3 from \"lodash.mergewith\";\n\n// src/system.ts\nimport mergeWith2 from \"lodash.mergewith\";\nvar systemProps = mergeWith2({}, background, border, color, flexbox, layout, filter, ring, interactivity, grid, others, position, effect, space, scroll, typography, textDecoration, transform, list, transition);\nvar layoutSystem = Object.assign({}, space, layout, flexbox, grid, position);\nvar layoutPropNames = Object.keys(layoutSystem);\nvar propNames = [...Object.keys(systemProps), ...pseudoPropNames];\nvar styleProps = { ...systemProps, ...pseudoSelectors };\nvar isStyleProp = (prop) => prop in styleProps;\n\n// src/utils/expand-responsive.ts\nvar expandResponsive = (styles) => (theme) => {\n if (!theme.__breakpoints)\n return styles;\n const { isResponsive, toArrayValue, media: medias } = theme.__breakpoints;\n const computedStyles = {};\n for (const key in styles) {\n let value = runIfFn(styles[key], theme);\n if (value == null)\n continue;\n value = isObject(value) && isResponsive(value) ? toArrayValue(value) : value;\n if (!Array.isArray(value)) {\n computedStyles[key] = value;\n continue;\n }\n const queries = value.slice(0, medias.length).length;\n for (let index = 0; index < queries; index += 1) {\n const media = medias == null ? void 0 : medias[index];\n if (!media) {\n computedStyles[key] = value[index];\n continue;\n }\n computedStyles[media] = computedStyles[media] || {};\n if (value[index] == null) {\n continue;\n }\n computedStyles[media][key] = value[index];\n }\n }\n return computedStyles;\n};\n\n// src/utils/split-by-comma.ts\nfunction splitByComma(value) {\n const chunks = [];\n let chunk = \"\";\n let inParens = false;\n for (let i = 0; i < value.length; i++) {\n const char = value[i];\n if (char === \"(\") {\n inParens = true;\n chunk += char;\n } else if (char === \")\") {\n inParens = false;\n chunk += char;\n } else if (char === \",\" && !inParens) {\n chunks.push(chunk);\n chunk = \"\";\n } else {\n chunk += char;\n }\n }\n chunk = chunk.trim();\n if (chunk) {\n chunks.push(chunk);\n }\n return chunks;\n}\n\n// src/css.ts\nfunction isCssVar2(value) {\n return /^var\\(--.+\\)$/.test(value);\n}\nvar isCSSVariableTokenValue = (key, value) => key.startsWith(\"--\") && typeof value === \"string\" && !isCssVar2(value);\nvar resolveTokenValue = (theme, value) => {\n if (value == null)\n return value;\n const getVar = (val) => {\n var _a, _b;\n return (_b = (_a = theme.__cssMap) == null ? void 0 : _a[val]) == null ? void 0 : _b.varRef;\n };\n const getValue = (val) => getVar(val) ?? val;\n const [tokenValue, fallbackValue] = splitByComma(value);\n value = getVar(tokenValue) ?? getValue(fallbackValue) ?? getValue(value);\n return value;\n};\nfunction getCss(options) {\n const { configs = {}, pseudos = {}, theme } = options;\n const css2 = (stylesOrFn, nested = false) => {\n var _a;\n const _styles = runIfFn(stylesOrFn, theme);\n const styles = expandResponsive(_styles)(theme);\n let computedStyles = {};\n for (let key in styles) {\n const valueOrFn = styles[key];\n let value = runIfFn(valueOrFn, theme);\n if (key in pseudos) {\n key = pseudos[key];\n }\n if (isCSSVariableTokenValue(key, value)) {\n value = resolveTokenValue(theme, value);\n }\n let config = configs[key];\n if (config === true) {\n config = { property: key };\n }\n if (isObject(value)) {\n computedStyles[key] = computedStyles[key] ?? {};\n computedStyles[key] = mergeWith3({}, computedStyles[key], css2(value, true));\n continue;\n }\n let rawValue = ((_a = config == null ? void 0 : config.transform) == null ? void 0 : _a.call(config, value, theme, _styles)) ?? value;\n rawValue = (config == null ? void 0 : config.processResult) ? css2(rawValue, true) : rawValue;\n const configProperty = runIfFn(config == null ? void 0 : config.property, theme);\n if (!nested && (config == null ? void 0 : config.static)) {\n const staticStyles = runIfFn(config.static, theme);\n computedStyles = mergeWith3({}, computedStyles, staticStyles);\n }\n if (configProperty && Array.isArray(configProperty)) {\n for (const property of configProperty) {\n computedStyles[property] = rawValue;\n }\n continue;\n }\n if (configProperty) {\n if (configProperty === \"&\" && isObject(rawValue)) {\n computedStyles = mergeWith3({}, computedStyles, rawValue);\n } else {\n computedStyles[configProperty] = rawValue;\n }\n continue;\n }\n if (isObject(rawValue)) {\n computedStyles = mergeWith3({}, computedStyles, rawValue);\n continue;\n }\n computedStyles[key] = rawValue;\n }\n return computedStyles;\n };\n return css2;\n}\nvar css = (styles) => (theme) => {\n const cssFn = getCss({\n theme,\n pseudos: pseudoSelectors,\n configs: systemProps\n });\n return cssFn(styles);\n};\n\n// src/define-styles.ts\nfunction defineStyle(styles) {\n return styles;\n}\nfunction defineStyleConfig(config) {\n return config;\n}\nfunction createMultiStyleConfigHelpers(parts) {\n return {\n definePartsStyle(config) {\n return config;\n },\n defineMultiStyleConfig(config) {\n return { parts, ...config };\n }\n };\n}\n\n// src/style-config.ts\nimport mergeWith4 from \"lodash.mergewith\";\nfunction normalize2(value, toArray) {\n if (Array.isArray(value))\n return value;\n if (isObject(value))\n return toArray(value);\n if (value != null)\n return [value];\n}\nfunction getNextIndex(values, i) {\n for (let j = i + 1; j < values.length; j++) {\n if (values[j] != null)\n return j;\n }\n return -1;\n}\nfunction createResolver(theme) {\n const breakpointUtil = theme.__breakpoints;\n return function resolver(config, prop, value, props) {\n var _a, _b;\n if (!breakpointUtil)\n return;\n const result = {};\n const normalized = normalize2(value, breakpointUtil.toArrayValue);\n if (!normalized)\n return result;\n const len = normalized.length;\n const isSingle = len === 1;\n const isMultipart = !!config.parts;\n for (let i = 0; i < len; i++) {\n const key = breakpointUtil.details[i];\n const nextKey = breakpointUtil.details[getNextIndex(normalized, i)];\n const query = toMediaQueryString(key.minW, nextKey == null ? void 0 : nextKey._minW);\n const styles = runIfFn((_a = config[prop]) == null ? void 0 : _a[normalized[i]], props);\n if (!styles)\n continue;\n if (isMultipart) {\n (_b = config.parts) == null ? void 0 : _b.forEach((part) => {\n mergeWith4(result, {\n [part]: isSingle ? styles[part] : { [query]: styles[part] }\n });\n });\n continue;\n }\n if (!isMultipart) {\n if (isSingle)\n mergeWith4(result, styles);\n else\n result[query] = styles;\n continue;\n }\n result[query] = styles;\n }\n return result;\n };\n}\nfunction resolveStyleConfig(config) {\n return (props) => {\n const { variant, size, theme } = props;\n const recipe = createResolver(theme);\n return mergeWith4({}, runIfFn(config.baseStyle ?? {}, props), recipe(config, \"sizes\", size, props), recipe(config, \"variants\", variant, props));\n };\n}\n\n// src/get-css-var.ts\nfunction getCSSVar(theme, scale, value) {\n var _a, _b;\n return ((_b = (_a = theme.__cssMap) == null ? void 0 : _a[`${scale}.${value}`]) == null ? void 0 : _b.varRef) ?? value;\n}\n\n// src/theming-props.ts\nfunction omitThemingProps(props) {\n return omit(props, [\"styleConfig\", \"size\", \"variant\", \"colorScheme\"]);\n}\nexport {\n addPrefix,\n background,\n border,\n calc,\n color,\n createMultiStyleConfigHelpers,\n css,\n cssVar,\n defineStyle,\n defineStyleConfig,\n effect,\n filter,\n flatten,\n flattenTokens,\n flexbox,\n getCSSVar,\n getCss,\n grid,\n interactivity,\n isStyleProp,\n layout,\n layoutPropNames,\n list,\n omitThemingProps,\n others,\n position,\n propNames,\n pseudoPropNames,\n pseudoSelectors,\n resolveStyleConfig,\n ring,\n scroll,\n space,\n systemProps,\n textDecoration,\n toCSSVar,\n toVarDefinition,\n toVarReference,\n tokenToCSSVar,\n transform,\n transition,\n typography\n};\n","// src/refs.ts\nimport { isFunction } from \"@chakra-ui/utils\";\nfunction assignRef(ref, value) {\n if (ref == null)\n return;\n if (isFunction(ref)) {\n ref(value);\n return;\n }\n try {\n ref.current = value;\n } catch (error) {\n throw new Error(`Cannot assign value '${value}' to ref '${ref}'`);\n }\n}\nfunction mergeRefs(...refs) {\n return (node) => {\n refs.forEach((ref) => assignRef(ref, node));\n };\n}\n\n// src/context.ts\nimport {\n createContext as createReactContext,\n useContext as useReactContext\n} from \"react\";\nfunction createContext(options = {}) {\n const {\n strict = true,\n errorMessage = \"useContext: `context` is undefined. Seems you forgot to wrap component within the Provider\",\n name\n } = options;\n const Context = createReactContext(void 0);\n Context.displayName = name;\n function useContext() {\n var _a;\n const context = useReactContext(Context);\n if (!context && strict) {\n const error = new Error(errorMessage);\n error.name = \"ContextError\";\n (_a = Error.captureStackTrace) == null ? void 0 : _a.call(Error, error, useContext);\n throw error;\n }\n return context;\n }\n return [\n Context.Provider,\n useContext,\n Context\n ];\n}\n\n// src/children.ts\nimport { Children, isValidElement } from \"react\";\nfunction getValidChildren(children) {\n return Children.toArray(children).filter((child) => isValidElement(child));\n}\nexport {\n assignRef,\n createContext,\n getValidChildren,\n mergeRefs\n};\n","// src/index.ts\nexport * from \"css-box-model\";\n\n// src/array.ts\nfunction getFirstItem(array) {\n return array != null && array.length ? array[0] : void 0;\n}\nfunction getLastItem(array) {\n const length = array == null ? 0 : array.length;\n return length ? array[length - 1] : void 0;\n}\nfunction getPrevItem(index, array, loop = true) {\n const prevIndex = getPrevIndex(index, array.length, loop);\n return array[prevIndex];\n}\nfunction getNextItem(index, array, loop = true) {\n const nextIndex = getNextIndex(index, array.length, 1, loop);\n return array[nextIndex];\n}\nfunction removeIndex(array, index) {\n return array.filter((_, idx) => idx !== index);\n}\nfunction addItem(array, item) {\n return [...array, item];\n}\nfunction removeItem(array, item) {\n return array.filter((eachItem) => eachItem !== item);\n}\nfunction getNextIndex(currentIndex, length, step = 1, loop = true) {\n const lastIndex = length - 1;\n if (currentIndex === -1) {\n return step > 0 ? 0 : lastIndex;\n }\n const nextIndex = currentIndex + step;\n if (nextIndex < 0) {\n return loop ? lastIndex : 0;\n }\n if (nextIndex >= length) {\n if (loop)\n return 0;\n return currentIndex > length ? length : currentIndex;\n }\n return nextIndex;\n}\nfunction getPrevIndex(index, count, loop = true) {\n return getNextIndex(index, count, -1, loop);\n}\nfunction chunk(array, size) {\n return array.reduce((rows, currentValue, index) => {\n if (index % size === 0) {\n rows.push([currentValue]);\n } else {\n rows[rows.length - 1].push(currentValue);\n }\n return rows;\n }, []);\n}\nfunction getNextItemFromSearch(items, searchString, itemToString, currentItem) {\n if (searchString == null) {\n return currentItem;\n }\n if (!currentItem) {\n const foundItem = items.find((item) => itemToString(item).toLowerCase().startsWith(searchString.toLowerCase()));\n return foundItem;\n }\n const matchingItems = items.filter((item) => itemToString(item).toLowerCase().startsWith(searchString.toLowerCase()));\n if (matchingItems.length > 0) {\n let nextIndex;\n if (matchingItems.includes(currentItem)) {\n const currentIndex = matchingItems.indexOf(currentItem);\n nextIndex = currentIndex + 1;\n if (nextIndex === matchingItems.length) {\n nextIndex = 0;\n }\n return matchingItems[nextIndex];\n }\n nextIndex = items.indexOf(matchingItems[0]);\n return items[nextIndex];\n }\n return currentItem;\n}\n\n// src/assertion.ts\nfunction isNumber(value) {\n return typeof value === \"number\";\n}\nfunction isNotNumber(value) {\n return typeof value !== \"number\" || Number.isNaN(value) || !Number.isFinite(value);\n}\nfunction isNumeric(value) {\n return value != null && value - parseFloat(value) + 1 >= 0;\n}\nfunction isArray(value) {\n return Array.isArray(value);\n}\nfunction isEmptyArray(value) {\n return isArray(value) && value.length === 0;\n}\nfunction isFunction(value) {\n return typeof value === \"function\";\n}\nfunction isDefined(value) {\n return typeof value !== \"undefined\" && value !== void 0;\n}\nfunction isUndefined(value) {\n return typeof value === \"undefined\" || value === void 0;\n}\nfunction isObject(value) {\n const type = typeof value;\n return value != null && (type === \"object\" || type === \"function\") && !isArray(value);\n}\nfunction isEmptyObject(value) {\n return isObject(value) && Object.keys(value).length === 0;\n}\nfunction isNotEmptyObject(value) {\n return value && !isEmptyObject(value);\n}\nfunction isNull(value) {\n return value == null;\n}\nfunction isString(value) {\n return Object.prototype.toString.call(value) === \"[object String]\";\n}\nfunction isCssVar(value) {\n return /^var\\(--.+\\)$/.test(value);\n}\nfunction isEmpty(value) {\n if (isArray(value))\n return isEmptyArray(value);\n if (isObject(value))\n return isEmptyObject(value);\n if (value == null || value === \"\")\n return true;\n return false;\n}\nvar __DEV__ = process.env.NODE_ENV !== \"production\";\nvar __TEST__ = process.env.NODE_ENV === \"test\";\nfunction isRefObject(val) {\n return \"current\" in val;\n}\nfunction isInputEvent(value) {\n return value && isObject(value) && isObject(value.target);\n}\n\n// src/object.ts\nimport { default as default2 } from \"lodash.mergewith\";\nfunction omit(object, keys2) {\n const result = {};\n Object.keys(object).forEach((key) => {\n if (keys2.includes(key))\n return;\n result[key] = object[key];\n });\n return result;\n}\nfunction pick(object, keys2) {\n const result = {};\n keys2.forEach((key) => {\n if (key in object) {\n result[key] = object[key];\n }\n });\n return result;\n}\nfunction split(object, keys2) {\n const picked = {};\n const omitted = {};\n Object.keys(object).forEach((key) => {\n if (keys2.includes(key)) {\n picked[key] = object[key];\n } else {\n omitted[key] = object[key];\n }\n });\n return [picked, omitted];\n}\nfunction get(obj, path, fallback, index) {\n const key = typeof path === \"string\" ? path.split(\".\") : [path];\n for (index = 0; index < key.length; index += 1) {\n if (!obj)\n break;\n obj = obj[key[index]];\n }\n return obj === void 0 ? fallback : obj;\n}\nvar memoize = (fn) => {\n const cache = /* @__PURE__ */ new WeakMap();\n const memoizedFn = (obj, path, fallback, index) => {\n if (typeof obj === \"undefined\") {\n return fn(obj, path, fallback);\n }\n if (!cache.has(obj)) {\n cache.set(obj, /* @__PURE__ */ new Map());\n }\n const map = cache.get(obj);\n if (map.has(path)) {\n return map.get(path);\n }\n const value = fn(obj, path, fallback, index);\n map.set(path, value);\n return value;\n };\n return memoizedFn;\n};\nvar memoizedGet = memoize(get);\nfunction getWithDefault(path, scale) {\n return memoizedGet(scale, path, path);\n}\nfunction objectFilter(object, fn) {\n const result = {};\n Object.keys(object).forEach((key) => {\n const value = object[key];\n const shouldPass = fn(value, key, object);\n if (shouldPass) {\n result[key] = value;\n }\n });\n return result;\n}\nvar filterUndefined = (object) => objectFilter(object, (val) => val !== null && val !== void 0);\nvar objectKeys = (obj) => Object.keys(obj);\nvar fromEntries = (entries) => entries.reduce((carry, [key, value]) => {\n carry[key] = value;\n return carry;\n}, {});\nvar getCSSVar = (theme, scale, value) => {\n var _a, _b;\n return ((_b = (_a = theme.__cssMap) == null ? void 0 : _a[`${scale}.${value}`]) == null ? void 0 : _b.varRef) ?? value;\n};\n\n// src/breakpoint.ts\nfunction analyzeCSSValue(value) {\n const num = parseFloat(value.toString());\n const unit = value.toString().replace(String(num), \"\");\n return { unitless: !unit, value: num, unit };\n}\nfunction px(value) {\n if (value == null)\n return value;\n const { unitless } = analyzeCSSValue(value);\n return unitless || isNumber(value) ? `${value}px` : value;\n}\nvar sortByBreakpointValue = (a, b) => parseInt(a[1], 10) > parseInt(b[1], 10) ? 1 : -1;\nvar sortBps = (breakpoints2) => fromEntries(Object.entries(breakpoints2).sort(sortByBreakpointValue));\nfunction normalize(breakpoints2) {\n const sorted = sortBps(breakpoints2);\n return Object.assign(Object.values(sorted), sorted);\n}\nfunction keys(breakpoints2) {\n const value = Object.keys(sortBps(breakpoints2));\n return new Set(value);\n}\nfunction subtract(value) {\n if (!value)\n return value;\n value = px(value) ?? value;\n const factor = value.endsWith(\"px\") ? -1 : -0.0625;\n return isNumber(value) ? `${value + factor}` : value.replace(/(\\d+\\.?\\d*)/u, (m) => `${parseFloat(m) + factor}`);\n}\nfunction toMediaQueryString(min, max) {\n const query = [\"@media screen\"];\n if (min)\n query.push(\"and\", `(min-width: ${px(min)})`);\n if (max)\n query.push(\"and\", `(max-width: ${px(max)})`);\n return query.join(\" \");\n}\nfunction analyzeBreakpoints(breakpoints2) {\n if (!breakpoints2)\n return null;\n breakpoints2.base = breakpoints2.base ?? \"0px\";\n const normalized = normalize(breakpoints2);\n const queries = Object.entries(breakpoints2).sort(sortByBreakpointValue).map(([breakpoint, minW], index, entry) => {\n let [, maxW] = entry[index + 1] ?? [];\n maxW = parseFloat(maxW) > 0 ? subtract(maxW) : void 0;\n return {\n _minW: subtract(minW),\n breakpoint,\n minW,\n maxW,\n maxWQuery: toMediaQueryString(null, maxW),\n minWQuery: toMediaQueryString(minW),\n minMaxQuery: toMediaQueryString(minW, maxW)\n };\n });\n const _keys = keys(breakpoints2);\n const _keysArr = Array.from(_keys.values());\n return {\n keys: _keys,\n normalized,\n isResponsive(test) {\n const keys2 = Object.keys(test);\n return keys2.length > 0 && keys2.every((key) => _keys.has(key));\n },\n asObject: sortBps(breakpoints2),\n asArray: normalize(breakpoints2),\n details: queries,\n media: [\n null,\n ...normalized.map((minW) => toMediaQueryString(minW)).slice(1)\n ],\n toArrayValue(test) {\n if (!isObject(test)) {\n throw new Error(\"toArrayValue: value must be an object\");\n }\n const result = _keysArr.map((bp) => test[bp] ?? null);\n while (getLastItem(result) === null) {\n result.pop();\n }\n return result;\n },\n toObjectValue(test) {\n if (!Array.isArray(test)) {\n throw new Error(\"toObjectValue: value must be an array\");\n }\n return test.reduce((acc, value, index) => {\n const key = _keysArr[index];\n if (key != null && value != null)\n acc[key] = value;\n return acc;\n }, {});\n }\n };\n}\n\n// src/dom.ts\nfunction isElement(el) {\n return el != null && typeof el == \"object\" && \"nodeType\" in el && el.nodeType === Node.ELEMENT_NODE;\n}\nfunction isHTMLElement(el) {\n if (!isElement(el)) {\n return false;\n }\n const win = el.ownerDocument.defaultView ?? window;\n return el instanceof win.HTMLElement;\n}\nfunction getOwnerWindow(node) {\n var _a;\n return isElement(node) ? ((_a = getOwnerDocument(node)) == null ? void 0 : _a.defaultView) ?? window : window;\n}\nfunction getOwnerDocument(node) {\n return isElement(node) ? node.ownerDocument ?? document : document;\n}\nfunction getEventWindow(event) {\n return event.view ?? window;\n}\nfunction canUseDOM() {\n return !!(typeof window !== \"undefined\" && window.document && window.document.createElement);\n}\nvar isBrowser = /* @__PURE__ */ canUseDOM();\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nfunction getActiveElement(node) {\n const doc = getOwnerDocument(node);\n return doc == null ? void 0 : doc.activeElement;\n}\nfunction contains(parent, child) {\n if (!parent)\n return false;\n return parent === child || parent.contains(child);\n}\nfunction addDomEvent(target, eventName, handler, options) {\n target.addEventListener(eventName, handler, options);\n return () => {\n target.removeEventListener(eventName, handler, options);\n };\n}\nfunction normalizeEventKey(event) {\n const { key, keyCode } = event;\n const isArrowKey = keyCode >= 37 && keyCode <= 40 && key.indexOf(\"Arrow\") !== 0;\n const eventKey = isArrowKey ? `Arrow${key}` : key;\n return eventKey;\n}\nfunction getRelatedTarget(event) {\n const target = event.target ?? event.currentTarget;\n const activeElement = getActiveElement(target);\n return event.relatedTarget ?? activeElement;\n}\nfunction isRightClick(event) {\n return event.button !== 0;\n}\n\n// src/tabbable.ts\nvar hasDisplayNone = (element) => window.getComputedStyle(element).display === \"none\";\nvar hasTabIndex = (element) => element.hasAttribute(\"tabindex\");\nvar hasNegativeTabIndex = (element) => hasTabIndex(element) && element.tabIndex === -1;\nfunction isDisabled(element) {\n return Boolean(element.getAttribute(\"disabled\")) === true || Boolean(element.getAttribute(\"aria-disabled\")) === true;\n}\nfunction isInputElement(element) {\n return isHTMLElement(element) && element.localName === \"input\" && \"select\" in element;\n}\nfunction isActiveElement(element) {\n const doc = isHTMLElement(element) ? getOwnerDocument(element) : document;\n return doc.activeElement === element;\n}\nfunction hasFocusWithin(element) {\n if (!document.activeElement)\n return false;\n return element.contains(document.activeElement);\n}\nfunction isHidden(element) {\n if (element.parentElement && isHidden(element.parentElement))\n return true;\n return element.hidden;\n}\nfunction isContentEditable(element) {\n const value = element.getAttribute(\"contenteditable\");\n return value !== \"false\" && value != null;\n}\nfunction isFocusable(element) {\n if (!isHTMLElement(element) || isHidden(element) || isDisabled(element)) {\n return false;\n }\n const { localName } = element;\n const focusableTags = [\"input\", \"select\", \"textarea\", \"button\"];\n if (focusableTags.indexOf(localName) >= 0)\n return true;\n const others = {\n a: () => element.hasAttribute(\"href\"),\n audio: () => element.hasAttribute(\"controls\"),\n video: () => element.hasAttribute(\"controls\")\n };\n if (localName in others) {\n return others[localName]();\n }\n if (isContentEditable(element))\n return true;\n return hasTabIndex(element);\n}\nfunction isTabbable(element) {\n if (!element)\n return false;\n return isHTMLElement(element) && isFocusable(element) && !hasNegativeTabIndex(element);\n}\n\n// src/dom-query.ts\nvar focusableElList = [\n \"input:not(:disabled):not([disabled])\",\n \"select:not(:disabled):not([disabled])\",\n \"textarea:not(:disabled):not([disabled])\",\n \"embed\",\n \"iframe\",\n \"object\",\n \"a[href]\",\n \"area[href]\",\n \"button:not(:disabled):not([disabled])\",\n \"[tabindex]\",\n \"audio[controls]\",\n \"video[controls]\",\n \"*[tabindex]:not([aria-disabled])\",\n \"*[contenteditable]\"\n];\nvar focusableElSelector = focusableElList.join();\nvar isVisible = (el) => el.offsetWidth > 0 && el.offsetHeight > 0;\nfunction getAllFocusable(container) {\n const focusableEls = Array.from(container.querySelectorAll(focusableElSelector));\n focusableEls.unshift(container);\n return focusableEls.filter((el) => isFocusable(el) && isVisible(el));\n}\nfunction getFirstFocusable(container) {\n const allFocusable = getAllFocusable(container);\n return allFocusable.length ? allFocusable[0] : null;\n}\nfunction getAllTabbable(container, fallbackToFocusable) {\n const allFocusable = Array.from(container.querySelectorAll(focusableElSelector));\n const allTabbable = allFocusable.filter(isTabbable);\n if (isTabbable(container)) {\n allTabbable.unshift(container);\n }\n if (!allTabbable.length && fallbackToFocusable) {\n return allFocusable;\n }\n return allTabbable;\n}\nfunction getFirstTabbableIn(container, fallbackToFocusable) {\n const [first] = getAllTabbable(container, fallbackToFocusable);\n return first || null;\n}\nfunction getLastTabbableIn(container, fallbackToFocusable) {\n const allTabbable = getAllTabbable(container, fallbackToFocusable);\n return allTabbable[allTabbable.length - 1] || null;\n}\nfunction getNextTabbable(container, fallbackToFocusable) {\n const allFocusable = getAllFocusable(container);\n const index = allFocusable.indexOf(document.activeElement);\n const slice = allFocusable.slice(index + 1);\n return slice.find(isTabbable) || allFocusable.find(isTabbable) || (fallbackToFocusable ? slice[0] : null);\n}\nfunction getPreviousTabbable(container, fallbackToFocusable) {\n const allFocusable = getAllFocusable(container).reverse();\n const index = allFocusable.indexOf(document.activeElement);\n const slice = allFocusable.slice(index + 1);\n return slice.find(isTabbable) || allFocusable.find(isTabbable) || (fallbackToFocusable ? slice[0] : null);\n}\nfunction focusNextTabbable(container, fallbackToFocusable) {\n const nextTabbable = getNextTabbable(container, fallbackToFocusable);\n if (nextTabbable && isHTMLElement(nextTabbable)) {\n nextTabbable.focus();\n }\n}\nfunction focusPreviousTabbable(container, fallbackToFocusable) {\n const previousTabbable = getPreviousTabbable(container, fallbackToFocusable);\n if (previousTabbable && isHTMLElement(previousTabbable)) {\n previousTabbable.focus();\n }\n}\nfunction matches(element, selectors) {\n if (\"matches\" in element)\n return element.matches(selectors);\n if (\"msMatchesSelector\" in element)\n return element.msMatchesSelector(selectors);\n return element.webkitMatchesSelector(selectors);\n}\nfunction closest(element, selectors) {\n if (\"closest\" in element)\n return element.closest(selectors);\n do {\n if (matches(element, selectors))\n return element;\n element = element.parentElement || element.parentNode;\n } while (element !== null && element.nodeType === 1);\n return null;\n}\n\n// src/function.ts\nfunction runIfFn(valueOrFn, ...args) {\n return isFunction(valueOrFn) ? valueOrFn(...args) : valueOrFn;\n}\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\nfunction callAll(...fns) {\n return function mergedFn(arg) {\n fns.forEach((fn) => {\n fn == null ? void 0 : fn(arg);\n });\n };\n}\nvar compose = (fn1, ...fns) => fns.reduce((f1, f2) => (...args) => f1(f2(...args)), fn1);\nfunction once(fn) {\n let result;\n return function func(...args) {\n if (fn) {\n result = fn.apply(this, args);\n fn = null;\n }\n return result;\n };\n}\nvar noop = () => {\n};\nvar warn = /* @__PURE__ */ once((options) => () => {\n const { condition, message } = options;\n if (condition && __DEV__) {\n console.warn(message);\n }\n});\nvar error = /* @__PURE__ */ once((options) => () => {\n const { condition, message } = options;\n if (condition && __DEV__) {\n console.error(message);\n }\n});\nvar pipe = (...fns) => (v) => fns.reduce((a, b) => b(a), v);\nvar distance1D = (a, b) => Math.abs(a - b);\nvar isPoint = (point) => \"x\" in point && \"y\" in point;\nfunction distance(a, b) {\n if (isNumber(a) && isNumber(b)) {\n return distance1D(a, b);\n }\n if (isPoint(a) && isPoint(b)) {\n const xDelta = distance1D(a.x, b.x);\n const yDelta = distance1D(a.y, b.y);\n return Math.sqrt(xDelta ** 2 + yDelta ** 2);\n }\n return 0;\n}\n\n// src/focus.ts\nfunction focus(element, options = {}) {\n const {\n isActive = isActiveElement,\n nextTick,\n preventScroll = true,\n selectTextIfInput = true\n } = options;\n if (!element || isActive(element))\n return -1;\n function triggerFocus() {\n if (!element) {\n warn({\n condition: true,\n message: \"[chakra-ui]: can't call focus() on `null` or `undefined` element\"\n });\n return;\n }\n if (supportsPreventScroll()) {\n element.focus({ preventScroll });\n } else {\n element.focus();\n if (preventScroll) {\n const scrollableElements = getScrollableElements(element);\n restoreScrollPosition(scrollableElements);\n }\n }\n if (selectTextIfInput) {\n if (isInputElement(element)) {\n element.select();\n } else if (\"setSelectionRange\" in element) {\n const el = element;\n el.setSelectionRange(el.value.length, el.value.length);\n }\n }\n }\n if (nextTick) {\n return requestAnimationFrame(triggerFocus);\n }\n triggerFocus();\n return -1;\n}\nvar supportsPreventScrollCached = null;\nfunction supportsPreventScroll() {\n if (supportsPreventScrollCached == null) {\n supportsPreventScrollCached = false;\n try {\n const div = document.createElement(\"div\");\n div.focus({\n get preventScroll() {\n supportsPreventScrollCached = true;\n return true;\n }\n });\n } catch (e) {\n }\n }\n return supportsPreventScrollCached;\n}\nfunction getScrollableElements(element) {\n const doc = getOwnerDocument(element);\n const win = doc.defaultView ?? window;\n let parent = element.parentNode;\n const scrollableElements = [];\n const rootScrollingElement = doc.scrollingElement || doc.documentElement;\n while (parent instanceof win.HTMLElement && parent !== rootScrollingElement) {\n if (parent.offsetHeight < parent.scrollHeight || parent.offsetWidth < parent.scrollWidth) {\n scrollableElements.push({\n element: parent,\n scrollTop: parent.scrollTop,\n scrollLeft: parent.scrollLeft\n });\n }\n parent = parent.parentNode;\n }\n if (rootScrollingElement instanceof win.HTMLElement) {\n scrollableElements.push({\n element: rootScrollingElement,\n scrollTop: rootScrollingElement.scrollTop,\n scrollLeft: rootScrollingElement.scrollLeft\n });\n }\n return scrollableElements;\n}\nfunction restoreScrollPosition(scrollableElements) {\n for (const { element, scrollTop, scrollLeft } of scrollableElements) {\n element.scrollTop = scrollTop;\n element.scrollLeft = scrollLeft;\n }\n}\n\n// src/flatten.ts\nfunction flatten(target, maxDepth = Infinity) {\n if (!isObject(target) && !Array.isArray(target) || !maxDepth) {\n return target;\n }\n return Object.entries(target).reduce((result, [key, value]) => {\n if (isObject(value) || isArray(value)) {\n Object.entries(flatten(value, maxDepth - 1)).forEach(([childKey, childValue]) => {\n result[`${key}.${childKey}`] = childValue;\n });\n } else {\n result[key] = value;\n }\n return result;\n }, {});\n}\n\n// src/lazy.ts\nfunction determineLazyBehavior(options) {\n const {\n hasBeenSelected,\n isLazy,\n isSelected,\n lazyBehavior = \"unmount\"\n } = options;\n if (!isLazy)\n return true;\n if (isSelected)\n return true;\n if (lazyBehavior === \"keepMounted\" && hasBeenSelected)\n return true;\n return false;\n}\n\n// src/number.ts\nvar minSafeInteger = Number.MIN_SAFE_INTEGER || -9007199254740991;\nvar maxSafeInteger = Number.MAX_SAFE_INTEGER || 9007199254740991;\nfunction toNumber(value) {\n const num = parseFloat(value);\n return isNotNumber(num) ? 0 : num;\n}\nfunction toPrecision(value, precision) {\n let nextValue = toNumber(value);\n const scaleFactor = 10 ** (precision ?? 10);\n nextValue = Math.round(nextValue * scaleFactor) / scaleFactor;\n return precision ? nextValue.toFixed(precision) : nextValue.toString();\n}\nfunction countDecimalPlaces(value) {\n if (!Number.isFinite(value))\n return 0;\n let e = 1;\n let p = 0;\n while (Math.round(value * e) / e !== value) {\n e *= 10;\n p += 1;\n }\n return p;\n}\nfunction valueToPercent(value, min, max) {\n return (value - min) * 100 / (max - min);\n}\nfunction percentToValue(percent, min, max) {\n return (max - min) * percent + min;\n}\nfunction roundValueToStep(value, from, step) {\n const nextValue = Math.round((value - from) / step) * step + from;\n const precision = countDecimalPlaces(step);\n return toPrecision(nextValue, precision);\n}\nfunction clampValue(value, min, max) {\n if (value == null)\n return value;\n warn({\n condition: max < min,\n message: \"clamp: max cannot be less than min\"\n });\n return Math.min(Math.max(value, min), max);\n}\n\n// src/pan-event.ts\nimport sync, { cancelSync, getFrameData } from \"framesync\";\n\n// src/pointer-event.ts\nfunction isMouseEvent(event) {\n const win = getEventWindow(event);\n if (typeof win.PointerEvent !== \"undefined\" && event instanceof win.PointerEvent) {\n return !!(event.pointerType === \"mouse\");\n }\n return event instanceof win.MouseEvent;\n}\nfunction isTouchEvent(event) {\n const hasTouches = !!event.touches;\n return hasTouches;\n}\nfunction filterPrimaryPointer(eventHandler) {\n return (event) => {\n const win = getEventWindow(event);\n const isMouseEvent2 = event instanceof win.MouseEvent;\n const isPrimaryPointer = !isMouseEvent2 || isMouseEvent2 && event.button === 0;\n if (isPrimaryPointer) {\n eventHandler(event);\n }\n };\n}\nvar defaultPagePoint = { pageX: 0, pageY: 0 };\nfunction pointFromTouch(e, pointType = \"page\") {\n const primaryTouch = e.touches[0] || e.changedTouches[0];\n const point = primaryTouch || defaultPagePoint;\n return {\n x: point[`${pointType}X`],\n y: point[`${pointType}Y`]\n };\n}\nfunction pointFromMouse(point, pointType = \"page\") {\n return {\n x: point[`${pointType}X`],\n y: point[`${pointType}Y`]\n };\n}\nfunction extractEventInfo(event, pointType = \"page\") {\n return {\n point: isTouchEvent(event) ? pointFromTouch(event, pointType) : pointFromMouse(event, pointType)\n };\n}\nfunction getViewportPointFromEvent(event) {\n return extractEventInfo(event, \"client\");\n}\nvar wrapPointerEventHandler = (handler, shouldFilterPrimaryPointer = false) => {\n const listener = (event) => handler(event, extractEventInfo(event));\n return shouldFilterPrimaryPointer ? filterPrimaryPointer(listener) : listener;\n};\nvar supportsPointerEvents = () => isBrowser && window.onpointerdown === null;\nvar supportsTouchEvents = () => isBrowser && window.ontouchstart === null;\nvar supportsMouseEvents = () => isBrowser && window.onmousedown === null;\nvar mouseEventNames = {\n pointerdown: \"mousedown\",\n pointermove: \"mousemove\",\n pointerup: \"mouseup\",\n pointercancel: \"mousecancel\",\n pointerover: \"mouseover\",\n pointerout: \"mouseout\",\n pointerenter: \"mouseenter\",\n pointerleave: \"mouseleave\"\n};\nvar touchEventNames = {\n pointerdown: \"touchstart\",\n pointermove: \"touchmove\",\n pointerup: \"touchend\",\n pointercancel: \"touchcancel\"\n};\nfunction getPointerEventName(name) {\n if (supportsPointerEvents()) {\n return name;\n }\n if (supportsTouchEvents()) {\n return touchEventNames[name];\n }\n if (supportsMouseEvents()) {\n return mouseEventNames[name];\n }\n return name;\n}\nfunction addPointerEvent(target, eventName, handler, options) {\n return addDomEvent(target, getPointerEventName(eventName), wrapPointerEventHandler(handler, eventName === \"pointerdown\"), options);\n}\nfunction isMultiTouchEvent(event) {\n return isTouchEvent(event) && event.touches.length > 1;\n}\n\n// src/pan-event.ts\nvar PanSession = class {\n history = [];\n startEvent = null;\n lastEvent = null;\n lastEventInfo = null;\n handlers = {};\n removeListeners = noop;\n threshold = 3;\n win;\n constructor(event, handlers, threshold) {\n this.win = getEventWindow(event);\n if (isMultiTouchEvent(event))\n return;\n this.handlers = handlers;\n if (threshold) {\n this.threshold = threshold;\n }\n event.stopPropagation();\n event.preventDefault();\n const info = extractEventInfo(event);\n const { timestamp } = getFrameData();\n this.history = [{ ...info.point, timestamp }];\n const { onSessionStart } = handlers;\n onSessionStart == null ? void 0 : onSessionStart(event, getPanInfo(info, this.history));\n this.removeListeners = pipe(addPointerEvent(this.win, \"pointermove\", this.onPointerMove), addPointerEvent(this.win, \"pointerup\", this.onPointerUp), addPointerEvent(this.win, \"pointercancel\", this.onPointerUp));\n }\n updatePoint = () => {\n if (!(this.lastEvent && this.lastEventInfo))\n return;\n const info = getPanInfo(this.lastEventInfo, this.history);\n const isPanStarted = this.startEvent !== null;\n const isDistancePastThreshold = distance(info.offset, { x: 0, y: 0 }) >= this.threshold;\n if (!isPanStarted && !isDistancePastThreshold)\n return;\n const { timestamp } = getFrameData();\n this.history.push({ ...info.point, timestamp });\n const { onStart, onMove } = this.handlers;\n if (!isPanStarted) {\n onStart == null ? void 0 : onStart(this.lastEvent, info);\n this.startEvent = this.lastEvent;\n }\n onMove == null ? void 0 : onMove(this.lastEvent, info);\n };\n onPointerMove = (event, info) => {\n this.lastEvent = event;\n this.lastEventInfo = info;\n if (isMouseEvent(event) && event.buttons === 0) {\n this.onPointerUp(event, info);\n return;\n }\n sync.update(this.updatePoint, true);\n };\n onPointerUp = (event, info) => {\n const panInfo = getPanInfo(info, this.history);\n const { onEnd, onSessionEnd } = this.handlers;\n onSessionEnd == null ? void 0 : onSessionEnd(event, panInfo);\n this.end();\n if (!onEnd || !this.startEvent)\n return;\n onEnd == null ? void 0 : onEnd(event, panInfo);\n };\n updateHandlers(handlers) {\n this.handlers = handlers;\n }\n end() {\n var _a;\n (_a = this.removeListeners) == null ? void 0 : _a.call(this);\n cancelSync.update(this.updatePoint);\n }\n};\nfunction subtractPoint(a, b) {\n return { x: a.x - b.x, y: a.y - b.y };\n}\nfunction startPanPoint(history) {\n return history[0];\n}\nfunction lastPanPoint(history) {\n return history[history.length - 1];\n}\nfunction getPanInfo(info, history) {\n return {\n point: info.point,\n delta: subtractPoint(info.point, lastPanPoint(history)),\n offset: subtractPoint(info.point, startPanPoint(history)),\n velocity: getVelocity(history, 0.1)\n };\n}\nfunction lastDevicePoint(history) {\n return history[history.length - 1];\n}\nvar toMilliseconds = (seconds) => seconds * 1e3;\nfunction getVelocity(history, timeDelta) {\n if (history.length < 2) {\n return { x: 0, y: 0 };\n }\n let i = history.length - 1;\n let timestampedPoint = null;\n const lastPoint = lastDevicePoint(history);\n while (i >= 0) {\n timestampedPoint = history[i];\n if (lastPoint.timestamp - timestampedPoint.timestamp > toMilliseconds(timeDelta)) {\n break;\n }\n i--;\n }\n if (!timestampedPoint) {\n return { x: 0, y: 0 };\n }\n const time = (lastPoint.timestamp - timestampedPoint.timestamp) / 1e3;\n if (time === 0) {\n return { x: 0, y: 0 };\n }\n const currentVelocity = {\n x: (lastPoint.x - timestampedPoint.x) / time,\n y: (lastPoint.y - timestampedPoint.y) / time\n };\n if (currentVelocity.x === Infinity) {\n currentVelocity.x = 0;\n }\n if (currentVelocity.y === Infinity) {\n currentVelocity.y = 0;\n }\n return currentVelocity;\n}\n\n// src/responsive.ts\nvar breakpoints = Object.freeze([\n \"base\",\n \"sm\",\n \"md\",\n \"lg\",\n \"xl\",\n \"2xl\"\n]);\nfunction mapResponsive(prop, mapper) {\n if (isArray(prop)) {\n return prop.map((item) => {\n if (item === null) {\n return null;\n }\n return mapper(item);\n });\n }\n if (isObject(prop)) {\n return objectKeys(prop).reduce((result, key) => {\n result[key] = mapper(prop[key]);\n return result;\n }, {});\n }\n if (prop != null) {\n return mapper(prop);\n }\n return null;\n}\nfunction objectToArrayNotation(obj, bps = breakpoints) {\n const result = bps.map((br) => obj[br] ?? null);\n while (getLastItem(result) === null) {\n result.pop();\n }\n return result;\n}\nfunction arrayToObjectNotation(values, bps = breakpoints) {\n const result = {};\n values.forEach((value, index) => {\n const key = bps[index];\n if (value == null)\n return;\n result[key] = value;\n });\n return result;\n}\nfunction isResponsiveObjectLike(obj, bps = breakpoints) {\n const keys2 = Object.keys(obj);\n return keys2.length > 0 && keys2.every((key) => bps.includes(key));\n}\nvar isCustomBreakpoint = (maybeBreakpoint) => Number.isNaN(Number(maybeBreakpoint));\n\n// src/user-agent.ts\nfunction getUserAgentBrowser(navigator) {\n const { userAgent: ua, vendor } = navigator;\n const android = /(android)/i.test(ua);\n switch (true) {\n case /CriOS/.test(ua):\n return \"Chrome for iOS\";\n case /Edg\\//.test(ua):\n return \"Edge\";\n case (android && /Silk\\//.test(ua)):\n return \"Silk\";\n case (/Chrome/.test(ua) && /Google Inc/.test(vendor)):\n return \"Chrome\";\n case /Firefox\\/\\d+\\.\\d+$/.test(ua):\n return \"Firefox\";\n case android:\n return \"AOSP\";\n case /MSIE|Trident/.test(ua):\n return \"IE\";\n case (/Safari/.test(navigator.userAgent) && /Apple Computer/.test(ua)):\n return \"Safari\";\n case /AppleWebKit/.test(ua):\n return \"WebKit\";\n default:\n return null;\n }\n}\nfunction getUserAgentOS(navigator) {\n const { userAgent: ua, platform } = navigator;\n switch (true) {\n case /Android/.test(ua):\n return \"Android\";\n case /iPhone|iPad|iPod/.test(platform):\n return \"iOS\";\n case /Win/.test(platform):\n return \"Windows\";\n case /Mac/.test(platform):\n return \"Mac\";\n case /CrOS/.test(ua):\n return \"Chrome OS\";\n case /Firefox/.test(ua):\n return \"Firefox OS\";\n default:\n return null;\n }\n}\nfunction detectDeviceType(navigator) {\n const { userAgent: ua } = navigator;\n if (/(tablet)|(iPad)|(Nexus 9)/i.test(ua))\n return \"tablet\";\n if (/(mobi)/i.test(ua))\n return \"phone\";\n return \"desktop\";\n}\nfunction detectOS(os) {\n if (!isBrowser)\n return false;\n return getUserAgentOS(window.navigator) === os;\n}\nfunction detectBrowser(browser) {\n if (!isBrowser)\n return false;\n return getUserAgentBrowser(window.navigator) === browser;\n}\nfunction detectTouch() {\n if (!isBrowser)\n return false;\n return window.ontouchstart === null && window.ontouchmove === null && window.ontouchend === null;\n}\n\n// src/walk-object.ts\nfunction walkObject(target, predicate) {\n function inner(value, path = []) {\n if (isArray(value)) {\n return value.map((item, index) => inner(item, [...path, String(index)]));\n }\n if (isObject(value)) {\n return fromEntries(Object.entries(value).map(([key, child]) => [\n key,\n inner(child, [...path, key])\n ]));\n }\n return predicate(value, path);\n }\n return inner(target);\n}\nexport {\n PanSession,\n __DEV__,\n __TEST__,\n addDomEvent,\n addItem,\n addPointerEvent,\n analyzeBreakpoints,\n ariaAttr,\n arrayToObjectNotation,\n breakpoints,\n callAll,\n callAllHandlers,\n canUseDOM,\n chunk,\n clampValue,\n closest,\n compose,\n contains,\n countDecimalPlaces,\n cx,\n dataAttr,\n detectBrowser,\n detectDeviceType,\n detectOS,\n detectTouch,\n determineLazyBehavior,\n distance,\n error,\n extractEventInfo,\n filterUndefined,\n flatten,\n focus,\n focusNextTabbable,\n focusPreviousTabbable,\n fromEntries,\n get,\n getActiveElement,\n getAllFocusable,\n getAllTabbable,\n getCSSVar,\n getEventWindow,\n getFirstFocusable,\n getFirstItem,\n getFirstTabbableIn,\n getLastItem,\n getLastTabbableIn,\n getNextIndex,\n getNextItem,\n getNextItemFromSearch,\n getNextTabbable,\n getOwnerDocument,\n getOwnerWindow,\n getPointerEventName,\n getPrevIndex,\n getPrevItem,\n getPreviousTabbable,\n getRelatedTarget,\n getViewportPointFromEvent,\n getWithDefault,\n hasDisplayNone,\n hasFocusWithin,\n hasNegativeTabIndex,\n hasTabIndex,\n isActiveElement,\n isArray,\n isBrowser,\n isContentEditable,\n isCssVar,\n isCustomBreakpoint,\n isDefined,\n isDisabled,\n isElement,\n isEmpty,\n isEmptyArray,\n isEmptyObject,\n isFocusable,\n isFunction,\n isHTMLElement,\n isHidden,\n isInputElement,\n isInputEvent,\n isMouseEvent,\n isMultiTouchEvent,\n isNotEmptyObject,\n isNotNumber,\n isNull,\n isNumber,\n isNumeric,\n isObject,\n isRefObject,\n isResponsiveObjectLike,\n isRightClick,\n isString,\n isTabbable,\n isTouchEvent,\n isUndefined,\n mapResponsive,\n maxSafeInteger,\n memoize,\n memoizedGet,\n default2 as mergeWith,\n minSafeInteger,\n noop,\n normalizeEventKey,\n objectFilter,\n objectKeys,\n objectToArrayNotation,\n omit,\n once,\n percentToValue,\n pick,\n pipe,\n px,\n removeIndex,\n removeItem,\n roundValueToStep,\n runIfFn,\n split,\n toMediaQueryString,\n toPrecision,\n valueToPercent,\n walkObject,\n warn,\n wrapPointerEventHandler\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/index.ts\nexport * from \"@chakra-ui/color-mode\";\nexport * from \"@chakra-ui/styled-system\";\nimport { keyframes } from \"@emotion/react\";\n\n// src/hooks.ts\nimport { useColorMode } from \"@chakra-ui/color-mode\";\n\n// src/use-theme.ts\nimport { ThemeContext } from \"@emotion/react\";\nimport { useContext } from \"react\";\nfunction useTheme() {\n const theme = useContext(ThemeContext);\n if (!theme) {\n throw Error(\"useTheme: `theme` is undefined. Seems you forgot to wrap your app in `` or ``\");\n }\n return theme;\n}\n\n// src/hooks.ts\nfunction useChakra() {\n const colorModeResult = useColorMode();\n const theme = useTheme();\n return { ...colorModeResult, theme };\n}\nfunction getBreakpointValue(theme, value, fallback) {\n if (value == null)\n return value;\n const getValue = (val) => {\n var _a, _b;\n return (_b = (_a = theme.__breakpoints) == null ? void 0 : _a.asArray) == null ? void 0 : _b[val];\n };\n return getValue(value) ?? getValue(fallback) ?? fallback;\n}\nfunction getTokenValue(theme, value, fallback) {\n if (value == null)\n return value;\n const getValue = (val) => {\n var _a, _b;\n return (_b = (_a = theme.__cssMap) == null ? void 0 : _a[val]) == null ? void 0 : _b.value;\n };\n return getValue(value) ?? getValue(fallback) ?? fallback;\n}\nfunction useToken(scale, token, fallback) {\n const theme = useTheme();\n return getToken(scale, token, fallback)(theme);\n}\nfunction getToken(scale, token, fallback) {\n const _token = Array.isArray(token) ? token : [token];\n const _fallback = Array.isArray(fallback) ? fallback : [fallback];\n return (theme) => {\n const fallbackArr = _fallback.filter(Boolean);\n const result = _token.map((token2, index) => {\n if (scale === \"breakpoints\") {\n return getBreakpointValue(theme, token2, fallbackArr[index] ?? token2);\n }\n const path = `${scale}.${token2}`;\n return getTokenValue(theme, path, fallbackArr[index] ?? token2);\n });\n return Array.isArray(token) ? result : result[0];\n };\n}\n\n// src/providers.tsx\nimport { useColorMode as useColorMode2 } from \"@chakra-ui/color-mode\";\nimport { createContext } from \"@chakra-ui/react-utils\";\nimport { css, toCSSVar } from \"@chakra-ui/styled-system\";\nimport { memoizedGet as get, runIfFn } from \"@chakra-ui/utils\";\nimport {\n Global,\n ThemeProvider as EmotionThemeProvider\n} from \"@emotion/react\";\nimport { useMemo } from \"react\";\nfunction ThemeProvider(props) {\n const { cssVarsRoot, theme, children } = props;\n const computedTheme = useMemo(() => toCSSVar(theme), [theme]);\n return /* @__PURE__ */ React.createElement(EmotionThemeProvider, {\n theme: computedTheme\n }, /* @__PURE__ */ React.createElement(CSSVars, {\n root: cssVarsRoot\n }), children);\n}\nfunction CSSVars({ root = \":host, :root\" }) {\n const selector = [root, `[data-theme]`].join(\",\");\n return /* @__PURE__ */ React.createElement(Global, {\n styles: (theme) => ({ [selector]: theme.__cssVars })\n });\n}\nvar [StylesProvider, useStyles] = createContext({\n name: \"StylesContext\",\n errorMessage: \"useStyles: `styles` is undefined. Seems you forgot to wrap the components in `` \"\n});\nfunction createStylesContext(componentName) {\n return createContext({\n name: `${componentName}StylesContext`,\n errorMessage: `useStyles: \"styles\" is undefined. Seems you forgot to wrap the components in \"<${componentName} />\" `\n });\n}\nfunction GlobalStyle() {\n const { colorMode } = useColorMode2();\n return /* @__PURE__ */ React.createElement(Global, {\n styles: (theme) => {\n const styleObjectOrFn = get(theme, \"styles.global\");\n const globalStyles = runIfFn(styleObjectOrFn, { theme, colorMode });\n if (!globalStyles)\n return void 0;\n const styles = css(globalStyles)(theme);\n return styles;\n }\n });\n}\n\n// src/system.ts\nimport { useColorMode as useColorMode3 } from \"@chakra-ui/color-mode\";\nimport {\n css as css2,\n isStyleProp\n} from \"@chakra-ui/styled-system\";\nimport { filterUndefined, objectFilter, runIfFn as runIfFn2 } from \"@chakra-ui/utils\";\nimport emotionStyled from \"@emotion/styled\";\nimport React2 from \"react\";\n\n// src/should-forward-prop.ts\nimport { propNames } from \"@chakra-ui/styled-system\";\nvar allPropNames = /* @__PURE__ */ new Set([\n ...propNames,\n \"textStyle\",\n \"layerStyle\",\n \"apply\",\n \"noOfLines\",\n \"focusBorderColor\",\n \"errorBorderColor\",\n \"as\",\n \"__css\",\n \"css\",\n \"sx\"\n]);\nvar validHTMLProps = /* @__PURE__ */ new Set([\"htmlWidth\", \"htmlHeight\", \"htmlSize\"]);\nfunction shouldForwardProp(prop) {\n return validHTMLProps.has(prop) || !allPropNames.has(prop);\n}\n\n// src/system.ts\nvar toCSSObject = ({ baseStyle }) => (props) => {\n const { theme, css: cssProp, __css, sx, ...rest } = props;\n const styleProps = objectFilter(rest, (_, prop) => isStyleProp(prop));\n const finalBaseStyle = runIfFn2(baseStyle, props);\n const finalStyles = Object.assign({}, __css, finalBaseStyle, filterUndefined(styleProps), sx);\n const computedCSS = css2(finalStyles)(props.theme);\n return cssProp ? [computedCSS, cssProp] : computedCSS;\n};\nfunction styled(component, options) {\n const { baseStyle, ...styledOptions } = options ?? {};\n if (!styledOptions.shouldForwardProp) {\n styledOptions.shouldForwardProp = shouldForwardProp;\n }\n const styleObject = toCSSObject({ baseStyle });\n const Component = emotionStyled(component, styledOptions)(styleObject);\n const chakraComponent = React2.forwardRef(function ChakraComponent(props, ref) {\n const { colorMode, forced } = useColorMode3();\n return React2.createElement(Component, {\n ref,\n \"data-theme\": forced ? colorMode : void 0,\n ...props\n });\n });\n return chakraComponent;\n}\n\n// src/forward-ref.tsx\nimport { forwardRef as forwardReactRef } from \"react\";\nfunction forwardRef(component) {\n return forwardReactRef(component);\n}\n\n// src/use-style-config.ts\nimport {\n resolveStyleConfig\n} from \"@chakra-ui/styled-system\";\nimport { mergeThemeOverride } from \"@chakra-ui/theme-utils\";\nimport {\n filterUndefined as filterUndefined2,\n memoizedGet as get2,\n mergeWith,\n omit\n} from \"@chakra-ui/utils\";\nimport { useRef } from \"react\";\nimport isEqual from \"react-fast-compare\";\nfunction useStyleConfigImpl(themeKey, props = {}) {\n const { styleConfig: styleConfigProp, ...rest } = props;\n const { theme, colorMode } = useChakra();\n const themeStyleConfig = themeKey ? get2(theme, `components.${themeKey}`) : void 0;\n const styleConfig = styleConfigProp || themeStyleConfig;\n const mergedProps = mergeWith({ theme, colorMode }, (styleConfig == null ? void 0 : styleConfig.defaultProps) ?? {}, filterUndefined2(omit(rest, [\"children\"])));\n const stylesRef = useRef({});\n if (styleConfig) {\n const getStyles = resolveStyleConfig(styleConfig);\n const styles = getStyles(mergedProps);\n const isStyleEqual = isEqual(stylesRef.current, styles);\n if (!isStyleEqual) {\n stylesRef.current = styles;\n }\n }\n return stylesRef.current;\n}\nfunction useStyleConfig(themeKey, props = {}) {\n return useStyleConfigImpl(themeKey, props);\n}\nfunction useMultiStyleConfig(themeKey, props = {}) {\n return useStyleConfigImpl(themeKey, props);\n}\nfunction useComponentStyles__unstable(themeKey, props) {\n var _a;\n const { baseConfig, ...restProps } = props;\n const { theme } = useChakra();\n const overrides = (_a = theme.components) == null ? void 0 : _a[themeKey];\n const styleConfig = overrides ? mergeThemeOverride(overrides, baseConfig) : baseConfig;\n return useStyleConfigImpl(null, {\n ...restProps,\n styleConfig\n });\n}\n\n// src/factory.ts\nfunction factory() {\n const cache = /* @__PURE__ */ new Map();\n return new Proxy(styled, {\n apply(target, thisArg, argArray) {\n return styled(...argArray);\n },\n get(_, element) {\n if (!cache.has(element)) {\n cache.set(element, styled(element));\n }\n return cache.get(element);\n }\n });\n}\nvar chakra = factory();\nexport {\n CSSVars,\n GlobalStyle,\n StylesProvider,\n ThemeProvider,\n chakra,\n createStylesContext,\n forwardRef,\n getToken,\n keyframes,\n shouldForwardProp,\n styled,\n toCSSObject,\n useChakra,\n useComponentStyles__unstable,\n useMultiStyleConfig,\n useStyleConfig,\n useStyles,\n useTheme,\n useToken\n};\n","// src/index.ts\nimport {\n createContext as createReactContext,\n useContext as useReactContext\n} from \"react\";\nfunction getErrorMessage(hook, provider) {\n return `${hook} returned \\`undefined\\`. Seems you forgot to wrap component within ${provider}`;\n}\nfunction createContext(options = {}) {\n const {\n name,\n strict = true,\n hookName = \"useContext\",\n providerName = \"Provider\",\n errorMessage\n } = options;\n const Context = createReactContext(void 0);\n Context.displayName = name;\n function useContext() {\n var _a;\n const context = useReactContext(Context);\n if (!context && strict) {\n const error = new Error(errorMessage ?? getErrorMessage(hookName, providerName));\n error.name = \"ContextError\";\n (_a = Error.captureStackTrace) == null ? void 0 : _a.call(Error, error, useContext);\n throw error;\n }\n return context;\n }\n return [Context.Provider, useContext, Context];\n}\nexport {\n createContext\n};\n","// src/index.ts\nimport { useMemo } from \"react\";\nfunction assignRef(ref, value) {\n if (ref == null)\n return;\n if (typeof ref === \"function\") {\n ref(value);\n return;\n }\n try {\n ref.current = value;\n } catch (error) {\n throw new Error(`Cannot assign value '${value}' to ref '${ref}'`);\n }\n}\nfunction mergeRefs(...refs) {\n return (node) => {\n refs.forEach((ref) => {\n assignRef(ref, node);\n });\n };\n}\nfunction useMergeRefs(...refs) {\n return useMemo(() => mergeRefs(...refs), refs);\n}\nexport {\n assignRef,\n mergeRefs,\n useMergeRefs\n};\n","// src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nfunction isDev() {\n return process.env.NODE_ENV !== \"production\";\n}\nfunction isObject(value) {\n const type = typeof value;\n return value != null && (type === \"object\" || type === \"function\") && !Array.isArray(value);\n}\nvar warn = (options) => {\n const { condition, message } = options;\n if (condition && isDev()) {\n console.warn(message);\n }\n};\nfunction runIfFn(valueOrFn, ...args) {\n return isFunction(valueOrFn) ? valueOrFn(...args) : valueOrFn;\n}\nvar isFunction = (value) => typeof value === \"function\";\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\nfunction callAll(...fns) {\n return function mergedFn(arg) {\n fns.forEach((fn) => {\n fn == null ? void 0 : fn(arg);\n });\n };\n}\nexport {\n ariaAttr,\n callAll,\n callAllHandlers,\n cx,\n dataAttr,\n isObject,\n runIfFn,\n warn\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/icon.tsx\nimport {\n chakra,\n forwardRef\n} from \"@chakra-ui/system\";\nimport { cx } from \"@chakra-ui/shared-utils\";\nvar fallbackIcon = {\n path: /* @__PURE__ */ React.createElement(\"g\", {\n stroke: \"currentColor\",\n strokeWidth: \"1.5\"\n }, /* @__PURE__ */ React.createElement(\"path\", {\n strokeLinecap: \"round\",\n fill: \"none\",\n d: \"M9,9a3,3,0,1,1,4,2.829,1.5,1.5,0,0,0-1,1.415V14.25\"\n }), /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n strokeLinecap: \"round\",\n d: \"M12,17.25a.375.375,0,1,0,.375.375A.375.375,0,0,0,12,17.25h0\"\n }), /* @__PURE__ */ React.createElement(\"circle\", {\n fill: \"none\",\n strokeMiterlimit: \"10\",\n cx: \"12\",\n cy: \"12\",\n r: \"11.25\"\n })),\n viewBox: \"0 0 24 24\"\n};\nvar Icon = forwardRef((props, ref) => {\n const {\n as: element,\n viewBox,\n color = \"currentColor\",\n focusable = false,\n children,\n className,\n __css,\n ...rest\n } = props;\n const _className = cx(\"chakra-icon\", className);\n const styles = {\n w: \"1em\",\n h: \"1em\",\n display: \"inline-block\",\n lineHeight: \"1em\",\n flexShrink: 0,\n color,\n ...__css\n };\n const shared = {\n ref,\n focusable,\n className: _className,\n __css: styles\n };\n const _viewBox = viewBox ?? fallbackIcon.viewBox;\n if (element && typeof element !== \"string\") {\n return /* @__PURE__ */ React.createElement(chakra.svg, {\n as: element,\n ...shared,\n ...rest\n });\n }\n const _path = children ?? fallbackIcon.path;\n return /* @__PURE__ */ React.createElement(chakra.svg, {\n verticalAlign: \"middle\",\n viewBox: _viewBox,\n ...shared,\n ...rest\n }, _path);\n});\nIcon.displayName = \"Icon\";\nvar icon_default = Icon;\n\n// src/create-icon.tsx\nimport { forwardRef as forwardRef2 } from \"@chakra-ui/system\";\nimport { Children } from \"react\";\nfunction createIcon(options) {\n const {\n viewBox = \"0 0 24 24\",\n d: pathDefinition,\n displayName,\n defaultProps = {}\n } = options;\n const path = Children.toArray(options.path);\n const Comp = forwardRef2((props, ref) => /* @__PURE__ */ React.createElement(Icon, {\n ref,\n viewBox,\n ...defaultProps,\n ...props\n }, path.length ? path : /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: pathDefinition\n })));\n Comp.displayName = displayName;\n return Comp;\n}\nexport {\n Icon,\n createIcon,\n icon_default as default\n};\n","// src/index.ts\nimport { useCallback, useEffect, useRef } from \"react\";\nfunction useCallbackRef(callback, deps = []) {\n const callbackRef = useRef(callback);\n useEffect(() => {\n callbackRef.current = callback;\n });\n return useCallback((...args) => {\n var _a;\n return (_a = callbackRef.current) == null ? void 0 : _a.call(callbackRef, ...args);\n }, deps);\n}\nexport {\n useCallbackRef\n};\n","// src/index.ts\nimport { useMemo, useState } from \"react\";\nimport { useCallbackRef } from \"@chakra-ui/react-use-callback-ref\";\nfunction useControllableProp(prop, state) {\n const controlled = typeof prop !== \"undefined\";\n const value = controlled ? prop : state;\n return useMemo(() => [controlled, value], [controlled, value]);\n}\nfunction useControllableState(props) {\n const {\n value: valueProp,\n defaultValue,\n onChange,\n shouldUpdate = (prev, next) => prev !== next\n } = props;\n const onChangeProp = useCallbackRef(onChange);\n const shouldUpdateProp = useCallbackRef(shouldUpdate);\n const [uncontrolledState, setUncontrolledState] = useState(defaultValue);\n const controlled = valueProp !== void 0;\n const value = controlled ? valueProp : uncontrolledState;\n const setValue = useCallbackRef((next) => {\n const setter = next;\n const nextValue = typeof next === \"function\" ? setter(value) : next;\n if (!shouldUpdateProp(value, nextValue)) {\n return;\n }\n if (!controlled) {\n setUncontrolledState(nextValue);\n }\n onChangeProp(nextValue);\n }, [controlled, onChangeProp, value, shouldUpdateProp]);\n return [value, setValue];\n}\nexport {\n useControllableProp,\n useControllableState\n};\n","// src/index.ts\nimport {\n createContext as createReactContext,\n useContext as useReactContext\n} from \"react\";\nfunction getErrorMessage(hook, provider) {\n return `${hook} returned \\`undefined\\`. Seems you forgot to wrap component within ${provider}`;\n}\nfunction createContext(options = {}) {\n const {\n name,\n strict = true,\n hookName = \"useContext\",\n providerName = \"Provider\",\n errorMessage\n } = options;\n const Context = createReactContext(void 0);\n Context.displayName = name;\n function useContext() {\n var _a;\n const context = useReactContext(Context);\n if (!context && strict) {\n const error = new Error(errorMessage ?? getErrorMessage(hookName, providerName));\n error.name = \"ContextError\";\n (_a = Error.captureStackTrace) == null ? void 0 : _a.call(Error, error, useContext);\n throw error;\n }\n return context;\n }\n return [Context.Provider, useContext, Context];\n}\nexport {\n createContext\n};\n","// src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nfunction isDev() {\n return process.env.NODE_ENV !== \"production\";\n}\nfunction isObject(value) {\n const type = typeof value;\n return value != null && (type === \"object\" || type === \"function\") && !Array.isArray(value);\n}\nvar warn = (options) => {\n const { condition, message } = options;\n if (condition && isDev()) {\n console.warn(message);\n }\n};\nfunction runIfFn(valueOrFn, ...args) {\n return isFunction(valueOrFn) ? valueOrFn(...args) : valueOrFn;\n}\nvar isFunction = (value) => typeof value === \"function\";\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\nfunction callAll(...fns) {\n return function mergedFn(arg) {\n fns.forEach((fn) => {\n fn == null ? void 0 : fn(arg);\n });\n };\n}\nexport {\n ariaAttr,\n callAll,\n callAllHandlers,\n cx,\n dataAttr,\n isObject,\n runIfFn,\n warn\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/icon.tsx\nimport {\n chakra,\n forwardRef\n} from \"@chakra-ui/system\";\nimport { cx } from \"@chakra-ui/shared-utils\";\nvar fallbackIcon = {\n path: /* @__PURE__ */ React.createElement(\"g\", {\n stroke: \"currentColor\",\n strokeWidth: \"1.5\"\n }, /* @__PURE__ */ React.createElement(\"path\", {\n strokeLinecap: \"round\",\n fill: \"none\",\n d: \"M9,9a3,3,0,1,1,4,2.829,1.5,1.5,0,0,0-1,1.415V14.25\"\n }), /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n strokeLinecap: \"round\",\n d: \"M12,17.25a.375.375,0,1,0,.375.375A.375.375,0,0,0,12,17.25h0\"\n }), /* @__PURE__ */ React.createElement(\"circle\", {\n fill: \"none\",\n strokeMiterlimit: \"10\",\n cx: \"12\",\n cy: \"12\",\n r: \"11.25\"\n })),\n viewBox: \"0 0 24 24\"\n};\nvar Icon = forwardRef((props, ref) => {\n const {\n as: element,\n viewBox,\n color = \"currentColor\",\n focusable = false,\n children,\n className,\n __css,\n ...rest\n } = props;\n const _className = cx(\"chakra-icon\", className);\n const styles = {\n w: \"1em\",\n h: \"1em\",\n display: \"inline-block\",\n lineHeight: \"1em\",\n flexShrink: 0,\n color,\n ...__css\n };\n const shared = {\n ref,\n focusable,\n className: _className,\n __css: styles\n };\n const _viewBox = viewBox ?? fallbackIcon.viewBox;\n if (element && typeof element !== \"string\") {\n return /* @__PURE__ */ React.createElement(chakra.svg, {\n as: element,\n ...shared,\n ...rest\n });\n }\n const _path = children ?? fallbackIcon.path;\n return /* @__PURE__ */ React.createElement(chakra.svg, {\n verticalAlign: \"middle\",\n viewBox: _viewBox,\n ...shared,\n ...rest\n }, _path);\n});\nIcon.displayName = \"Icon\";\nvar icon_default = Icon;\n\n// src/create-icon.tsx\nimport { forwardRef as forwardRef2 } from \"@chakra-ui/system\";\nimport { Children } from \"react\";\nfunction createIcon(options) {\n const {\n viewBox = \"0 0 24 24\",\n d: pathDefinition,\n displayName,\n defaultProps = {}\n } = options;\n const path = Children.toArray(options.path);\n const Comp = forwardRef2((props, ref) => /* @__PURE__ */ React.createElement(Icon, {\n ref,\n viewBox,\n ...defaultProps,\n ...props\n }, path.length ? path : /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: pathDefinition\n })));\n Comp.displayName = displayName;\n return Comp;\n}\nexport {\n Icon,\n createIcon,\n icon_default as default\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/alert.tsx\nimport {\n chakra,\n forwardRef,\n omitThemingProps,\n useMultiStyleConfig\n} from \"@chakra-ui/system\";\n\n// ../../utilities/shared-utils/src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\n\n// src/alert-context.ts\nimport { createContext } from \"@chakra-ui/react-context\";\n\n// src/icons.tsx\nimport { Icon } from \"@chakra-ui/icon\";\nfunction CheckIcon(props) {\n return /* @__PURE__ */ React.createElement(Icon, {\n viewBox: \"0 0 24 24\",\n ...props\n }, /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: \"M12,0A12,12,0,1,0,24,12,12.014,12.014,0,0,0,12,0Zm6.927,8.2-6.845,9.289a1.011,1.011,0,0,1-1.43.188L5.764,13.769a1,1,0,1,1,1.25-1.562l4.076,3.261,6.227-8.451A1,1,0,1,1,18.927,8.2Z\"\n }));\n}\nfunction InfoIcon(props) {\n return /* @__PURE__ */ React.createElement(Icon, {\n viewBox: \"0 0 24 24\",\n ...props\n }, /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: \"M12,0A12,12,0,1,0,24,12,12.013,12.013,0,0,0,12,0Zm.25,5a1.5,1.5,0,1,1-1.5,1.5A1.5,1.5,0,0,1,12.25,5ZM14.5,18.5h-4a1,1,0,0,1,0-2h.75a.25.25,0,0,0,.25-.25v-4.5a.25.25,0,0,0-.25-.25H10.5a1,1,0,0,1,0-2h1a2,2,0,0,1,2,2v4.75a.25.25,0,0,0,.25.25h.75a1,1,0,1,1,0,2Z\"\n }));\n}\nfunction WarningIcon(props) {\n return /* @__PURE__ */ React.createElement(Icon, {\n viewBox: \"0 0 24 24\",\n ...props\n }, /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: \"M11.983,0a12.206,12.206,0,0,0-8.51,3.653A11.8,11.8,0,0,0,0,12.207,11.779,11.779,0,0,0,11.8,24h.214A12.111,12.111,0,0,0,24,11.791h0A11.766,11.766,0,0,0,11.983,0ZM10.5,16.542a1.476,1.476,0,0,1,1.449-1.53h.027a1.527,1.527,0,0,1,1.523,1.47,1.475,1.475,0,0,1-1.449,1.53h-.027A1.529,1.529,0,0,1,10.5,16.542ZM11,12.5v-6a1,1,0,0,1,2,0v6a1,1,0,1,1-2,0Z\"\n }));\n}\n\n// src/alert-context.ts\nimport { Spinner } from \"@chakra-ui/spinner\";\nvar [AlertProvider, useAlertContext] = createContext({\n name: \"AlertContext\",\n hookName: \"useAlertContext\",\n providerName: \"\"\n});\nvar [AlertStylesProvider, useAlertStyles] = createContext({\n name: `AlertStylesContext`,\n hookName: `useAlertStyles`,\n providerName: \"\"\n});\nvar STATUSES = {\n info: { icon: InfoIcon, colorScheme: \"blue\" },\n warning: { icon: WarningIcon, colorScheme: \"orange\" },\n success: { icon: CheckIcon, colorScheme: \"green\" },\n error: { icon: WarningIcon, colorScheme: \"red\" },\n loading: { icon: Spinner, colorScheme: \"blue\" }\n};\nfunction getStatusColorScheme(status) {\n return STATUSES[status].colorScheme;\n}\nfunction getStatusIcon(status) {\n return STATUSES[status].icon;\n}\n\n// src/alert.tsx\nvar Alert = forwardRef(function Alert2(props, ref) {\n const { status = \"info\", addRole = true, ...rest } = omitThemingProps(props);\n const colorScheme = props.colorScheme ?? getStatusColorScheme(status);\n const styles = useMultiStyleConfig(\"Alert\", { ...props, colorScheme });\n const alertStyles = {\n width: \"100%\",\n display: \"flex\",\n alignItems: \"center\",\n position: \"relative\",\n overflow: \"hidden\",\n ...styles.container\n };\n return /* @__PURE__ */ React.createElement(AlertProvider, {\n value: { status }\n }, /* @__PURE__ */ React.createElement(AlertStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra.div, {\n role: addRole ? \"alert\" : void 0,\n ref,\n ...rest,\n className: cx(\"chakra-alert\", props.className),\n __css: alertStyles\n })));\n});\nAlert.displayName = \"Alert\";\n\n// src/alert-description.tsx\nimport {\n chakra as chakra2,\n forwardRef as forwardRef2\n} from \"@chakra-ui/system\";\nvar AlertDescription = forwardRef2(function AlertDescription2(props, ref) {\n const styles = useAlertStyles();\n const descriptionStyles = {\n display: \"inline\",\n ...styles.description\n };\n return /* @__PURE__ */ React.createElement(chakra2.div, {\n ref,\n ...props,\n className: cx(\"chakra-alert__desc\", props.className),\n __css: descriptionStyles\n });\n});\nAlertDescription.displayName = \"AlertDescription\";\n\n// src/alert-icon.tsx\nimport { chakra as chakra3 } from \"@chakra-ui/system\";\nfunction AlertIcon(props) {\n const { status } = useAlertContext();\n const BaseIcon = getStatusIcon(status);\n const styles = useAlertStyles();\n const css = status === \"loading\" ? styles.spinner : styles.icon;\n return /* @__PURE__ */ React.createElement(chakra3.span, {\n display: \"inherit\",\n ...props,\n className: cx(\"chakra-alert__icon\", props.className),\n __css: css\n }, props.children || /* @__PURE__ */ React.createElement(BaseIcon, {\n h: \"100%\",\n w: \"100%\"\n }));\n}\nAlertIcon.displayName = \"AlertIcon\";\n\n// src/alert-title.tsx\nimport { chakra as chakra4, forwardRef as forwardRef3 } from \"@chakra-ui/system\";\nvar AlertTitle = forwardRef3(function AlertTitle2(props, ref) {\n const styles = useAlertStyles();\n return /* @__PURE__ */ React.createElement(chakra4.div, {\n ref,\n ...props,\n className: cx(\"chakra-alert__title\", props.className),\n __css: styles.title\n });\n});\nAlertTitle.displayName = \"AlertTitle\";\nexport {\n Alert,\n AlertDescription,\n AlertIcon,\n AlertTitle,\n useAlertStyles\n};\n","// src/index.ts\nimport { useMemo } from \"react\";\nfunction assignRef(ref, value) {\n if (ref == null)\n return;\n if (typeof ref === \"function\") {\n ref(value);\n return;\n }\n try {\n ref.current = value;\n } catch (error) {\n throw new Error(`Cannot assign value '${value}' to ref '${ref}'`);\n }\n}\nfunction mergeRefs(...refs) {\n return (node) => {\n refs.forEach((ref) => {\n assignRef(ref, node);\n });\n };\n}\nfunction useMergeRefs(...refs) {\n return useMemo(() => mergeRefs(...refs), refs);\n}\nexport {\n assignRef,\n mergeRefs,\n useMergeRefs\n};\n","// src/index.ts\nimport {\n createContext as createReactContext,\n useContext as useReactContext\n} from \"react\";\nfunction getErrorMessage(hook, provider) {\n return `${hook} returned \\`undefined\\`. Seems you forgot to wrap component within ${provider}`;\n}\nfunction createContext(options = {}) {\n const {\n name,\n strict = true,\n hookName = \"useContext\",\n providerName = \"Provider\",\n errorMessage\n } = options;\n const Context = createReactContext(void 0);\n Context.displayName = name;\n function useContext() {\n var _a;\n const context = useReactContext(Context);\n if (!context && strict) {\n const error = new Error(errorMessage ?? getErrorMessage(hookName, providerName));\n error.name = \"ContextError\";\n (_a = Error.captureStackTrace) == null ? void 0 : _a.call(Error, error, useContext);\n throw error;\n }\n return context;\n }\n return [Context.Provider, useContext, Context];\n}\nexport {\n createContext\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/button.tsx\nimport { useMergeRefs } from \"@chakra-ui/react-use-merge-refs\";\nimport {\n chakra as chakra3,\n forwardRef,\n omitThemingProps,\n useStyleConfig\n} from \"@chakra-ui/system\";\n\n// ../../utilities/shared-utils/src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nvar dataAttr = (condition) => condition ? \"\" : void 0;\n\n// src/button.tsx\nimport { useMemo as useMemo2 } from \"react\";\n\n// src/button-context.ts\nimport { createContext } from \"@chakra-ui/react-context\";\nvar [ButtonGroupProvider, useButtonGroup] = createContext({\n strict: false,\n name: \"ButtonGroupContext\"\n});\n\n// src/button-icon.tsx\nimport { chakra } from \"@chakra-ui/system\";\nimport { cloneElement, isValidElement } from \"react\";\nfunction ButtonIcon(props) {\n const { children, className, ...rest } = props;\n const _children = isValidElement(children) ? cloneElement(children, {\n \"aria-hidden\": true,\n focusable: false\n }) : children;\n const _className = cx(\"chakra-button__icon\", className);\n return /* @__PURE__ */ React.createElement(chakra.span, {\n display: \"inline-flex\",\n alignSelf: \"center\",\n flexShrink: 0,\n ...rest,\n className: _className\n }, _children);\n}\nButtonIcon.displayName = \"ButtonIcon\";\n\n// src/button-spinner.tsx\nimport { Spinner } from \"@chakra-ui/spinner\";\nimport { chakra as chakra2 } from \"@chakra-ui/system\";\nimport { useMemo } from \"react\";\nfunction ButtonSpinner(props) {\n const {\n label,\n placement,\n spacing = \"0.5rem\",\n children = /* @__PURE__ */ React.createElement(Spinner, {\n color: \"currentColor\",\n width: \"1em\",\n height: \"1em\"\n }),\n className,\n __css,\n ...rest\n } = props;\n const _className = cx(\"chakra-button__spinner\", className);\n const marginProp = placement === \"start\" ? \"marginEnd\" : \"marginStart\";\n const spinnerStyles = useMemo(() => ({\n display: \"flex\",\n alignItems: \"center\",\n position: label ? \"relative\" : \"absolute\",\n [marginProp]: label ? spacing : 0,\n fontSize: \"1em\",\n lineHeight: \"normal\",\n ...__css\n }), [__css, label, marginProp, spacing]);\n return /* @__PURE__ */ React.createElement(chakra2.div, {\n className: _className,\n ...rest,\n __css: spinnerStyles\n }, children);\n}\nButtonSpinner.displayName = \"ButtonSpinner\";\n\n// src/use-button-type.tsx\nimport { useCallback, useState } from \"react\";\nfunction useButtonType(value) {\n const [isButton, setIsButton] = useState(!value);\n const refCallback = useCallback((node) => {\n if (!node)\n return;\n setIsButton(node.tagName === \"BUTTON\");\n }, []);\n const type = isButton ? \"button\" : void 0;\n return { ref: refCallback, type };\n}\n\n// src/button.tsx\nvar Button = forwardRef((props, ref) => {\n const group = useButtonGroup();\n const styles = useStyleConfig(\"Button\", { ...group, ...props });\n const {\n isDisabled = group == null ? void 0 : group.isDisabled,\n isLoading,\n isActive,\n children,\n leftIcon,\n rightIcon,\n loadingText,\n iconSpacing = \"0.5rem\",\n type,\n spinner,\n spinnerPlacement = \"start\",\n className,\n as,\n ...rest\n } = omitThemingProps(props);\n const buttonStyles = useMemo2(() => {\n const _focus = { ...styles == null ? void 0 : styles[\"_focus\"], zIndex: 1 };\n return {\n display: \"inline-flex\",\n appearance: \"none\",\n alignItems: \"center\",\n justifyContent: \"center\",\n userSelect: \"none\",\n position: \"relative\",\n whiteSpace: \"nowrap\",\n verticalAlign: \"middle\",\n outline: \"none\",\n ...styles,\n ...!!group && { _focus }\n };\n }, [styles, group]);\n const { ref: _ref, type: defaultType } = useButtonType(as);\n const contentProps = { rightIcon, leftIcon, iconSpacing, children };\n return /* @__PURE__ */ React.createElement(chakra3.button, {\n disabled: isDisabled || isLoading,\n ref: useMergeRefs(ref, _ref),\n as,\n type: type ?? defaultType,\n \"data-active\": dataAttr(isActive),\n \"data-loading\": dataAttr(isLoading),\n __css: buttonStyles,\n className: cx(\"chakra-button\", className),\n ...rest\n }, isLoading && spinnerPlacement === \"start\" && /* @__PURE__ */ React.createElement(ButtonSpinner, {\n className: \"chakra-button__spinner--start\",\n label: loadingText,\n placement: \"start\",\n spacing: iconSpacing\n }, spinner), isLoading ? loadingText || /* @__PURE__ */ React.createElement(chakra3.span, {\n opacity: 0\n }, /* @__PURE__ */ React.createElement(ButtonContent, {\n ...contentProps\n })) : /* @__PURE__ */ React.createElement(ButtonContent, {\n ...contentProps\n }), isLoading && spinnerPlacement === \"end\" && /* @__PURE__ */ React.createElement(ButtonSpinner, {\n className: \"chakra-button__spinner--end\",\n label: loadingText,\n placement: \"end\",\n spacing: iconSpacing\n }, spinner));\n});\nButton.displayName = \"Button\";\nfunction ButtonContent(props) {\n const { leftIcon, rightIcon, children, iconSpacing } = props;\n return /* @__PURE__ */ React.createElement(React.Fragment, null, leftIcon && /* @__PURE__ */ React.createElement(ButtonIcon, {\n marginEnd: iconSpacing\n }, leftIcon), children, rightIcon && /* @__PURE__ */ React.createElement(ButtonIcon, {\n marginStart: iconSpacing\n }, rightIcon));\n}\n\n// src/button-group.tsx\nimport {\n chakra as chakra4,\n forwardRef as forwardRef2\n} from \"@chakra-ui/system\";\nimport { useMemo as useMemo3 } from \"react\";\nvar ButtonGroup = forwardRef2(function ButtonGroup2(props, ref) {\n const {\n size,\n colorScheme,\n variant,\n className,\n spacing = \"0.5rem\",\n isAttached,\n isDisabled,\n ...rest\n } = props;\n const _className = cx(\"chakra-button__group\", className);\n const context = useMemo3(() => ({ size, colorScheme, variant, isDisabled }), [size, colorScheme, variant, isDisabled]);\n let groupStyles = {\n display: \"inline-flex\"\n };\n if (isAttached) {\n groupStyles = {\n ...groupStyles,\n \"> *:first-of-type:not(:last-of-type)\": { borderEndRadius: 0 },\n \"> *:not(:first-of-type):not(:last-of-type)\": { borderRadius: 0 },\n \"> *:not(:first-of-type):last-of-type\": { borderStartRadius: 0 }\n };\n } else {\n groupStyles = {\n ...groupStyles,\n \"& > *:not(style) ~ *:not(style)\": { marginStart: spacing }\n };\n }\n return /* @__PURE__ */ React.createElement(ButtonGroupProvider, {\n value: context\n }, /* @__PURE__ */ React.createElement(chakra4.div, {\n ref,\n role: \"group\",\n __css: groupStyles,\n className: _className,\n \"data-attached\": isAttached ? \"\" : void 0,\n ...rest\n }));\n});\nButtonGroup.displayName = \"ButtonGroup\";\n\n// src/icon-button.tsx\nimport { forwardRef as forwardRef3 } from \"@chakra-ui/system\";\nimport { cloneElement as cloneElement2, isValidElement as isValidElement2 } from \"react\";\nvar IconButton = forwardRef3((props, ref) => {\n const { icon, children, isRound, \"aria-label\": ariaLabel, ...rest } = props;\n const element = icon || children;\n const _children = isValidElement2(element) ? cloneElement2(element, {\n \"aria-hidden\": true,\n focusable: false\n }) : null;\n return /* @__PURE__ */ React.createElement(Button, {\n padding: \"0\",\n borderRadius: isRound ? \"full\" : void 0,\n ref,\n \"aria-label\": ariaLabel,\n ...rest\n }, _children);\n});\nIconButton.displayName = \"IconButton\";\nexport {\n Button,\n ButtonGroup,\n ButtonSpinner,\n IconButton,\n useButtonGroup\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/form-control.tsx\nimport { createContext } from \"@chakra-ui/react-context\";\nimport { mergeRefs } from \"@chakra-ui/react-use-merge-refs\";\nimport {\n chakra,\n forwardRef,\n omitThemingProps,\n useMultiStyleConfig\n} from \"@chakra-ui/system\";\n\n// ../../utilities/shared-utils/src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\n\n// src/form-control.tsx\nimport { useCallback, useId, useState } from \"react\";\nvar [FormControlStylesProvider, useFormControlStyles] = createContext({\n name: `FormControlStylesContext`,\n errorMessage: `useFormControlStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar [FormControlProvider, useFormControlContext] = createContext({\n strict: false,\n name: \"FormControlContext\"\n});\nfunction useFormControlProvider(props) {\n const {\n id: idProp,\n isRequired,\n isInvalid,\n isDisabled,\n isReadOnly,\n ...htmlProps\n } = props;\n const uuid = useId();\n const id = idProp || `field-${uuid}`;\n const labelId = `${id}-label`;\n const feedbackId = `${id}-feedback`;\n const helpTextId = `${id}-helptext`;\n const [hasFeedbackText, setHasFeedbackText] = useState(false);\n const [hasHelpText, setHasHelpText] = useState(false);\n const [isFocused, setFocus] = useState(false);\n const getHelpTextProps = useCallback((props2 = {}, forwardedRef = null) => ({\n id: helpTextId,\n ...props2,\n ref: mergeRefs(forwardedRef, (node) => {\n if (!node)\n return;\n setHasHelpText(true);\n })\n }), [helpTextId]);\n const getLabelProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ref: forwardedRef,\n \"data-focus\": dataAttr(isFocused),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-readonly\": dataAttr(isReadOnly),\n id: props2.id ?? labelId,\n htmlFor: props2.htmlFor ?? id\n }), [id, isDisabled, isFocused, isInvalid, isReadOnly, labelId]);\n const getErrorMessageProps = useCallback((props2 = {}, forwardedRef = null) => ({\n id: feedbackId,\n ...props2,\n ref: mergeRefs(forwardedRef, (node) => {\n if (!node)\n return;\n setHasFeedbackText(true);\n }),\n \"aria-live\": \"polite\"\n }), [feedbackId]);\n const getRootProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ...htmlProps,\n ref: forwardedRef,\n role: \"group\"\n }), [htmlProps]);\n const getRequiredIndicatorProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ref: forwardedRef,\n role: \"presentation\",\n \"aria-hidden\": true,\n children: props2.children || \"*\"\n }), []);\n return {\n isRequired: !!isRequired,\n isInvalid: !!isInvalid,\n isReadOnly: !!isReadOnly,\n isDisabled: !!isDisabled,\n isFocused: !!isFocused,\n onFocus: () => setFocus(true),\n onBlur: () => setFocus(false),\n hasFeedbackText,\n setHasFeedbackText,\n hasHelpText,\n setHasHelpText,\n id,\n labelId,\n feedbackId,\n helpTextId,\n htmlProps,\n getHelpTextProps,\n getErrorMessageProps,\n getRootProps,\n getLabelProps,\n getRequiredIndicatorProps\n };\n}\nvar FormControl = forwardRef(function FormControl2(props, ref) {\n const styles = useMultiStyleConfig(\"Form\", props);\n const ownProps = omitThemingProps(props);\n const {\n getRootProps,\n htmlProps: _,\n ...context\n } = useFormControlProvider(ownProps);\n const className = cx(\"chakra-form-control\", props.className);\n return /* @__PURE__ */ React.createElement(FormControlProvider, {\n value: context\n }, /* @__PURE__ */ React.createElement(FormControlStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra.div, {\n ...getRootProps({}, ref),\n className,\n __css: styles[\"container\"]\n })));\n});\nFormControl.displayName = \"FormControl\";\nvar FormHelperText = forwardRef(function FormHelperText2(props, ref) {\n const field = useFormControlContext();\n const styles = useFormControlStyles();\n const className = cx(\"chakra-form__helper-text\", props.className);\n return /* @__PURE__ */ React.createElement(chakra.div, {\n ...field == null ? void 0 : field.getHelpTextProps(props, ref),\n __css: styles.helperText,\n className\n });\n});\nFormHelperText.displayName = \"FormHelperText\";\n\n// src/use-form-control.ts\nfunction useFormControl(props) {\n const { isDisabled, isInvalid, isReadOnly, isRequired, ...rest } = useFormControlProps(props);\n return {\n ...rest,\n disabled: isDisabled,\n readOnly: isReadOnly,\n required: isRequired,\n \"aria-invalid\": ariaAttr(isInvalid),\n \"aria-required\": ariaAttr(isRequired),\n \"aria-readonly\": ariaAttr(isReadOnly)\n };\n}\nfunction useFormControlProps(props) {\n const field = useFormControlContext();\n const {\n id,\n disabled,\n readOnly,\n required,\n isRequired,\n isInvalid,\n isReadOnly,\n isDisabled,\n onFocus,\n onBlur,\n ...rest\n } = props;\n const labelIds = props[\"aria-describedby\"] ? [props[\"aria-describedby\"]] : [];\n if ((field == null ? void 0 : field.hasFeedbackText) && (field == null ? void 0 : field.isInvalid)) {\n labelIds.push(field.feedbackId);\n }\n if (field == null ? void 0 : field.hasHelpText) {\n labelIds.push(field.helpTextId);\n }\n return {\n ...rest,\n \"aria-describedby\": labelIds.join(\" \") || void 0,\n id: id ?? (field == null ? void 0 : field.id),\n isDisabled: disabled ?? isDisabled ?? (field == null ? void 0 : field.isDisabled),\n isReadOnly: readOnly ?? isReadOnly ?? (field == null ? void 0 : field.isReadOnly),\n isRequired: required ?? isRequired ?? (field == null ? void 0 : field.isRequired),\n isInvalid: isInvalid ?? (field == null ? void 0 : field.isInvalid),\n onFocus: callAllHandlers(field == null ? void 0 : field.onFocus, onFocus),\n onBlur: callAllHandlers(field == null ? void 0 : field.onBlur, onBlur)\n };\n}\n\n// src/form-error.tsx\nimport { Icon } from \"@chakra-ui/icon\";\nimport { createContext as createContext2 } from \"@chakra-ui/react-context\";\nimport {\n chakra as chakra2,\n forwardRef as forwardRef2,\n omitThemingProps as omitThemingProps2,\n useMultiStyleConfig as useMultiStyleConfig2\n} from \"@chakra-ui/system\";\nvar [FormErrorStylesProvider, useFormErrorStyles] = createContext2({\n name: `FormErrorStylesContext`,\n errorMessage: `useFormErrorStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar FormErrorMessage = forwardRef2((props, ref) => {\n const styles = useMultiStyleConfig2(\"FormError\", props);\n const ownProps = omitThemingProps2(props);\n const field = useFormControlContext();\n if (!(field == null ? void 0 : field.isInvalid))\n return null;\n return /* @__PURE__ */ React.createElement(FormErrorStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra2.div, {\n ...field == null ? void 0 : field.getErrorMessageProps(ownProps, ref),\n className: cx(\"chakra-form__error-message\", props.className),\n __css: {\n display: \"flex\",\n alignItems: \"center\",\n ...styles.text\n }\n }));\n});\nFormErrorMessage.displayName = \"FormErrorMessage\";\nvar FormErrorIcon = forwardRef2((props, ref) => {\n const styles = useFormErrorStyles();\n const field = useFormControlContext();\n if (!(field == null ? void 0 : field.isInvalid))\n return null;\n const _className = cx(\"chakra-form__error-icon\", props.className);\n return /* @__PURE__ */ React.createElement(Icon, {\n ref,\n \"aria-hidden\": true,\n ...props,\n __css: styles.icon,\n className: _className\n }, /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: \"M11.983,0a12.206,12.206,0,0,0-8.51,3.653A11.8,11.8,0,0,0,0,12.207,11.779,11.779,0,0,0,11.8,24h.214A12.111,12.111,0,0,0,24,11.791h0A11.766,11.766,0,0,0,11.983,0ZM10.5,16.542a1.476,1.476,0,0,1,1.449-1.53h.027a1.527,1.527,0,0,1,1.523,1.47,1.475,1.475,0,0,1-1.449,1.53h-.027A1.529,1.529,0,0,1,10.5,16.542ZM11,12.5v-6a1,1,0,0,1,2,0v6a1,1,0,1,1-2,0Z\"\n }));\n});\nFormErrorIcon.displayName = \"FormErrorIcon\";\n\n// src/form-label.tsx\nimport {\n chakra as chakra3,\n forwardRef as forwardRef3,\n omitThemingProps as omitThemingProps3,\n useStyleConfig\n} from \"@chakra-ui/system\";\nvar FormLabel = forwardRef3(function FormLabel2(passedProps, ref) {\n const styles = useStyleConfig(\"FormLabel\", passedProps);\n const props = omitThemingProps3(passedProps);\n const {\n className,\n children,\n requiredIndicator = /* @__PURE__ */ React.createElement(RequiredIndicator, null),\n optionalIndicator = null,\n ...rest\n } = props;\n const field = useFormControlContext();\n const ownProps = (field == null ? void 0 : field.getLabelProps(rest, ref)) ?? { ref, ...rest };\n return /* @__PURE__ */ React.createElement(chakra3.label, {\n ...ownProps,\n className: cx(\"chakra-form__label\", props.className),\n __css: {\n display: \"block\",\n textAlign: \"start\",\n ...styles\n }\n }, children, (field == null ? void 0 : field.isRequired) ? requiredIndicator : optionalIndicator);\n});\nFormLabel.displayName = \"FormLabel\";\nvar RequiredIndicator = forwardRef3(function RequiredIndicator2(props, ref) {\n const field = useFormControlContext();\n const styles = useFormControlStyles();\n if (!(field == null ? void 0 : field.isRequired))\n return null;\n const className = cx(\"chakra-form__required-indicator\", props.className);\n return /* @__PURE__ */ React.createElement(chakra3.span, {\n ...field == null ? void 0 : field.getRequiredIndicatorProps(props, ref),\n __css: styles.requiredIndicator,\n className\n });\n});\nRequiredIndicator.displayName = \"RequiredIndicator\";\nexport {\n FormControl,\n FormErrorIcon,\n FormErrorMessage,\n FormHelperText,\n FormLabel,\n RequiredIndicator,\n useFormControl,\n useFormControlContext,\n useFormControlProps,\n useFormControlStyles,\n useFormErrorStyles\n};\n","// src/index.ts\nimport { useEffect, useRef } from \"react\";\nfunction useUpdateEffect(callback, deps) {\n const renderCycleRef = useRef(false);\n const effectCycleRef = useRef(false);\n useEffect(() => {\n const mounted = renderCycleRef.current;\n const run = mounted && effectCycleRef.current;\n if (run) {\n return callback();\n }\n effectCycleRef.current = true;\n }, deps);\n useEffect(() => {\n renderCycleRef.current = true;\n return () => {\n renderCycleRef.current = false;\n };\n }, []);\n}\nexport {\n useUpdateEffect\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/visually-hidden.tsx\nimport { chakra } from \"@chakra-ui/system\";\n\n// src/visually-hidden.style.ts\nvar visuallyHiddenStyle = {\n border: \"0px\",\n clip: \"rect(0px, 0px, 0px, 0px)\",\n height: \"1px\",\n width: \"1px\",\n margin: \"-1px\",\n padding: \"0px\",\n overflow: \"hidden\",\n whiteSpace: \"nowrap\",\n position: \"absolute\"\n};\n\n// src/visually-hidden.tsx\nvar VisuallyHidden = chakra(\"span\", {\n baseStyle: visuallyHiddenStyle\n});\nVisuallyHidden.displayName = \"VisuallyHidden\";\nvar VisuallyHiddenInput = chakra(\"input\", {\n baseStyle: visuallyHiddenStyle\n});\nVisuallyHiddenInput.displayName = \"VisuallyHiddenInput\";\nvar visually_hidden_default = VisuallyHidden;\nexport {\n VisuallyHidden,\n VisuallyHiddenInput,\n visually_hidden_default as default,\n visuallyHiddenStyle\n};\n","// src/index.ts\nvar hasSetup = false;\nvar modality = null;\nvar hasEventBeforeFocus = false;\nvar handlers = /* @__PURE__ */ new Set();\nvar isMac = typeof window !== \"undefined\" && window.navigator != null ? /^Mac/.test(window.navigator.platform) : false;\nfunction isValidKey(event) {\n return !(event.metaKey || !isMac && event.altKey || event.ctrlKey);\n}\nfunction trigger(modality2, event) {\n handlers.forEach((handler) => handler(modality2, event));\n}\nfunction onKeyboardEvent(event) {\n hasEventBeforeFocus = true;\n if (isValidKey(event)) {\n modality = \"keyboard\";\n trigger(\"keyboard\", event);\n }\n}\nfunction onPointerEvent(event) {\n modality = \"pointer\";\n if (event.type === \"mousedown\" || event.type === \"pointerdown\") {\n hasEventBeforeFocus = true;\n trigger(\"pointer\", event);\n }\n}\nfunction onWindowFocus(event) {\n if (event.target === window || event.target === document) {\n return;\n }\n if (!hasEventBeforeFocus) {\n modality = \"keyboard\";\n trigger(\"keyboard\", event);\n }\n hasEventBeforeFocus = false;\n}\nfunction onWindowBlur() {\n hasEventBeforeFocus = false;\n}\nfunction isFocusVisible() {\n return modality !== \"pointer\";\n}\nfunction setupGlobalFocusEvents() {\n if (typeof window === \"undefined\" || hasSetup) {\n return;\n }\n const { focus } = HTMLElement.prototype;\n HTMLElement.prototype.focus = function focusElement(...args) {\n hasEventBeforeFocus = true;\n focus.apply(this, args);\n };\n document.addEventListener(\"keydown\", onKeyboardEvent, true);\n document.addEventListener(\"keyup\", onKeyboardEvent, true);\n window.addEventListener(\"focus\", onWindowFocus, true);\n window.addEventListener(\"blur\", onWindowBlur, false);\n if (typeof PointerEvent !== \"undefined\") {\n document.addEventListener(\"pointerdown\", onPointerEvent, true);\n document.addEventListener(\"pointermove\", onPointerEvent, true);\n document.addEventListener(\"pointerup\", onPointerEvent, true);\n } else {\n document.addEventListener(\"mousedown\", onPointerEvent, true);\n document.addEventListener(\"mousemove\", onPointerEvent, true);\n document.addEventListener(\"mouseup\", onPointerEvent, true);\n }\n hasSetup = true;\n}\nfunction trackFocusVisible(fn) {\n setupGlobalFocusEvents();\n fn(isFocusVisible());\n const handler = () => fn(isFocusVisible());\n handlers.add(handler);\n return () => {\n handlers.delete(handler);\n };\n}\nexport {\n trackFocusVisible\n};\n//# sourceMappingURL=index.mjs.map\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/checkbox-group.tsx\nimport { useMemo } from \"react\";\n\n// src/checkbox-context.ts\nimport { createContext } from \"@chakra-ui/react-context\";\nvar [CheckboxGroupProvider, useCheckboxGroupContext] = createContext({\n name: \"CheckboxGroupContext\",\n strict: false\n});\n\n// src/use-checkbox-group.ts\nimport { useCallbackRef } from \"@chakra-ui/react-use-callback-ref\";\nimport { useControllableState } from \"@chakra-ui/react-use-controllable-state\";\n\n// ../../utilities/shared-utils/src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nfunction isObject(value) {\n const type = typeof value;\n return value != null && (type === \"object\" || type === \"function\") && !Array.isArray(value);\n}\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\nfunction callAll(...fns) {\n return function mergedFn(arg) {\n fns.forEach((fn) => {\n fn == null ? void 0 : fn(arg);\n });\n };\n}\n\n// src/use-checkbox-group.ts\nimport { useCallback } from \"react\";\nfunction isInputEvent(value) {\n return value && isObject(value) && isObject(value.target);\n}\nfunction useCheckboxGroup(props = {}) {\n const {\n defaultValue,\n value: valueProp,\n onChange,\n isDisabled,\n isNative\n } = props;\n const onChangeProp = useCallbackRef(onChange);\n const [value, setValue] = useControllableState({\n value: valueProp,\n defaultValue: defaultValue || [],\n onChange: onChangeProp\n });\n const handleChange = useCallback((eventOrValue) => {\n if (!value)\n return;\n const isChecked = isInputEvent(eventOrValue) ? eventOrValue.target.checked : !value.includes(eventOrValue);\n const selectedValue = isInputEvent(eventOrValue) ? eventOrValue.target.value : eventOrValue;\n const nextValue = isChecked ? [...value, selectedValue] : value.filter((v) => String(v) !== String(selectedValue));\n setValue(nextValue);\n }, [setValue, value]);\n const getCheckboxProps = useCallback((props2 = {}) => {\n const checkedKey = isNative ? \"checked\" : \"isChecked\";\n return {\n ...props2,\n [checkedKey]: value.some((val) => String(props2.value) === String(val)),\n onChange: handleChange\n };\n }, [handleChange, isNative, value]);\n return {\n value,\n isDisabled,\n onChange: handleChange,\n setValue,\n getCheckboxProps\n };\n}\n\n// src/checkbox-group.tsx\nfunction CheckboxGroup(props) {\n const { colorScheme, size, variant, children, isDisabled } = props;\n const { value, onChange } = useCheckboxGroup(props);\n const group = useMemo(() => ({\n size,\n onChange,\n colorScheme,\n value,\n variant,\n isDisabled\n }), [size, onChange, colorScheme, value, variant, isDisabled]);\n return /* @__PURE__ */ React.createElement(CheckboxGroupProvider, {\n value: group,\n children\n });\n}\nCheckboxGroup.displayName = \"CheckboxGroup\";\n\n// src/checkbox-icon.tsx\nimport { chakra } from \"@chakra-ui/system\";\nimport { AnimatePresence, motion } from \"framer-motion\";\nvar MotionSvg = chakra(motion.svg);\nfunction CheckIcon(props) {\n return /* @__PURE__ */ React.createElement(MotionSvg, {\n width: \"1.2em\",\n viewBox: \"0 0 12 10\",\n variants: {\n unchecked: {\n opacity: 0,\n strokeDashoffset: 16\n },\n checked: {\n opacity: 1,\n strokeDashoffset: 0,\n transition: { duration: 0.2 }\n }\n },\n style: {\n fill: \"none\",\n strokeWidth: 2,\n stroke: \"currentColor\",\n strokeDasharray: 16\n },\n ...props\n }, /* @__PURE__ */ React.createElement(\"polyline\", {\n points: \"1.5 6 4.5 9 10.5 1\"\n }));\n}\nfunction IndeterminateIcon(props) {\n return /* @__PURE__ */ React.createElement(MotionSvg, {\n width: \"1.2em\",\n viewBox: \"0 0 24 24\",\n variants: {\n unchecked: {\n scaleX: 0.65,\n opacity: 0\n },\n checked: {\n scaleX: 1,\n opacity: 1,\n transition: {\n scaleX: { duration: 0 },\n opacity: { duration: 0.02 }\n }\n }\n },\n style: { stroke: \"currentColor\", strokeWidth: 4 },\n ...props\n }, /* @__PURE__ */ React.createElement(\"line\", {\n x1: \"21\",\n x2: \"3\",\n y1: \"12\",\n y2: \"12\"\n }));\n}\nfunction CheckboxTransition({ open, children }) {\n return /* @__PURE__ */ React.createElement(AnimatePresence, {\n initial: false\n }, open && /* @__PURE__ */ React.createElement(motion.div, {\n variants: {\n unchecked: { scale: 0.5 },\n checked: { scale: 1 }\n },\n initial: \"unchecked\",\n animate: \"checked\",\n exit: \"unchecked\",\n style: {\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n height: \"100%\"\n }\n }, children));\n}\nfunction CheckboxIcon(props) {\n const { isIndeterminate, isChecked, ...rest } = props;\n const BaseIcon = isIndeterminate ? IndeterminateIcon : CheckIcon;\n return /* @__PURE__ */ React.createElement(CheckboxTransition, {\n open: isChecked || isIndeterminate\n }, /* @__PURE__ */ React.createElement(BaseIcon, {\n ...rest\n }));\n}\n\n// src/checkbox.tsx\nimport {\n chakra as chakra2,\n forwardRef,\n omitThemingProps,\n useMultiStyleConfig\n} from \"@chakra-ui/system\";\nimport { cloneElement, useMemo as useMemo2 } from \"react\";\n\n// src/use-checkbox.ts\nimport { useFormControlProps } from \"@chakra-ui/form-control\";\nimport { useSafeLayoutEffect } from \"@chakra-ui/react-use-safe-layout-effect\";\nimport { useUpdateEffect } from \"@chakra-ui/react-use-update-effect\";\nimport { useCallbackRef as useCallbackRef2 } from \"@chakra-ui/react-use-callback-ref\";\nimport { mergeRefs } from \"@chakra-ui/react-use-merge-refs\";\n\n// ../../utilities/object-utils/src/index.ts\nfunction omit(object, keysToOmit = []) {\n const clone = Object.assign({}, object);\n for (const key of keysToOmit) {\n if (key in clone)\n delete clone[key];\n }\n return clone;\n}\n\n// src/use-checkbox.ts\nimport { visuallyHiddenStyle } from \"@chakra-ui/visually-hidden\";\nimport { trackFocusVisible } from \"@zag-js/focus-visible\";\nimport { useCallback as useCallback2, useEffect, useRef, useState } from \"react\";\nfunction useCheckbox(props = {}) {\n const formControlProps = useFormControlProps(props);\n const {\n isDisabled,\n isReadOnly,\n isRequired,\n isInvalid,\n id,\n onBlur,\n onFocus,\n \"aria-describedby\": ariaDescribedBy\n } = formControlProps;\n const {\n defaultChecked,\n isChecked: checkedProp,\n isFocusable,\n onChange,\n isIndeterminate,\n name,\n value,\n tabIndex = void 0,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n \"aria-invalid\": ariaInvalid,\n ...rest\n } = props;\n const htmlProps = omit(rest, [\n \"isDisabled\",\n \"isReadOnly\",\n \"isRequired\",\n \"isInvalid\",\n \"id\",\n \"onBlur\",\n \"onFocus\",\n \"aria-describedby\"\n ]);\n const onChangeProp = useCallbackRef2(onChange);\n const onBlurProp = useCallbackRef2(onBlur);\n const onFocusProp = useCallbackRef2(onFocus);\n const [isFocusVisible, setIsFocusVisible] = useState(false);\n const [isFocused, setFocused] = useState(false);\n const [isHovered, setHovered] = useState(false);\n const [isActive, setActive] = useState(false);\n useEffect(() => {\n return trackFocusVisible(setIsFocusVisible);\n }, []);\n const inputRef = useRef(null);\n const [rootIsLabelElement, setRootIsLabelElement] = useState(true);\n const [checkedState, setCheckedState] = useState(!!defaultChecked);\n const isControlled = checkedProp !== void 0;\n const isChecked = isControlled ? checkedProp : checkedState;\n const handleChange = useCallback2((event) => {\n if (isReadOnly || isDisabled) {\n event.preventDefault();\n return;\n }\n if (!isControlled) {\n if (isChecked) {\n setCheckedState(event.target.checked);\n } else {\n setCheckedState(isIndeterminate ? true : event.target.checked);\n }\n }\n onChangeProp == null ? void 0 : onChangeProp(event);\n }, [\n isReadOnly,\n isDisabled,\n isChecked,\n isControlled,\n isIndeterminate,\n onChangeProp\n ]);\n useSafeLayoutEffect(() => {\n if (inputRef.current) {\n inputRef.current.indeterminate = Boolean(isIndeterminate);\n }\n }, [isIndeterminate]);\n useUpdateEffect(() => {\n if (isDisabled) {\n setFocused(false);\n }\n }, [isDisabled, setFocused]);\n useSafeLayoutEffect(() => {\n const el = inputRef.current;\n if (!(el == null ? void 0 : el.form))\n return;\n el.form.onreset = () => {\n setCheckedState(!!defaultChecked);\n };\n }, []);\n const trulyDisabled = isDisabled && !isFocusable;\n const onKeyDown = useCallback2((event) => {\n if (event.key === \" \") {\n setActive(true);\n }\n }, [setActive]);\n const onKeyUp = useCallback2((event) => {\n if (event.key === \" \") {\n setActive(false);\n }\n }, [setActive]);\n useSafeLayoutEffect(() => {\n if (!inputRef.current)\n return;\n const notInSync = inputRef.current.checked !== isChecked;\n if (notInSync) {\n setCheckedState(inputRef.current.checked);\n }\n }, [inputRef.current]);\n const getCheckboxProps = useCallback2((props2 = {}, forwardedRef = null) => {\n const onPressDown = (event) => {\n if (isFocused) {\n event.preventDefault();\n }\n setActive(true);\n };\n return {\n ...props2,\n ref: forwardedRef,\n \"data-active\": dataAttr(isActive),\n \"data-hover\": dataAttr(isHovered),\n \"data-checked\": dataAttr(isChecked),\n \"data-focus\": dataAttr(isFocused),\n \"data-focus-visible\": dataAttr(isFocused && isFocusVisible),\n \"data-indeterminate\": dataAttr(isIndeterminate),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-readonly\": dataAttr(isReadOnly),\n \"aria-hidden\": true,\n onMouseDown: callAllHandlers(props2.onMouseDown, onPressDown),\n onMouseUp: callAllHandlers(props2.onMouseUp, () => setActive(false)),\n onMouseEnter: callAllHandlers(props2.onMouseEnter, () => setHovered(true)),\n onMouseLeave: callAllHandlers(props2.onMouseLeave, () => setHovered(false))\n };\n }, [\n isActive,\n isChecked,\n isDisabled,\n isFocused,\n isFocusVisible,\n isHovered,\n isIndeterminate,\n isInvalid,\n isReadOnly\n ]);\n const getRootProps = useCallback2((props2 = {}, forwardedRef = null) => ({\n ...htmlProps,\n ...props2,\n ref: mergeRefs(forwardedRef, (node) => {\n if (!node)\n return;\n setRootIsLabelElement(node.tagName === \"LABEL\");\n }),\n onClick: callAllHandlers(props2.onClick, () => {\n var _a;\n if (!rootIsLabelElement) {\n (_a = inputRef.current) == null ? void 0 : _a.click();\n requestAnimationFrame(() => {\n var _a2;\n (_a2 = inputRef.current) == null ? void 0 : _a2.focus();\n });\n }\n }),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-checked\": dataAttr(isChecked),\n \"data-invalid\": dataAttr(isInvalid)\n }), [htmlProps, isDisabled, isChecked, isInvalid, rootIsLabelElement]);\n const getInputProps = useCallback2((props2 = {}, forwardedRef = null) => {\n return {\n ...props2,\n ref: mergeRefs(inputRef, forwardedRef),\n type: \"checkbox\",\n name,\n value,\n id,\n tabIndex,\n onChange: callAllHandlers(props2.onChange, handleChange),\n onBlur: callAllHandlers(props2.onBlur, onBlurProp, () => setFocused(false)),\n onFocus: callAllHandlers(props2.onFocus, onFocusProp, () => setFocused(true)),\n onKeyDown: callAllHandlers(props2.onKeyDown, onKeyDown),\n onKeyUp: callAllHandlers(props2.onKeyUp, onKeyUp),\n required: isRequired,\n checked: isChecked,\n disabled: trulyDisabled,\n readOnly: isReadOnly,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n \"aria-invalid\": ariaInvalid ? Boolean(ariaInvalid) : isInvalid,\n \"aria-describedby\": ariaDescribedBy,\n \"aria-disabled\": isDisabled,\n style: visuallyHiddenStyle\n };\n }, [\n name,\n value,\n id,\n handleChange,\n onBlurProp,\n onFocusProp,\n onKeyDown,\n onKeyUp,\n isRequired,\n isChecked,\n trulyDisabled,\n isReadOnly,\n ariaLabel,\n ariaLabelledBy,\n ariaInvalid,\n isInvalid,\n ariaDescribedBy,\n isDisabled,\n tabIndex\n ]);\n const getLabelProps = useCallback2((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ref: forwardedRef,\n onMouseDown: callAllHandlers(props2.onMouseDown, stopEvent),\n onTouchStart: callAllHandlers(props2.onTouchStart, stopEvent),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-checked\": dataAttr(isChecked),\n \"data-invalid\": dataAttr(isInvalid)\n }), [isChecked, isDisabled, isInvalid]);\n const state = {\n isInvalid,\n isFocused,\n isChecked,\n isActive,\n isHovered,\n isIndeterminate,\n isDisabled,\n isReadOnly,\n isRequired\n };\n return {\n state,\n getRootProps,\n getCheckboxProps,\n getInputProps,\n getLabelProps,\n htmlProps\n };\n}\nfunction stopEvent(event) {\n event.preventDefault();\n event.stopPropagation();\n}\n\n// src/checkbox.tsx\nvar controlStyles = {\n display: \"inline-flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n verticalAlign: \"top\",\n userSelect: \"none\",\n flexShrink: 0\n};\nvar rootStyles = {\n cursor: \"pointer\",\n display: \"inline-flex\",\n alignItems: \"center\",\n verticalAlign: \"top\",\n position: \"relative\"\n};\nvar Checkbox = forwardRef(function Checkbox2(props, ref) {\n const group = useCheckboxGroupContext();\n const mergedProps = { ...group, ...props };\n const styles = useMultiStyleConfig(\"Checkbox\", mergedProps);\n const ownProps = omitThemingProps(props);\n const {\n spacing = \"0.5rem\",\n className,\n children,\n iconColor,\n iconSize,\n icon = /* @__PURE__ */ React.createElement(CheckboxIcon, null),\n isChecked: isCheckedProp,\n isDisabled = group == null ? void 0 : group.isDisabled,\n onChange: onChangeProp,\n inputProps,\n ...rest\n } = ownProps;\n let isChecked = isCheckedProp;\n if ((group == null ? void 0 : group.value) && ownProps.value) {\n isChecked = group.value.includes(ownProps.value);\n }\n let onChange = onChangeProp;\n if ((group == null ? void 0 : group.onChange) && ownProps.value) {\n onChange = callAll(group.onChange, onChangeProp);\n }\n const {\n state,\n getInputProps,\n getCheckboxProps,\n getLabelProps,\n getRootProps\n } = useCheckbox({\n ...rest,\n isDisabled,\n isChecked,\n onChange\n });\n const iconStyles = useMemo2(() => ({\n opacity: state.isChecked || state.isIndeterminate ? 1 : 0,\n transform: state.isChecked || state.isIndeterminate ? \"scale(1)\" : \"scale(0.95)\",\n fontSize: iconSize,\n color: iconColor,\n ...styles.icon\n }), [iconColor, iconSize, state.isChecked, state.isIndeterminate, styles.icon]);\n const clonedIcon = cloneElement(icon, {\n __css: iconStyles,\n isIndeterminate: state.isIndeterminate,\n isChecked: state.isChecked\n });\n return /* @__PURE__ */ React.createElement(chakra2.label, {\n __css: { ...rootStyles, ...styles.container },\n className: cx(\"chakra-checkbox\", className),\n ...getRootProps()\n }, /* @__PURE__ */ React.createElement(\"input\", {\n className: \"chakra-checkbox__input\",\n ...getInputProps(inputProps, ref)\n }), /* @__PURE__ */ React.createElement(chakra2.span, {\n __css: { ...controlStyles, ...styles.control },\n className: \"chakra-checkbox__control\",\n ...getCheckboxProps()\n }, clonedIcon), children && /* @__PURE__ */ React.createElement(chakra2.span, {\n className: \"chakra-checkbox__label\",\n ...getLabelProps(),\n __css: {\n marginStart: spacing,\n ...styles.label\n }\n }, children));\n});\nCheckbox.displayName = \"Checkbox\";\nexport {\n Checkbox,\n CheckboxGroup,\n CheckboxIcon,\n useCheckbox,\n useCheckboxGroup\n};\n","// src/index.ts\nimport { useCallback, useEffect, useRef } from \"react\";\nfunction useCallbackRef(callback, deps = []) {\n const callbackRef = useRef(callback);\n useEffect(() => {\n callbackRef.current = callback;\n });\n return useCallback((...args) => {\n var _a;\n return (_a = callbackRef.current) == null ? void 0 : _a.call(callbackRef, ...args);\n }, deps);\n}\nexport {\n useCallbackRef\n};\n","// src/index.ts\nfunction toNumber(value) {\n const num = parseFloat(value);\n return typeof num !== \"number\" || Number.isNaN(num) ? 0 : num;\n}\nfunction toPrecision(value, precision) {\n let nextValue = toNumber(value);\n const scaleFactor = 10 ** (precision ?? 10);\n nextValue = Math.round(nextValue * scaleFactor) / scaleFactor;\n return precision ? nextValue.toFixed(precision) : nextValue.toString();\n}\nfunction countDecimalPlaces(value) {\n if (!Number.isFinite(value))\n return 0;\n let e = 1;\n let p = 0;\n while (Math.round(value * e) / e !== value) {\n e *= 10;\n p += 1;\n }\n return p;\n}\nfunction valueToPercent(value, min, max) {\n return (value - min) * 100 / (max - min);\n}\nfunction percentToValue(percent, min, max) {\n return (max - min) * percent + min;\n}\nfunction roundValueToStep(value, from, step) {\n const nextValue = Math.round((value - from) / step) * step + from;\n const precision = countDecimalPlaces(step);\n return toPrecision(nextValue, precision);\n}\nfunction clampValue(value, min, max) {\n if (value == null)\n return value;\n if (max < min) {\n console.warn(\"clamp: max cannot be less than min\");\n }\n return Math.min(Math.max(value, min), max);\n}\nexport {\n clampValue,\n countDecimalPlaces,\n percentToValue,\n roundValueToStep,\n toPrecision,\n valueToPercent\n};\n","// src/use-counter.ts\nimport { useCallbackRef } from \"@chakra-ui/react-use-callback-ref\";\nimport {\n clampValue,\n countDecimalPlaces,\n toPrecision\n} from \"@chakra-ui/number-utils\";\nimport { useCallback, useState } from \"react\";\nfunction useCounter(props = {}) {\n const {\n onChange,\n precision: precisionProp,\n defaultValue,\n value: valueProp,\n step: stepProp = 1,\n min = Number.MIN_SAFE_INTEGER,\n max = Number.MAX_SAFE_INTEGER,\n keepWithinRange = true\n } = props;\n const onChangeProp = useCallbackRef(onChange);\n const [valueState, setValue] = useState(() => {\n if (defaultValue == null)\n return \"\";\n return cast(defaultValue, stepProp, precisionProp) ?? \"\";\n });\n const isControlled = typeof valueProp !== \"undefined\";\n const value = isControlled ? valueProp : valueState;\n const decimalPlaces = getDecimalPlaces(parse(value), stepProp);\n const precision = precisionProp ?? decimalPlaces;\n const update = useCallback((next) => {\n if (next === value)\n return;\n if (!isControlled) {\n setValue(next.toString());\n }\n onChangeProp == null ? void 0 : onChangeProp(next.toString(), parse(next));\n }, [onChangeProp, isControlled, value]);\n const clamp = useCallback((value2) => {\n let nextValue = value2;\n if (keepWithinRange) {\n nextValue = clampValue(nextValue, min, max);\n }\n return toPrecision(nextValue, precision);\n }, [precision, keepWithinRange, max, min]);\n const increment = useCallback((step = stepProp) => {\n let next;\n if (value === \"\") {\n next = parse(step);\n } else {\n next = parse(value) + step;\n }\n next = clamp(next);\n update(next);\n }, [clamp, stepProp, update, value]);\n const decrement = useCallback((step = stepProp) => {\n let next;\n if (value === \"\") {\n next = parse(-step);\n } else {\n next = parse(value) - step;\n }\n next = clamp(next);\n update(next);\n }, [clamp, stepProp, update, value]);\n const reset = useCallback(() => {\n let next;\n if (defaultValue == null) {\n next = \"\";\n } else {\n next = cast(defaultValue, stepProp, precisionProp) ?? min;\n }\n update(next);\n }, [defaultValue, precisionProp, stepProp, update, min]);\n const castValue = useCallback((value2) => {\n const nextValue = cast(value2, stepProp, precision) ?? min;\n update(nextValue);\n }, [precision, stepProp, update, min]);\n const valueAsNumber = parse(value);\n const isOutOfRange = valueAsNumber > max || valueAsNumber < min;\n const isAtMax = valueAsNumber === max;\n const isAtMin = valueAsNumber === min;\n return {\n isOutOfRange,\n isAtMax,\n isAtMin,\n precision,\n value,\n valueAsNumber,\n update,\n reset,\n increment,\n decrement,\n clamp,\n cast: castValue,\n setValue\n };\n}\nfunction parse(value) {\n return parseFloat(value.toString().replace(/[^\\w.-]+/g, \"\"));\n}\nfunction getDecimalPlaces(value, step) {\n return Math.max(countDecimalPlaces(step), countDecimalPlaces(value));\n}\nfunction cast(value, step, precision) {\n const parsedValue = parse(value);\n if (Number.isNaN(parsedValue))\n return void 0;\n const decimalPlaces = getDecimalPlaces(parsedValue, step);\n return toPrecision(parsedValue, precision ?? decimalPlaces);\n}\nexport {\n useCounter\n};\n","// src/index.ts\nimport { useCallback, useEffect, useRef } from \"react\";\nfunction useCallbackRef(callback, deps = []) {\n const callbackRef = useRef(callback);\n useEffect(() => {\n callbackRef.current = callback;\n });\n return useCallback((...args) => {\n var _a;\n return (_a = callbackRef.current) == null ? void 0 : _a.call(callbackRef, ...args);\n }, deps);\n}\nexport {\n useCallbackRef\n};\n","// src/index.ts\nimport { useEffect } from \"react\";\nimport { useCallbackRef } from \"@chakra-ui/react-use-callback-ref\";\nfunction useEventListener(target, event, handler, options) {\n const listener = useCallbackRef(handler);\n useEffect(() => {\n const node = typeof target === \"function\" ? target() : target ?? document;\n if (!handler || !node)\n return;\n node.addEventListener(event, listener, options);\n return () => {\n node.removeEventListener(event, listener, options);\n };\n }, [event, target, options, listener, handler]);\n return () => {\n const node = typeof target === \"function\" ? target() : target ?? document;\n node == null ? void 0 : node.removeEventListener(event, listener, options);\n };\n}\nexport {\n useEventListener\n};\n","// src/index.ts\nimport {\n createContext as createReactContext,\n useContext as useReactContext\n} from \"react\";\nfunction getErrorMessage(hook, provider) {\n return `${hook} returned \\`undefined\\`. Seems you forgot to wrap component within ${provider}`;\n}\nfunction createContext(options = {}) {\n const {\n name,\n strict = true,\n hookName = \"useContext\",\n providerName = \"Provider\",\n errorMessage\n } = options;\n const Context = createReactContext(void 0);\n Context.displayName = name;\n function useContext() {\n var _a;\n const context = useReactContext(Context);\n if (!context && strict) {\n const error = new Error(errorMessage ?? getErrorMessage(hookName, providerName));\n error.name = \"ContextError\";\n (_a = Error.captureStackTrace) == null ? void 0 : _a.call(Error, error, useContext);\n throw error;\n }\n return context;\n }\n return [Context.Provider, useContext, Context];\n}\nexport {\n createContext\n};\n","// src/index.ts\nimport { useMemo } from \"react\";\nfunction assignRef(ref, value) {\n if (ref == null)\n return;\n if (typeof ref === \"function\") {\n ref(value);\n return;\n }\n try {\n ref.current = value;\n } catch (error) {\n throw new Error(`Cannot assign value '${value}' to ref '${ref}'`);\n }\n}\nfunction mergeRefs(...refs) {\n return (node) => {\n refs.forEach((ref) => {\n assignRef(ref, node);\n });\n };\n}\nfunction useMergeRefs(...refs) {\n return useMemo(() => mergeRefs(...refs), refs);\n}\nexport {\n assignRef,\n mergeRefs,\n useMergeRefs\n};\n","// src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nfunction isDev() {\n return process.env.NODE_ENV !== \"production\";\n}\nfunction isObject(value) {\n const type = typeof value;\n return value != null && (type === \"object\" || type === \"function\") && !Array.isArray(value);\n}\nvar warn = (options) => {\n const { condition, message } = options;\n if (condition && isDev()) {\n console.warn(message);\n }\n};\nfunction runIfFn(valueOrFn, ...args) {\n return isFunction(valueOrFn) ? valueOrFn(...args) : valueOrFn;\n}\nvar isFunction = (value) => typeof value === \"function\";\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\nfunction callAll(...fns) {\n return function mergedFn(arg) {\n fns.forEach((fn) => {\n fn == null ? void 0 : fn(arg);\n });\n };\n}\nexport {\n ariaAttr,\n callAll,\n callAllHandlers,\n cx,\n dataAttr,\n isObject,\n runIfFn,\n warn\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/icon.tsx\nimport {\n chakra,\n forwardRef\n} from \"@chakra-ui/system\";\nimport { cx } from \"@chakra-ui/shared-utils\";\nvar fallbackIcon = {\n path: /* @__PURE__ */ React.createElement(\"g\", {\n stroke: \"currentColor\",\n strokeWidth: \"1.5\"\n }, /* @__PURE__ */ React.createElement(\"path\", {\n strokeLinecap: \"round\",\n fill: \"none\",\n d: \"M9,9a3,3,0,1,1,4,2.829,1.5,1.5,0,0,0-1,1.415V14.25\"\n }), /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n strokeLinecap: \"round\",\n d: \"M12,17.25a.375.375,0,1,0,.375.375A.375.375,0,0,0,12,17.25h0\"\n }), /* @__PURE__ */ React.createElement(\"circle\", {\n fill: \"none\",\n strokeMiterlimit: \"10\",\n cx: \"12\",\n cy: \"12\",\n r: \"11.25\"\n })),\n viewBox: \"0 0 24 24\"\n};\nvar Icon = forwardRef((props, ref) => {\n const {\n as: element,\n viewBox,\n color = \"currentColor\",\n focusable = false,\n children,\n className,\n __css,\n ...rest\n } = props;\n const _className = cx(\"chakra-icon\", className);\n const styles = {\n w: \"1em\",\n h: \"1em\",\n display: \"inline-block\",\n lineHeight: \"1em\",\n flexShrink: 0,\n color,\n ...__css\n };\n const shared = {\n ref,\n focusable,\n className: _className,\n __css: styles\n };\n const _viewBox = viewBox ?? fallbackIcon.viewBox;\n if (element && typeof element !== \"string\") {\n return /* @__PURE__ */ React.createElement(chakra.svg, {\n as: element,\n ...shared,\n ...rest\n });\n }\n const _path = children ?? fallbackIcon.path;\n return /* @__PURE__ */ React.createElement(chakra.svg, {\n verticalAlign: \"middle\",\n viewBox: _viewBox,\n ...shared,\n ...rest\n }, _path);\n});\nIcon.displayName = \"Icon\";\nvar icon_default = Icon;\n\n// src/create-icon.tsx\nimport { forwardRef as forwardRef2 } from \"@chakra-ui/system\";\nimport { Children } from \"react\";\nfunction createIcon(options) {\n const {\n viewBox = \"0 0 24 24\",\n d: pathDefinition,\n displayName,\n defaultProps = {}\n } = options;\n const path = Children.toArray(options.path);\n const Comp = forwardRef2((props, ref) => /* @__PURE__ */ React.createElement(Icon, {\n ref,\n viewBox,\n ...defaultProps,\n ...props\n }, path.length ? path : /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: pathDefinition\n })));\n Comp.displayName = displayName;\n return Comp;\n}\nexport {\n Icon,\n createIcon,\n icon_default as default\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/form-control.tsx\nimport { createContext } from \"@chakra-ui/react-context\";\nimport { mergeRefs } from \"@chakra-ui/react-use-merge-refs\";\nimport {\n chakra,\n forwardRef,\n omitThemingProps,\n useMultiStyleConfig\n} from \"@chakra-ui/system\";\n\n// ../../utilities/shared-utils/src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\n\n// src/form-control.tsx\nimport { useCallback, useId, useState } from \"react\";\nvar [FormControlStylesProvider, useFormControlStyles] = createContext({\n name: `FormControlStylesContext`,\n errorMessage: `useFormControlStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar [FormControlProvider, useFormControlContext] = createContext({\n strict: false,\n name: \"FormControlContext\"\n});\nfunction useFormControlProvider(props) {\n const {\n id: idProp,\n isRequired,\n isInvalid,\n isDisabled,\n isReadOnly,\n ...htmlProps\n } = props;\n const uuid = useId();\n const id = idProp || `field-${uuid}`;\n const labelId = `${id}-label`;\n const feedbackId = `${id}-feedback`;\n const helpTextId = `${id}-helptext`;\n const [hasFeedbackText, setHasFeedbackText] = useState(false);\n const [hasHelpText, setHasHelpText] = useState(false);\n const [isFocused, setFocus] = useState(false);\n const getHelpTextProps = useCallback((props2 = {}, forwardedRef = null) => ({\n id: helpTextId,\n ...props2,\n ref: mergeRefs(forwardedRef, (node) => {\n if (!node)\n return;\n setHasHelpText(true);\n })\n }), [helpTextId]);\n const getLabelProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ref: forwardedRef,\n \"data-focus\": dataAttr(isFocused),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-readonly\": dataAttr(isReadOnly),\n id: props2.id ?? labelId,\n htmlFor: props2.htmlFor ?? id\n }), [id, isDisabled, isFocused, isInvalid, isReadOnly, labelId]);\n const getErrorMessageProps = useCallback((props2 = {}, forwardedRef = null) => ({\n id: feedbackId,\n ...props2,\n ref: mergeRefs(forwardedRef, (node) => {\n if (!node)\n return;\n setHasFeedbackText(true);\n }),\n \"aria-live\": \"polite\"\n }), [feedbackId]);\n const getRootProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ...htmlProps,\n ref: forwardedRef,\n role: \"group\"\n }), [htmlProps]);\n const getRequiredIndicatorProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ref: forwardedRef,\n role: \"presentation\",\n \"aria-hidden\": true,\n children: props2.children || \"*\"\n }), []);\n return {\n isRequired: !!isRequired,\n isInvalid: !!isInvalid,\n isReadOnly: !!isReadOnly,\n isDisabled: !!isDisabled,\n isFocused: !!isFocused,\n onFocus: () => setFocus(true),\n onBlur: () => setFocus(false),\n hasFeedbackText,\n setHasFeedbackText,\n hasHelpText,\n setHasHelpText,\n id,\n labelId,\n feedbackId,\n helpTextId,\n htmlProps,\n getHelpTextProps,\n getErrorMessageProps,\n getRootProps,\n getLabelProps,\n getRequiredIndicatorProps\n };\n}\nvar FormControl = forwardRef(function FormControl2(props, ref) {\n const styles = useMultiStyleConfig(\"Form\", props);\n const ownProps = omitThemingProps(props);\n const {\n getRootProps,\n htmlProps: _,\n ...context\n } = useFormControlProvider(ownProps);\n const className = cx(\"chakra-form-control\", props.className);\n return /* @__PURE__ */ React.createElement(FormControlProvider, {\n value: context\n }, /* @__PURE__ */ React.createElement(FormControlStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra.div, {\n ...getRootProps({}, ref),\n className,\n __css: styles[\"container\"]\n })));\n});\nFormControl.displayName = \"FormControl\";\nvar FormHelperText = forwardRef(function FormHelperText2(props, ref) {\n const field = useFormControlContext();\n const styles = useFormControlStyles();\n const className = cx(\"chakra-form__helper-text\", props.className);\n return /* @__PURE__ */ React.createElement(chakra.div, {\n ...field == null ? void 0 : field.getHelpTextProps(props, ref),\n __css: styles.helperText,\n className\n });\n});\nFormHelperText.displayName = \"FormHelperText\";\n\n// src/use-form-control.ts\nfunction useFormControl(props) {\n const { isDisabled, isInvalid, isReadOnly, isRequired, ...rest } = useFormControlProps(props);\n return {\n ...rest,\n disabled: isDisabled,\n readOnly: isReadOnly,\n required: isRequired,\n \"aria-invalid\": ariaAttr(isInvalid),\n \"aria-required\": ariaAttr(isRequired),\n \"aria-readonly\": ariaAttr(isReadOnly)\n };\n}\nfunction useFormControlProps(props) {\n const field = useFormControlContext();\n const {\n id,\n disabled,\n readOnly,\n required,\n isRequired,\n isInvalid,\n isReadOnly,\n isDisabled,\n onFocus,\n onBlur,\n ...rest\n } = props;\n const labelIds = props[\"aria-describedby\"] ? [props[\"aria-describedby\"]] : [];\n if ((field == null ? void 0 : field.hasFeedbackText) && (field == null ? void 0 : field.isInvalid)) {\n labelIds.push(field.feedbackId);\n }\n if (field == null ? void 0 : field.hasHelpText) {\n labelIds.push(field.helpTextId);\n }\n return {\n ...rest,\n \"aria-describedby\": labelIds.join(\" \") || void 0,\n id: id ?? (field == null ? void 0 : field.id),\n isDisabled: disabled ?? isDisabled ?? (field == null ? void 0 : field.isDisabled),\n isReadOnly: readOnly ?? isReadOnly ?? (field == null ? void 0 : field.isReadOnly),\n isRequired: required ?? isRequired ?? (field == null ? void 0 : field.isRequired),\n isInvalid: isInvalid ?? (field == null ? void 0 : field.isInvalid),\n onFocus: callAllHandlers(field == null ? void 0 : field.onFocus, onFocus),\n onBlur: callAllHandlers(field == null ? void 0 : field.onBlur, onBlur)\n };\n}\n\n// src/form-error.tsx\nimport { Icon } from \"@chakra-ui/icon\";\nimport { createContext as createContext2 } from \"@chakra-ui/react-context\";\nimport {\n chakra as chakra2,\n forwardRef as forwardRef2,\n omitThemingProps as omitThemingProps2,\n useMultiStyleConfig as useMultiStyleConfig2\n} from \"@chakra-ui/system\";\nvar [FormErrorStylesProvider, useFormErrorStyles] = createContext2({\n name: `FormErrorStylesContext`,\n errorMessage: `useFormErrorStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar FormErrorMessage = forwardRef2((props, ref) => {\n const styles = useMultiStyleConfig2(\"FormError\", props);\n const ownProps = omitThemingProps2(props);\n const field = useFormControlContext();\n if (!(field == null ? void 0 : field.isInvalid))\n return null;\n return /* @__PURE__ */ React.createElement(FormErrorStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra2.div, {\n ...field == null ? void 0 : field.getErrorMessageProps(ownProps, ref),\n className: cx(\"chakra-form__error-message\", props.className),\n __css: {\n display: \"flex\",\n alignItems: \"center\",\n ...styles.text\n }\n }));\n});\nFormErrorMessage.displayName = \"FormErrorMessage\";\nvar FormErrorIcon = forwardRef2((props, ref) => {\n const styles = useFormErrorStyles();\n const field = useFormControlContext();\n if (!(field == null ? void 0 : field.isInvalid))\n return null;\n const _className = cx(\"chakra-form__error-icon\", props.className);\n return /* @__PURE__ */ React.createElement(Icon, {\n ref,\n \"aria-hidden\": true,\n ...props,\n __css: styles.icon,\n className: _className\n }, /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: \"M11.983,0a12.206,12.206,0,0,0-8.51,3.653A11.8,11.8,0,0,0,0,12.207,11.779,11.779,0,0,0,11.8,24h.214A12.111,12.111,0,0,0,24,11.791h0A11.766,11.766,0,0,0,11.983,0ZM10.5,16.542a1.476,1.476,0,0,1,1.449-1.53h.027a1.527,1.527,0,0,1,1.523,1.47,1.475,1.475,0,0,1-1.449,1.53h-.027A1.529,1.529,0,0,1,10.5,16.542ZM11,12.5v-6a1,1,0,0,1,2,0v6a1,1,0,1,1-2,0Z\"\n }));\n});\nFormErrorIcon.displayName = \"FormErrorIcon\";\n\n// src/form-label.tsx\nimport {\n chakra as chakra3,\n forwardRef as forwardRef3,\n omitThemingProps as omitThemingProps3,\n useStyleConfig\n} from \"@chakra-ui/system\";\nvar FormLabel = forwardRef3(function FormLabel2(passedProps, ref) {\n const styles = useStyleConfig(\"FormLabel\", passedProps);\n const props = omitThemingProps3(passedProps);\n const {\n className,\n children,\n requiredIndicator = /* @__PURE__ */ React.createElement(RequiredIndicator, null),\n optionalIndicator = null,\n ...rest\n } = props;\n const field = useFormControlContext();\n const ownProps = (field == null ? void 0 : field.getLabelProps(rest, ref)) ?? { ref, ...rest };\n return /* @__PURE__ */ React.createElement(chakra3.label, {\n ...ownProps,\n className: cx(\"chakra-form__label\", props.className),\n __css: {\n display: \"block\",\n textAlign: \"start\",\n ...styles\n }\n }, children, (field == null ? void 0 : field.isRequired) ? requiredIndicator : optionalIndicator);\n});\nFormLabel.displayName = \"FormLabel\";\nvar RequiredIndicator = forwardRef3(function RequiredIndicator2(props, ref) {\n const field = useFormControlContext();\n const styles = useFormControlStyles();\n if (!(field == null ? void 0 : field.isRequired))\n return null;\n const className = cx(\"chakra-form__required-indicator\", props.className);\n return /* @__PURE__ */ React.createElement(chakra3.span, {\n ...field == null ? void 0 : field.getRequiredIndicatorProps(props, ref),\n __css: styles.requiredIndicator,\n className\n });\n});\nRequiredIndicator.displayName = \"RequiredIndicator\";\nexport {\n FormControl,\n FormErrorIcon,\n FormErrorMessage,\n FormHelperText,\n FormLabel,\n RequiredIndicator,\n useFormControl,\n useFormControlContext,\n useFormControlProps,\n useFormControlStyles,\n useFormErrorStyles\n};\n","// src/index.ts\nimport { Children, isValidElement } from \"react\";\nfunction getValidChildren(children) {\n return Children.toArray(children).filter((child) => isValidElement(child));\n}\nexport {\n getValidChildren\n};\n","// src/index.ts\nfunction compact(object) {\n const clone = Object.assign({}, object);\n for (let key in clone) {\n if (clone[key] === void 0)\n delete clone[key];\n }\n return clone;\n}\nfunction omit(object, keysToOmit = []) {\n const clone = Object.assign({}, object);\n for (const key of keysToOmit) {\n if (key in clone)\n delete clone[key];\n }\n return clone;\n}\nfunction pick(object, keysToPick) {\n const result = {};\n for (const key of keysToPick) {\n if (key in object) {\n result[key] = object[key];\n }\n }\n return result;\n}\nfunction split(object, keys) {\n const picked = {};\n const omitted = {};\n for (const [key, value] of Object.entries(object)) {\n if (keys.includes(key))\n picked[key] = value;\n else\n omitted[key] = value;\n }\n return [picked, omitted];\n}\nexport {\n compact,\n omit,\n pick,\n split\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/input.tsx\nimport { useFormControl } from \"@chakra-ui/form-control\";\nimport {\n chakra,\n forwardRef,\n omitThemingProps,\n useMultiStyleConfig\n} from \"@chakra-ui/system\";\nimport { cx } from \"@chakra-ui/shared-utils\";\nvar Input = forwardRef(function Input2(props, ref) {\n const { htmlSize, ...rest } = props;\n const styles = useMultiStyleConfig(\"Input\", rest);\n const ownProps = omitThemingProps(rest);\n const input = useFormControl(ownProps);\n const _className = cx(\"chakra-input\", props.className);\n return /* @__PURE__ */ React.createElement(chakra.input, {\n size: htmlSize,\n ...input,\n __css: styles.field,\n ref,\n className: _className\n });\n});\nInput.displayName = \"Input\";\nInput.id = \"Input\";\n\n// src/input-addon.tsx\nimport { chakra as chakra3, forwardRef as forwardRef3 } from \"@chakra-ui/system\";\nimport { cx as cx3 } from \"@chakra-ui/shared-utils\";\n\n// src/input-group.tsx\nimport { createContext } from \"@chakra-ui/react-context\";\nimport { getValidChildren } from \"@chakra-ui/react-children-utils\";\nimport {\n chakra as chakra2,\n forwardRef as forwardRef2,\n omitThemingProps as omitThemingProps2,\n useMultiStyleConfig as useMultiStyleConfig2\n} from \"@chakra-ui/system\";\nimport { cx as cx2 } from \"@chakra-ui/shared-utils\";\nimport { compact } from \"@chakra-ui/object-utils\";\nimport { cloneElement } from \"react\";\nvar [InputGroupStylesProvider, useInputGroupStyles] = createContext({\n name: `InputGroupStylesContext`,\n errorMessage: `useInputGroupStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar InputGroup = forwardRef2(function InputGroup2(props, ref) {\n const styles = useMultiStyleConfig2(\"Input\", props);\n const { children, className, ...rest } = omitThemingProps2(props);\n const _className = cx2(\"chakra-input__group\", className);\n const groupStyles = {};\n const validChildren = getValidChildren(children);\n const input = styles.field;\n validChildren.forEach((child) => {\n if (!styles)\n return;\n if (input && child.type.id === \"InputLeftElement\") {\n groupStyles.paddingStart = input.height ?? input.h;\n }\n if (input && child.type.id === \"InputRightElement\") {\n groupStyles.paddingEnd = input.height ?? input.h;\n }\n if (child.type.id === \"InputRightAddon\") {\n groupStyles.borderEndRadius = 0;\n }\n if (child.type.id === \"InputLeftAddon\") {\n groupStyles.borderStartRadius = 0;\n }\n });\n const clones = validChildren.map((child) => {\n var _a, _b;\n const theming = compact({\n size: ((_a = child.props) == null ? void 0 : _a.size) || props.size,\n variant: ((_b = child.props) == null ? void 0 : _b.variant) || props.variant\n });\n return child.type.id !== \"Input\" ? cloneElement(child, theming) : cloneElement(child, Object.assign(theming, groupStyles, child.props));\n });\n return /* @__PURE__ */ React.createElement(chakra2.div, {\n className: _className,\n ref,\n __css: {\n width: \"100%\",\n display: \"flex\",\n position: \"relative\"\n },\n ...rest\n }, /* @__PURE__ */ React.createElement(InputGroupStylesProvider, {\n value: styles\n }, clones));\n});\nInputGroup.displayName = \"InputGroup\";\n\n// src/input-addon.tsx\nvar placements = {\n left: {\n marginEnd: \"-1px\",\n borderEndRadius: 0,\n borderEndColor: \"transparent\"\n },\n right: {\n marginStart: \"-1px\",\n borderStartRadius: 0,\n borderStartColor: \"transparent\"\n }\n};\nvar StyledAddon = chakra3(\"div\", {\n baseStyle: {\n flex: \"0 0 auto\",\n width: \"auto\",\n display: \"flex\",\n alignItems: \"center\",\n whiteSpace: \"nowrap\"\n }\n});\nvar InputAddon = forwardRef3(function InputAddon2(props, ref) {\n const { placement = \"left\", ...rest } = props;\n const placementStyles = placements[placement] ?? {};\n const styles = useInputGroupStyles();\n return /* @__PURE__ */ React.createElement(StyledAddon, {\n ref,\n ...rest,\n __css: {\n ...styles.addon,\n ...placementStyles\n }\n });\n});\nInputAddon.displayName = \"InputAddon\";\nvar InputLeftAddon = forwardRef3(function InputLeftAddon2(props, ref) {\n return /* @__PURE__ */ React.createElement(InputAddon, {\n ref,\n placement: \"left\",\n ...props,\n className: cx3(\"chakra-input__left-addon\", props.className)\n });\n});\nInputLeftAddon.displayName = \"InputLeftAddon\";\nInputLeftAddon.id = \"InputLeftAddon\";\nvar InputRightAddon = forwardRef3(function InputRightAddon2(props, ref) {\n return /* @__PURE__ */ React.createElement(InputAddon, {\n ref,\n placement: \"right\",\n ...props,\n className: cx3(\"chakra-input__right-addon\", props.className)\n });\n});\nInputRightAddon.displayName = \"InputRightAddon\";\nInputRightAddon.id = \"InputRightAddon\";\n\n// src/input-element.tsx\nimport {\n chakra as chakra4,\n forwardRef as forwardRef4\n} from \"@chakra-ui/system\";\nimport { cx as cx4 } from \"@chakra-ui/shared-utils\";\nvar StyledInputElement = chakra4(\"div\", {\n baseStyle: {\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n position: \"absolute\",\n top: \"0\",\n zIndex: 2\n }\n});\nvar InputElement = forwardRef4(function InputElement2(props, ref) {\n const { placement = \"left\", ...rest } = props;\n const styles = useInputGroupStyles();\n const input = styles.field;\n const attr = placement === \"left\" ? \"insetStart\" : \"insetEnd\";\n const elementStyles = {\n [attr]: \"0\",\n width: (input == null ? void 0 : input.height) ?? (input == null ? void 0 : input.h),\n height: (input == null ? void 0 : input.height) ?? (input == null ? void 0 : input.h),\n fontSize: input == null ? void 0 : input.fontSize,\n ...styles.element\n };\n return /* @__PURE__ */ React.createElement(StyledInputElement, {\n ref,\n __css: elementStyles,\n ...rest\n });\n});\nInputElement.id = \"InputElement\";\nInputElement.displayName = \"InputElement\";\nvar InputLeftElement = forwardRef4(function InputLeftElement2(props, ref) {\n const { className, ...rest } = props;\n const _className = cx4(\"chakra-input__left-element\", className);\n return /* @__PURE__ */ React.createElement(InputElement, {\n ref,\n placement: \"left\",\n className: _className,\n ...rest\n });\n});\nInputLeftElement.id = \"InputLeftElement\";\nInputLeftElement.displayName = \"InputLeftElement\";\nvar InputRightElement = forwardRef4(function InputRightElement2(props, ref) {\n const { className, ...rest } = props;\n const _className = cx4(\"chakra-input__right-element\", className);\n return /* @__PURE__ */ React.createElement(InputElement, {\n ref,\n placement: \"right\",\n className: _className,\n ...rest\n });\n});\nInputRightElement.id = \"InputRightElement\";\nInputRightElement.displayName = \"InputRightElement\";\nexport {\n Input,\n InputAddon,\n InputGroup,\n InputLeftAddon,\n InputLeftElement,\n InputRightAddon,\n InputRightElement,\n useInputGroupStyles\n};\n","// src/index.ts\nimport {\n createContext as createReactContext,\n useContext as useReactContext\n} from \"react\";\nfunction getErrorMessage(hook, provider) {\n return `${hook} returned \\`undefined\\`. Seems you forgot to wrap component within ${provider}`;\n}\nfunction createContext(options = {}) {\n const {\n name,\n strict = true,\n hookName = \"useContext\",\n providerName = \"Provider\",\n errorMessage\n } = options;\n const Context = createReactContext(void 0);\n Context.displayName = name;\n function useContext() {\n var _a;\n const context = useReactContext(Context);\n if (!context && strict) {\n const error = new Error(errorMessage ?? getErrorMessage(hookName, providerName));\n error.name = \"ContextError\";\n (_a = Error.captureStackTrace) == null ? void 0 : _a.call(Error, error, useContext);\n throw error;\n }\n return context;\n }\n return [Context.Provider, useContext, Context];\n}\nexport {\n createContext\n};\n","// src/index.ts\nimport { useMemo } from \"react\";\nfunction assignRef(ref, value) {\n if (ref == null)\n return;\n if (typeof ref === \"function\") {\n ref(value);\n return;\n }\n try {\n ref.current = value;\n } catch (error) {\n throw new Error(`Cannot assign value '${value}' to ref '${ref}'`);\n }\n}\nfunction mergeRefs(...refs) {\n return (node) => {\n refs.forEach((ref) => {\n assignRef(ref, node);\n });\n };\n}\nfunction useMergeRefs(...refs) {\n return useMemo(() => mergeRefs(...refs), refs);\n}\nexport {\n assignRef,\n mergeRefs,\n useMergeRefs\n};\n","// src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nfunction isDev() {\n return process.env.NODE_ENV !== \"production\";\n}\nfunction isObject(value) {\n const type = typeof value;\n return value != null && (type === \"object\" || type === \"function\") && !Array.isArray(value);\n}\nvar warn = (options) => {\n const { condition, message } = options;\n if (condition && isDev()) {\n console.warn(message);\n }\n};\nfunction runIfFn(valueOrFn, ...args) {\n return isFunction(valueOrFn) ? valueOrFn(...args) : valueOrFn;\n}\nvar isFunction = (value) => typeof value === \"function\";\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\nfunction callAll(...fns) {\n return function mergedFn(arg) {\n fns.forEach((fn) => {\n fn == null ? void 0 : fn(arg);\n });\n };\n}\nexport {\n ariaAttr,\n callAll,\n callAllHandlers,\n cx,\n dataAttr,\n isObject,\n runIfFn,\n warn\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/icon.tsx\nimport {\n chakra,\n forwardRef\n} from \"@chakra-ui/system\";\nimport { cx } from \"@chakra-ui/shared-utils\";\nvar fallbackIcon = {\n path: /* @__PURE__ */ React.createElement(\"g\", {\n stroke: \"currentColor\",\n strokeWidth: \"1.5\"\n }, /* @__PURE__ */ React.createElement(\"path\", {\n strokeLinecap: \"round\",\n fill: \"none\",\n d: \"M9,9a3,3,0,1,1,4,2.829,1.5,1.5,0,0,0-1,1.415V14.25\"\n }), /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n strokeLinecap: \"round\",\n d: \"M12,17.25a.375.375,0,1,0,.375.375A.375.375,0,0,0,12,17.25h0\"\n }), /* @__PURE__ */ React.createElement(\"circle\", {\n fill: \"none\",\n strokeMiterlimit: \"10\",\n cx: \"12\",\n cy: \"12\",\n r: \"11.25\"\n })),\n viewBox: \"0 0 24 24\"\n};\nvar Icon = forwardRef((props, ref) => {\n const {\n as: element,\n viewBox,\n color = \"currentColor\",\n focusable = false,\n children,\n className,\n __css,\n ...rest\n } = props;\n const _className = cx(\"chakra-icon\", className);\n const styles = {\n w: \"1em\",\n h: \"1em\",\n display: \"inline-block\",\n lineHeight: \"1em\",\n flexShrink: 0,\n color,\n ...__css\n };\n const shared = {\n ref,\n focusable,\n className: _className,\n __css: styles\n };\n const _viewBox = viewBox ?? fallbackIcon.viewBox;\n if (element && typeof element !== \"string\") {\n return /* @__PURE__ */ React.createElement(chakra.svg, {\n as: element,\n ...shared,\n ...rest\n });\n }\n const _path = children ?? fallbackIcon.path;\n return /* @__PURE__ */ React.createElement(chakra.svg, {\n verticalAlign: \"middle\",\n viewBox: _viewBox,\n ...shared,\n ...rest\n }, _path);\n});\nIcon.displayName = \"Icon\";\nvar icon_default = Icon;\n\n// src/create-icon.tsx\nimport { forwardRef as forwardRef2 } from \"@chakra-ui/system\";\nimport { Children } from \"react\";\nfunction createIcon(options) {\n const {\n viewBox = \"0 0 24 24\",\n d: pathDefinition,\n displayName,\n defaultProps = {}\n } = options;\n const path = Children.toArray(options.path);\n const Comp = forwardRef2((props, ref) => /* @__PURE__ */ React.createElement(Icon, {\n ref,\n viewBox,\n ...defaultProps,\n ...props\n }, path.length ? path : /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: pathDefinition\n })));\n Comp.displayName = displayName;\n return Comp;\n}\nexport {\n Icon,\n createIcon,\n icon_default as default\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/form-control.tsx\nimport { createContext } from \"@chakra-ui/react-context\";\nimport { mergeRefs } from \"@chakra-ui/react-use-merge-refs\";\nimport {\n chakra,\n forwardRef,\n omitThemingProps,\n useMultiStyleConfig\n} from \"@chakra-ui/system\";\n\n// ../../utilities/shared-utils/src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\n\n// src/form-control.tsx\nimport { useCallback, useId, useState } from \"react\";\nvar [FormControlStylesProvider, useFormControlStyles] = createContext({\n name: `FormControlStylesContext`,\n errorMessage: `useFormControlStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar [FormControlProvider, useFormControlContext] = createContext({\n strict: false,\n name: \"FormControlContext\"\n});\nfunction useFormControlProvider(props) {\n const {\n id: idProp,\n isRequired,\n isInvalid,\n isDisabled,\n isReadOnly,\n ...htmlProps\n } = props;\n const uuid = useId();\n const id = idProp || `field-${uuid}`;\n const labelId = `${id}-label`;\n const feedbackId = `${id}-feedback`;\n const helpTextId = `${id}-helptext`;\n const [hasFeedbackText, setHasFeedbackText] = useState(false);\n const [hasHelpText, setHasHelpText] = useState(false);\n const [isFocused, setFocus] = useState(false);\n const getHelpTextProps = useCallback((props2 = {}, forwardedRef = null) => ({\n id: helpTextId,\n ...props2,\n ref: mergeRefs(forwardedRef, (node) => {\n if (!node)\n return;\n setHasHelpText(true);\n })\n }), [helpTextId]);\n const getLabelProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ref: forwardedRef,\n \"data-focus\": dataAttr(isFocused),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-readonly\": dataAttr(isReadOnly),\n id: props2.id ?? labelId,\n htmlFor: props2.htmlFor ?? id\n }), [id, isDisabled, isFocused, isInvalid, isReadOnly, labelId]);\n const getErrorMessageProps = useCallback((props2 = {}, forwardedRef = null) => ({\n id: feedbackId,\n ...props2,\n ref: mergeRefs(forwardedRef, (node) => {\n if (!node)\n return;\n setHasFeedbackText(true);\n }),\n \"aria-live\": \"polite\"\n }), [feedbackId]);\n const getRootProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ...htmlProps,\n ref: forwardedRef,\n role: \"group\"\n }), [htmlProps]);\n const getRequiredIndicatorProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ref: forwardedRef,\n role: \"presentation\",\n \"aria-hidden\": true,\n children: props2.children || \"*\"\n }), []);\n return {\n isRequired: !!isRequired,\n isInvalid: !!isInvalid,\n isReadOnly: !!isReadOnly,\n isDisabled: !!isDisabled,\n isFocused: !!isFocused,\n onFocus: () => setFocus(true),\n onBlur: () => setFocus(false),\n hasFeedbackText,\n setHasFeedbackText,\n hasHelpText,\n setHasHelpText,\n id,\n labelId,\n feedbackId,\n helpTextId,\n htmlProps,\n getHelpTextProps,\n getErrorMessageProps,\n getRootProps,\n getLabelProps,\n getRequiredIndicatorProps\n };\n}\nvar FormControl = forwardRef(function FormControl2(props, ref) {\n const styles = useMultiStyleConfig(\"Form\", props);\n const ownProps = omitThemingProps(props);\n const {\n getRootProps,\n htmlProps: _,\n ...context\n } = useFormControlProvider(ownProps);\n const className = cx(\"chakra-form-control\", props.className);\n return /* @__PURE__ */ React.createElement(FormControlProvider, {\n value: context\n }, /* @__PURE__ */ React.createElement(FormControlStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra.div, {\n ...getRootProps({}, ref),\n className,\n __css: styles[\"container\"]\n })));\n});\nFormControl.displayName = \"FormControl\";\nvar FormHelperText = forwardRef(function FormHelperText2(props, ref) {\n const field = useFormControlContext();\n const styles = useFormControlStyles();\n const className = cx(\"chakra-form__helper-text\", props.className);\n return /* @__PURE__ */ React.createElement(chakra.div, {\n ...field == null ? void 0 : field.getHelpTextProps(props, ref),\n __css: styles.helperText,\n className\n });\n});\nFormHelperText.displayName = \"FormHelperText\";\n\n// src/use-form-control.ts\nfunction useFormControl(props) {\n const { isDisabled, isInvalid, isReadOnly, isRequired, ...rest } = useFormControlProps(props);\n return {\n ...rest,\n disabled: isDisabled,\n readOnly: isReadOnly,\n required: isRequired,\n \"aria-invalid\": ariaAttr(isInvalid),\n \"aria-required\": ariaAttr(isRequired),\n \"aria-readonly\": ariaAttr(isReadOnly)\n };\n}\nfunction useFormControlProps(props) {\n const field = useFormControlContext();\n const {\n id,\n disabled,\n readOnly,\n required,\n isRequired,\n isInvalid,\n isReadOnly,\n isDisabled,\n onFocus,\n onBlur,\n ...rest\n } = props;\n const labelIds = props[\"aria-describedby\"] ? [props[\"aria-describedby\"]] : [];\n if ((field == null ? void 0 : field.hasFeedbackText) && (field == null ? void 0 : field.isInvalid)) {\n labelIds.push(field.feedbackId);\n }\n if (field == null ? void 0 : field.hasHelpText) {\n labelIds.push(field.helpTextId);\n }\n return {\n ...rest,\n \"aria-describedby\": labelIds.join(\" \") || void 0,\n id: id ?? (field == null ? void 0 : field.id),\n isDisabled: disabled ?? isDisabled ?? (field == null ? void 0 : field.isDisabled),\n isReadOnly: readOnly ?? isReadOnly ?? (field == null ? void 0 : field.isReadOnly),\n isRequired: required ?? isRequired ?? (field == null ? void 0 : field.isRequired),\n isInvalid: isInvalid ?? (field == null ? void 0 : field.isInvalid),\n onFocus: callAllHandlers(field == null ? void 0 : field.onFocus, onFocus),\n onBlur: callAllHandlers(field == null ? void 0 : field.onBlur, onBlur)\n };\n}\n\n// src/form-error.tsx\nimport { Icon } from \"@chakra-ui/icon\";\nimport { createContext as createContext2 } from \"@chakra-ui/react-context\";\nimport {\n chakra as chakra2,\n forwardRef as forwardRef2,\n omitThemingProps as omitThemingProps2,\n useMultiStyleConfig as useMultiStyleConfig2\n} from \"@chakra-ui/system\";\nvar [FormErrorStylesProvider, useFormErrorStyles] = createContext2({\n name: `FormErrorStylesContext`,\n errorMessage: `useFormErrorStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar FormErrorMessage = forwardRef2((props, ref) => {\n const styles = useMultiStyleConfig2(\"FormError\", props);\n const ownProps = omitThemingProps2(props);\n const field = useFormControlContext();\n if (!(field == null ? void 0 : field.isInvalid))\n return null;\n return /* @__PURE__ */ React.createElement(FormErrorStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra2.div, {\n ...field == null ? void 0 : field.getErrorMessageProps(ownProps, ref),\n className: cx(\"chakra-form__error-message\", props.className),\n __css: {\n display: \"flex\",\n alignItems: \"center\",\n ...styles.text\n }\n }));\n});\nFormErrorMessage.displayName = \"FormErrorMessage\";\nvar FormErrorIcon = forwardRef2((props, ref) => {\n const styles = useFormErrorStyles();\n const field = useFormControlContext();\n if (!(field == null ? void 0 : field.isInvalid))\n return null;\n const _className = cx(\"chakra-form__error-icon\", props.className);\n return /* @__PURE__ */ React.createElement(Icon, {\n ref,\n \"aria-hidden\": true,\n ...props,\n __css: styles.icon,\n className: _className\n }, /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: \"M11.983,0a12.206,12.206,0,0,0-8.51,3.653A11.8,11.8,0,0,0,0,12.207,11.779,11.779,0,0,0,11.8,24h.214A12.111,12.111,0,0,0,24,11.791h0A11.766,11.766,0,0,0,11.983,0ZM10.5,16.542a1.476,1.476,0,0,1,1.449-1.53h.027a1.527,1.527,0,0,1,1.523,1.47,1.475,1.475,0,0,1-1.449,1.53h-.027A1.529,1.529,0,0,1,10.5,16.542ZM11,12.5v-6a1,1,0,0,1,2,0v6a1,1,0,1,1-2,0Z\"\n }));\n});\nFormErrorIcon.displayName = \"FormErrorIcon\";\n\n// src/form-label.tsx\nimport {\n chakra as chakra3,\n forwardRef as forwardRef3,\n omitThemingProps as omitThemingProps3,\n useStyleConfig\n} from \"@chakra-ui/system\";\nvar FormLabel = forwardRef3(function FormLabel2(passedProps, ref) {\n const styles = useStyleConfig(\"FormLabel\", passedProps);\n const props = omitThemingProps3(passedProps);\n const {\n className,\n children,\n requiredIndicator = /* @__PURE__ */ React.createElement(RequiredIndicator, null),\n optionalIndicator = null,\n ...rest\n } = props;\n const field = useFormControlContext();\n const ownProps = (field == null ? void 0 : field.getLabelProps(rest, ref)) ?? { ref, ...rest };\n return /* @__PURE__ */ React.createElement(chakra3.label, {\n ...ownProps,\n className: cx(\"chakra-form__label\", props.className),\n __css: {\n display: \"block\",\n textAlign: \"start\",\n ...styles\n }\n }, children, (field == null ? void 0 : field.isRequired) ? requiredIndicator : optionalIndicator);\n});\nFormLabel.displayName = \"FormLabel\";\nvar RequiredIndicator = forwardRef3(function RequiredIndicator2(props, ref) {\n const field = useFormControlContext();\n const styles = useFormControlStyles();\n if (!(field == null ? void 0 : field.isRequired))\n return null;\n const className = cx(\"chakra-form__required-indicator\", props.className);\n return /* @__PURE__ */ React.createElement(chakra3.span, {\n ...field == null ? void 0 : field.getRequiredIndicatorProps(props, ref),\n __css: styles.requiredIndicator,\n className\n });\n});\nRequiredIndicator.displayName = \"RequiredIndicator\";\nexport {\n FormControl,\n FormErrorIcon,\n FormErrorMessage,\n FormHelperText,\n FormLabel,\n RequiredIndicator,\n useFormControl,\n useFormControlContext,\n useFormControlProps,\n useFormControlStyles,\n useFormErrorStyles\n};\n","// src/index.ts\nimport { useEffect, useRef } from \"react\";\nfunction useUpdateEffect(callback, deps) {\n const renderCycleRef = useRef(false);\n const effectCycleRef = useRef(false);\n useEffect(() => {\n const mounted = renderCycleRef.current;\n const run = mounted && effectCycleRef.current;\n if (run) {\n return callback();\n }\n effectCycleRef.current = true;\n }, deps);\n useEffect(() => {\n renderCycleRef.current = true;\n return () => {\n renderCycleRef.current = false;\n };\n }, []);\n}\nexport {\n useUpdateEffect\n};\n","// src/index.ts\nimport { useEffect, useLayoutEffect } from \"react\";\nvar useSafeLayoutEffect = Boolean(globalThis == null ? void 0 : globalThis.document) ? useLayoutEffect : useEffect;\nexport {\n useSafeLayoutEffect\n};\n","// src/index.ts\nimport { useCallback, useEffect, useRef } from \"react\";\nfunction useCallbackRef(callback, deps = []) {\n const callbackRef = useRef(callback);\n useEffect(() => {\n callbackRef.current = callback;\n });\n return useCallback((...args) => {\n var _a;\n return (_a = callbackRef.current) == null ? void 0 : _a.call(callbackRef, ...args);\n }, deps);\n}\nexport {\n useCallbackRef\n};\n","// src/index.ts\nimport { useCallback, useEffect, useRef } from \"react\";\nfunction useCallbackRef(callback, deps = []) {\n const callbackRef = useRef(callback);\n useEffect(() => {\n callbackRef.current = callback;\n });\n return useCallback((...args) => {\n var _a;\n return (_a = callbackRef.current) == null ? void 0 : _a.call(callbackRef, ...args);\n }, deps);\n}\nexport {\n useCallbackRef\n};\n","// src/index.ts\nimport { useEffect } from \"react\";\nimport { useCallbackRef } from \"@chakra-ui/react-use-callback-ref\";\nfunction useInterval(callback, delay) {\n const fn = useCallbackRef(callback);\n useEffect(() => {\n let intervalId = null;\n const tick = () => fn();\n if (delay !== null) {\n intervalId = window.setInterval(tick, delay);\n }\n return () => {\n if (intervalId) {\n window.clearInterval(intervalId);\n }\n };\n }, [delay, fn]);\n}\nexport {\n useInterval\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/number-input.tsx\nimport { useFormControlProps } from \"@chakra-ui/form-control\";\nimport { createContext } from \"@chakra-ui/react-context\";\nimport {\n chakra,\n forwardRef,\n omitThemingProps,\n useMultiStyleConfig\n} from \"@chakra-ui/system\";\n\n// ../../utilities/shared-utils/src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\n\n// src/number-input.tsx\nimport { useMemo as useMemo2 } from \"react\";\n\n// src/icons.tsx\nimport { Icon } from \"@chakra-ui/icon\";\nvar TriangleDownIcon = (props) => /* @__PURE__ */ React.createElement(Icon, {\n viewBox: \"0 0 24 24\",\n ...props\n}, /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: \"M21,5H3C2.621,5,2.275,5.214,2.105,5.553C1.937,5.892,1.973,6.297,2.2,6.6l9,12 c0.188,0.252,0.485,0.4,0.8,0.4s0.611-0.148,0.8-0.4l9-12c0.228-0.303,0.264-0.708,0.095-1.047C21.725,5.214,21.379,5,21,5z\"\n}));\nvar TriangleUpIcon = (props) => /* @__PURE__ */ React.createElement(Icon, {\n viewBox: \"0 0 24 24\",\n ...props\n}, /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: \"M12.8,5.4c-0.377-0.504-1.223-0.504-1.6,0l-9,12c-0.228,0.303-0.264,0.708-0.095,1.047 C2.275,18.786,2.621,19,3,19h18c0.379,0,0.725-0.214,0.895-0.553c0.169-0.339,0.133-0.744-0.095-1.047L12.8,5.4z\"\n}));\n\n// src/use-number-input.ts\nimport { useCounter } from \"@chakra-ui/counter\";\nimport { useEventListener } from \"@chakra-ui/react-use-event-listener\";\nimport { useUpdateEffect } from \"@chakra-ui/react-use-update-effect\";\nimport { useSafeLayoutEffect } from \"@chakra-ui/react-use-safe-layout-effect\";\nimport { useCallbackRef } from \"@chakra-ui/react-use-callback-ref\";\nimport { mergeRefs } from \"@chakra-ui/react-use-merge-refs\";\nimport { useCallback as useCallback2, useMemo, useRef as useRef2, useState as useState2 } from \"react\";\n\n// src/use-attr-observer.ts\nimport { useEffect } from \"react\";\nfunction useAttributeObserver(ref, attributes, fn, enabled) {\n useEffect(() => {\n if (!ref.current || !enabled)\n return;\n const win = ref.current.ownerDocument.defaultView ?? window;\n const attrs = Array.isArray(attributes) ? attributes : [attributes];\n const obs = new win.MutationObserver((changes) => {\n for (const change of changes) {\n if (change.type === \"attributes\" && change.attributeName && attrs.includes(change.attributeName)) {\n fn(change);\n }\n }\n });\n obs.observe(ref.current, { attributes: true, attributeFilter: attrs });\n return () => obs.disconnect();\n });\n}\n\n// src/use-spinner.ts\nimport { useInterval } from \"@chakra-ui/react-use-interval\";\nimport { useCallback, useEffect as useEffect2, useRef, useState } from \"react\";\nvar CONTINUOUS_CHANGE_INTERVAL = 50;\nvar CONTINUOUS_CHANGE_DELAY = 300;\nfunction useSpinner(increment, decrement) {\n const [isSpinning, setIsSpinning] = useState(false);\n const [action, setAction] = useState(null);\n const [runOnce, setRunOnce] = useState(true);\n const timeoutRef = useRef(null);\n const removeTimeout = () => clearTimeout(timeoutRef.current);\n useInterval(() => {\n if (action === \"increment\") {\n increment();\n }\n if (action === \"decrement\") {\n decrement();\n }\n }, isSpinning ? CONTINUOUS_CHANGE_INTERVAL : null);\n const up = useCallback(() => {\n if (runOnce) {\n increment();\n }\n timeoutRef.current = setTimeout(() => {\n setRunOnce(false);\n setIsSpinning(true);\n setAction(\"increment\");\n }, CONTINUOUS_CHANGE_DELAY);\n }, [increment, runOnce]);\n const down = useCallback(() => {\n if (runOnce) {\n decrement();\n }\n timeoutRef.current = setTimeout(() => {\n setRunOnce(false);\n setIsSpinning(true);\n setAction(\"decrement\");\n }, CONTINUOUS_CHANGE_DELAY);\n }, [decrement, runOnce]);\n const stop = useCallback(() => {\n setRunOnce(true);\n setIsSpinning(false);\n removeTimeout();\n }, []);\n useEffect2(() => {\n return () => removeTimeout();\n }, []);\n return { up, down, stop, isSpinning };\n}\n\n// src/use-number-input.ts\nvar FLOATING_POINT_REGEX = /^[Ee0-9+\\-.]$/;\nfunction isFloatingPointNumericCharacter(character) {\n return FLOATING_POINT_REGEX.test(character);\n}\nfunction isValidNumericKeyboardEvent(event, isValid) {\n if (event.key == null)\n return true;\n const isModifierKey = event.ctrlKey || event.altKey || event.metaKey;\n const isSingleCharacterKey = event.key.length === 1;\n if (!isSingleCharacterKey || isModifierKey)\n return true;\n return isValid(event.key);\n}\nfunction useNumberInput(props = {}) {\n const {\n focusInputOnChange = true,\n clampValueOnBlur = true,\n keepWithinRange = true,\n min = Number.MIN_SAFE_INTEGER,\n max = Number.MAX_SAFE_INTEGER,\n step: stepProp = 1,\n isReadOnly,\n isDisabled,\n isRequired,\n isInvalid,\n pattern = \"[0-9]*(.[0-9]+)?\",\n inputMode = \"decimal\",\n allowMouseWheel,\n id,\n onChange: _,\n precision,\n name,\n \"aria-describedby\": ariaDescBy,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n onFocus: onFocusProp,\n onBlur: onBlurProp,\n onInvalid: onInvalidProp,\n getAriaValueText: getAriaValueTextProp,\n isValidCharacter: isValidCharacterProp,\n format: formatValue,\n parse: parseValue,\n ...htmlProps\n } = props;\n const onFocus = useCallbackRef(onFocusProp);\n const onBlur = useCallbackRef(onBlurProp);\n const onInvalid = useCallbackRef(onInvalidProp);\n const isValidCharacter = useCallbackRef(isValidCharacterProp ?? isFloatingPointNumericCharacter);\n const getAriaValueText = useCallbackRef(getAriaValueTextProp);\n const counter = useCounter(props);\n const {\n update: updateFn,\n increment: incrementFn,\n decrement: decrementFn\n } = counter;\n const [isFocused, setFocused] = useState2(false);\n const isInteractive = !(isReadOnly || isDisabled);\n const inputRef = useRef2(null);\n const inputSelectionRef = useRef2(null);\n const incrementButtonRef = useRef2(null);\n const decrementButtonRef = useRef2(null);\n const sanitize = useCallback2((value) => value.split(\"\").filter(isValidCharacter).join(\"\"), [isValidCharacter]);\n const parse = useCallback2((value) => (parseValue == null ? void 0 : parseValue(value)) ?? value, [parseValue]);\n const format = useCallback2((value) => ((formatValue == null ? void 0 : formatValue(value)) ?? value).toString(), [formatValue]);\n useUpdateEffect(() => {\n if (counter.valueAsNumber > max) {\n onInvalid == null ? void 0 : onInvalid(\"rangeOverflow\", format(counter.value), counter.valueAsNumber);\n } else if (counter.valueAsNumber < min) {\n onInvalid == null ? void 0 : onInvalid(\"rangeOverflow\", format(counter.value), counter.valueAsNumber);\n }\n }, [counter.valueAsNumber, counter.value, format, onInvalid]);\n useSafeLayoutEffect(() => {\n if (!inputRef.current)\n return;\n const notInSync = inputRef.current.value != counter.value;\n if (notInSync) {\n const parsedInput = parse(inputRef.current.value);\n counter.setValue(sanitize(parsedInput));\n }\n }, [parse, sanitize]);\n const increment = useCallback2((step = stepProp) => {\n if (isInteractive) {\n incrementFn(step);\n }\n }, [incrementFn, isInteractive, stepProp]);\n const decrement = useCallback2((step = stepProp) => {\n if (isInteractive) {\n decrementFn(step);\n }\n }, [decrementFn, isInteractive, stepProp]);\n const spinner = useSpinner(increment, decrement);\n useAttributeObserver(incrementButtonRef, \"disabled\", spinner.stop, spinner.isSpinning);\n useAttributeObserver(decrementButtonRef, \"disabled\", spinner.stop, spinner.isSpinning);\n const onChange = useCallback2((event) => {\n const evt = event.nativeEvent;\n if (evt.isComposing)\n return;\n const parsedInput = parse(event.currentTarget.value);\n updateFn(sanitize(parsedInput));\n inputSelectionRef.current = {\n start: event.currentTarget.selectionStart,\n end: event.currentTarget.selectionEnd\n };\n }, [updateFn, sanitize, parse]);\n const _onFocus = useCallback2((event) => {\n var _a;\n onFocus == null ? void 0 : onFocus(event);\n if (!inputSelectionRef.current)\n return;\n event.target.selectionStart = inputSelectionRef.current.start ?? ((_a = event.currentTarget.value) == null ? void 0 : _a.length);\n event.currentTarget.selectionEnd = inputSelectionRef.current.end ?? event.currentTarget.selectionStart;\n }, [onFocus]);\n const onKeyDown = useCallback2((event) => {\n if (event.nativeEvent.isComposing)\n return;\n if (!isValidNumericKeyboardEvent(event, isValidCharacter)) {\n event.preventDefault();\n }\n const stepFactor = getStepFactor(event) * stepProp;\n const eventKey = event.key;\n const keyMap = {\n ArrowUp: () => increment(stepFactor),\n ArrowDown: () => decrement(stepFactor),\n Home: () => updateFn(min),\n End: () => updateFn(max)\n };\n const action = keyMap[eventKey];\n if (action) {\n event.preventDefault();\n action(event);\n }\n }, [isValidCharacter, stepProp, increment, decrement, updateFn, min, max]);\n const getStepFactor = (event) => {\n let ratio = 1;\n if (event.metaKey || event.ctrlKey) {\n ratio = 0.1;\n }\n if (event.shiftKey) {\n ratio = 10;\n }\n return ratio;\n };\n const ariaValueText = useMemo(() => {\n const text = getAriaValueText == null ? void 0 : getAriaValueText(counter.value);\n if (text != null)\n return text;\n const defaultText = counter.value.toString();\n return !defaultText ? void 0 : defaultText;\n }, [counter.value, getAriaValueText]);\n const validateAndClamp = useCallback2(() => {\n let next = counter.value;\n if (counter.value === \"\")\n return;\n const valueStartsWithE = /^[eE]/.test(counter.value.toString());\n if (valueStartsWithE) {\n counter.setValue(\"\");\n } else {\n if (counter.valueAsNumber < min) {\n next = min;\n }\n if (counter.valueAsNumber > max) {\n next = max;\n }\n counter.cast(next);\n }\n }, [counter, max, min]);\n const onInputBlur = useCallback2(() => {\n setFocused(false);\n if (clampValueOnBlur) {\n validateAndClamp();\n }\n }, [clampValueOnBlur, setFocused, validateAndClamp]);\n const focusInput = useCallback2(() => {\n if (focusInputOnChange) {\n requestAnimationFrame(() => {\n var _a;\n (_a = inputRef.current) == null ? void 0 : _a.focus();\n });\n }\n }, [focusInputOnChange]);\n const spinUp = useCallback2((event) => {\n event.preventDefault();\n spinner.up();\n focusInput();\n }, [focusInput, spinner]);\n const spinDown = useCallback2((event) => {\n event.preventDefault();\n spinner.down();\n focusInput();\n }, [focusInput, spinner]);\n useEventListener(() => inputRef.current, \"wheel\", (event) => {\n var _a;\n const doc = ((_a = inputRef.current) == null ? void 0 : _a.ownerDocument) ?? document;\n const isInputFocused = doc.activeElement === inputRef.current;\n if (!allowMouseWheel || !isInputFocused)\n return;\n event.preventDefault();\n const stepFactor = getStepFactor(event) * stepProp;\n const direction = Math.sign(event.deltaY);\n if (direction === -1) {\n increment(stepFactor);\n } else if (direction === 1) {\n decrement(stepFactor);\n }\n }, { passive: false });\n const getIncrementButtonProps = useCallback2((props2 = {}, ref = null) => {\n const disabled = isDisabled || keepWithinRange && counter.isAtMax;\n return {\n ...props2,\n ref: mergeRefs(ref, incrementButtonRef),\n role: \"button\",\n tabIndex: -1,\n onPointerDown: callAllHandlers(props2.onPointerDown, (event) => {\n if (event.button !== 0 || disabled)\n return;\n spinUp(event);\n }),\n onPointerLeave: callAllHandlers(props2.onPointerLeave, spinner.stop),\n onPointerUp: callAllHandlers(props2.onPointerUp, spinner.stop),\n disabled,\n \"aria-disabled\": ariaAttr(disabled)\n };\n }, [counter.isAtMax, keepWithinRange, spinUp, spinner.stop, isDisabled]);\n const getDecrementButtonProps = useCallback2((props2 = {}, ref = null) => {\n const disabled = isDisabled || keepWithinRange && counter.isAtMin;\n return {\n ...props2,\n ref: mergeRefs(ref, decrementButtonRef),\n role: \"button\",\n tabIndex: -1,\n onPointerDown: callAllHandlers(props2.onPointerDown, (event) => {\n if (event.button !== 0 || disabled)\n return;\n spinDown(event);\n }),\n onPointerLeave: callAllHandlers(props2.onPointerLeave, spinner.stop),\n onPointerUp: callAllHandlers(props2.onPointerUp, spinner.stop),\n disabled,\n \"aria-disabled\": ariaAttr(disabled)\n };\n }, [counter.isAtMin, keepWithinRange, spinDown, spinner.stop, isDisabled]);\n const getInputProps = useCallback2((props2 = {}, ref = null) => ({\n name,\n inputMode,\n type: \"text\",\n pattern,\n \"aria-labelledby\": ariaLabelledBy,\n \"aria-label\": ariaLabel,\n \"aria-describedby\": ariaDescBy,\n id,\n disabled: isDisabled,\n ...props2,\n readOnly: props2.readOnly ?? isReadOnly,\n \"aria-readonly\": props2.readOnly ?? isReadOnly,\n \"aria-required\": props2.required ?? isRequired,\n required: props2.required ?? isRequired,\n ref: mergeRefs(inputRef, ref),\n value: format(counter.value),\n role: \"spinbutton\",\n \"aria-valuemin\": min,\n \"aria-valuemax\": max,\n \"aria-valuenow\": Number.isNaN(counter.valueAsNumber) ? void 0 : counter.valueAsNumber,\n \"aria-invalid\": ariaAttr(isInvalid ?? counter.isOutOfRange),\n \"aria-valuetext\": ariaValueText,\n autoComplete: \"off\",\n autoCorrect: \"off\",\n onChange: callAllHandlers(props2.onChange, onChange),\n onKeyDown: callAllHandlers(props2.onKeyDown, onKeyDown),\n onFocus: callAllHandlers(props2.onFocus, _onFocus, () => setFocused(true)),\n onBlur: callAllHandlers(props2.onBlur, onBlur, onInputBlur)\n }), [\n name,\n inputMode,\n pattern,\n ariaLabelledBy,\n ariaLabel,\n format,\n ariaDescBy,\n id,\n isDisabled,\n isRequired,\n isReadOnly,\n isInvalid,\n counter.value,\n counter.valueAsNumber,\n counter.isOutOfRange,\n min,\n max,\n ariaValueText,\n onChange,\n onKeyDown,\n _onFocus,\n onBlur,\n onInputBlur\n ]);\n return {\n value: format(counter.value),\n valueAsNumber: counter.valueAsNumber,\n isFocused,\n isDisabled,\n isReadOnly,\n getIncrementButtonProps,\n getDecrementButtonProps,\n getInputProps,\n htmlProps\n };\n}\n\n// src/number-input.tsx\nvar [NumberInputStylesProvider, useNumberInputStyles] = createContext({\n name: `NumberInputStylesContext`,\n errorMessage: `useNumberInputStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar [NumberInputProvider, useNumberInputContext] = createContext({\n name: \"NumberInputContext\",\n errorMessage: \"useNumberInputContext: `context` is undefined. Seems you forgot to wrap number-input's components within \"\n});\nvar NumberInput = forwardRef(function NumberInput2(props, ref) {\n const styles = useMultiStyleConfig(\"NumberInput\", props);\n const ownProps = omitThemingProps(props);\n const controlProps = useFormControlProps(ownProps);\n const { htmlProps, ...context } = useNumberInput(controlProps);\n const ctx = useMemo2(() => context, [context]);\n return /* @__PURE__ */ React.createElement(NumberInputProvider, {\n value: ctx\n }, /* @__PURE__ */ React.createElement(NumberInputStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra.div, {\n ...htmlProps,\n ref,\n className: cx(\"chakra-numberinput\", props.className),\n __css: {\n position: \"relative\",\n zIndex: 0,\n ...styles.root\n }\n })));\n});\nNumberInput.displayName = \"NumberInput\";\nvar NumberInputStepper = forwardRef(function NumberInputStepper2(props, ref) {\n const styles = useNumberInputStyles();\n return /* @__PURE__ */ React.createElement(chakra.div, {\n \"aria-hidden\": true,\n ref,\n ...props,\n __css: {\n display: \"flex\",\n flexDirection: \"column\",\n position: \"absolute\",\n top: \"0\",\n insetEnd: \"0px\",\n margin: \"1px\",\n height: \"calc(100% - 2px)\",\n zIndex: 1,\n ...styles.stepperGroup\n }\n });\n});\nNumberInputStepper.displayName = \"NumberInputStepper\";\nvar NumberInputField = forwardRef(function NumberInputField2(props, ref) {\n const { getInputProps } = useNumberInputContext();\n const input = getInputProps(props, ref);\n const styles = useNumberInputStyles();\n return /* @__PURE__ */ React.createElement(chakra.input, {\n ...input,\n className: cx(\"chakra-numberinput__field\", props.className),\n __css: {\n width: \"100%\",\n ...styles.field\n }\n });\n});\nNumberInputField.displayName = \"NumberInputField\";\nvar StyledStepper = chakra(\"div\", {\n baseStyle: {\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n flex: 1,\n transitionProperty: \"common\",\n transitionDuration: \"normal\",\n userSelect: \"none\",\n cursor: \"pointer\",\n lineHeight: \"normal\"\n }\n});\nvar NumberDecrementStepper = forwardRef(function NumberDecrementStepper2(props, ref) {\n const styles = useNumberInputStyles();\n const { getDecrementButtonProps } = useNumberInputContext();\n const decrement = getDecrementButtonProps(props, ref);\n return /* @__PURE__ */ React.createElement(StyledStepper, {\n ...decrement,\n __css: styles.stepper\n }, props.children ?? /* @__PURE__ */ React.createElement(TriangleDownIcon, null));\n});\nNumberDecrementStepper.displayName = \"NumberDecrementStepper\";\nvar NumberIncrementStepper = forwardRef(function NumberIncrementStepper2(props, ref) {\n const { getIncrementButtonProps } = useNumberInputContext();\n const increment = getIncrementButtonProps(props, ref);\n const styles = useNumberInputStyles();\n return /* @__PURE__ */ React.createElement(StyledStepper, {\n ...increment,\n __css: styles.stepper\n }, props.children ?? /* @__PURE__ */ React.createElement(TriangleUpIcon, null));\n});\nNumberIncrementStepper.displayName = \"NumberIncrementStepper\";\nexport {\n NumberDecrementStepper,\n NumberIncrementStepper,\n NumberInput,\n NumberInputField,\n NumberInputStepper,\n StyledStepper,\n useNumberInput,\n useNumberInputStyles\n};\n","// src/index.ts\nimport {\n createContext as createReactContext,\n useContext as useReactContext\n} from \"react\";\nfunction getErrorMessage(hook, provider) {\n return `${hook} returned \\`undefined\\`. Seems you forgot to wrap component within ${provider}`;\n}\nfunction createContext(options = {}) {\n const {\n name,\n strict = true,\n hookName = \"useContext\",\n providerName = \"Provider\",\n errorMessage\n } = options;\n const Context = createReactContext(void 0);\n Context.displayName = name;\n function useContext() {\n var _a;\n const context = useReactContext(Context);\n if (!context && strict) {\n const error = new Error(errorMessage ?? getErrorMessage(hookName, providerName));\n error.name = \"ContextError\";\n (_a = Error.captureStackTrace) == null ? void 0 : _a.call(Error, error, useContext);\n throw error;\n }\n return context;\n }\n return [Context.Provider, useContext, Context];\n}\nexport {\n createContext\n};\n","// src/index.ts\nimport { useMemo } from \"react\";\nfunction assignRef(ref, value) {\n if (ref == null)\n return;\n if (typeof ref === \"function\") {\n ref(value);\n return;\n }\n try {\n ref.current = value;\n } catch (error) {\n throw new Error(`Cannot assign value '${value}' to ref '${ref}'`);\n }\n}\nfunction mergeRefs(...refs) {\n return (node) => {\n refs.forEach((ref) => {\n assignRef(ref, node);\n });\n };\n}\nfunction useMergeRefs(...refs) {\n return useMemo(() => mergeRefs(...refs), refs);\n}\nexport {\n assignRef,\n mergeRefs,\n useMergeRefs\n};\n","// src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nfunction isDev() {\n return process.env.NODE_ENV !== \"production\";\n}\nfunction isObject(value) {\n const type = typeof value;\n return value != null && (type === \"object\" || type === \"function\") && !Array.isArray(value);\n}\nvar warn = (options) => {\n const { condition, message } = options;\n if (condition && isDev()) {\n console.warn(message);\n }\n};\nfunction runIfFn(valueOrFn, ...args) {\n return isFunction(valueOrFn) ? valueOrFn(...args) : valueOrFn;\n}\nvar isFunction = (value) => typeof value === \"function\";\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\nfunction callAll(...fns) {\n return function mergedFn(arg) {\n fns.forEach((fn) => {\n fn == null ? void 0 : fn(arg);\n });\n };\n}\nexport {\n ariaAttr,\n callAll,\n callAllHandlers,\n cx,\n dataAttr,\n isObject,\n runIfFn,\n warn\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/icon.tsx\nimport {\n chakra,\n forwardRef\n} from \"@chakra-ui/system\";\nimport { cx } from \"@chakra-ui/shared-utils\";\nvar fallbackIcon = {\n path: /* @__PURE__ */ React.createElement(\"g\", {\n stroke: \"currentColor\",\n strokeWidth: \"1.5\"\n }, /* @__PURE__ */ React.createElement(\"path\", {\n strokeLinecap: \"round\",\n fill: \"none\",\n d: \"M9,9a3,3,0,1,1,4,2.829,1.5,1.5,0,0,0-1,1.415V14.25\"\n }), /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n strokeLinecap: \"round\",\n d: \"M12,17.25a.375.375,0,1,0,.375.375A.375.375,0,0,0,12,17.25h0\"\n }), /* @__PURE__ */ React.createElement(\"circle\", {\n fill: \"none\",\n strokeMiterlimit: \"10\",\n cx: \"12\",\n cy: \"12\",\n r: \"11.25\"\n })),\n viewBox: \"0 0 24 24\"\n};\nvar Icon = forwardRef((props, ref) => {\n const {\n as: element,\n viewBox,\n color = \"currentColor\",\n focusable = false,\n children,\n className,\n __css,\n ...rest\n } = props;\n const _className = cx(\"chakra-icon\", className);\n const styles = {\n w: \"1em\",\n h: \"1em\",\n display: \"inline-block\",\n lineHeight: \"1em\",\n flexShrink: 0,\n color,\n ...__css\n };\n const shared = {\n ref,\n focusable,\n className: _className,\n __css: styles\n };\n const _viewBox = viewBox ?? fallbackIcon.viewBox;\n if (element && typeof element !== \"string\") {\n return /* @__PURE__ */ React.createElement(chakra.svg, {\n as: element,\n ...shared,\n ...rest\n });\n }\n const _path = children ?? fallbackIcon.path;\n return /* @__PURE__ */ React.createElement(chakra.svg, {\n verticalAlign: \"middle\",\n viewBox: _viewBox,\n ...shared,\n ...rest\n }, _path);\n});\nIcon.displayName = \"Icon\";\nvar icon_default = Icon;\n\n// src/create-icon.tsx\nimport { forwardRef as forwardRef2 } from \"@chakra-ui/system\";\nimport { Children } from \"react\";\nfunction createIcon(options) {\n const {\n viewBox = \"0 0 24 24\",\n d: pathDefinition,\n displayName,\n defaultProps = {}\n } = options;\n const path = Children.toArray(options.path);\n const Comp = forwardRef2((props, ref) => /* @__PURE__ */ React.createElement(Icon, {\n ref,\n viewBox,\n ...defaultProps,\n ...props\n }, path.length ? path : /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: pathDefinition\n })));\n Comp.displayName = displayName;\n return Comp;\n}\nexport {\n Icon,\n createIcon,\n icon_default as default\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/form-control.tsx\nimport { createContext } from \"@chakra-ui/react-context\";\nimport { mergeRefs } from \"@chakra-ui/react-use-merge-refs\";\nimport {\n chakra,\n forwardRef,\n omitThemingProps,\n useMultiStyleConfig\n} from \"@chakra-ui/system\";\n\n// ../../utilities/shared-utils/src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\n\n// src/form-control.tsx\nimport { useCallback, useId, useState } from \"react\";\nvar [FormControlStylesProvider, useFormControlStyles] = createContext({\n name: `FormControlStylesContext`,\n errorMessage: `useFormControlStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar [FormControlProvider, useFormControlContext] = createContext({\n strict: false,\n name: \"FormControlContext\"\n});\nfunction useFormControlProvider(props) {\n const {\n id: idProp,\n isRequired,\n isInvalid,\n isDisabled,\n isReadOnly,\n ...htmlProps\n } = props;\n const uuid = useId();\n const id = idProp || `field-${uuid}`;\n const labelId = `${id}-label`;\n const feedbackId = `${id}-feedback`;\n const helpTextId = `${id}-helptext`;\n const [hasFeedbackText, setHasFeedbackText] = useState(false);\n const [hasHelpText, setHasHelpText] = useState(false);\n const [isFocused, setFocus] = useState(false);\n const getHelpTextProps = useCallback((props2 = {}, forwardedRef = null) => ({\n id: helpTextId,\n ...props2,\n ref: mergeRefs(forwardedRef, (node) => {\n if (!node)\n return;\n setHasHelpText(true);\n })\n }), [helpTextId]);\n const getLabelProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ref: forwardedRef,\n \"data-focus\": dataAttr(isFocused),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-readonly\": dataAttr(isReadOnly),\n id: props2.id ?? labelId,\n htmlFor: props2.htmlFor ?? id\n }), [id, isDisabled, isFocused, isInvalid, isReadOnly, labelId]);\n const getErrorMessageProps = useCallback((props2 = {}, forwardedRef = null) => ({\n id: feedbackId,\n ...props2,\n ref: mergeRefs(forwardedRef, (node) => {\n if (!node)\n return;\n setHasFeedbackText(true);\n }),\n \"aria-live\": \"polite\"\n }), [feedbackId]);\n const getRootProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ...htmlProps,\n ref: forwardedRef,\n role: \"group\"\n }), [htmlProps]);\n const getRequiredIndicatorProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ref: forwardedRef,\n role: \"presentation\",\n \"aria-hidden\": true,\n children: props2.children || \"*\"\n }), []);\n return {\n isRequired: !!isRequired,\n isInvalid: !!isInvalid,\n isReadOnly: !!isReadOnly,\n isDisabled: !!isDisabled,\n isFocused: !!isFocused,\n onFocus: () => setFocus(true),\n onBlur: () => setFocus(false),\n hasFeedbackText,\n setHasFeedbackText,\n hasHelpText,\n setHasHelpText,\n id,\n labelId,\n feedbackId,\n helpTextId,\n htmlProps,\n getHelpTextProps,\n getErrorMessageProps,\n getRootProps,\n getLabelProps,\n getRequiredIndicatorProps\n };\n}\nvar FormControl = forwardRef(function FormControl2(props, ref) {\n const styles = useMultiStyleConfig(\"Form\", props);\n const ownProps = omitThemingProps(props);\n const {\n getRootProps,\n htmlProps: _,\n ...context\n } = useFormControlProvider(ownProps);\n const className = cx(\"chakra-form-control\", props.className);\n return /* @__PURE__ */ React.createElement(FormControlProvider, {\n value: context\n }, /* @__PURE__ */ React.createElement(FormControlStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra.div, {\n ...getRootProps({}, ref),\n className,\n __css: styles[\"container\"]\n })));\n});\nFormControl.displayName = \"FormControl\";\nvar FormHelperText = forwardRef(function FormHelperText2(props, ref) {\n const field = useFormControlContext();\n const styles = useFormControlStyles();\n const className = cx(\"chakra-form__helper-text\", props.className);\n return /* @__PURE__ */ React.createElement(chakra.div, {\n ...field == null ? void 0 : field.getHelpTextProps(props, ref),\n __css: styles.helperText,\n className\n });\n});\nFormHelperText.displayName = \"FormHelperText\";\n\n// src/use-form-control.ts\nfunction useFormControl(props) {\n const { isDisabled, isInvalid, isReadOnly, isRequired, ...rest } = useFormControlProps(props);\n return {\n ...rest,\n disabled: isDisabled,\n readOnly: isReadOnly,\n required: isRequired,\n \"aria-invalid\": ariaAttr(isInvalid),\n \"aria-required\": ariaAttr(isRequired),\n \"aria-readonly\": ariaAttr(isReadOnly)\n };\n}\nfunction useFormControlProps(props) {\n const field = useFormControlContext();\n const {\n id,\n disabled,\n readOnly,\n required,\n isRequired,\n isInvalid,\n isReadOnly,\n isDisabled,\n onFocus,\n onBlur,\n ...rest\n } = props;\n const labelIds = props[\"aria-describedby\"] ? [props[\"aria-describedby\"]] : [];\n if ((field == null ? void 0 : field.hasFeedbackText) && (field == null ? void 0 : field.isInvalid)) {\n labelIds.push(field.feedbackId);\n }\n if (field == null ? void 0 : field.hasHelpText) {\n labelIds.push(field.helpTextId);\n }\n return {\n ...rest,\n \"aria-describedby\": labelIds.join(\" \") || void 0,\n id: id ?? (field == null ? void 0 : field.id),\n isDisabled: disabled ?? isDisabled ?? (field == null ? void 0 : field.isDisabled),\n isReadOnly: readOnly ?? isReadOnly ?? (field == null ? void 0 : field.isReadOnly),\n isRequired: required ?? isRequired ?? (field == null ? void 0 : field.isRequired),\n isInvalid: isInvalid ?? (field == null ? void 0 : field.isInvalid),\n onFocus: callAllHandlers(field == null ? void 0 : field.onFocus, onFocus),\n onBlur: callAllHandlers(field == null ? void 0 : field.onBlur, onBlur)\n };\n}\n\n// src/form-error.tsx\nimport { Icon } from \"@chakra-ui/icon\";\nimport { createContext as createContext2 } from \"@chakra-ui/react-context\";\nimport {\n chakra as chakra2,\n forwardRef as forwardRef2,\n omitThemingProps as omitThemingProps2,\n useMultiStyleConfig as useMultiStyleConfig2\n} from \"@chakra-ui/system\";\nvar [FormErrorStylesProvider, useFormErrorStyles] = createContext2({\n name: `FormErrorStylesContext`,\n errorMessage: `useFormErrorStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar FormErrorMessage = forwardRef2((props, ref) => {\n const styles = useMultiStyleConfig2(\"FormError\", props);\n const ownProps = omitThemingProps2(props);\n const field = useFormControlContext();\n if (!(field == null ? void 0 : field.isInvalid))\n return null;\n return /* @__PURE__ */ React.createElement(FormErrorStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra2.div, {\n ...field == null ? void 0 : field.getErrorMessageProps(ownProps, ref),\n className: cx(\"chakra-form__error-message\", props.className),\n __css: {\n display: \"flex\",\n alignItems: \"center\",\n ...styles.text\n }\n }));\n});\nFormErrorMessage.displayName = \"FormErrorMessage\";\nvar FormErrorIcon = forwardRef2((props, ref) => {\n const styles = useFormErrorStyles();\n const field = useFormControlContext();\n if (!(field == null ? void 0 : field.isInvalid))\n return null;\n const _className = cx(\"chakra-form__error-icon\", props.className);\n return /* @__PURE__ */ React.createElement(Icon, {\n ref,\n \"aria-hidden\": true,\n ...props,\n __css: styles.icon,\n className: _className\n }, /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: \"M11.983,0a12.206,12.206,0,0,0-8.51,3.653A11.8,11.8,0,0,0,0,12.207,11.779,11.779,0,0,0,11.8,24h.214A12.111,12.111,0,0,0,24,11.791h0A11.766,11.766,0,0,0,11.983,0ZM10.5,16.542a1.476,1.476,0,0,1,1.449-1.53h.027a1.527,1.527,0,0,1,1.523,1.47,1.475,1.475,0,0,1-1.449,1.53h-.027A1.529,1.529,0,0,1,10.5,16.542ZM11,12.5v-6a1,1,0,0,1,2,0v6a1,1,0,1,1-2,0Z\"\n }));\n});\nFormErrorIcon.displayName = \"FormErrorIcon\";\n\n// src/form-label.tsx\nimport {\n chakra as chakra3,\n forwardRef as forwardRef3,\n omitThemingProps as omitThemingProps3,\n useStyleConfig\n} from \"@chakra-ui/system\";\nvar FormLabel = forwardRef3(function FormLabel2(passedProps, ref) {\n const styles = useStyleConfig(\"FormLabel\", passedProps);\n const props = omitThemingProps3(passedProps);\n const {\n className,\n children,\n requiredIndicator = /* @__PURE__ */ React.createElement(RequiredIndicator, null),\n optionalIndicator = null,\n ...rest\n } = props;\n const field = useFormControlContext();\n const ownProps = (field == null ? void 0 : field.getLabelProps(rest, ref)) ?? { ref, ...rest };\n return /* @__PURE__ */ React.createElement(chakra3.label, {\n ...ownProps,\n className: cx(\"chakra-form__label\", props.className),\n __css: {\n display: \"block\",\n textAlign: \"start\",\n ...styles\n }\n }, children, (field == null ? void 0 : field.isRequired) ? requiredIndicator : optionalIndicator);\n});\nFormLabel.displayName = \"FormLabel\";\nvar RequiredIndicator = forwardRef3(function RequiredIndicator2(props, ref) {\n const field = useFormControlContext();\n const styles = useFormControlStyles();\n if (!(field == null ? void 0 : field.isRequired))\n return null;\n const className = cx(\"chakra-form__required-indicator\", props.className);\n return /* @__PURE__ */ React.createElement(chakra3.span, {\n ...field == null ? void 0 : field.getRequiredIndicatorProps(props, ref),\n __css: styles.requiredIndicator,\n className\n });\n});\nRequiredIndicator.displayName = \"RequiredIndicator\";\nexport {\n FormControl,\n FormErrorIcon,\n FormErrorMessage,\n FormHelperText,\n FormLabel,\n RequiredIndicator,\n useFormControl,\n useFormControlContext,\n useFormControlProps,\n useFormControlStyles,\n useFormErrorStyles\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/radio.tsx\nimport {\n chakra as chakra2,\n forwardRef as forwardRef2,\n layoutPropNames,\n omitThemingProps,\n useMultiStyleConfig\n} from \"@chakra-ui/system\";\n\n// ../../utilities/shared-utils/src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nfunction isObject(value) {\n const type = typeof value;\n return value != null && (type === \"object\" || type === \"function\") && !Array.isArray(value);\n}\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\nfunction callAll(...fns) {\n return function mergedFn(arg) {\n fns.forEach((fn) => {\n fn == null ? void 0 : fn(arg);\n });\n };\n}\n\n// ../../utilities/object-utils/src/index.ts\nfunction split(object, keys) {\n const picked = {};\n const omitted = {};\n for (const [key, value] of Object.entries(object)) {\n if (keys.includes(key))\n picked[key] = value;\n else\n omitted[key] = value;\n }\n return [picked, omitted];\n}\n\n// src/radio-group.tsx\nimport {\n chakra,\n forwardRef\n} from \"@chakra-ui/system\";\nimport { createContext } from \"@chakra-ui/react-context\";\n\n// src/use-radio-group.ts\nimport { mergeRefs } from \"@chakra-ui/react-use-merge-refs\";\nimport { useCallback, useRef, useState, useId } from \"react\";\nfunction isInputEvent(value) {\n return value && isObject(value) && isObject(value.target);\n}\nfunction useRadioGroup(props = {}) {\n const {\n onChange: onChangeProp,\n value: valueProp,\n defaultValue,\n name: nameProp,\n isDisabled,\n isFocusable,\n isNative,\n ...htmlProps\n } = props;\n const [valueState, setValue] = useState(defaultValue || \"\");\n const isControlled = typeof valueProp !== \"undefined\";\n const value = isControlled ? valueProp : valueState;\n const ref = useRef(null);\n const focus = useCallback(() => {\n const rootNode = ref.current;\n if (!rootNode)\n return;\n let query = `input:not(:disabled):checked`;\n const firstEnabledAndCheckedInput = rootNode.querySelector(query);\n if (firstEnabledAndCheckedInput) {\n firstEnabledAndCheckedInput.focus();\n return;\n }\n query = `input:not(:disabled)`;\n const firstEnabledInput = rootNode.querySelector(query);\n firstEnabledInput == null ? void 0 : firstEnabledInput.focus();\n }, []);\n const uuid = useId();\n const fallbackName = `radio-${uuid}`;\n const name = nameProp || fallbackName;\n const onChange = useCallback((eventOrValue) => {\n const nextValue = isInputEvent(eventOrValue) ? eventOrValue.target.value : eventOrValue;\n if (!isControlled) {\n setValue(nextValue);\n }\n onChangeProp == null ? void 0 : onChangeProp(String(nextValue));\n }, [onChangeProp, isControlled]);\n const getRootProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ref: mergeRefs(forwardedRef, ref),\n role: \"radiogroup\"\n }), []);\n const getRadioProps = useCallback((props2 = {}, ref2 = null) => {\n const checkedKey = isNative ? \"checked\" : \"isChecked\";\n return {\n ...props2,\n ref: ref2,\n name,\n [checkedKey]: value != null ? props2.value === value : void 0,\n onChange(event) {\n onChange(event);\n },\n \"data-radiogroup\": true\n };\n }, [isNative, name, onChange, value]);\n return {\n getRootProps,\n getRadioProps,\n name,\n ref,\n focus,\n setValue,\n value,\n onChange,\n isDisabled,\n isFocusable,\n htmlProps\n };\n}\n\n// src/radio-group.tsx\nimport { useMemo } from \"react\";\nvar [RadioGroupProvider, useRadioGroupContext] = createContext({\n name: \"RadioGroupContext\",\n strict: false\n});\nvar RadioGroup = forwardRef((props, ref) => {\n const {\n colorScheme,\n size,\n variant,\n children,\n className,\n isDisabled,\n isFocusable,\n ...rest\n } = props;\n const { value, onChange, getRootProps, name, htmlProps } = useRadioGroup(rest);\n const group = useMemo(() => ({\n name,\n size,\n onChange,\n colorScheme,\n value,\n variant,\n isDisabled,\n isFocusable\n }), [\n name,\n size,\n onChange,\n colorScheme,\n value,\n variant,\n isDisabled,\n isFocusable\n ]);\n return /* @__PURE__ */ React.createElement(RadioGroupProvider, {\n value: group\n }, /* @__PURE__ */ React.createElement(chakra.div, {\n ...getRootProps(htmlProps, ref),\n className: cx(\"chakra-radio-group\", className)\n }, children));\n});\nRadioGroup.displayName = \"RadioGroup\";\n\n// src/use-radio.ts\nimport { useFormControlContext } from \"@chakra-ui/form-control\";\n\n// ../visually-hidden/src/visually-hidden.style.ts\nvar visuallyHiddenStyle = {\n border: \"0px\",\n clip: \"rect(0px, 0px, 0px, 0px)\",\n height: \"1px\",\n width: \"1px\",\n margin: \"-1px\",\n padding: \"0px\",\n overflow: \"hidden\",\n whiteSpace: \"nowrap\",\n position: \"absolute\"\n};\n\n// src/use-radio.ts\nimport { trackFocusVisible } from \"@zag-js/focus-visible\";\nimport { useCallback as useCallback2, useEffect, useState as useState2, useId as useId2 } from \"react\";\nfunction useRadio(props = {}) {\n const {\n defaultChecked,\n isChecked: isCheckedProp,\n isFocusable,\n isDisabled: isDisabledProp,\n isReadOnly: isReadOnlyProp,\n isRequired: isRequiredProp,\n onChange,\n isInvalid: isInvalidProp,\n name,\n value,\n id: idProp,\n \"data-radiogroup\": dataRadioGroup,\n \"aria-describedby\": ariaDescribedBy,\n ...htmlProps\n } = props;\n const uuid = `radio-${useId2()}`;\n const formControl = useFormControlContext();\n const group = useRadioGroupContext();\n const isWithinRadioGroup = !!group || !!dataRadioGroup;\n const isWithinFormControl = !!formControl;\n let id = isWithinFormControl && !isWithinRadioGroup ? formControl.id : uuid;\n id = idProp ?? id;\n const isDisabled = isDisabledProp ?? (formControl == null ? void 0 : formControl.isDisabled);\n const isReadOnly = isReadOnlyProp ?? (formControl == null ? void 0 : formControl.isReadOnly);\n const isRequired = isRequiredProp ?? (formControl == null ? void 0 : formControl.isRequired);\n const isInvalid = isInvalidProp ?? (formControl == null ? void 0 : formControl.isInvalid);\n const [isFocusVisible, setIsFocusVisible] = useState2(false);\n const [isFocused, setFocused] = useState2(false);\n const [isHovered, setHovering] = useState2(false);\n const [isActive, setActive] = useState2(false);\n const [isCheckedState, setChecked] = useState2(Boolean(defaultChecked));\n const isControlled = typeof isCheckedProp !== \"undefined\";\n const isChecked = isControlled ? isCheckedProp : isCheckedState;\n useEffect(() => {\n return trackFocusVisible(setIsFocusVisible);\n }, []);\n const handleChange = useCallback2((event) => {\n if (isReadOnly || isDisabled) {\n event.preventDefault();\n return;\n }\n if (!isControlled) {\n setChecked(event.target.checked);\n }\n onChange == null ? void 0 : onChange(event);\n }, [isControlled, isDisabled, isReadOnly, onChange]);\n const onKeyDown = useCallback2((event) => {\n if (event.key === \" \") {\n setActive(true);\n }\n }, [setActive]);\n const onKeyUp = useCallback2((event) => {\n if (event.key === \" \") {\n setActive(false);\n }\n }, [setActive]);\n const getRadioProps = useCallback2((props2 = {}, ref = null) => ({\n ...props2,\n ref,\n \"data-active\": dataAttr(isActive),\n \"data-hover\": dataAttr(isHovered),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-checked\": dataAttr(isChecked),\n \"data-focus\": dataAttr(isFocused),\n \"data-focus-visible\": dataAttr(isFocused && isFocusVisible),\n \"data-readonly\": dataAttr(isReadOnly),\n \"aria-hidden\": true,\n onMouseDown: callAllHandlers(props2.onMouseDown, () => setActive(true)),\n onMouseUp: callAllHandlers(props2.onMouseUp, () => setActive(false)),\n onMouseEnter: callAllHandlers(props2.onMouseEnter, () => setHovering(true)),\n onMouseLeave: callAllHandlers(props2.onMouseLeave, () => setHovering(false))\n }), [\n isActive,\n isHovered,\n isDisabled,\n isInvalid,\n isChecked,\n isFocused,\n isReadOnly,\n isFocusVisible\n ]);\n const { onFocus, onBlur } = formControl ?? {};\n const getInputProps = useCallback2((props2 = {}, ref = null) => {\n const trulyDisabled = isDisabled && !isFocusable;\n return {\n ...props2,\n id,\n ref,\n type: \"radio\",\n name,\n value,\n onChange: callAllHandlers(props2.onChange, handleChange),\n onBlur: callAllHandlers(onBlur, props2.onBlur, () => setFocused(false)),\n onFocus: callAllHandlers(onFocus, props2.onFocus, () => setFocused(true)),\n onKeyDown: callAllHandlers(props2.onKeyDown, onKeyDown),\n onKeyUp: callAllHandlers(props2.onKeyUp, onKeyUp),\n checked: isChecked,\n disabled: trulyDisabled,\n readOnly: isReadOnly,\n required: isRequired,\n \"aria-invalid\": ariaAttr(isInvalid),\n \"aria-disabled\": ariaAttr(trulyDisabled),\n \"aria-required\": ariaAttr(isRequired),\n \"data-readonly\": dataAttr(isReadOnly),\n \"aria-describedby\": ariaDescribedBy,\n style: visuallyHiddenStyle\n };\n }, [\n isDisabled,\n isFocusable,\n id,\n name,\n value,\n handleChange,\n onBlur,\n onFocus,\n onKeyDown,\n onKeyUp,\n isChecked,\n isReadOnly,\n isRequired,\n isInvalid,\n ariaDescribedBy\n ]);\n const getLabelProps = (props2 = {}, ref = null) => ({\n ...props2,\n ref,\n onMouseDown: callAllHandlers(props2.onMouseDown, stop),\n onTouchStart: callAllHandlers(props2.onTouchStart, stop),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-checked\": dataAttr(isChecked),\n \"data-invalid\": dataAttr(isInvalid)\n });\n const getRootProps = (props2, ref = null) => ({\n ...props2,\n ref,\n \"data-disabled\": dataAttr(isDisabled),\n \"data-checked\": dataAttr(isChecked),\n \"data-invalid\": dataAttr(isInvalid)\n });\n const state = {\n isInvalid,\n isFocused,\n isChecked,\n isActive,\n isHovered,\n isDisabled,\n isReadOnly,\n isRequired\n };\n return {\n state,\n getCheckboxProps: getRadioProps,\n getInputProps,\n getLabelProps,\n getRootProps,\n htmlProps\n };\n}\nfunction stop(event) {\n event.preventDefault();\n event.stopPropagation();\n}\n\n// src/radio.tsx\nvar Radio = forwardRef2((props, ref) => {\n const group = useRadioGroupContext();\n const { onChange: onChangeProp, value: valueProp } = props;\n const styles = useMultiStyleConfig(\"Radio\", { ...group, ...props });\n const ownProps = omitThemingProps(props);\n const {\n spacing = \"0.5rem\",\n children,\n isDisabled = group == null ? void 0 : group.isDisabled,\n isFocusable = group == null ? void 0 : group.isFocusable,\n inputProps: htmlInputProps,\n ...rest\n } = ownProps;\n let isChecked = props.isChecked;\n if ((group == null ? void 0 : group.value) != null && valueProp != null) {\n isChecked = group.value === valueProp;\n }\n let onChange = onChangeProp;\n if ((group == null ? void 0 : group.onChange) && valueProp != null) {\n onChange = callAll(group.onChange, onChangeProp);\n }\n const name = (props == null ? void 0 : props.name) ?? (group == null ? void 0 : group.name);\n const {\n getInputProps,\n getCheckboxProps,\n getLabelProps,\n getRootProps,\n htmlProps\n } = useRadio({\n ...rest,\n isChecked,\n isFocusable,\n isDisabled,\n onChange,\n name\n });\n const [layoutProps, otherProps] = split(htmlProps, layoutPropNames);\n const checkboxProps = getCheckboxProps(otherProps);\n const inputProps = getInputProps(htmlInputProps, ref);\n const labelProps = getLabelProps();\n const rootProps = Object.assign({}, layoutProps, getRootProps());\n const rootStyles = {\n display: \"inline-flex\",\n alignItems: \"center\",\n verticalAlign: \"top\",\n cursor: \"pointer\",\n position: \"relative\",\n ...styles.container\n };\n const checkboxStyles = {\n display: \"inline-flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n flexShrink: 0,\n ...styles.control\n };\n const labelStyles = {\n userSelect: \"none\",\n marginStart: spacing,\n ...styles.label\n };\n return /* @__PURE__ */ React.createElement(chakra2.label, {\n className: \"chakra-radio\",\n ...rootProps,\n __css: rootStyles\n }, /* @__PURE__ */ React.createElement(\"input\", {\n className: \"chakra-radio__input\",\n ...inputProps\n }), /* @__PURE__ */ React.createElement(chakra2.span, {\n className: \"chakra-radio__control\",\n ...checkboxProps,\n __css: checkboxStyles\n }), children && /* @__PURE__ */ React.createElement(chakra2.span, {\n className: \"chakra-radio__label\",\n ...labelProps,\n __css: labelStyles\n }, children));\n});\nRadio.displayName = \"Radio\";\nexport {\n Radio,\n RadioGroup,\n useRadio,\n useRadioGroup,\n useRadioGroupContext\n};\n","// src/index.ts\nimport {\n createContext as createReactContext,\n useContext as useReactContext\n} from \"react\";\nfunction getErrorMessage(hook, provider) {\n return `${hook} returned \\`undefined\\`. Seems you forgot to wrap component within ${provider}`;\n}\nfunction createContext(options = {}) {\n const {\n name,\n strict = true,\n hookName = \"useContext\",\n providerName = \"Provider\",\n errorMessage\n } = options;\n const Context = createReactContext(void 0);\n Context.displayName = name;\n function useContext() {\n var _a;\n const context = useReactContext(Context);\n if (!context && strict) {\n const error = new Error(errorMessage ?? getErrorMessage(hookName, providerName));\n error.name = \"ContextError\";\n (_a = Error.captureStackTrace) == null ? void 0 : _a.call(Error, error, useContext);\n throw error;\n }\n return context;\n }\n return [Context.Provider, useContext, Context];\n}\nexport {\n createContext\n};\n","// src/add-dom-event.ts\nfunction addDomEvent(target, eventName, handler, options) {\n target.addEventListener(eventName, handler, options);\n return () => {\n target.removeEventListener(eventName, handler, options);\n };\n}\n\n// src/assertion.ts\nfunction isMouseEvent(event) {\n const win = getEventWindow(event);\n if (typeof win.PointerEvent !== \"undefined\" && event instanceof win.PointerEvent) {\n return !!(event.pointerType === \"mouse\");\n }\n return event instanceof win.MouseEvent;\n}\nfunction isTouchEvent(event) {\n const hasTouches = !!event.touches;\n return hasTouches;\n}\nfunction isMultiTouchEvent(event) {\n return isTouchEvent(event) && event.touches.length > 1;\n}\nfunction getEventWindow(event) {\n return event.view ?? window;\n}\n\n// src/get-event-point.ts\nfunction pointFromTouch(e, type = \"page\") {\n const point = e.touches[0] || e.changedTouches[0];\n return { x: point[`${type}X`], y: point[`${type}Y`] };\n}\nfunction pointFromMouse(point, type = \"page\") {\n return {\n x: point[`${type}X`],\n y: point[`${type}Y`]\n };\n}\nfunction getEventPoint(event, type = \"page\") {\n return isTouchEvent(event) ? pointFromTouch(event, type) : pointFromMouse(event, type);\n}\n\n// src/add-pointer-event.ts\nfunction filter(cb) {\n return (event) => {\n const isMouse = isMouseEvent(event);\n if (!isMouse || isMouse && event.button === 0) {\n cb(event);\n }\n };\n}\nfunction wrap(cb, filterPrimary = false) {\n function listener(event) {\n cb(event, { point: getEventPoint(event) });\n }\n const fn = filterPrimary ? filter(listener) : listener;\n return fn;\n}\nfunction addPointerEvent(target, type, cb, options) {\n return addDomEvent(target, type, wrap(cb, type === \"pointerdown\"), options);\n}\nexport {\n addDomEvent,\n addPointerEvent,\n getEventPoint,\n isMouseEvent,\n isMultiTouchEvent,\n isTouchEvent\n};\n","// src/index.ts\nimport { useRef } from \"react\";\nfunction useLatestRef(value) {\n const ref = useRef(null);\n ref.current = value;\n return ref;\n}\nexport {\n useLatestRef\n};\n","// src/use-pan-event.ts\nimport { addPointerEvent as addPointerEvent2 } from \"@chakra-ui/event-utils\";\nimport { useLatestRef } from \"@chakra-ui/react-use-latest-ref\";\nimport { useEffect, useRef } from \"react\";\n\n// src/pan-event.ts\nimport {\n addPointerEvent,\n getEventPoint,\n isMultiTouchEvent\n} from \"@chakra-ui/event-utils\";\nimport sync, { cancelSync, getFrameData } from \"framesync\";\nvar PanEvent = class {\n history = [];\n startEvent = null;\n lastEvent = null;\n lastEventInfo = null;\n handlers = {};\n removeListeners = () => {\n };\n threshold = 3;\n win;\n constructor(event, handlers, threshold) {\n this.win = event.view ?? window;\n if (isMultiTouchEvent(event))\n return;\n this.handlers = handlers;\n if (threshold) {\n this.threshold = threshold;\n }\n event.stopPropagation();\n event.preventDefault();\n const info = { point: getEventPoint(event) };\n const { timestamp } = getFrameData();\n this.history = [{ ...info.point, timestamp }];\n const { onSessionStart } = handlers;\n onSessionStart == null ? void 0 : onSessionStart(event, getPanInfo(info, this.history));\n this.removeListeners = pipe(addPointerEvent(this.win, \"pointermove\", this.onPointerMove), addPointerEvent(this.win, \"pointerup\", this.onPointerUp), addPointerEvent(this.win, \"pointercancel\", this.onPointerUp));\n }\n updatePoint = () => {\n if (!(this.lastEvent && this.lastEventInfo))\n return;\n const info = getPanInfo(this.lastEventInfo, this.history);\n const isPanStarted = this.startEvent !== null;\n const isDistancePastThreshold = distance(info.offset, { x: 0, y: 0 }) >= this.threshold;\n if (!isPanStarted && !isDistancePastThreshold)\n return;\n const { timestamp } = getFrameData();\n this.history.push({ ...info.point, timestamp });\n const { onStart, onMove } = this.handlers;\n if (!isPanStarted) {\n onStart == null ? void 0 : onStart(this.lastEvent, info);\n this.startEvent = this.lastEvent;\n }\n onMove == null ? void 0 : onMove(this.lastEvent, info);\n };\n onPointerMove = (event, info) => {\n this.lastEvent = event;\n this.lastEventInfo = info;\n sync.update(this.updatePoint, true);\n };\n onPointerUp = (event, info) => {\n const panInfo = getPanInfo(info, this.history);\n const { onEnd, onSessionEnd } = this.handlers;\n onSessionEnd == null ? void 0 : onSessionEnd(event, panInfo);\n this.end();\n if (!onEnd || !this.startEvent)\n return;\n onEnd == null ? void 0 : onEnd(event, panInfo);\n };\n updateHandlers(handlers) {\n this.handlers = handlers;\n }\n end() {\n var _a;\n (_a = this.removeListeners) == null ? void 0 : _a.call(this);\n cancelSync.update(this.updatePoint);\n }\n};\nfunction subtract(a, b) {\n return { x: a.x - b.x, y: a.y - b.y };\n}\nfunction getPanInfo(info, history) {\n return {\n point: info.point,\n delta: subtract(info.point, history[history.length - 1]),\n offset: subtract(info.point, history[0]),\n velocity: getVelocity(history, 0.1)\n };\n}\nvar toMilliseconds = (v) => v * 1e3;\nfunction getVelocity(history, timeDelta) {\n if (history.length < 2) {\n return { x: 0, y: 0 };\n }\n let i = history.length - 1;\n let timestampedPoint = null;\n const lastPoint = history[history.length - 1];\n while (i >= 0) {\n timestampedPoint = history[i];\n if (lastPoint.timestamp - timestampedPoint.timestamp > toMilliseconds(timeDelta)) {\n break;\n }\n i--;\n }\n if (!timestampedPoint) {\n return { x: 0, y: 0 };\n }\n const time = (lastPoint.timestamp - timestampedPoint.timestamp) / 1e3;\n if (time === 0) {\n return { x: 0, y: 0 };\n }\n const currentVelocity = {\n x: (lastPoint.x - timestampedPoint.x) / time,\n y: (lastPoint.y - timestampedPoint.y) / time\n };\n if (currentVelocity.x === Infinity) {\n currentVelocity.x = 0;\n }\n if (currentVelocity.y === Infinity) {\n currentVelocity.y = 0;\n }\n return currentVelocity;\n}\nfunction pipe(...fns) {\n return (v) => fns.reduce((a, b) => b(a), v);\n}\nfunction distance1D(a, b) {\n return Math.abs(a - b);\n}\nfunction isPoint(point) {\n return \"x\" in point && \"y\" in point;\n}\nfunction distance(a, b) {\n if (typeof a === \"number\" && typeof b === \"number\") {\n return distance1D(a, b);\n }\n if (isPoint(a) && isPoint(b)) {\n const xDelta = distance1D(a.x, b.x);\n const yDelta = distance1D(a.y, b.y);\n return Math.sqrt(xDelta ** 2 + yDelta ** 2);\n }\n return 0;\n}\n\n// src/use-pan-event.ts\nfunction usePanEvent(ref, options) {\n const {\n onPan,\n onPanStart,\n onPanEnd,\n onPanSessionStart,\n onPanSessionEnd,\n threshold\n } = options;\n const hasPanEvents = Boolean(onPan || onPanStart || onPanEnd || onPanSessionStart || onPanSessionEnd);\n const panSession = useRef(null);\n const handlersRef = useLatestRef({\n onSessionStart: onPanSessionStart,\n onSessionEnd: onPanSessionEnd,\n onStart: onPanStart,\n onMove: onPan,\n onEnd(event, info) {\n panSession.current = null;\n onPanEnd == null ? void 0 : onPanEnd(event, info);\n }\n });\n useEffect(() => {\n var _a;\n (_a = panSession.current) == null ? void 0 : _a.updateHandlers(handlersRef.current);\n });\n useEffect(() => {\n const node = ref.current;\n if (!node || !hasPanEvents)\n return;\n function onPointerDown(event) {\n panSession.current = new PanEvent(event, handlersRef.current, threshold);\n }\n return addPointerEvent2(node, \"pointerdown\", onPointerDown);\n }, [ref, hasPanEvents, handlersRef, threshold]);\n useEffect(() => {\n return () => {\n var _a;\n (_a = panSession.current) == null ? void 0 : _a.end();\n panSession.current = null;\n };\n }, []);\n}\nexport {\n usePanEvent\n};\n","// src/index.ts\nimport { useCallback, useEffect, useRef } from \"react\";\nfunction useCallbackRef(callback, deps = []) {\n const callbackRef = useRef(callback);\n useEffect(() => {\n callbackRef.current = callback;\n });\n return useCallback((...args) => {\n var _a;\n return (_a = callbackRef.current) == null ? void 0 : _a.call(callbackRef, ...args);\n }, deps);\n}\nexport {\n useCallbackRef\n};\n","// src/index.ts\nimport { useMemo, useState } from \"react\";\nimport { useCallbackRef } from \"@chakra-ui/react-use-callback-ref\";\nfunction useControllableProp(prop, state) {\n const controlled = typeof prop !== \"undefined\";\n const value = controlled ? prop : state;\n return useMemo(() => [controlled, value], [controlled, value]);\n}\nfunction useControllableState(props) {\n const {\n value: valueProp,\n defaultValue,\n onChange,\n shouldUpdate = (prev, next) => prev !== next\n } = props;\n const onChangeProp = useCallbackRef(onChange);\n const shouldUpdateProp = useCallbackRef(shouldUpdate);\n const [uncontrolledState, setUncontrolledState] = useState(defaultValue);\n const controlled = valueProp !== void 0;\n const value = controlled ? valueProp : uncontrolledState;\n const setValue = useCallbackRef((next) => {\n const setter = next;\n const nextValue = typeof next === \"function\" ? setter(value) : next;\n if (!shouldUpdateProp(value, nextValue)) {\n return;\n }\n if (!controlled) {\n setUncontrolledState(nextValue);\n }\n onChangeProp(nextValue);\n }, [controlled, onChangeProp, value, shouldUpdateProp]);\n return [value, setValue];\n}\nexport {\n useControllableProp,\n useControllableState\n};\n","// src/index.ts\nimport { useEffect, useRef } from \"react\";\nfunction useUpdateEffect(callback, deps) {\n const renderCycleRef = useRef(false);\n const effectCycleRef = useRef(false);\n useEffect(() => {\n const mounted = renderCycleRef.current;\n const run = mounted && effectCycleRef.current;\n if (run) {\n return callback();\n }\n effectCycleRef.current = true;\n }, deps);\n useEffect(() => {\n renderCycleRef.current = true;\n return () => {\n renderCycleRef.current = false;\n };\n }, []);\n}\nexport {\n useUpdateEffect\n};\n","// src/index.ts\nimport { useMemo } from \"react\";\nfunction assignRef(ref, value) {\n if (ref == null)\n return;\n if (typeof ref === \"function\") {\n ref(value);\n return;\n }\n try {\n ref.current = value;\n } catch (error) {\n throw new Error(`Cannot assign value '${value}' to ref '${ref}'`);\n }\n}\nfunction mergeRefs(...refs) {\n return (node) => {\n refs.forEach((ref) => {\n assignRef(ref, node);\n });\n };\n}\nfunction useMergeRefs(...refs) {\n return useMemo(() => mergeRefs(...refs), refs);\n}\nexport {\n assignRef,\n mergeRefs,\n useMergeRefs\n};\n","// src/index.ts\nfunction toNumber(value) {\n const num = parseFloat(value);\n return typeof num !== \"number\" || Number.isNaN(num) ? 0 : num;\n}\nfunction toPrecision(value, precision) {\n let nextValue = toNumber(value);\n const scaleFactor = 10 ** (precision ?? 10);\n nextValue = Math.round(nextValue * scaleFactor) / scaleFactor;\n return precision ? nextValue.toFixed(precision) : nextValue.toString();\n}\nfunction countDecimalPlaces(value) {\n if (!Number.isFinite(value))\n return 0;\n let e = 1;\n let p = 0;\n while (Math.round(value * e) / e !== value) {\n e *= 10;\n p += 1;\n }\n return p;\n}\nfunction valueToPercent(value, min, max) {\n return (value - min) * 100 / (max - min);\n}\nfunction percentToValue(percent, min, max) {\n return (max - min) * percent + min;\n}\nfunction roundValueToStep(value, from, step) {\n const nextValue = Math.round((value - from) / step) * step + from;\n const precision = countDecimalPlaces(step);\n return toPrecision(nextValue, precision);\n}\nfunction clampValue(value, min, max) {\n if (value == null)\n return value;\n if (max < min) {\n console.warn(\"clamp: max cannot be less than min\");\n }\n return Math.min(Math.max(value, min), max);\n}\nexport {\n clampValue,\n countDecimalPlaces,\n percentToValue,\n roundValueToStep,\n toPrecision,\n valueToPercent\n};\n","// src/index.ts\nfunction trackElementSize(element, callback) {\n if (!element) {\n callback(void 0);\n return;\n }\n callback({ width: element.offsetWidth, height: element.offsetHeight });\n const win = element.ownerDocument.defaultView ?? window;\n const observer = new win.ResizeObserver((entries) => {\n if (!Array.isArray(entries) || !entries.length)\n return;\n const [entry] = entries;\n let width;\n let height;\n if (\"borderBoxSize\" in entry) {\n const borderSizeEntry = entry[\"borderBoxSize\"];\n const borderSize = Array.isArray(borderSizeEntry) ? borderSizeEntry[0] : borderSizeEntry;\n width = borderSize[\"inlineSize\"];\n height = borderSize[\"blockSize\"];\n } else {\n width = element.offsetWidth;\n height = element.offsetHeight;\n }\n callback({ width, height });\n });\n observer.observe(element, { box: \"border-box\" });\n return () => observer.unobserve(element);\n}\nexport {\n trackElementSize\n};\n","// src/index.ts\nimport { trackElementSize } from \"@zag-js/element-size\";\nimport { useEffect, useLayoutEffect, useState } from \"react\";\nvar useSafeLayoutEffect = Boolean(globalThis == null ? void 0 : globalThis.document) ? useLayoutEffect : useEffect;\nfunction trackMutation(el, cb) {\n var _a;\n if (!el || !el.parentElement)\n return;\n const win = ((_a = el.ownerDocument) == null ? void 0 : _a.defaultView) ?? window;\n const observer = new win.MutationObserver(() => {\n cb();\n });\n observer.observe(el.parentElement, { childList: true });\n return () => {\n observer.disconnect();\n };\n}\nfunction useSizes({\n getNodes,\n observeMutation = true\n}) {\n const [sizes, setSizes] = useState([]);\n const [count, setCount] = useState(0);\n useSafeLayoutEffect(() => {\n const elements = getNodes();\n const cleanups = elements.map((element, index) => trackElementSize(element, (size) => {\n setSizes((sizes2) => {\n return [\n ...sizes2.slice(0, index),\n size,\n ...sizes2.slice(index + 1)\n ];\n });\n }));\n if (observeMutation) {\n const firstNode = elements[0];\n cleanups.push(trackMutation(firstNode, () => {\n setCount((count2) => count2 + 1);\n }));\n }\n return () => {\n cleanups.forEach((cleanup) => {\n cleanup == null ? void 0 : cleanup();\n });\n };\n }, [count]);\n return sizes;\n}\nfunction isRef(ref) {\n return typeof ref === \"object\" && ref !== null && \"current\" in ref;\n}\nfunction useSize(subject) {\n const [size] = useSizes({\n observeMutation: false,\n getNodes() {\n const node = isRef(subject) ? subject.current : subject;\n return [node];\n }\n });\n return size;\n}\nexport {\n useSize,\n useSizes\n};\n","var __getOwnPropNames = Object.getOwnPropertyNames;\nvar __esm = (fn, res) => function __init() {\n return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;\n};\n\n// ../../../react-shim.js\nimport React from \"react\";\nvar init_react_shim = __esm({\n \"../../../react-shim.js\"() {\n \"use strict\";\n }\n});\n\n// src/index.ts\ninit_react_shim();\n\n// src/range-slider.tsx\ninit_react_shim();\nimport { createContext } from \"@chakra-ui/react-context\";\nimport {\n chakra,\n forwardRef,\n omitThemingProps,\n useMultiStyleConfig,\n useTheme\n} from \"@chakra-ui/system\";\n\n// ../../legacy/utils/src/dom.ts\ninit_react_shim();\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\n\n// ../../legacy/utils/src/function.ts\ninit_react_shim();\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\n\n// src/range-slider.tsx\nimport { useMemo as useMemo2 } from \"react\";\n\n// src/use-range-slider.ts\ninit_react_shim();\nimport { usePanEvent } from \"@chakra-ui/react-use-pan-event\";\nimport { useControllableState } from \"@chakra-ui/react-use-controllable-state\";\nimport { useCallbackRef } from \"@chakra-ui/react-use-callback-ref\";\nimport { useUpdateEffect } from \"@chakra-ui/react-use-update-effect\";\nimport { mergeRefs } from \"@chakra-ui/react-use-merge-refs\";\nimport {\n percentToValue,\n roundValueToStep,\n valueToPercent,\n clampValue\n} from \"@chakra-ui/number-utils\";\nimport { useCallback, useMemo, useRef, useState, useId } from \"react\";\n\n// src/slider-utils.ts\ninit_react_shim();\nfunction getIds(id) {\n return {\n root: `slider-root-${id}`,\n getThumb: (i) => `slider-thumb-${id}-${i}`,\n getInput: (i) => `slider-input-${id}-${i}`,\n track: `slider-track-${id}`,\n innerTrack: `slider-filled-track-${id}`,\n getMarker: (i) => `slider-marker-${id}-${i}`,\n output: `slider-output-${id}`\n };\n}\nfunction orient(options) {\n const { orientation, vertical, horizontal } = options;\n return orientation === \"vertical\" ? vertical : horizontal;\n}\nvar zeroSize = { width: 0, height: 0 };\nvar normalize = (a) => a || zeroSize;\nfunction getStyles(options) {\n const { orientation, thumbPercents, thumbRects, isReversed } = options;\n const getThumbStyle = (i) => {\n const rect = thumbRects[i] ?? zeroSize;\n return {\n position: \"absolute\",\n userSelect: \"none\",\n WebkitUserSelect: \"none\",\n MozUserSelect: \"none\",\n msUserSelect: \"none\",\n touchAction: \"none\",\n ...orient({\n orientation,\n vertical: {\n bottom: `calc(${thumbPercents[i]}% - ${rect.height / 2}px)`\n },\n horizontal: {\n left: `calc(${thumbPercents[i]}% - ${rect.width / 2}px)`\n }\n })\n };\n };\n const size = orientation === \"vertical\" ? thumbRects.reduce((a, b) => normalize(a).height > normalize(b).height ? a : b, zeroSize) : thumbRects.reduce((a, b) => normalize(a).width > normalize(b).width ? a : b, zeroSize);\n const rootStyle = {\n position: \"relative\",\n touchAction: \"none\",\n WebkitTapHighlightColor: \"rgba(0,0,0,0)\",\n userSelect: \"none\",\n outline: 0,\n ...orient({\n orientation,\n vertical: size ? {\n paddingLeft: size.width / 2,\n paddingRight: size.width / 2\n } : {},\n horizontal: size ? {\n paddingTop: size.height / 2,\n paddingBottom: size.height / 2\n } : {}\n })\n };\n const trackStyle = {\n position: \"absolute\",\n ...orient({\n orientation,\n vertical: {\n left: \"50%\",\n transform: \"translateX(-50%)\",\n height: \"100%\"\n },\n horizontal: {\n top: \"50%\",\n transform: \"translateY(-50%)\",\n width: \"100%\"\n }\n })\n };\n const isSingleThumb = thumbPercents.length === 1;\n const fallback = [0, isReversed ? 100 - thumbPercents[0] : thumbPercents[0]];\n const range = isSingleThumb ? fallback : thumbPercents;\n let start = range[0];\n if (!isSingleThumb && isReversed) {\n start = 100 - start;\n }\n const percent = Math.abs(range[range.length - 1] - range[0]);\n const innerTrackStyle = {\n ...trackStyle,\n ...orient({\n orientation,\n vertical: isReversed ? { height: `${percent}%`, top: `${start}%` } : { height: `${percent}%`, bottom: `${start}%` },\n horizontal: isReversed ? { width: `${percent}%`, right: `${start}%` } : { width: `${percent}%`, left: `${start}%` }\n })\n };\n return { trackStyle, innerTrackStyle, rootStyle, getThumbStyle };\n}\nfunction getIsReversed(options) {\n const { isReversed, direction, orientation } = options;\n if (direction === \"ltr\" || orientation === \"vertical\") {\n return isReversed;\n }\n return !isReversed;\n}\n\n// src/use-range-slider.ts\nimport { useSizes } from \"@chakra-ui/react-use-size\";\nfunction useRangeSlider(props) {\n const {\n min = 0,\n max = 100,\n onChange,\n value: valueProp,\n defaultValue,\n isReversed: isReversedProp,\n direction = \"ltr\",\n orientation = \"horizontal\",\n id: idProp,\n isDisabled,\n isReadOnly,\n onChangeStart: onChangeStartProp,\n onChangeEnd: onChangeEndProp,\n step = 1,\n getAriaValueText: getAriaValueTextProp,\n \"aria-valuetext\": ariaValueText,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n name,\n focusThumbOnChange = true,\n minStepsBetweenThumbs = 0,\n ...htmlProps\n } = props;\n const onChangeStart = useCallbackRef(onChangeStartProp);\n const onChangeEnd = useCallbackRef(onChangeEndProp);\n const getAriaValueText = useCallbackRef(getAriaValueTextProp);\n const isReversed = getIsReversed({\n isReversed: isReversedProp,\n direction,\n orientation\n });\n const [valueState, setValue] = useControllableState({\n value: valueProp,\n defaultValue: defaultValue ?? [25, 75],\n onChange\n });\n if (!Array.isArray(valueState)) {\n throw new TypeError(`[range-slider] You passed an invalid value for \\`value\\` or \\`defaultValue\\`, expected \\`Array\\` but got \\`${typeof valueState}\\``);\n }\n const [isDragging, setDragging] = useState(false);\n const [isFocused, setFocused] = useState(false);\n const [activeIndex, setActiveIndex] = useState(-1);\n const isInteractive = !(isDisabled || isReadOnly);\n const initialValue = useRef(valueState);\n const value = valueState.map((val) => clampValue(val, min, max));\n const spacing = minStepsBetweenThumbs * step;\n const valueBounds = getValueBounds(value, min, max, spacing);\n const stateRef = useRef({\n eventSource: null,\n value: [],\n valueBounds: []\n });\n stateRef.current.value = value;\n stateRef.current.valueBounds = valueBounds;\n const reversedValue = value.map((val) => max - val + min);\n const thumbValues = isReversed ? reversedValue : value;\n const thumbPercents = thumbValues.map((val) => valueToPercent(val, min, max));\n const isVertical = orientation === \"vertical\";\n const trackRef = useRef(null);\n const rootRef = useRef(null);\n const thumbRects = useSizes({\n getNodes() {\n const rootNode = rootRef.current;\n const thumbNodes = rootNode == null ? void 0 : rootNode.querySelectorAll(\"[role=slider]\");\n return thumbNodes ? Array.from(thumbNodes) : [];\n }\n });\n const reactId = useId();\n const uuid = idProp ?? reactId;\n const ids = getIds(uuid);\n const getValueFromPointer = useCallback((event) => {\n var _a;\n if (!trackRef.current)\n return;\n stateRef.current.eventSource = \"pointer\";\n const rect = trackRef.current.getBoundingClientRect();\n const { clientX, clientY } = ((_a = event.touches) == null ? void 0 : _a[0]) ?? event;\n const diff = isVertical ? rect.bottom - clientY : clientX - rect.left;\n const length = isVertical ? rect.height : rect.width;\n let percent = diff / length;\n if (isReversed)\n percent = 1 - percent;\n return percentToValue(percent, min, max);\n }, [isVertical, isReversed, max, min]);\n const tenSteps = (max - min) / 10;\n const oneStep = step || (max - min) / 100;\n const actions = useMemo(() => ({\n setValueAtIndex(index, val) {\n if (!isInteractive)\n return;\n const bounds = stateRef.current.valueBounds[index];\n val = parseFloat(roundValueToStep(val, bounds.min, oneStep));\n val = clampValue(val, bounds.min, bounds.max);\n const next = [...stateRef.current.value];\n next[index] = val;\n setValue(next);\n },\n setActiveIndex,\n stepUp(index, step2 = oneStep) {\n const valueAtIndex = stateRef.current.value[index];\n const next = isReversed ? valueAtIndex - step2 : valueAtIndex + step2;\n actions.setValueAtIndex(index, next);\n },\n stepDown(index, step2 = oneStep) {\n const valueAtIndex = stateRef.current.value[index];\n const next = isReversed ? valueAtIndex + step2 : valueAtIndex - step2;\n actions.setValueAtIndex(index, next);\n },\n reset() {\n setValue(initialValue.current);\n }\n }), [oneStep, isReversed, setValue, isInteractive]);\n const onKeyDown = useCallback((event) => {\n const eventKey = event.key;\n const keyMap = {\n ArrowRight: () => actions.stepUp(activeIndex),\n ArrowUp: () => actions.stepUp(activeIndex),\n ArrowLeft: () => actions.stepDown(activeIndex),\n ArrowDown: () => actions.stepDown(activeIndex),\n PageUp: () => actions.stepUp(activeIndex, tenSteps),\n PageDown: () => actions.stepDown(activeIndex, tenSteps),\n Home: () => {\n const { min: value2 } = valueBounds[activeIndex];\n actions.setValueAtIndex(activeIndex, value2);\n },\n End: () => {\n const { max: value2 } = valueBounds[activeIndex];\n actions.setValueAtIndex(activeIndex, value2);\n }\n };\n const action = keyMap[eventKey];\n if (action) {\n event.preventDefault();\n event.stopPropagation();\n action(event);\n stateRef.current.eventSource = \"keyboard\";\n }\n }, [actions, activeIndex, tenSteps, valueBounds]);\n const { getThumbStyle, rootStyle, trackStyle, innerTrackStyle } = useMemo(() => getStyles({\n isReversed,\n orientation,\n thumbRects,\n thumbPercents\n }), [isReversed, orientation, thumbPercents, thumbRects]);\n const focusThumb = useCallback((index) => {\n var _a;\n const idx = index ?? activeIndex;\n if (idx !== -1 && focusThumbOnChange) {\n const id = ids.getThumb(idx);\n const thumb = (_a = rootRef.current) == null ? void 0 : _a.ownerDocument.getElementById(id);\n if (thumb) {\n setTimeout(() => thumb.focus());\n }\n }\n }, [focusThumbOnChange, activeIndex, ids]);\n useUpdateEffect(() => {\n if (stateRef.current.eventSource === \"keyboard\") {\n onChangeEnd == null ? void 0 : onChangeEnd(stateRef.current.value);\n }\n }, [value, onChangeEnd]);\n const onPanSessionStart = (event) => {\n const pointValue = getValueFromPointer(event) || 0;\n const distances = stateRef.current.value.map((val) => Math.abs(val - pointValue));\n const closest = Math.min(...distances);\n let index = distances.indexOf(closest);\n const thumbsAtPosition = distances.filter((distance) => distance === closest);\n const isThumbStacked = thumbsAtPosition.length > 1;\n if (isThumbStacked && pointValue > stateRef.current.value[index]) {\n index = index + thumbsAtPosition.length - 1;\n }\n setActiveIndex(index);\n actions.setValueAtIndex(index, pointValue);\n focusThumb(index);\n };\n const onPan = (event) => {\n if (activeIndex == -1)\n return;\n const pointValue = getValueFromPointer(event) || 0;\n setActiveIndex(activeIndex);\n actions.setValueAtIndex(activeIndex, pointValue);\n focusThumb(activeIndex);\n };\n usePanEvent(rootRef, {\n onPanSessionStart(event) {\n if (!isInteractive)\n return;\n setDragging(true);\n onPanSessionStart(event);\n onChangeStart == null ? void 0 : onChangeStart(stateRef.current.value);\n },\n onPanSessionEnd() {\n if (!isInteractive)\n return;\n setDragging(false);\n onChangeEnd == null ? void 0 : onChangeEnd(stateRef.current.value);\n },\n onPan(event) {\n if (!isInteractive)\n return;\n onPan(event);\n }\n });\n const getRootProps = useCallback((props2 = {}, ref = null) => {\n return {\n ...props2,\n ...htmlProps,\n id: ids.root,\n ref: mergeRefs(ref, rootRef),\n tabIndex: -1,\n \"aria-disabled\": ariaAttr(isDisabled),\n \"data-focused\": dataAttr(isFocused),\n style: { ...props2.style, ...rootStyle }\n };\n }, [htmlProps, isDisabled, isFocused, rootStyle, ids]);\n const getTrackProps = useCallback((props2 = {}, ref = null) => {\n return {\n ...props2,\n ref: mergeRefs(ref, trackRef),\n id: ids.track,\n \"data-disabled\": dataAttr(isDisabled),\n style: { ...props2.style, ...trackStyle }\n };\n }, [isDisabled, trackStyle, ids]);\n const getInnerTrackProps = useCallback((props2 = {}, ref = null) => {\n return {\n ...props2,\n ref,\n id: ids.innerTrack,\n style: {\n ...props2.style,\n ...innerTrackStyle\n }\n };\n }, [innerTrackStyle, ids]);\n const getThumbProps = useCallback((props2, ref = null) => {\n const { index, ...rest } = props2;\n const valueAtIndex = value[index];\n if (valueAtIndex == null) {\n throw new TypeError(`[range-slider > thumb] Cannot find value at index \\`${index}\\`. The \\`value\\` or \\`defaultValue\\` length is : ${value.length}`);\n }\n const bounds = valueBounds[index];\n return {\n ...rest,\n ref,\n role: \"slider\",\n tabIndex: isInteractive ? 0 : void 0,\n id: ids.getThumb(index),\n \"data-active\": dataAttr(isDragging && activeIndex === index),\n \"aria-valuetext\": (getAriaValueText == null ? void 0 : getAriaValueText(valueAtIndex)) ?? (ariaValueText == null ? void 0 : ariaValueText[index]),\n \"aria-valuemin\": bounds.min,\n \"aria-valuemax\": bounds.max,\n \"aria-valuenow\": valueAtIndex,\n \"aria-orientation\": orientation,\n \"aria-disabled\": ariaAttr(isDisabled),\n \"aria-readonly\": ariaAttr(isReadOnly),\n \"aria-label\": ariaLabel == null ? void 0 : ariaLabel[index],\n \"aria-labelledby\": (ariaLabel == null ? void 0 : ariaLabel[index]) ? void 0 : ariaLabelledBy == null ? void 0 : ariaLabelledBy[index],\n style: { ...props2.style, ...getThumbStyle(index) },\n onKeyDown: callAllHandlers(props2.onKeyDown, onKeyDown),\n onFocus: callAllHandlers(props2.onFocus, () => {\n setFocused(true);\n setActiveIndex(index);\n }),\n onBlur: callAllHandlers(props2.onBlur, () => {\n setFocused(false);\n setActiveIndex(-1);\n })\n };\n }, [\n ids,\n value,\n valueBounds,\n isInteractive,\n isDragging,\n activeIndex,\n getAriaValueText,\n ariaValueText,\n orientation,\n isDisabled,\n isReadOnly,\n ariaLabel,\n ariaLabelledBy,\n getThumbStyle,\n onKeyDown,\n setFocused\n ]);\n const getOutputProps = useCallback((props2 = {}, ref = null) => {\n return {\n ...props2,\n ref,\n id: ids.output,\n htmlFor: value.map((v, i) => ids.getThumb(i)).join(\" \"),\n \"aria-live\": \"off\"\n };\n }, [ids, value]);\n const getMarkerProps = useCallback((props2, ref = null) => {\n const { value: v, ...rest } = props2;\n const isInRange = !(v < min || v > max);\n const isHighlighted = v >= value[0] && v <= value[value.length - 1];\n let percent = valueToPercent(v, min, max);\n percent = isReversed ? 100 - percent : percent;\n const markerStyle = {\n position: \"absolute\",\n pointerEvents: \"none\",\n ...orient({\n orientation,\n vertical: { bottom: `${percent}%` },\n horizontal: { left: `${percent}%` }\n })\n };\n return {\n ...rest,\n ref,\n id: ids.getMarker(props2.value),\n role: \"presentation\",\n \"aria-hidden\": true,\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(!isInRange),\n \"data-highlighted\": dataAttr(isHighlighted),\n style: {\n ...props2.style,\n ...markerStyle\n }\n };\n }, [isDisabled, isReversed, max, min, orientation, value, ids]);\n const getInputProps = useCallback((props2, ref = null) => {\n const { index, ...rest } = props2;\n return {\n ...rest,\n ref,\n id: ids.getInput(index),\n type: \"hidden\",\n value: value[index],\n name: Array.isArray(name) ? name[index] : `${name}-${index}`\n };\n }, [name, value, ids]);\n return {\n state: {\n value,\n isFocused,\n isDragging,\n getThumbPercent: (index) => thumbPercents[index],\n getThumbMinValue: (index) => valueBounds[index].min,\n getThumbMaxValue: (index) => valueBounds[index].max\n },\n actions,\n getRootProps,\n getTrackProps,\n getInnerTrackProps,\n getThumbProps,\n getMarkerProps,\n getInputProps,\n getOutputProps\n };\n}\nfunction getValueBounds(arr, min, max, spacing) {\n return arr.map((v, i) => {\n const _min = i === 0 ? min : arr[i - 1] + spacing;\n const _max = i === arr.length - 1 ? max : arr[i + 1] - spacing;\n return { min: _min, max: _max };\n });\n}\n\n// src/range-slider.tsx\nvar [RangeSliderProvider, useRangeSliderContext] = createContext({\n name: \"SliderContext\",\n errorMessage: \"useSliderContext: `context` is undefined. Seems you forgot to wrap all slider components within \"\n});\nvar [RangeSliderStylesProvider, useRangeSliderStyles] = createContext({\n name: `RangeSliderStylesContext`,\n errorMessage: `useRangeSliderStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar RangeSlider = forwardRef(function RangeSlider2(props, ref) {\n const styles = useMultiStyleConfig(\"Slider\", props);\n const ownProps = omitThemingProps(props);\n const { direction } = useTheme();\n ownProps.direction = direction;\n const { getRootProps, ...context } = useRangeSlider(ownProps);\n const ctx = useMemo2(() => ({ ...context, name: props.name }), [context, props.name]);\n return /* @__PURE__ */ React.createElement(RangeSliderProvider, {\n value: ctx\n }, /* @__PURE__ */ React.createElement(RangeSliderStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra.div, {\n ...getRootProps({}, ref),\n className: \"chakra-slider\",\n __css: styles.container\n }, props.children)));\n});\nRangeSlider.defaultProps = {\n orientation: \"horizontal\"\n};\nRangeSlider.displayName = \"RangeSlider\";\nvar RangeSliderThumb = forwardRef(function RangeSliderThumb2(props, ref) {\n const { getThumbProps, getInputProps, name } = useRangeSliderContext();\n const styles = useRangeSliderStyles();\n const thumbProps = getThumbProps(props, ref);\n return /* @__PURE__ */ React.createElement(chakra.div, {\n ...thumbProps,\n className: cx(\"chakra-slider__thumb\", props.className),\n __css: styles.thumb\n }, thumbProps.children, name && /* @__PURE__ */ React.createElement(\"input\", {\n ...getInputProps({ index: props.index })\n }));\n});\nRangeSliderThumb.displayName = \"RangeSliderThumb\";\nvar RangeSliderTrack = forwardRef(function RangeSliderTrack2(props, ref) {\n const { getTrackProps } = useRangeSliderContext();\n const styles = useRangeSliderStyles();\n const trackProps = getTrackProps(props, ref);\n return /* @__PURE__ */ React.createElement(chakra.div, {\n ...trackProps,\n className: cx(\"chakra-slider__track\", props.className),\n __css: styles.track,\n \"data-testid\": \"chakra-range-slider-track\"\n });\n});\nRangeSliderTrack.displayName = \"RangeSliderTrack\";\nvar RangeSliderFilledTrack = forwardRef(function RangeSliderFilledTrack2(props, ref) {\n const { getInnerTrackProps } = useRangeSliderContext();\n const styles = useRangeSliderStyles();\n const trackProps = getInnerTrackProps(props, ref);\n return /* @__PURE__ */ React.createElement(chakra.div, {\n ...trackProps,\n className: \"chakra-slider__filled-track\",\n __css: styles.filledTrack\n });\n});\nRangeSliderFilledTrack.displayName = \"RangeSliderFilledTrack\";\nvar RangeSliderMark = forwardRef(function RangeSliderMark2(props, ref) {\n const { getMarkerProps } = useRangeSliderContext();\n const markProps = getMarkerProps(props, ref);\n return /* @__PURE__ */ React.createElement(chakra.div, {\n ...markProps,\n className: cx(\"chakra-slider__marker\", props.className)\n });\n});\nRangeSliderMark.displayName = \"RangeSliderMark\";\n\n// src/slider.tsx\ninit_react_shim();\nimport { createContext as createContext2 } from \"@chakra-ui/react-context\";\nimport {\n chakra as chakra2,\n forwardRef as forwardRef2,\n omitThemingProps as omitThemingProps2,\n useMultiStyleConfig as useMultiStyleConfig2,\n useTheme as useTheme2\n} from \"@chakra-ui/system\";\n\n// src/use-slider.ts\ninit_react_shim();\nimport { usePanEvent as usePanEvent2 } from \"@chakra-ui/react-use-pan-event\";\nimport { useCallbackRef as useCallbackRef2 } from \"@chakra-ui/react-use-callback-ref\";\nimport { useUpdateEffect as useUpdateEffect2 } from \"@chakra-ui/react-use-update-effect\";\nimport { useControllableState as useControllableState2 } from \"@chakra-ui/react-use-controllable-state\";\nimport { useSize } from \"@chakra-ui/react-use-size\";\nimport { mergeRefs as mergeRefs2 } from \"@chakra-ui/react-use-merge-refs\";\nimport { useLatestRef } from \"@chakra-ui/react-use-latest-ref\";\nimport {\n clampValue as clampValue2,\n percentToValue as percentToValue2,\n roundValueToStep as roundValueToStep2,\n valueToPercent as valueToPercent2\n} from \"@chakra-ui/number-utils\";\nimport { useCallback as useCallback2, useMemo as useMemo3, useRef as useRef2, useId as useId2, useState as useState2 } from \"react\";\nfunction useSlider(props) {\n const {\n min = 0,\n max = 100,\n onChange,\n value: valueProp,\n defaultValue,\n isReversed: isReversedProp,\n direction = \"ltr\",\n orientation = \"horizontal\",\n id: idProp,\n isDisabled,\n isReadOnly,\n onChangeStart: onChangeStartProp,\n onChangeEnd: onChangeEndProp,\n step = 1,\n getAriaValueText: getAriaValueTextProp,\n \"aria-valuetext\": ariaValueText,\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabelledBy,\n name,\n focusThumbOnChange = true,\n ...htmlProps\n } = props;\n const onChangeStart = useCallbackRef2(onChangeStartProp);\n const onChangeEnd = useCallbackRef2(onChangeEndProp);\n const getAriaValueText = useCallbackRef2(getAriaValueTextProp);\n const isReversed = getIsReversed({\n isReversed: isReversedProp,\n direction,\n orientation\n });\n const [computedValue, setValue] = useControllableState2({\n value: valueProp,\n defaultValue: defaultValue ?? getDefaultValue(min, max),\n onChange\n });\n const [isDragging, setDragging] = useState2(false);\n const [isFocused, setFocused] = useState2(false);\n const isInteractive = !(isDisabled || isReadOnly);\n const tenSteps = (max - min) / 10;\n const oneStep = step || (max - min) / 100;\n const value = clampValue2(computedValue, min, max);\n const reversedValue = max - value + min;\n const trackValue = isReversed ? reversedValue : value;\n const thumbPercent = valueToPercent2(trackValue, min, max);\n const isVertical = orientation === \"vertical\";\n const stateRef = useLatestRef({\n min,\n max,\n step,\n isDisabled,\n value,\n isInteractive,\n isReversed,\n isVertical,\n eventSource: null,\n focusThumbOnChange,\n orientation\n });\n const trackRef = useRef2(null);\n const thumbRef = useRef2(null);\n const rootRef = useRef2(null);\n const reactId = useId2();\n const uuid = idProp ?? reactId;\n const [thumbId, trackId] = [`slider-thumb-${uuid}`, `slider-track-${uuid}`];\n const getValueFromPointer = useCallback2((event) => {\n var _a;\n if (!trackRef.current)\n return;\n const state = stateRef.current;\n state.eventSource = \"pointer\";\n const trackRect = trackRef.current.getBoundingClientRect();\n const { clientX, clientY } = ((_a = event.touches) == null ? void 0 : _a[0]) ?? event;\n const diff = isVertical ? trackRect.bottom - clientY : clientX - trackRect.left;\n const length = isVertical ? trackRect.height : trackRect.width;\n let percent = diff / length;\n if (isReversed) {\n percent = 1 - percent;\n }\n let nextValue = percentToValue2(percent, state.min, state.max);\n if (state.step) {\n nextValue = parseFloat(roundValueToStep2(nextValue, state.min, state.step));\n }\n nextValue = clampValue2(nextValue, state.min, state.max);\n return nextValue;\n }, [isVertical, isReversed, stateRef]);\n const constrain = useCallback2((value2) => {\n const state = stateRef.current;\n if (!state.isInteractive)\n return;\n value2 = parseFloat(roundValueToStep2(value2, state.min, oneStep));\n value2 = clampValue2(value2, state.min, state.max);\n setValue(value2);\n }, [oneStep, setValue, stateRef]);\n const actions = useMemo3(() => ({\n stepUp(step2 = oneStep) {\n const next = isReversed ? value - step2 : value + step2;\n constrain(next);\n },\n stepDown(step2 = oneStep) {\n const next = isReversed ? value + step2 : value - step2;\n constrain(next);\n },\n reset() {\n constrain(defaultValue || 0);\n },\n stepTo(value2) {\n constrain(value2);\n }\n }), [constrain, isReversed, value, oneStep, defaultValue]);\n const onKeyDown = useCallback2((event) => {\n const state = stateRef.current;\n const keyMap = {\n ArrowRight: () => actions.stepUp(),\n ArrowUp: () => actions.stepUp(),\n ArrowLeft: () => actions.stepDown(),\n ArrowDown: () => actions.stepDown(),\n PageUp: () => actions.stepUp(tenSteps),\n PageDown: () => actions.stepDown(tenSteps),\n Home: () => constrain(state.min),\n End: () => constrain(state.max)\n };\n const action = keyMap[event.key];\n if (action) {\n event.preventDefault();\n event.stopPropagation();\n action(event);\n state.eventSource = \"keyboard\";\n }\n }, [actions, constrain, tenSteps, stateRef]);\n const valueText = (getAriaValueText == null ? void 0 : getAriaValueText(value)) ?? ariaValueText;\n const thumbSize = useSize(thumbRef);\n const { getThumbStyle, rootStyle, trackStyle, innerTrackStyle } = useMemo3(() => {\n const state = stateRef.current;\n const thumbRect = thumbSize ?? { width: 0, height: 0 };\n return getStyles({\n isReversed,\n orientation: state.orientation,\n thumbRects: [thumbRect],\n thumbPercents: [thumbPercent]\n });\n }, [isReversed, thumbSize, thumbPercent, stateRef]);\n const focusThumb = useCallback2(() => {\n const state = stateRef.current;\n if (state.focusThumbOnChange) {\n setTimeout(() => {\n var _a;\n return (_a = thumbRef.current) == null ? void 0 : _a.focus();\n });\n }\n }, [stateRef]);\n useUpdateEffect2(() => {\n const state = stateRef.current;\n focusThumb();\n if (state.eventSource === \"keyboard\") {\n onChangeEnd == null ? void 0 : onChangeEnd(state.value);\n }\n }, [value, onChangeEnd]);\n function setValueFromPointer(event) {\n const nextValue = getValueFromPointer(event);\n if (nextValue != null && nextValue !== stateRef.current.value) {\n setValue(nextValue);\n }\n }\n usePanEvent2(rootRef, {\n onPanSessionStart(event) {\n const state = stateRef.current;\n if (!state.isInteractive)\n return;\n setDragging(true);\n focusThumb();\n setValueFromPointer(event);\n onChangeStart == null ? void 0 : onChangeStart(state.value);\n },\n onPanSessionEnd() {\n const state = stateRef.current;\n if (!state.isInteractive)\n return;\n setDragging(false);\n onChangeEnd == null ? void 0 : onChangeEnd(state.value);\n },\n onPan(event) {\n const state = stateRef.current;\n if (!state.isInteractive)\n return;\n setValueFromPointer(event);\n }\n });\n const getRootProps = useCallback2((props2 = {}, ref = null) => {\n return {\n ...props2,\n ...htmlProps,\n ref: mergeRefs2(ref, rootRef),\n tabIndex: -1,\n \"aria-disabled\": ariaAttr(isDisabled),\n \"data-focused\": dataAttr(isFocused),\n style: {\n ...props2.style,\n ...rootStyle\n }\n };\n }, [htmlProps, isDisabled, isFocused, rootStyle]);\n const getTrackProps = useCallback2((props2 = {}, ref = null) => {\n return {\n ...props2,\n ref: mergeRefs2(ref, trackRef),\n id: trackId,\n \"data-disabled\": dataAttr(isDisabled),\n style: {\n ...props2.style,\n ...trackStyle\n }\n };\n }, [isDisabled, trackId, trackStyle]);\n const getInnerTrackProps = useCallback2((props2 = {}, ref = null) => {\n return {\n ...props2,\n ref,\n style: {\n ...props2.style,\n ...innerTrackStyle\n }\n };\n }, [innerTrackStyle]);\n const getThumbProps = useCallback2((props2 = {}, ref = null) => {\n return {\n ...props2,\n ref: mergeRefs2(ref, thumbRef),\n role: \"slider\",\n tabIndex: isInteractive ? 0 : void 0,\n id: thumbId,\n \"data-active\": dataAttr(isDragging),\n \"aria-valuetext\": valueText,\n \"aria-valuemin\": min,\n \"aria-valuemax\": max,\n \"aria-valuenow\": value,\n \"aria-orientation\": orientation,\n \"aria-disabled\": ariaAttr(isDisabled),\n \"aria-readonly\": ariaAttr(isReadOnly),\n \"aria-label\": ariaLabel,\n \"aria-labelledby\": ariaLabel ? void 0 : ariaLabelledBy,\n style: {\n ...props2.style,\n ...getThumbStyle(0)\n },\n onKeyDown: callAllHandlers(props2.onKeyDown, onKeyDown),\n onFocus: callAllHandlers(props2.onFocus, () => setFocused(true)),\n onBlur: callAllHandlers(props2.onBlur, () => setFocused(false))\n };\n }, [\n isInteractive,\n thumbId,\n isDragging,\n valueText,\n min,\n max,\n value,\n orientation,\n isDisabled,\n isReadOnly,\n ariaLabel,\n ariaLabelledBy,\n getThumbStyle,\n onKeyDown\n ]);\n const getMarkerProps = useCallback2((props2, ref = null) => {\n const isInRange = !(props2.value < min || props2.value > max);\n const isHighlighted = value >= props2.value;\n const markerPercent = valueToPercent2(props2.value, min, max);\n const markerStyle = {\n position: \"absolute\",\n pointerEvents: \"none\",\n ...orient2({\n orientation,\n vertical: {\n bottom: isReversed ? `${100 - markerPercent}%` : `${markerPercent}%`\n },\n horizontal: {\n left: isReversed ? `${100 - markerPercent}%` : `${markerPercent}%`\n }\n })\n };\n return {\n ...props2,\n ref,\n role: \"presentation\",\n \"aria-hidden\": true,\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(!isInRange),\n \"data-highlighted\": dataAttr(isHighlighted),\n style: {\n ...props2.style,\n ...markerStyle\n }\n };\n }, [isDisabled, isReversed, max, min, orientation, value]);\n const getInputProps = useCallback2((props2 = {}, ref = null) => {\n return {\n ...props2,\n ref,\n type: \"hidden\",\n value,\n name\n };\n }, [name, value]);\n return {\n state: { value, isFocused, isDragging },\n actions,\n getRootProps,\n getTrackProps,\n getInnerTrackProps,\n getThumbProps,\n getMarkerProps,\n getInputProps\n };\n}\nfunction orient2(options) {\n const { orientation, vertical, horizontal } = options;\n return orientation === \"vertical\" ? vertical : horizontal;\n}\nfunction getDefaultValue(min, max) {\n return max < min ? min : min + (max - min) / 2;\n}\n\n// src/slider.tsx\nvar [SliderProvider, useSliderContext] = createContext2({\n name: \"SliderContext\",\n hookName: \"useSliderContext\",\n providerName: \"\"\n});\nvar [SliderStylesProvider, useSliderStyles] = createContext2({\n name: `SliderStylesContext`,\n hookName: `useSliderStyles`,\n providerName: \"\"\n});\nvar Slider = forwardRef2((props, ref) => {\n const styles = useMultiStyleConfig2(\"Slider\", props);\n const ownProps = omitThemingProps2(props);\n const { direction } = useTheme2();\n ownProps.direction = direction;\n const { getInputProps, getRootProps, ...context } = useSlider(ownProps);\n const rootProps = getRootProps();\n const inputProps = getInputProps({}, ref);\n return /* @__PURE__ */ React.createElement(SliderProvider, {\n value: context\n }, /* @__PURE__ */ React.createElement(SliderStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra2.div, {\n ...rootProps,\n className: cx(\"chakra-slider\", props.className),\n __css: styles.container\n }, props.children, /* @__PURE__ */ React.createElement(\"input\", {\n ...inputProps\n }))));\n});\nSlider.defaultProps = {\n orientation: \"horizontal\"\n};\nSlider.displayName = \"Slider\";\nvar SliderThumb = forwardRef2((props, ref) => {\n const { getThumbProps } = useSliderContext();\n const styles = useSliderStyles();\n const thumbProps = getThumbProps(props, ref);\n return /* @__PURE__ */ React.createElement(chakra2.div, {\n ...thumbProps,\n className: cx(\"chakra-slider__thumb\", props.className),\n __css: styles.thumb\n });\n});\nSliderThumb.displayName = \"SliderThumb\";\nvar SliderTrack = forwardRef2((props, ref) => {\n const { getTrackProps } = useSliderContext();\n const styles = useSliderStyles();\n const trackProps = getTrackProps(props, ref);\n return /* @__PURE__ */ React.createElement(chakra2.div, {\n ...trackProps,\n className: cx(\"chakra-slider__track\", props.className),\n __css: styles.track\n });\n});\nSliderTrack.displayName = \"SliderTrack\";\nvar SliderFilledTrack = forwardRef2((props, ref) => {\n const { getInnerTrackProps } = useSliderContext();\n const styles = useSliderStyles();\n const trackProps = getInnerTrackProps(props, ref);\n return /* @__PURE__ */ React.createElement(chakra2.div, {\n ...trackProps,\n className: cx(\"chakra-slider__filled-track\", props.className),\n __css: styles.filledTrack\n });\n});\nSliderFilledTrack.displayName = \"SliderFilledTrack\";\nvar SliderMark = forwardRef2((props, ref) => {\n const { getMarkerProps } = useSliderContext();\n const styles = useSliderStyles();\n const markProps = getMarkerProps(props, ref);\n return /* @__PURE__ */ React.createElement(chakra2.div, {\n ...markProps,\n className: cx(\"chakra-slider__marker\", props.className),\n __css: styles.mark\n });\n});\nSliderMark.displayName = \"SliderMark\";\nexport {\n RangeSlider,\n RangeSliderFilledTrack,\n RangeSliderMark,\n RangeSliderProvider,\n RangeSliderThumb,\n RangeSliderTrack,\n Slider,\n SliderFilledTrack,\n SliderMark,\n SliderProvider,\n SliderThumb,\n SliderTrack,\n useRangeSlider,\n useRangeSliderContext,\n useRangeSliderStyles,\n useSlider,\n useSliderContext,\n useSliderStyles\n};\n","// src/index.ts\nimport {\n createContext as createReactContext,\n useContext as useReactContext\n} from \"react\";\nfunction getErrorMessage(hook, provider) {\n return `${hook} returned \\`undefined\\`. Seems you forgot to wrap component within ${provider}`;\n}\nfunction createContext(options = {}) {\n const {\n name,\n strict = true,\n hookName = \"useContext\",\n providerName = \"Provider\",\n errorMessage\n } = options;\n const Context = createReactContext(void 0);\n Context.displayName = name;\n function useContext() {\n var _a;\n const context = useReactContext(Context);\n if (!context && strict) {\n const error = new Error(errorMessage ?? getErrorMessage(hookName, providerName));\n error.name = \"ContextError\";\n (_a = Error.captureStackTrace) == null ? void 0 : _a.call(Error, error, useContext);\n throw error;\n }\n return context;\n }\n return [Context.Provider, useContext, Context];\n}\nexport {\n createContext\n};\n","// src/index.ts\nimport { useMemo } from \"react\";\nfunction assignRef(ref, value) {\n if (ref == null)\n return;\n if (typeof ref === \"function\") {\n ref(value);\n return;\n }\n try {\n ref.current = value;\n } catch (error) {\n throw new Error(`Cannot assign value '${value}' to ref '${ref}'`);\n }\n}\nfunction mergeRefs(...refs) {\n return (node) => {\n refs.forEach((ref) => {\n assignRef(ref, node);\n });\n };\n}\nfunction useMergeRefs(...refs) {\n return useMemo(() => mergeRefs(...refs), refs);\n}\nexport {\n assignRef,\n mergeRefs,\n useMergeRefs\n};\n","// src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nfunction isDev() {\n return process.env.NODE_ENV !== \"production\";\n}\nfunction isObject(value) {\n const type = typeof value;\n return value != null && (type === \"object\" || type === \"function\") && !Array.isArray(value);\n}\nvar warn = (options) => {\n const { condition, message } = options;\n if (condition && isDev()) {\n console.warn(message);\n }\n};\nfunction runIfFn(valueOrFn, ...args) {\n return isFunction(valueOrFn) ? valueOrFn(...args) : valueOrFn;\n}\nvar isFunction = (value) => typeof value === \"function\";\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\nfunction callAll(...fns) {\n return function mergedFn(arg) {\n fns.forEach((fn) => {\n fn == null ? void 0 : fn(arg);\n });\n };\n}\nexport {\n ariaAttr,\n callAll,\n callAllHandlers,\n cx,\n dataAttr,\n isObject,\n runIfFn,\n warn\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/icon.tsx\nimport {\n chakra,\n forwardRef\n} from \"@chakra-ui/system\";\nimport { cx } from \"@chakra-ui/shared-utils\";\nvar fallbackIcon = {\n path: /* @__PURE__ */ React.createElement(\"g\", {\n stroke: \"currentColor\",\n strokeWidth: \"1.5\"\n }, /* @__PURE__ */ React.createElement(\"path\", {\n strokeLinecap: \"round\",\n fill: \"none\",\n d: \"M9,9a3,3,0,1,1,4,2.829,1.5,1.5,0,0,0-1,1.415V14.25\"\n }), /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n strokeLinecap: \"round\",\n d: \"M12,17.25a.375.375,0,1,0,.375.375A.375.375,0,0,0,12,17.25h0\"\n }), /* @__PURE__ */ React.createElement(\"circle\", {\n fill: \"none\",\n strokeMiterlimit: \"10\",\n cx: \"12\",\n cy: \"12\",\n r: \"11.25\"\n })),\n viewBox: \"0 0 24 24\"\n};\nvar Icon = forwardRef((props, ref) => {\n const {\n as: element,\n viewBox,\n color = \"currentColor\",\n focusable = false,\n children,\n className,\n __css,\n ...rest\n } = props;\n const _className = cx(\"chakra-icon\", className);\n const styles = {\n w: \"1em\",\n h: \"1em\",\n display: \"inline-block\",\n lineHeight: \"1em\",\n flexShrink: 0,\n color,\n ...__css\n };\n const shared = {\n ref,\n focusable,\n className: _className,\n __css: styles\n };\n const _viewBox = viewBox ?? fallbackIcon.viewBox;\n if (element && typeof element !== \"string\") {\n return /* @__PURE__ */ React.createElement(chakra.svg, {\n as: element,\n ...shared,\n ...rest\n });\n }\n const _path = children ?? fallbackIcon.path;\n return /* @__PURE__ */ React.createElement(chakra.svg, {\n verticalAlign: \"middle\",\n viewBox: _viewBox,\n ...shared,\n ...rest\n }, _path);\n});\nIcon.displayName = \"Icon\";\nvar icon_default = Icon;\n\n// src/create-icon.tsx\nimport { forwardRef as forwardRef2 } from \"@chakra-ui/system\";\nimport { Children } from \"react\";\nfunction createIcon(options) {\n const {\n viewBox = \"0 0 24 24\",\n d: pathDefinition,\n displayName,\n defaultProps = {}\n } = options;\n const path = Children.toArray(options.path);\n const Comp = forwardRef2((props, ref) => /* @__PURE__ */ React.createElement(Icon, {\n ref,\n viewBox,\n ...defaultProps,\n ...props\n }, path.length ? path : /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: pathDefinition\n })));\n Comp.displayName = displayName;\n return Comp;\n}\nexport {\n Icon,\n createIcon,\n icon_default as default\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/form-control.tsx\nimport { createContext } from \"@chakra-ui/react-context\";\nimport { mergeRefs } from \"@chakra-ui/react-use-merge-refs\";\nimport {\n chakra,\n forwardRef,\n omitThemingProps,\n useMultiStyleConfig\n} from \"@chakra-ui/system\";\n\n// ../../utilities/shared-utils/src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\nvar dataAttr = (condition) => condition ? \"\" : void 0;\nvar ariaAttr = (condition) => condition ? true : void 0;\nfunction callAllHandlers(...fns) {\n return function func(event) {\n fns.some((fn) => {\n fn == null ? void 0 : fn(event);\n return event == null ? void 0 : event.defaultPrevented;\n });\n };\n}\n\n// src/form-control.tsx\nimport { useCallback, useId, useState } from \"react\";\nvar [FormControlStylesProvider, useFormControlStyles] = createContext({\n name: `FormControlStylesContext`,\n errorMessage: `useFormControlStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar [FormControlProvider, useFormControlContext] = createContext({\n strict: false,\n name: \"FormControlContext\"\n});\nfunction useFormControlProvider(props) {\n const {\n id: idProp,\n isRequired,\n isInvalid,\n isDisabled,\n isReadOnly,\n ...htmlProps\n } = props;\n const uuid = useId();\n const id = idProp || `field-${uuid}`;\n const labelId = `${id}-label`;\n const feedbackId = `${id}-feedback`;\n const helpTextId = `${id}-helptext`;\n const [hasFeedbackText, setHasFeedbackText] = useState(false);\n const [hasHelpText, setHasHelpText] = useState(false);\n const [isFocused, setFocus] = useState(false);\n const getHelpTextProps = useCallback((props2 = {}, forwardedRef = null) => ({\n id: helpTextId,\n ...props2,\n ref: mergeRefs(forwardedRef, (node) => {\n if (!node)\n return;\n setHasHelpText(true);\n })\n }), [helpTextId]);\n const getLabelProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ref: forwardedRef,\n \"data-focus\": dataAttr(isFocused),\n \"data-disabled\": dataAttr(isDisabled),\n \"data-invalid\": dataAttr(isInvalid),\n \"data-readonly\": dataAttr(isReadOnly),\n id: props2.id ?? labelId,\n htmlFor: props2.htmlFor ?? id\n }), [id, isDisabled, isFocused, isInvalid, isReadOnly, labelId]);\n const getErrorMessageProps = useCallback((props2 = {}, forwardedRef = null) => ({\n id: feedbackId,\n ...props2,\n ref: mergeRefs(forwardedRef, (node) => {\n if (!node)\n return;\n setHasFeedbackText(true);\n }),\n \"aria-live\": \"polite\"\n }), [feedbackId]);\n const getRootProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ...htmlProps,\n ref: forwardedRef,\n role: \"group\"\n }), [htmlProps]);\n const getRequiredIndicatorProps = useCallback((props2 = {}, forwardedRef = null) => ({\n ...props2,\n ref: forwardedRef,\n role: \"presentation\",\n \"aria-hidden\": true,\n children: props2.children || \"*\"\n }), []);\n return {\n isRequired: !!isRequired,\n isInvalid: !!isInvalid,\n isReadOnly: !!isReadOnly,\n isDisabled: !!isDisabled,\n isFocused: !!isFocused,\n onFocus: () => setFocus(true),\n onBlur: () => setFocus(false),\n hasFeedbackText,\n setHasFeedbackText,\n hasHelpText,\n setHasHelpText,\n id,\n labelId,\n feedbackId,\n helpTextId,\n htmlProps,\n getHelpTextProps,\n getErrorMessageProps,\n getRootProps,\n getLabelProps,\n getRequiredIndicatorProps\n };\n}\nvar FormControl = forwardRef(function FormControl2(props, ref) {\n const styles = useMultiStyleConfig(\"Form\", props);\n const ownProps = omitThemingProps(props);\n const {\n getRootProps,\n htmlProps: _,\n ...context\n } = useFormControlProvider(ownProps);\n const className = cx(\"chakra-form-control\", props.className);\n return /* @__PURE__ */ React.createElement(FormControlProvider, {\n value: context\n }, /* @__PURE__ */ React.createElement(FormControlStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra.div, {\n ...getRootProps({}, ref),\n className,\n __css: styles[\"container\"]\n })));\n});\nFormControl.displayName = \"FormControl\";\nvar FormHelperText = forwardRef(function FormHelperText2(props, ref) {\n const field = useFormControlContext();\n const styles = useFormControlStyles();\n const className = cx(\"chakra-form__helper-text\", props.className);\n return /* @__PURE__ */ React.createElement(chakra.div, {\n ...field == null ? void 0 : field.getHelpTextProps(props, ref),\n __css: styles.helperText,\n className\n });\n});\nFormHelperText.displayName = \"FormHelperText\";\n\n// src/use-form-control.ts\nfunction useFormControl(props) {\n const { isDisabled, isInvalid, isReadOnly, isRequired, ...rest } = useFormControlProps(props);\n return {\n ...rest,\n disabled: isDisabled,\n readOnly: isReadOnly,\n required: isRequired,\n \"aria-invalid\": ariaAttr(isInvalid),\n \"aria-required\": ariaAttr(isRequired),\n \"aria-readonly\": ariaAttr(isReadOnly)\n };\n}\nfunction useFormControlProps(props) {\n const field = useFormControlContext();\n const {\n id,\n disabled,\n readOnly,\n required,\n isRequired,\n isInvalid,\n isReadOnly,\n isDisabled,\n onFocus,\n onBlur,\n ...rest\n } = props;\n const labelIds = props[\"aria-describedby\"] ? [props[\"aria-describedby\"]] : [];\n if ((field == null ? void 0 : field.hasFeedbackText) && (field == null ? void 0 : field.isInvalid)) {\n labelIds.push(field.feedbackId);\n }\n if (field == null ? void 0 : field.hasHelpText) {\n labelIds.push(field.helpTextId);\n }\n return {\n ...rest,\n \"aria-describedby\": labelIds.join(\" \") || void 0,\n id: id ?? (field == null ? void 0 : field.id),\n isDisabled: disabled ?? isDisabled ?? (field == null ? void 0 : field.isDisabled),\n isReadOnly: readOnly ?? isReadOnly ?? (field == null ? void 0 : field.isReadOnly),\n isRequired: required ?? isRequired ?? (field == null ? void 0 : field.isRequired),\n isInvalid: isInvalid ?? (field == null ? void 0 : field.isInvalid),\n onFocus: callAllHandlers(field == null ? void 0 : field.onFocus, onFocus),\n onBlur: callAllHandlers(field == null ? void 0 : field.onBlur, onBlur)\n };\n}\n\n// src/form-error.tsx\nimport { Icon } from \"@chakra-ui/icon\";\nimport { createContext as createContext2 } from \"@chakra-ui/react-context\";\nimport {\n chakra as chakra2,\n forwardRef as forwardRef2,\n omitThemingProps as omitThemingProps2,\n useMultiStyleConfig as useMultiStyleConfig2\n} from \"@chakra-ui/system\";\nvar [FormErrorStylesProvider, useFormErrorStyles] = createContext2({\n name: `FormErrorStylesContext`,\n errorMessage: `useFormErrorStyles returned is 'undefined'. Seems you forgot to wrap the components in \"\" `\n});\nvar FormErrorMessage = forwardRef2((props, ref) => {\n const styles = useMultiStyleConfig2(\"FormError\", props);\n const ownProps = omitThemingProps2(props);\n const field = useFormControlContext();\n if (!(field == null ? void 0 : field.isInvalid))\n return null;\n return /* @__PURE__ */ React.createElement(FormErrorStylesProvider, {\n value: styles\n }, /* @__PURE__ */ React.createElement(chakra2.div, {\n ...field == null ? void 0 : field.getErrorMessageProps(ownProps, ref),\n className: cx(\"chakra-form__error-message\", props.className),\n __css: {\n display: \"flex\",\n alignItems: \"center\",\n ...styles.text\n }\n }));\n});\nFormErrorMessage.displayName = \"FormErrorMessage\";\nvar FormErrorIcon = forwardRef2((props, ref) => {\n const styles = useFormErrorStyles();\n const field = useFormControlContext();\n if (!(field == null ? void 0 : field.isInvalid))\n return null;\n const _className = cx(\"chakra-form__error-icon\", props.className);\n return /* @__PURE__ */ React.createElement(Icon, {\n ref,\n \"aria-hidden\": true,\n ...props,\n __css: styles.icon,\n className: _className\n }, /* @__PURE__ */ React.createElement(\"path\", {\n fill: \"currentColor\",\n d: \"M11.983,0a12.206,12.206,0,0,0-8.51,3.653A11.8,11.8,0,0,0,0,12.207,11.779,11.779,0,0,0,11.8,24h.214A12.111,12.111,0,0,0,24,11.791h0A11.766,11.766,0,0,0,11.983,0ZM10.5,16.542a1.476,1.476,0,0,1,1.449-1.53h.027a1.527,1.527,0,0,1,1.523,1.47,1.475,1.475,0,0,1-1.449,1.53h-.027A1.529,1.529,0,0,1,10.5,16.542ZM11,12.5v-6a1,1,0,0,1,2,0v6a1,1,0,1,1-2,0Z\"\n }));\n});\nFormErrorIcon.displayName = \"FormErrorIcon\";\n\n// src/form-label.tsx\nimport {\n chakra as chakra3,\n forwardRef as forwardRef3,\n omitThemingProps as omitThemingProps3,\n useStyleConfig\n} from \"@chakra-ui/system\";\nvar FormLabel = forwardRef3(function FormLabel2(passedProps, ref) {\n const styles = useStyleConfig(\"FormLabel\", passedProps);\n const props = omitThemingProps3(passedProps);\n const {\n className,\n children,\n requiredIndicator = /* @__PURE__ */ React.createElement(RequiredIndicator, null),\n optionalIndicator = null,\n ...rest\n } = props;\n const field = useFormControlContext();\n const ownProps = (field == null ? void 0 : field.getLabelProps(rest, ref)) ?? { ref, ...rest };\n return /* @__PURE__ */ React.createElement(chakra3.label, {\n ...ownProps,\n className: cx(\"chakra-form__label\", props.className),\n __css: {\n display: \"block\",\n textAlign: \"start\",\n ...styles\n }\n }, children, (field == null ? void 0 : field.isRequired) ? requiredIndicator : optionalIndicator);\n});\nFormLabel.displayName = \"FormLabel\";\nvar RequiredIndicator = forwardRef3(function RequiredIndicator2(props, ref) {\n const field = useFormControlContext();\n const styles = useFormControlStyles();\n if (!(field == null ? void 0 : field.isRequired))\n return null;\n const className = cx(\"chakra-form__required-indicator\", props.className);\n return /* @__PURE__ */ React.createElement(chakra3.span, {\n ...field == null ? void 0 : field.getRequiredIndicatorProps(props, ref),\n __css: styles.requiredIndicator,\n className\n });\n});\nRequiredIndicator.displayName = \"RequiredIndicator\";\nexport {\n FormControl,\n FormErrorIcon,\n FormErrorMessage,\n FormHelperText,\n FormLabel,\n RequiredIndicator,\n useFormControl,\n useFormControlContext,\n useFormControlProps,\n useFormControlStyles,\n useFormErrorStyles\n};\n","// ../../../react-shim.js\nimport React from \"react\";\n\n// src/textarea.tsx\nimport { useFormControl } from \"@chakra-ui/form-control\";\nimport {\n chakra,\n forwardRef,\n omitThemingProps,\n useStyleConfig\n} from \"@chakra-ui/system\";\n\n// ../../utilities/shared-utils/src/index.ts\nvar cx = (...classNames) => classNames.filter(Boolean).join(\" \");\n\n// ../../utilities/object-utils/src/index.ts\nfunction omit(object, keysToOmit = []) {\n const clone = Object.assign({}, object);\n for (const key of keysToOmit) {\n if (key in clone)\n delete clone[key];\n }\n return clone;\n}\n\n// src/textarea.tsx\nvar omitted = [\"h\", \"minH\", \"height\", \"minHeight\"];\nvar Textarea = forwardRef((props, ref) => {\n const styles = useStyleConfig(\"Textarea\", props);\n const { className, rows, ...rest } = omitThemingProps(props);\n const textareaProps = useFormControl(rest);\n const textareaStyles = rows ? omit(styles, omitted) : styles;\n return /* @__PURE__ */ React.createElement(chakra.textarea, {\n ref,\n rows,\n ...textareaProps,\n className: cx(\"chakra-textarea\", className),\n __css: textareaStyles\n });\n});\nTextarea.displayName = \"Textarea\";\nexport {\n Textarea\n};\n","// src/Warning.tsx\nimport { createIcon } from \"@chakra-ui/icon\";\nvar WarningIcon = createIcon({\n d: \"M11.983,0a12.206,12.206,0,0,0-8.51,3.653A11.8,11.8,0,0,0,0,12.207,11.779,11.779,0,0,0,11.8,24h.214A12.111,12.111,0,0,0,24,11.791h0A11.766,11.766,0,0,0,11.983,0ZM10.5,16.542a1.476,1.476,0,0,1,1.449-1.53h.027a1.527,1.527,0,0,1,1.523,1.47,1.475,1.475,0,0,1-1.449,1.53h-.027A1.529,1.529,0,0,1,10.5,16.542ZM11,12.5v-6a1,1,0,0,1,2,0v6a1,1,0,1,1-2,0Z\",\n displayName: \"WarningIcon\"\n});\n\nexport {\n WarningIcon\n};\n","// src/Copy.tsx\nimport { createIcon } from \"@chakra-ui/icon\";\nvar CopyIcon = createIcon({\n d: \"M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z\",\n displayName: \"CopyIcon\"\n});\n\nexport {\n CopyIcon\n};\n","// src/Delete.tsx\nimport { createIcon } from \"@chakra-ui/icon\";\nimport { jsx } from \"react/jsx-runtime\";\nvar DeleteIcon = createIcon({\n displayName: \"DeleteIcon\",\n path: /* @__PURE__ */ jsx(\"g\", { fill: \"currentColor\", children: /* @__PURE__ */ jsx(\"path\", { d: \"M19.452 7.5H4.547a.5.5 0 00-.5.545l1.287 14.136A2 2 0 007.326 24h9.347a2 2 0 001.992-1.819L19.95 8.045a.5.5 0 00-.129-.382.5.5 0 00-.369-.163zm-9.2 13a.75.75 0 01-1.5 0v-9a.75.75 0 011.5 0zm5 0a.75.75 0 01-1.5 0v-9a.75.75 0 011.5 0zM22 4h-4.75a.25.25 0 01-.25-.25V2.5A2.5 2.5 0 0014.5 0h-5A2.5 2.5 0 007 2.5v1.25a.25.25 0 01-.25.25H2a1 1 0 000 2h20a1 1 0 000-2zM9 3.75V2.5a.5.5 0 01.5-.5h5a.5.5 0 01.5.5v1.25a.25.25 0 01-.25.25h-5.5A.25.25 0 019 3.75z\" }) })\n});\n\nexport {\n DeleteIcon\n};\n","// src/Add.tsx\nimport { createIcon } from \"@chakra-ui/icon\";\nvar AddIcon = createIcon({\n d: \"M0,12a1.5,1.5,0,0,0,1.5,1.5h8.75a.25.25,0,0,1,.25.25V22.5a1.5,1.5,0,0,0,3,0V13.75a.25.25,0,0,1,.25-.25H22.5a1.5,1.5,0,0,0,0-3H13.75a.25.25,0,0,1-.25-.25V1.5a1.5,1.5,0,0,0-3,0v8.75a.25.25,0,0,1-.25.25H1.5A1.5,1.5,0,0,0,0,12Z\",\n displayName: \"AddIcon\"\n});\n\nexport {\n AddIcon\n};\n","// src/ArrowDown.tsx\nimport { createIcon } from \"@chakra-ui/icon\";\nvar ArrowDownIcon = createIcon({\n d: \"M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z\",\n displayName: \"ArrowDownIcon\"\n});\n\nexport {\n ArrowDownIcon\n};\n","// src/ArrowUp.tsx\nimport { createIcon } from \"@chakra-ui/icon\";\nvar ArrowUpIcon = createIcon({\n d: \"M4 12l1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z\",\n displayName: \"ArrowUpIcon\"\n});\n\nexport {\n ArrowUpIcon\n};\n","import { withTheme } from '@rjsf/core';\nimport { jsx, jsxs, Fragment } from 'react/jsx-runtime';\nimport { TranslatableString, getUiOptions, getTemplate, getInputProps, labelValue, examplesId, ariaDescribedByIds, errorId, helpId, titleId, descriptionId, canExpand, getSubmitButtonOptions, ADDITIONAL_PROPERTY_FLAG, parseDateString, toDateString, pad, schemaRequiresTrueValue, enumOptionsIndexForValue, enumOptionsValueForIndex, enumOptionsIsSelected, optionId, rangeSpec } from '@rjsf/utils';\nimport { Button, HStack, Box, ButtonGroup, Grid, GridItem, shouldForwardProp, FormControl, FormLabel, Input, Text, Alert, AlertTitle, List, ListItem, ListIcon, IconButton, FormErrorMessage, FormHelperText, Heading, Divider, Checkbox, CheckboxGroup, Stack, RadioGroup, Radio, Slider, SliderTrack, SliderFilledTrack, SliderThumb, Textarea, NumberInput, NumberInputField, NumberInputStepper, NumberIncrementStepper, NumberDecrementStepper, ChakraProvider } from '@chakra-ui/react';\nimport { AddIcon, WarningIcon, CopyIcon, ArrowDownIcon, ArrowUpIcon, DeleteIcon } from '@chakra-ui/icons';\nimport { useMemo, memo, useState, useEffect } from 'react';\nimport { Select } from 'chakra-react-select';\nimport { Global, CacheProvider } from '@emotion/react';\nimport createCache from '@emotion/cache';\nimport weakMemoize from '@emotion/weak-memoize';\n\nfunction _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\n\nvar _excluded$2 = [\"uiSchema\", \"registry\"];\nfunction AddButton(_ref) {\n var registry = _ref.registry,\n props = _objectWithoutPropertiesLoose(_ref, _excluded$2);\n var translateString = registry.translateString;\n return jsx(Button, _extends({\n leftIcon: jsx(AddIcon, {})\n }, props, {\n children: translateString(TranslatableString.AddItemButton)\n }));\n}\n\nfunction ArrayFieldItemTemplate(props) {\n var children = props.children,\n disabled = props.disabled,\n hasToolbar = props.hasToolbar,\n hasCopy = props.hasCopy,\n hasMoveDown = props.hasMoveDown,\n hasMoveUp = props.hasMoveUp,\n hasRemove = props.hasRemove,\n index = props.index,\n onCopyIndexClick = props.onCopyIndexClick,\n onDropIndexClick = props.onDropIndexClick,\n onReorderClick = props.onReorderClick,\n readonly = props.readonly,\n uiSchema = props.uiSchema,\n registry = props.registry;\n var _registry$templates$B = registry.templates.ButtonTemplates,\n CopyButton = _registry$templates$B.CopyButton,\n MoveDownButton = _registry$templates$B.MoveDownButton,\n MoveUpButton = _registry$templates$B.MoveUpButton,\n RemoveButton = _registry$templates$B.RemoveButton;\n var onCopyClick = useMemo(function () {\n return onCopyIndexClick(index);\n }, [index, onCopyIndexClick]);\n var onRemoveClick = useMemo(function () {\n return onDropIndexClick(index);\n }, [index, onDropIndexClick]);\n var onArrowUpClick = useMemo(function () {\n return onReorderClick(index, index - 1);\n }, [index, onReorderClick]);\n var onArrowDownClick = useMemo(function () {\n return onReorderClick(index, index + 1);\n }, [index, onReorderClick]);\n return jsxs(HStack, {\n alignItems: 'flex-end',\n py: 1,\n children: [jsx(Box, {\n w: '100%',\n children: children\n }), hasToolbar && jsx(Box, {\n children: jsxs(ButtonGroup, {\n isAttached: true,\n mb: 1,\n children: [(hasMoveUp || hasMoveDown) && jsx(MoveUpButton, {\n disabled: disabled || readonly || !hasMoveUp,\n onClick: onArrowUpClick,\n uiSchema: uiSchema,\n registry: registry\n }), (hasMoveUp || hasMoveDown) && jsx(MoveDownButton, {\n disabled: disabled || readonly || !hasMoveDown,\n onClick: onArrowDownClick,\n uiSchema: uiSchema,\n registry: registry\n }), hasCopy && jsx(CopyButton, {\n disabled: disabled || readonly,\n onClick: onCopyClick,\n uiSchema: uiSchema,\n registry: registry\n }), hasRemove && jsx(RemoveButton, {\n disabled: disabled || readonly,\n onClick: onRemoveClick,\n uiSchema: uiSchema,\n registry: registry\n })]\n })\n })]\n });\n}\n\nvar _excluded$1 = [\"key\"];\nfunction ArrayFieldTemplate(props) {\n var canAdd = props.canAdd,\n disabled = props.disabled,\n idSchema = props.idSchema,\n uiSchema = props.uiSchema,\n items = props.items,\n onAddClick = props.onAddClick,\n readonly = props.readonly,\n registry = props.registry,\n required = props.required,\n schema = props.schema,\n title = props.title;\n var uiOptions = getUiOptions(uiSchema);\n var ArrayFieldDescriptionTemplate = getTemplate('ArrayFieldDescriptionTemplate', registry, uiOptions);\n var ArrayFieldItemTemplate = getTemplate('ArrayFieldItemTemplate', registry, uiOptions);\n var ArrayFieldTitleTemplate = getTemplate('ArrayFieldTitleTemplate', registry, uiOptions);\n // Button templates are not overridden in the uiSchema\n var AddButton = registry.templates.ButtonTemplates.AddButton;\n return jsxs(Box, {\n children: [jsx(ArrayFieldTitleTemplate, {\n idSchema: idSchema,\n title: uiOptions.title || title,\n schema: schema,\n uiSchema: uiSchema,\n required: required,\n registry: registry\n }), jsx(ArrayFieldDescriptionTemplate, {\n idSchema: idSchema,\n description: uiOptions.description || schema.description,\n schema: schema,\n uiSchema: uiSchema,\n registry: registry\n }), jsxs(Grid, {\n children: [jsx(GridItem, {\n children: items.length > 0 && items.map(function (_ref) {\n var key = _ref.key,\n itemProps = _objectWithoutPropertiesLoose(_ref, _excluded$1);\n return jsx(ArrayFieldItemTemplate, _extends({}, itemProps), key);\n })\n }), canAdd && jsx(GridItem, {\n justifySelf: 'flex-end',\n children: jsx(Box, {\n mt: 2,\n children: jsx(AddButton, {\n className: 'array-item-add',\n onClick: onAddClick,\n disabled: disabled || readonly,\n uiSchema: uiSchema,\n registry: registry\n })\n })\n })]\n }, \"array-item-list-\" + idSchema.$id)]\n });\n}\n\nfunction getChakra(_ref) {\n var _ref$uiSchema = _ref.uiSchema,\n uiSchema = _ref$uiSchema === void 0 ? {} : _ref$uiSchema;\n var chakraProps = uiSchema['ui:options'] && uiSchema['ui:options'].chakra || {};\n Object.keys(chakraProps).forEach(function (key) {\n /**\r\n * Leveraging `shouldForwardProp` to remove props\r\n *\r\n * This is a utility function that's used in `@chakra-ui/react`'s factory function.\r\n * Normally, it prevents ChakraProps from being passed to the DOM.\r\n * In this case we just want to delete the unknown props. So we flip the boolean.\r\n */\n if (shouldForwardProp(key)) {\n delete chakraProps[key];\n }\n });\n return chakraProps;\n}\n\nfunction BaseInputTemplate(props) {\n var id = props.id,\n type = props.type,\n value = props.value,\n label = props.label,\n hideLabel = props.hideLabel,\n schema = props.schema,\n uiSchema = props.uiSchema,\n onChange = props.onChange,\n onChangeOverride = props.onChangeOverride,\n onBlur = props.onBlur,\n onFocus = props.onFocus,\n options = props.options,\n required = props.required,\n readonly = props.readonly,\n rawErrors = props.rawErrors,\n autofocus = props.autofocus,\n placeholder = props.placeholder,\n disabled = props.disabled;\n var inputProps = getInputProps(schema, type, options);\n var chakraProps = getChakra({\n uiSchema: uiSchema\n });\n var _onChange = function _onChange(_ref) {\n var value = _ref.target.value;\n return onChange(value === '' ? options.emptyValue : value);\n };\n var _onBlur = function _onBlur(_ref2) {\n var value = _ref2.target.value;\n return onBlur(id, value);\n };\n var _onFocus = function _onFocus(_ref3) {\n var value = _ref3.target.value;\n return onFocus(id, value);\n };\n return jsxs(FormControl, _extends({\n mb: 1\n }, chakraProps, {\n isDisabled: disabled || readonly,\n isRequired: required,\n isReadOnly: readonly,\n isInvalid: rawErrors && rawErrors.length > 0,\n children: [labelValue(jsx(FormLabel, {\n htmlFor: id,\n id: id + \"-label\",\n children: label\n }), hideLabel || !label), jsx(Input, _extends({\n id: id,\n name: id,\n value: value || value === 0 ? value : '',\n onChange: onChangeOverride || _onChange,\n onBlur: _onBlur,\n onFocus: _onFocus,\n autoFocus: autofocus,\n placeholder: placeholder\n }, inputProps, {\n list: schema.examples ? examplesId(id) : undefined,\n \"aria-describedby\": ariaDescribedByIds(id, !!schema.examples)\n })), Array.isArray(schema.examples) ? jsx(\"datalist\", {\n id: examplesId(id),\n children: schema.examples.concat(schema[\"default\"] && !schema.examples.includes(schema[\"default\"]) ? [schema[\"default\"]] : []).map(function (example) {\n return jsx(\"option\", {\n value: example\n }, example);\n })\n }) : null]\n }));\n}\n\nfunction DescriptionField(_ref) {\n var description = _ref.description,\n id = _ref.id;\n if (!description) {\n return null;\n }\n if (typeof description === 'string') {\n return jsx(Text, {\n id: id,\n mt: 2,\n mb: 4,\n children: description\n });\n }\n return jsx(Fragment, {\n children: description\n });\n}\n\nfunction ErrorList(_ref) {\n var errors = _ref.errors,\n registry = _ref.registry;\n var translateString = registry.translateString;\n return jsxs(Alert, {\n flexDirection: 'column',\n alignItems: 'flex-start',\n gap: 3,\n status: 'error',\n children: [jsx(AlertTitle, {\n children: translateString(TranslatableString.ErrorsLabel)\n }), jsx(List, {\n children: errors.map(function (error, i) {\n return jsxs(ListItem, {\n children: [jsx(ListIcon, {\n as: WarningIcon,\n color: 'red.500'\n }), error.stack]\n }, i);\n })\n })]\n });\n}\n\nvar _excluded = [\"icon\", \"iconType\", \"uiSchema\", \"registry\"];\nfunction ChakraIconButton(props) {\n var icon = props.icon,\n otherProps = _objectWithoutPropertiesLoose(props, _excluded);\n return jsx(IconButton, _extends({\n \"aria-label\": props.title\n }, otherProps, {\n icon: icon\n }));\n}\nChakraIconButton.displayName = 'ChakraIconButton';\nvar ChakraIconButton$1 = /*#__PURE__*/memo(ChakraIconButton);\n\nfunction CopyButton(props) {\n var translateString = props.registry.translateString;\n return jsx(ChakraIconButton$1, _extends({\n title: translateString(TranslatableString.CopyButton)\n }, props, {\n icon: jsx(CopyIcon, {})\n }));\n}\nfunction MoveDownButton(props) {\n var translateString = props.registry.translateString;\n return jsx(ChakraIconButton$1, _extends({\n title: translateString(TranslatableString.MoveDownButton)\n }, props, {\n icon: jsx(ArrowDownIcon, {})\n }));\n}\nfunction MoveUpButton(props) {\n var translateString = props.registry.translateString;\n return jsx(ChakraIconButton$1, _extends({\n title: translateString(TranslatableString.MoveUpButton)\n }, props, {\n icon: jsx(ArrowUpIcon, {})\n }));\n}\nfunction RemoveButton(props) {\n var translateString = props.registry.translateString;\n return jsx(ChakraIconButton$1, _extends({\n title: translateString(TranslatableString.RemoveButton)\n }, props, {\n icon: jsx(DeleteIcon, {})\n }));\n}\n\n/** The `FieldErrorTemplate` component renders the errors local to the particular field\r\n *\r\n * @param props - The `FieldErrorProps` for the errors being rendered\r\n */\nfunction FieldErrorTemplate(props) {\n var _props$errors = props.errors,\n errors = _props$errors === void 0 ? [] : _props$errors,\n idSchema = props.idSchema;\n if (errors.length === 0) {\n return null;\n }\n var id = errorId(idSchema);\n return jsx(List, {\n children: errors.map(function (error, i) {\n return jsx(ListItem, {\n children: jsx(FormErrorMessage, {\n id: id,\n children: error\n })\n }, i);\n })\n });\n}\n\n/** The `FieldHelpTemplate` component renders any help desired for a field\r\n *\r\n * @param props - The `FieldHelpProps` to be rendered\r\n */\nfunction FieldHelpTemplate(props) {\n var idSchema = props.idSchema,\n help = props.help;\n if (!help) {\n return null;\n }\n var id = helpId(idSchema);\n return jsx(FormHelperText, {\n id: id,\n children: help\n });\n}\n\nfunction FieldTemplate(props) {\n var id = props.id,\n children = props.children,\n classNames = props.classNames,\n style = props.style,\n disabled = props.disabled,\n displayLabel = props.displayLabel,\n hidden = props.hidden,\n label = props.label,\n onDropPropertyClick = props.onDropPropertyClick,\n onKeyChange = props.onKeyChange,\n readonly = props.readonly,\n registry = props.registry,\n required = props.required,\n _props$rawErrors = props.rawErrors,\n rawErrors = _props$rawErrors === void 0 ? [] : _props$rawErrors,\n errors = props.errors,\n help = props.help,\n rawDescription = props.rawDescription,\n schema = props.schema,\n uiSchema = props.uiSchema;\n var uiOptions = getUiOptions(uiSchema);\n var WrapIfAdditionalTemplate = getTemplate('WrapIfAdditionalTemplate', registry, uiOptions);\n if (hidden) {\n return jsx(\"div\", {\n style: {\n display: 'none'\n },\n children: children\n });\n }\n return jsx(WrapIfAdditionalTemplate, {\n classNames: classNames,\n style: style,\n disabled: disabled,\n id: id,\n label: label,\n onDropPropertyClick: onDropPropertyClick,\n onKeyChange: onKeyChange,\n readonly: readonly,\n required: required,\n schema: schema,\n uiSchema: uiSchema,\n registry: registry,\n children: jsxs(FormControl, {\n isRequired: required,\n isInvalid: rawErrors && rawErrors.length > 0,\n children: [children, displayLabel && rawDescription ? jsx(Text, {\n mt: 2,\n children: rawDescription\n }) : null, errors, help]\n })\n });\n}\n\nfunction ObjectFieldTemplate(props) {\n var description = props.description,\n title = props.title,\n properties = props.properties,\n required = props.required,\n disabled = props.disabled,\n readonly = props.readonly,\n uiSchema = props.uiSchema,\n idSchema = props.idSchema,\n schema = props.schema,\n formData = props.formData,\n onAddClick = props.onAddClick,\n registry = props.registry;\n var uiOptions = getUiOptions(uiSchema);\n var TitleFieldTemplate = getTemplate('TitleFieldTemplate', registry, uiOptions);\n var DescriptionFieldTemplate = getTemplate('DescriptionFieldTemplate', registry, uiOptions);\n // Button templates are not overridden in the uiSchema\n var AddButton = registry.templates.ButtonTemplates.AddButton;\n return jsxs(Fragment, {\n children: [title && jsx(TitleFieldTemplate, {\n id: titleId(idSchema),\n title: title,\n required: required,\n schema: schema,\n uiSchema: uiSchema,\n registry: registry\n }), description && jsx(DescriptionFieldTemplate, {\n id: descriptionId(idSchema),\n description: description,\n schema: schema,\n uiSchema: uiSchema,\n registry: registry\n }), jsxs(Grid, {\n gap: description ? 2 : 6,\n mb: 4,\n children: [properties.map(function (element, index) {\n return element.hidden ? element.content : jsx(GridItem, {\n children: element.content\n }, idSchema.$id + \"-\" + element.name + \"-\" + index);\n }), canExpand(schema, uiSchema, formData) && jsx(GridItem, {\n justifySelf: 'flex-end',\n children: jsx(AddButton, {\n className: 'object-property-expand',\n onClick: onAddClick(schema),\n disabled: disabled || readonly,\n uiSchema: uiSchema,\n registry: registry\n })\n })]\n })]\n });\n}\n\nfunction SubmitButton(_ref) {\n var uiSchema = _ref.uiSchema;\n var _getSubmitButtonOptio = getSubmitButtonOptions(uiSchema),\n submitText = _getSubmitButtonOptio.submitText,\n norender = _getSubmitButtonOptio.norender,\n submitButtonProps = _getSubmitButtonOptio.props;\n if (norender) {\n return null;\n }\n return jsx(Box, {\n marginTop: 3,\n children: jsx(Button, _extends({\n type: 'submit',\n variant: 'solid'\n }, submitButtonProps, {\n children: submitText\n }))\n });\n}\n\nfunction TitleField(_ref) {\n var id = _ref.id,\n title = _ref.title;\n return jsxs(Box, {\n id: id,\n mt: 1,\n mb: 4,\n children: [jsx(Heading, {\n as: 'h5',\n children: title\n }), jsx(Divider, {})]\n });\n}\n\nfunction WrapIfAdditionalTemplate(props) {\n var children = props.children,\n classNames = props.classNames,\n style = props.style,\n disabled = props.disabled,\n id = props.id,\n label = props.label,\n onDropPropertyClick = props.onDropPropertyClick,\n onKeyChange = props.onKeyChange,\n readonly = props.readonly,\n registry = props.registry,\n required = props.required,\n schema = props.schema,\n uiSchema = props.uiSchema;\n var templates = registry.templates,\n translateString = registry.translateString;\n // Button templates are not overridden in the uiSchema\n var RemoveButton = templates.ButtonTemplates.RemoveButton;\n var keyLabel = translateString(TranslatableString.KeyLabel, [label]);\n var additional = (ADDITIONAL_PROPERTY_FLAG in schema);\n if (!additional) {\n return jsx(\"div\", {\n className: classNames,\n style: style,\n children: children\n });\n }\n var handleBlur = function handleBlur(_ref) {\n var target = _ref.target;\n return onKeyChange(target.value);\n };\n return jsxs(Grid, {\n className: classNames,\n style: style,\n alignItems: 'center',\n gap: 2,\n children: [jsx(GridItem, {\n children: jsxs(FormControl, {\n isRequired: required,\n children: [jsx(FormLabel, {\n htmlFor: id + \"-key\",\n id: id + \"-key-label\",\n children: keyLabel\n }), jsx(Input, {\n defaultValue: label,\n disabled: disabled || readonly,\n id: id + \"-key\",\n name: id + \"-key\",\n onBlur: !readonly ? handleBlur : undefined,\n type: 'text',\n mb: 1\n })]\n })\n }), jsx(GridItem, {\n children: children\n }), jsx(GridItem, {\n children: jsx(RemoveButton, {\n disabled: disabled || readonly,\n onClick: onDropPropertyClick(label),\n uiSchema: uiSchema,\n registry: registry\n })\n })]\n }, id + \"-key\");\n}\n\nfunction generateTemplates() {\n return {\n ArrayFieldItemTemplate: ArrayFieldItemTemplate,\n ArrayFieldTemplate: ArrayFieldTemplate,\n BaseInputTemplate: BaseInputTemplate,\n ButtonTemplates: {\n CopyButton: CopyButton,\n AddButton: AddButton,\n MoveDownButton: MoveDownButton,\n MoveUpButton: MoveUpButton,\n RemoveButton: RemoveButton,\n SubmitButton: SubmitButton\n },\n DescriptionFieldTemplate: DescriptionField,\n ErrorListTemplate: ErrorList,\n FieldErrorTemplate: FieldErrorTemplate,\n FieldHelpTemplate: FieldHelpTemplate,\n FieldTemplate: FieldTemplate,\n ObjectFieldTemplate: ObjectFieldTemplate,\n TitleFieldTemplate: TitleField,\n WrapIfAdditionalTemplate: WrapIfAdditionalTemplate\n };\n}\nvar Templates = /*#__PURE__*/generateTemplates();\n\nvar rangeOptions = function rangeOptions(start, stop) {\n var options = [];\n for (var i = start; i <= stop; i++) {\n options.push({\n value: i,\n label: pad(i, 2)\n });\n }\n return options;\n};\nfunction DateElement(props) {\n var SelectWidget = props.registry.widgets.SelectWidget;\n var value = props.value ? props.value : undefined;\n return jsx(SelectWidget, _extends({}, props, {\n label: '',\n className: 'form-control',\n onChange: function onChange(elemValue) {\n return props.select(props.type, elemValue);\n },\n options: {\n enumOptions: rangeOptions(props.range[0], props.range[1])\n },\n placeholder: props.type,\n schema: {\n type: 'integer'\n },\n value: value,\n \"aria-describedby\": ariaDescribedByIds(props.name)\n }));\n}\nvar readyForChange = function readyForChange(state) {\n return Object.keys(state).every(function (key) {\n return typeof state[key] !== 'undefined' && state[key] !== -1;\n });\n};\nfunction AltDateWidget(props) {\n var autofocus = props.autofocus,\n disabled = props.disabled,\n id = props.id,\n onBlur = props.onBlur,\n onChange = props.onChange,\n onFocus = props.onFocus,\n options = props.options,\n readonly = props.readonly,\n registry = props.registry,\n showTime = props.showTime,\n value = props.value;\n var translateString = registry.translateString;\n var _useState = useState(parseDateString(value, showTime)),\n state = _useState[0],\n setState = _useState[1];\n useEffect(function () {\n setState(parseDateString(value, showTime));\n }, [showTime, value]);\n var handleChange = function handleChange(property, nextValue) {\n var _extends2;\n var nextState = _extends({}, state, (_extends2 = {}, _extends2[property] = typeof nextValue === 'undefined' ? -1 : nextValue, _extends2));\n if (readyForChange(nextState)) {\n onChange(toDateString(nextState, showTime));\n } else {\n setState(nextState);\n }\n };\n var handleNow = function handleNow(event) {\n event.preventDefault();\n if (disabled || readonly) {\n return;\n }\n var nextState = parseDateString(new Date().toJSON(), showTime);\n onChange(toDateString(nextState, showTime));\n };\n var handleClear = function handleClear(event) {\n event.preventDefault();\n if (disabled || readonly) {\n return;\n }\n onChange(undefined);\n };\n var dateElementProps = function dateElementProps() {\n var year = state.year,\n month = state.month,\n day = state.day,\n hour = state.hour,\n minute = state.minute,\n second = state.second;\n var data = [{\n type: 'year',\n range: options.yearsRange,\n value: year\n }, {\n type: 'month',\n range: [1, 12],\n value: month\n }, {\n type: 'day',\n range: [1, 31],\n value: day\n }];\n if (showTime) {\n data.push({\n type: 'hour',\n range: [0, 23],\n value: hour\n }, {\n type: 'minute',\n range: [0, 59],\n value: minute\n }, {\n type: 'second',\n range: [0, 59],\n value: second\n });\n }\n return data;\n };\n return jsxs(Box, {\n children: [jsx(Box, {\n display: 'flex',\n flexWrap: 'wrap',\n alignItems: 'center',\n justify: 'center',\n children: dateElementProps().map(function (elemProps, i) {\n var elemId = id + '_' + elemProps.type;\n return jsx(Box, {\n mr: '2',\n mb: '2',\n children: jsx(DateElement, _extends({}, props, elemProps, {\n autofocus: autofocus && i === 0,\n disabled: disabled,\n id: elemId,\n name: id,\n onBlur: onBlur,\n onFocus: onFocus,\n readonly: readonly,\n registry: registry,\n select: handleChange,\n value: elemProps.value < 0 ? '' : elemProps.value\n }))\n }, elemId);\n })\n }), jsxs(Box, {\n display: 'flex',\n children: [!options.hideNowButton && jsx(Button, {\n onClick: function onClick(e) {\n return handleNow(e);\n },\n mr: '2',\n children: translateString(TranslatableString.NowLabel)\n }), !options.hideClearButton && jsx(Button, {\n onClick: function onClick(e) {\n return handleClear(e);\n },\n children: translateString(TranslatableString.ClearLabel)\n })]\n })]\n });\n}\nAltDateWidget.defaultProps = {\n autofocus: false,\n disabled: false,\n readonly: false,\n showTime: false,\n options: {\n yearsRange: [1900, /*#__PURE__*/new Date().getFullYear() + 2]\n }\n};\n\nfunction AltDateTimeWidget(props) {\n var AltDateWidget = props.registry.widgets.AltDateWidget;\n return jsx(AltDateWidget, _extends({}, props, {\n showTime: true\n }));\n}\nAltDateTimeWidget.defaultProps = /*#__PURE__*/_extends({}, AltDateWidget.defaultProps, {\n showTime: true\n});\n\nfunction CheckboxWidget(props) {\n var id = props.id,\n value = props.value,\n disabled = props.disabled,\n readonly = props.readonly,\n onChange = props.onChange,\n onBlur = props.onBlur,\n onFocus = props.onFocus,\n label = props.label,\n hideLabel = props.hideLabel,\n registry = props.registry,\n options = props.options,\n uiSchema = props.uiSchema,\n schema = props.schema;\n var chakraProps = getChakra({\n uiSchema: uiSchema\n });\n // Because an unchecked checkbox will cause html5 validation to fail, only add\n // the \"required\" attribute if the field value must be \"true\", due to the\n // \"const\" or \"enum\" keywords\n var required = schemaRequiresTrueValue(schema);\n var DescriptionFieldTemplate = getTemplate('DescriptionFieldTemplate', registry, options);\n var description = options.description || schema.description;\n var _onChange = function _onChange(_ref) {\n var checked = _ref.target.checked;\n return onChange(checked);\n };\n var _onBlur = function _onBlur(_ref2) {\n var value = _ref2.target.value;\n return onBlur(id, value);\n };\n var _onFocus = function _onFocus(_ref3) {\n var value = _ref3.target.value;\n return onFocus(id, value);\n };\n return jsxs(FormControl, _extends({\n mb: 1\n }, chakraProps, {\n isRequired: required,\n children: [!hideLabel && !!description && jsx(DescriptionFieldTemplate, {\n id: descriptionId(id),\n description: description,\n schema: schema,\n uiSchema: uiSchema,\n registry: registry\n }), jsx(Checkbox, {\n id: id,\n name: id,\n isChecked: typeof value === 'undefined' ? false : value,\n isDisabled: disabled || readonly,\n onChange: _onChange,\n onBlur: _onBlur,\n onFocus: _onFocus,\n \"aria-describedby\": ariaDescribedByIds(id),\n children: labelValue(jsx(Text, {\n children: label\n }), hideLabel || !label)\n })]\n }));\n}\n\nfunction CheckboxesWidget(props) {\n var id = props.id,\n disabled = props.disabled,\n options = props.options,\n value = props.value,\n readonly = props.readonly,\n _onChange = props.onChange,\n onBlur = props.onBlur,\n onFocus = props.onFocus,\n required = props.required,\n label = props.label,\n hideLabel = props.hideLabel,\n uiSchema = props.uiSchema,\n _props$rawErrors = props.rawErrors,\n rawErrors = _props$rawErrors === void 0 ? [] : _props$rawErrors;\n var enumOptions = options.enumOptions,\n enumDisabled = options.enumDisabled,\n emptyValue = options.emptyValue;\n var chakraProps = getChakra({\n uiSchema: uiSchema\n });\n var checkboxesValues = Array.isArray(value) ? value : [value];\n var _onBlur = function _onBlur(_ref) {\n var value = _ref.target.value;\n return onBlur(id, enumOptionsValueForIndex(value, enumOptions, emptyValue));\n };\n var _onFocus = function _onFocus(_ref2) {\n var value = _ref2.target.value;\n return onFocus(id, enumOptionsValueForIndex(value, enumOptions, emptyValue));\n };\n var row = options ? options.inline : false;\n var selectedIndexes = enumOptionsIndexForValue(value, enumOptions, true);\n return jsxs(FormControl, _extends({\n mb: 1\n }, chakraProps, {\n isDisabled: disabled || readonly,\n isRequired: required,\n isReadOnly: readonly,\n isInvalid: rawErrors && rawErrors.length > 0,\n children: [labelValue(jsx(FormLabel, {\n htmlFor: id,\n id: id + \"-label\",\n children: label\n }), hideLabel || !label), jsx(CheckboxGroup, {\n onChange: function onChange(option) {\n return _onChange(enumOptionsValueForIndex(option, enumOptions, emptyValue));\n },\n defaultValue: selectedIndexes,\n \"aria-describedby\": ariaDescribedByIds(id),\n children: jsx(Stack, {\n direction: row ? 'row' : 'column',\n children: Array.isArray(enumOptions) && enumOptions.map(function (option, index) {\n var checked = enumOptionsIsSelected(option.value, checkboxesValues);\n var itemDisabled = Array.isArray(enumDisabled) && enumDisabled.indexOf(option.value) !== -1;\n return jsx(Checkbox, {\n id: optionId(id, index),\n name: id,\n value: String(index),\n isChecked: checked,\n isDisabled: disabled || itemDisabled || readonly,\n onBlur: _onBlur,\n onFocus: _onFocus,\n children: option.label && jsx(Text, {\n children: option.label\n })\n }, index);\n })\n })\n })]\n }));\n}\n\nfunction RadioWidget(_ref) {\n var _enumOptionsIndexForV;\n var id = _ref.id,\n options = _ref.options,\n value = _ref.value,\n required = _ref.required,\n disabled = _ref.disabled,\n readonly = _ref.readonly,\n label = _ref.label,\n hideLabel = _ref.hideLabel,\n onChange = _ref.onChange,\n onBlur = _ref.onBlur,\n onFocus = _ref.onFocus,\n uiSchema = _ref.uiSchema;\n var enumOptions = options.enumOptions,\n enumDisabled = options.enumDisabled,\n emptyValue = options.emptyValue;\n var chakraProps = getChakra({\n uiSchema: uiSchema\n });\n var _onChange = function _onChange(nextValue) {\n return onChange(enumOptionsValueForIndex(nextValue, enumOptions, emptyValue));\n };\n var _onBlur = function _onBlur(_ref2) {\n var value = _ref2.target.value;\n return onBlur(id, enumOptionsValueForIndex(value, enumOptions, emptyValue));\n };\n var _onFocus = function _onFocus(_ref3) {\n var value = _ref3.target.value;\n return onFocus(id, enumOptionsValueForIndex(value, enumOptions, emptyValue));\n };\n var row = options ? options.inline : false;\n var selectedIndex = (_enumOptionsIndexForV = enumOptionsIndexForValue(value, enumOptions)) != null ? _enumOptionsIndexForV : null;\n return jsxs(FormControl, _extends({\n mb: 1\n }, chakraProps, {\n isDisabled: disabled || readonly,\n isRequired: required,\n isReadOnly: readonly,\n children: [labelValue(jsx(FormLabel, {\n htmlFor: id,\n id: id + \"-label\",\n children: label\n }), hideLabel || !label), jsx(RadioGroup, {\n onChange: _onChange,\n onBlur: _onBlur,\n onFocus: _onFocus,\n value: selectedIndex,\n name: id,\n \"aria-describedby\": ariaDescribedByIds(id),\n children: jsx(Stack, {\n direction: row ? 'row' : 'column',\n children: Array.isArray(enumOptions) && enumOptions.map(function (option, index) {\n var itemDisabled = Array.isArray(enumDisabled) && enumDisabled.indexOf(option.value) !== -1;\n return jsx(Radio, {\n value: String(index),\n id: optionId(id, index),\n disabled: disabled || itemDisabled || readonly,\n children: option.label\n }, index);\n })\n })\n })]\n }));\n}\n\nfunction RangeWidget(_ref) {\n var value = _ref.value,\n readonly = _ref.readonly,\n disabled = _ref.disabled,\n onBlur = _ref.onBlur,\n onFocus = _ref.onFocus,\n options = _ref.options,\n schema = _ref.schema,\n uiSchema = _ref.uiSchema,\n onChange = _ref.onChange,\n label = _ref.label,\n hideLabel = _ref.hideLabel,\n id = _ref.id;\n var chakraProps = getChakra({\n uiSchema: uiSchema\n });\n var sliderWidgetProps = _extends({\n value: value,\n label: label,\n id: id\n }, rangeSpec(schema));\n var _onChange = function _onChange(value) {\n return onChange(value === undefined ? options.emptyValue : value);\n };\n var _onBlur = function _onBlur(_ref2) {\n var value = _ref2.target.value;\n return onBlur(id, value);\n };\n var _onFocus = function _onFocus(_ref3) {\n var value = _ref3.target.value;\n return onFocus(id, value);\n };\n return jsxs(FormControl, _extends({\n mb: 1\n }, chakraProps, {\n children: [labelValue(jsx(FormLabel, {\n htmlFor: id,\n children: label\n }), hideLabel || !label), jsxs(Slider, _extends({}, sliderWidgetProps, {\n id: id,\n name: id,\n isDisabled: disabled || readonly,\n onChange: _onChange,\n onBlur: _onBlur,\n onFocus: _onFocus,\n \"aria-describedby\": ariaDescribedByIds(id),\n children: [jsx(SliderTrack, {\n children: jsx(SliderFilledTrack, {})\n }), jsx(SliderThumb, {})]\n }))]\n }));\n}\n\nfunction SelectWidget(props) {\n var id = props.id,\n options = props.options,\n label = props.label,\n hideLabel = props.hideLabel,\n placeholder = props.placeholder,\n multiple = props.multiple,\n required = props.required,\n disabled = props.disabled,\n readonly = props.readonly,\n value = props.value,\n autofocus = props.autofocus,\n onChange = props.onChange,\n onBlur = props.onBlur,\n onFocus = props.onFocus,\n _props$rawErrors = props.rawErrors,\n rawErrors = _props$rawErrors === void 0 ? [] : _props$rawErrors,\n uiSchema = props.uiSchema;\n var enumOptions = options.enumOptions,\n enumDisabled = options.enumDisabled,\n emptyValue = options.emptyValue;\n var chakraProps = getChakra({\n uiSchema: uiSchema\n });\n var _onMultiChange = function _onMultiChange(e) {\n return onChange(enumOptionsValueForIndex(e.map(function (v) {\n return v.value;\n }), enumOptions, emptyValue));\n };\n var _onChange = function _onChange(e) {\n return onChange(enumOptionsValueForIndex(e.value, enumOptions, emptyValue));\n };\n var _onBlur = function _onBlur(_ref) {\n var value = _ref.target.value;\n return onBlur(id, enumOptionsValueForIndex(value, enumOptions, emptyValue));\n };\n var _onFocus = function _onFocus(_ref2) {\n var value = _ref2.target.value;\n return onFocus(id, enumOptionsValueForIndex(value, enumOptions, emptyValue));\n };\n var _valueLabelMap = {};\n var displayEnumOptions = Array.isArray(enumOptions) ? enumOptions.map(function (option, index) {\n var value = option.value,\n label = option.label;\n _valueLabelMap[index] = label || String(value);\n return {\n label: label,\n value: String(index),\n isDisabled: Array.isArray(enumDisabled) && enumDisabled.indexOf(value) !== -1\n };\n }) : [];\n var isMultiple = typeof multiple !== 'undefined' && Boolean(enumOptions);\n var selectedIndex = enumOptionsIndexForValue(value, enumOptions, isMultiple);\n var formValue = isMultiple ? (selectedIndex || []).map(function (i) {\n return {\n label: _valueLabelMap[i],\n value: i\n };\n }) : {\n label: _valueLabelMap[selectedIndex] || '',\n selectedIndex: selectedIndex\n };\n return jsxs(FormControl, _extends({\n mb: 1\n }, chakraProps, {\n isDisabled: disabled || readonly,\n isRequired: required,\n isReadOnly: readonly,\n isInvalid: rawErrors && rawErrors.length > 0,\n children: [labelValue(jsx(FormLabel, {\n htmlFor: id,\n id: id + \"-label\",\n children: label\n }), hideLabel || !label), jsx(Select, {\n inputId: id,\n name: id,\n isMulti: isMultiple,\n options: displayEnumOptions,\n placeholder: placeholder,\n closeMenuOnSelect: !isMultiple,\n onBlur: _onBlur,\n onChange: isMultiple ? _onMultiChange : _onChange,\n onFocus: _onFocus,\n autoFocus: autofocus,\n value: formValue,\n \"aria-describedby\": ariaDescribedByIds(id)\n })]\n }));\n}\n\nfunction TextareaWidget(_ref) {\n var id = _ref.id,\n placeholder = _ref.placeholder,\n value = _ref.value,\n label = _ref.label,\n hideLabel = _ref.hideLabel,\n disabled = _ref.disabled,\n autofocus = _ref.autofocus,\n readonly = _ref.readonly,\n onBlur = _ref.onBlur,\n onFocus = _ref.onFocus,\n onChange = _ref.onChange,\n options = _ref.options,\n uiSchema = _ref.uiSchema,\n required = _ref.required,\n rawErrors = _ref.rawErrors;\n var chakraProps = getChakra({\n uiSchema: uiSchema\n });\n var _onChange = function _onChange(_ref2) {\n var value = _ref2.target.value;\n return onChange(value === '' ? options.emptyValue : value);\n };\n var _onBlur = function _onBlur(_ref3) {\n var value = _ref3.target.value;\n return onBlur(id, value);\n };\n var _onFocus = function _onFocus(_ref4) {\n var value = _ref4.target.value;\n return onFocus(id, value);\n };\n return jsxs(FormControl, _extends({\n mb: 1\n }, chakraProps, {\n isDisabled: disabled || readonly,\n isRequired: required,\n isReadOnly: readonly,\n isInvalid: rawErrors && rawErrors.length > 0,\n children: [labelValue(jsx(FormLabel, {\n htmlFor: id,\n children: label\n }), hideLabel || !label), jsx(Textarea, {\n id: id,\n name: id,\n value: value != null ? value : '',\n placeholder: placeholder,\n autoFocus: autofocus,\n onChange: _onChange,\n onBlur: _onBlur,\n onFocus: _onFocus,\n \"aria-describedby\": ariaDescribedByIds(id)\n })]\n }));\n}\n\nfunction UpDownWidget(props) {\n var id = props.id,\n uiSchema = props.uiSchema,\n readonly = props.readonly,\n disabled = props.disabled,\n label = props.label,\n hideLabel = props.hideLabel,\n value = props.value,\n onChange = props.onChange,\n onBlur = props.onBlur,\n onFocus = props.onFocus,\n rawErrors = props.rawErrors,\n required = props.required;\n var chakraProps = getChakra({\n uiSchema: uiSchema\n });\n var _onChange = function _onChange(value) {\n return onChange(value);\n };\n var _onBlur = function _onBlur(_ref) {\n var value = _ref.target.value;\n return onBlur(id, value);\n };\n var _onFocus = function _onFocus(_ref2) {\n var value = _ref2.target.value;\n return onFocus(id, value);\n };\n return jsxs(FormControl, _extends({\n mb: 1\n }, chakraProps, {\n isDisabled: disabled || readonly,\n isRequired: required,\n isReadOnly: readonly,\n isInvalid: rawErrors && rawErrors.length > 0,\n children: [labelValue(jsx(FormLabel, {\n htmlFor: id,\n children: label\n }), hideLabel || !label), jsxs(NumberInput, {\n value: value != null ? value : '',\n onChange: _onChange,\n onBlur: _onBlur,\n onFocus: _onFocus,\n \"aria-describedby\": ariaDescribedByIds(id),\n children: [jsx(NumberInputField, {\n id: id,\n name: id\n }), jsxs(NumberInputStepper, {\n children: [jsx(NumberIncrementStepper, {}), jsx(NumberDecrementStepper, {})]\n })]\n })]\n }));\n}\n\nfunction generateWidgets() {\n return {\n AltDateTimeWidget: AltDateTimeWidget,\n AltDateWidget: AltDateWidget,\n CheckboxWidget: CheckboxWidget,\n CheckboxesWidget: CheckboxesWidget,\n RadioWidget: RadioWidget,\n RangeWidget: RangeWidget,\n SelectWidget: SelectWidget,\n TextareaWidget: TextareaWidget,\n UpDownWidget: UpDownWidget\n };\n}\nvar Widgets = /*#__PURE__*/generateWidgets();\n\nfunction generateTheme() {\n return {\n templates: generateTemplates(),\n widgets: generateWidgets()\n };\n}\nvar Theme = /*#__PURE__*/generateTheme();\n\nfunction generateForm() {\n return withTheme(generateTheme());\n}\nvar Form = /*#__PURE__*/generateForm();\n\n/**\r\n *\r\n * The reason we need this is for ChakraProvider styling in Playground.\r\n * The User Developer would be responsible for styling with ChakraProvider in their app.\r\n *\r\n * Exact duplicate of `@chakra-ui/react`'s `CSSReset` component. Except for the following:\r\n *\r\n ```css\r\n input {\r\n border-width: revert;\r\n border-color: revert;\r\n border-style: revert;\r\n }\r\n .array-item > hr {\r\n margin-top: 16px;\r\n margin-bottom: 16px;\r\n }\r\n ```\r\n\n It is located at the bottom of the styles string.\r\n */\nvar CSSReset = function CSSReset() {\n return jsx(Global, {\n styles: \"\\n html {\\n line-height: 1.5;\\n -webkit-text-size-adjust: 100%;\\n font-family: system-ui, sans-serif;\\n -webkit-font-smoothing: antialiased;\\n text-rendering: optimizeLegibility;\\n -moz-osx-font-smoothing: grayscale;\\n touch-action: manipulation;\\n }\\n body {\\n position: relative;\\n min-height: 100%;\\n font-feature-settings: 'kern';\\n }\\n *,\\n *::before,\\n *::after {\\n border-width: 0;\\n border-style: solid;\\n box-sizing: border-box;\\n }\\n main {\\n display: block;\\n }\\n hr {\\n border-top-width: 1px;\\n box-sizing: content-box;\\n height: 0;\\n overflow: visible;\\n }\\n pre,\\n code,\\n kbd,\\n samp {\\n font-family: SFMono-Regular, Menlo, Monaco, Consolas, monospace;\\n font-size: 1em;\\n }\\n a {\\n background-color: transparent;\\n color: inherit;\\n text-decoration: inherit;\\n }\\n abbr[title] {\\n border-bottom: none;\\n text-decoration: underline;\\n -webkit-text-decoration: underline dotted;\\n text-decoration: underline dotted;\\n }\\n b,\\n strong {\\n font-weight: bold;\\n }\\n small {\\n font-size: 80%;\\n }\\n sub,\\n sup {\\n font-size: 75%;\\n line-height: 0;\\n position: relative;\\n vertical-align: baseline;\\n }\\n sub {\\n bottom: -0.25em;\\n }\\n sup {\\n top: -0.5em;\\n }\\n img {\\n border-style: none;\\n }\\n button,\\n input,\\n optgroup,\\n select,\\n textarea {\\n font-family: inherit;\\n font-size: 100%;\\n line-height: 1.15;\\n margin: 0;\\n }\\n button,\\n input {\\n overflow: visible;\\n }\\n button,\\n select {\\n text-transform: none;\\n }\\n button::-moz-focus-inner,\\n [type=\\\"button\\\"]::-moz-focus-inner,\\n [type=\\\"reset\\\"]::-moz-focus-inner,\\n [type=\\\"submit\\\"]::-moz-focus-inner {\\n border-style: none;\\n padding: 0;\\n }\\n fieldset {\\n padding: 0.35em 0.75em 0.625em;\\n }\\n legend {\\n box-sizing: border-box;\\n color: inherit;\\n display: table;\\n max-width: 100%;\\n padding: 0;\\n white-space: normal;\\n }\\n progress {\\n vertical-align: baseline;\\n }\\n textarea {\\n overflow: auto;\\n }\\n [type=\\\"checkbox\\\"],\\n [type=\\\"radio\\\"] {\\n box-sizing: border-box;\\n padding: 0;\\n }\\n [type=\\\"number\\\"]::-webkit-inner-spin-button,\\n [type=\\\"number\\\"]::-webkit-outer-spin-button {\\n -webkit-appearance: none !important;\\n }\\n input[type=\\\"number\\\"] {\\n -moz-appearance: textfield;\\n }\\n [type=\\\"search\\\"] {\\n -webkit-appearance: textfield;\\n outline-offset: -2px;\\n }\\n [type=\\\"search\\\"]::-webkit-search-decoration {\\n -webkit-appearance: none !important;\\n }\\n ::-webkit-file-upload-button {\\n -webkit-appearance: button;\\n font: inherit;\\n }\\n details {\\n display: block;\\n }\\n summary {\\n display: list-item;\\n }\\n template {\\n display: none;\\n }\\n [hidden] {\\n display: none !important;\\n }\\n body,\\n blockquote,\\n dl,\\n dd,\\n h1,\\n h2,\\n h3,\\n h4,\\n h5,\\n h6,\\n hr,\\n figure,\\n p,\\n pre {\\n margin: 0;\\n }\\n button {\\n background: transparent;\\n padding: 0;\\n }\\n fieldset {\\n margin: 0;\\n padding: 0;\\n }\\n ol,\\n ul {\\n margin: 0;\\n padding: 0;\\n }\\n textarea {\\n resize: vertical;\\n }\\n button,\\n [role=\\\"button\\\"] {\\n cursor: pointer;\\n }\\n button::-moz-focus-inner {\\n border: 0 !important;\\n }\\n table {\\n border-collapse: collapse;\\n }\\n h1,\\n h2,\\n h3,\\n h4,\\n h5,\\n h6 {\\n font-size: inherit;\\n font-weight: inherit;\\n }\\n button,\\n input,\\n optgroup,\\n select,\\n textarea {\\n padding: 0;\\n line-height: inherit;\\n color: inherit;\\n }\\n img,\\n svg,\\n video,\\n canvas,\\n audio,\\n iframe,\\n embed,\\n object {\\n display: block;\\n }\\n img,\\n video {\\n max-width: 100%;\\n height: auto;\\n }\\n [data-js-focus-visible] :focus:not([data-focus-visible-added]) {\\n outline: none;\\n box-shadow: none;\\n }\\n select::-ms-expand {\\n display: none;\\n }\\n input {\\n border-width: revert;\\n border-color: revert;\\n border-style: revert;\\n }\\n .array-item > hr {\\n margin-top: 16px;\\n margin-bottom: 16px;\\n }\\n \"\n });\n};\n\n/**\r\n * __createChakraFrameProvider is used to ensure that emotion components\r\n * can be rendered within an iframe without changing the styles of the parent page.\r\n * Required for using Chakra UI in the playground.\r\n *\r\n * We have to define ChakraFrameProvider in this library, as opposed to the playground,\r\n * in order to avoid conflicting versions of emotion, which breaks the styling.\r\n *\r\n * NOTE: This is an internal component only used by @rjsf/playground (no\r\n * backwards compatibility guarantees!)\r\n *\r\n * From: https://codesandbox.io/s/p98y9o7jz0?file=/src/frame-provider.js:0-650\r\n * Also see: https://github.com/emotion-js/emotion/issues/760#issuecomment-404353706\r\n */\nvar memoizedCreateCacheWithContainer = /*#__PURE__*/weakMemoize(function (container) {\n var newCache = createCache({\n container: container,\n key: 'rjsf'\n });\n return newCache;\n});\nvar __createChakraFrameProvider = function __createChakraFrameProvider(props) {\n return function (_ref) {\n var document = _ref.document;\n return jsx(\"div\", {\n style: {\n margin: 2\n },\n children: jsx(CacheProvider, {\n value: memoizedCreateCacheWithContainer(document.head),\n children: jsxs(ChakraProvider, {\n resetCSS: false,\n children: [jsx(CSSReset, {}), props.children]\n })\n })\n });\n };\n};\n\nexport { Form, Templates, Theme, Widgets, __createChakraFrameProvider, Form as default, generateForm, generateTemplates, generateTheme, generateWidgets };\n//# sourceMappingURL=chakra-ui.esm.js.map\n","import {\n Box,\n Button,\n ButtonGroup,\n ChakraProps,\n Checkbox,\n CheckboxGroup,\n Divider,\n FormControl,\n FormHelperText,\n FormLabel,\n FormLabelProps,\n Grid,\n GridItem,\n HStack,\n Icon,\n IconButton,\n Input,\n NumberDecrementStepper,\n NumberIncrementStepper,\n NumberInput,\n NumberInputField,\n NumberInputStepper,\n Radio,\n RadioGroup,\n Slider,\n SliderFilledTrack,\n SliderThumb,\n SliderTrack,\n Stack,\n Text,\n Textarea,\n Tooltip,\n VStack,\n shouldForwardProp\n} from '@chakra-ui/react'\nimport {\n mdiArrowDown,\n mdiArrowUp,\n mdiContentDuplicate,\n mdiDelete,\n mdiDeleteOutline,\n mdiInformationOutline,\n mdiPlus,\n mdiTrashCan,\n mdiTrashCanOutline\n} from '@mdi/js'\nimport { Form } from '@rjsf/chakra-ui'\nimport { FormProps } from '@rjsf/core'\nimport {\n ArrayFieldTemplateItemType,\n ArrayFieldTemplateProps,\n BaseInputTemplateProps,\n EnumOptionsType,\n FieldHelpProps,\n FieldTemplateProps,\n FormContextType,\n IconButtonProps,\n ObjectFieldTemplateProps,\n RJSFSchema,\n StrictRJSFSchema,\n UiSchema,\n WidgetProps,\n ariaDescribedByIds,\n canExpand,\n descriptionId,\n enumOptionsIndexForValue,\n enumOptionsIsSelected,\n enumOptionsValueForIndex,\n examplesId,\n getInputProps,\n getTemplate,\n getUiOptions,\n helpId,\n labelValue,\n optionId,\n rangeSpec,\n schemaRequiresTrueValue,\n titleId\n} from '@rjsf/utils'\nimport { OptionsOrGroups } from 'chakra-react-select'\nimport { ChangeEvent, FocusEvent, useMemo } from 'react'\nimport { Select } from './Select.js'\n\nexport function ArrayFieldItemTemplate<\n T = any,\n S extends StrictRJSFSchema = RJSFSchema,\n F extends FormContextType = any\n>(props: ArrayFieldTemplateItemType) {\n const {\n children,\n disabled,\n hasToolbar,\n hasCopy,\n hasMoveDown,\n hasMoveUp,\n hasRemove,\n index,\n onCopyIndexClick,\n onDropIndexClick,\n onReorderClick,\n readonly,\n uiSchema,\n schema,\n registry\n } = props\n const { CopyButton, MoveDownButton, MoveUpButton, RemoveButton } = registry.templates.ButtonTemplates\n const onCopyClick = useMemo(() => onCopyIndexClick(index), [index, onCopyIndexClick])\n\n const onRemoveClick = useMemo(() => onDropIndexClick(index), [index, onDropIndexClick])\n\n const onArrowUpClick = useMemo(() => onReorderClick(index, index - 1), [index, onReorderClick])\n\n const onArrowDownClick = useMemo(() => onReorderClick(index, index + 1), [index, onReorderClick])\n\n return (\n \n {hasToolbar && (\n \n {(hasMoveUp || hasMoveDown) && (\n \n )}\n {(hasMoveUp || hasMoveDown) && (\n \n )}\n {hasCopy && (\n \n )}\n {hasRemove && (\n \n )}\n \n )}\n {children}\n \n )\n}\n\nexport function CustomFormLabel(props: any) {\n return \n}\n\nexport function AddButton({\n uiSchema,\n registry,\n ...props\n}: IconButtonProps) {\n const { translateString } = registry\n return (\n \n \n \n }\n size='sm'\n variant='outline'\n {...props}\n >\n Add item\n \n )\n}\nexport function ChakraIconButton(\n props: IconButtonProps\n) {\n return (\n \n {/* @ts-ignore */}\n \n \n )\n}\nexport function CopyButton(\n props: IconButtonProps\n) {\n const {\n registry: { translateString }\n } = props\n return (\n \n title={'Copy'}\n {...props}\n icon={\n \n \n \n }\n />\n )\n}\n\nexport function MoveDownButton(\n props: IconButtonProps\n) {\n const {\n registry: { translateString }\n } = props\n return (\n \n title={'Move down'}\n {...props}\n icon={\n \n \n \n }\n />\n )\n}\n\nexport function MoveUpButton(\n props: IconButtonProps\n) {\n const {\n registry: { translateString }\n } = props\n return (\n \n title={'Move up'}\n {...props}\n icon={\n \n \n \n }\n />\n )\n}\n\nexport function RemoveButton(\n props: IconButtonProps\n) {\n const {\n registry: { translateString }\n } = props\n return (\n \n title={'Remove'}\n {...props}\n icon={\n \n \n \n }\n />\n )\n}\nexport function ArrayFieldTemplate(\n props: ArrayFieldTemplateProps\n) {\n const { canAdd, disabled, idSchema, uiSchema, items, onAddClick, readonly, registry, required, schema, title } = props\n const uiOptions = getUiOptions(uiSchema)\n const ArrayFieldDescriptionTemplate = getTemplate<'ArrayFieldDescriptionTemplate', T, S, F>(\n 'ArrayFieldDescriptionTemplate',\n registry,\n uiOptions\n )\n const ArrayFieldItemTemplate = getTemplate<'ArrayFieldItemTemplate', T, S, F>(\n 'ArrayFieldItemTemplate',\n registry,\n uiOptions\n )\n const ArrayFieldTitleTemplate = getTemplate<'ArrayFieldTitleTemplate', T, S, F>(\n 'ArrayFieldTitleTemplate',\n registry,\n uiOptions\n )\n // Button templates are not overridden in the uiSchema\n const {\n ButtonTemplates: { AddButton }\n } = registry.templates\n return (\n \n \n {title && !titleId(idSchema).includes('root__') && (\n \n {labelWithTooltip(uiOptions.title || title, uiOptions.description || schema.description)}\n \n )}\n \n \n {items.length > 0 &&\n items.map(({ key, ...itemProps }: ArrayFieldTemplateItemType) => (\n \n ))}\n {items.length == 0 && (\n <>\n \n No items added yet\n \n \n )}\n \n {canAdd && (\n \n \n \n \n \n )}\n \n \n )\n}\nfunction labelWithTooltip(label: string, description: string) {\n return (\n <>\n {label}\n {description && <>{' '}\n \n \n \n \n }\n \n )\n}\n\nexport function ObjectFieldTemplate(\n props: ObjectFieldTemplateProps\n) {\n const {\n description,\n title,\n properties,\n required,\n disabled,\n readonly,\n uiSchema,\n idSchema,\n schema,\n formData,\n onAddClick,\n registry\n } = props\n const uiOptions = getUiOptions(uiSchema)\n\n // Button templates are not overridden in the uiSchema\n const {\n ButtonTemplates: { AddButton }\n } = registry.templates\n\n return (\n <>\n {title && !titleId(idSchema).includes('root__') && (\n <>\n \n {labelWithTooltip(title, description)}\n \n \n )}\n (idSchema).includes('root__') ? 6 : 2} mb={4}>\n {properties.map((element, index) =>\n element.hidden ? (\n element.content\n ) : (\n {element.content}\n )\n )}\n {canExpand(schema, uiSchema, formData) && (\n \n \n \n )}\n \n \n )\n}\nexport interface ChakraUiSchema extends Omit {\n 'ui:options'?: ChakraUiOptions\n}\n\ntype ChakraUiOptions = UiSchema['ui:options'] & { chakra?: ChakraProps }\n\ninterface GetChakraProps {\n uiSchema?: ChakraUiSchema\n}\n\nexport function getChakra({ uiSchema = {} }: GetChakraProps): ChakraProps {\n const chakraProps = (uiSchema['ui:options'] && uiSchema['ui:options'].chakra) || {}\n\n Object.keys(chakraProps).forEach((key) => {\n /**\n * Leveraging `shouldForwardProp` to remove props\n *\n * This is a utility function that's used in `@chakra-ui/react`'s factory function.\n * Normally, it prevents ChakraProps from being passed to the DOM.\n * In this case we just want to delete the unknown props. So we flip the boolean.\n */\n if (shouldForwardProp(key)) {\n delete (chakraProps as any)[key]\n }\n })\n\n return chakraProps\n}\n\nexport function CheckboxesWidget(\n props: WidgetProps\n) {\n const {\n id,\n disabled,\n options,\n value,\n readonly,\n onChange,\n onBlur,\n onFocus,\n required,\n label,\n hideLabel,\n schema,\n uiSchema,\n rawErrors = []\n } = props\n const { enumOptions, enumDisabled, emptyValue } = options\n const chakraProps = getChakra({ uiSchema })\n const checkboxesValues = Array.isArray(value) ? value : [value]\n\n const _onBlur = ({ target: { value } }: FocusEvent) =>\n onBlur(id, enumOptionsValueForIndex(value, enumOptions, emptyValue))\n const _onFocus = ({ target: { value } }: FocusEvent) =>\n onFocus(id, enumOptionsValueForIndex(value, enumOptions, emptyValue))\n\n const row = options ? options.inline : false\n const selectedIndexes = enumOptionsIndexForValue(value, enumOptions, true) as string[]\n\n return (\n 0}\n >\n {labelValue(\n \n {labelWithTooltip(label, schema?.description)}\n ,\n hideLabel || !label\n )}\n onChange(enumOptionsValueForIndex(option, enumOptions, emptyValue))}\n defaultValue={selectedIndexes}\n aria-describedby={ariaDescribedByIds(id)}\n >\n \n {Array.isArray(enumOptions) &&\n enumOptions.map((option, index) => {\n const checked = enumOptionsIsSelected(option.value, checkboxesValues)\n const itemDisabled = Array.isArray(enumDisabled) && enumDisabled.indexOf(option.value) !== -1\n return (\n \n {option.label && {option.label}}\n \n )\n })}\n \n \n \n )\n}\n\nexport function RadioWidget({\n id,\n schema,\n options,\n value,\n required,\n disabled,\n readonly,\n label,\n hideLabel,\n onChange,\n onBlur,\n onFocus,\n uiSchema\n}: WidgetProps) {\n const { enumOptions, enumDisabled, emptyValue } = options\n const chakraProps = getChakra({ uiSchema })\n\n const _onChange = (nextValue: any) => onChange(enumOptionsValueForIndex(nextValue, enumOptions, emptyValue))\n const _onBlur = ({ target: { value } }: FocusEvent) =>\n onBlur(id, enumOptionsValueForIndex(value, enumOptions, emptyValue))\n const _onFocus = ({ target: { value } }: FocusEvent) =>\n onFocus(id, enumOptionsValueForIndex(value, enumOptions, emptyValue))\n\n const row = options ? options.inline : false\n const selectedIndex = (enumOptionsIndexForValue(value, enumOptions) as string) ?? null\n\n return (\n \n {labelValue(\n \n {labelWithTooltip(label, schema?.description)}\n ,\n hideLabel || !label\n )}\n (id)}\n >\n \n {Array.isArray(enumOptions) &&\n enumOptions.map((option, index) => {\n const itemDisabled = Array.isArray(enumDisabled) && enumDisabled.indexOf(option.value) !== -1\n\n return (\n \n {option.label}\n \n )\n })}\n \n \n \n )\n}\n\nexport function TextareaWidget({\n id,\n placeholder,\n value,\n label,\n hideLabel,\n disabled,\n autofocus,\n readonly,\n onBlur,\n onFocus,\n onChange,\n options,\n uiSchema,\n schema,\n required,\n rawErrors\n}: WidgetProps) {\n const chakraProps = getChakra({ uiSchema })\n\n const _onChange = ({ target: { value } }: ChangeEvent) =>\n onChange(value === '' ? options.emptyValue : value)\n const _onBlur = ({ target: { value } }: FocusEvent) => onBlur(id, value)\n const _onFocus = ({ target: { value } }: FocusEvent) => onFocus(id, value)\n\n return (\n 0}\n >\n {labelValue(\n {labelWithTooltip(label, schema?.description)},\n hideLabel || !label\n )}\n (id)}\n />\n \n )\n}\n\nexport function SelectWidget(\n props: WidgetProps\n) {\n const {\n id,\n options,\n label,\n hideLabel,\n placeholder,\n multiple,\n required,\n disabled,\n readonly,\n value,\n autofocus,\n onChange,\n onBlur,\n onFocus,\n rawErrors = [],\n uiSchema,\n schema\n } = props\n const { enumOptions, enumDisabled, emptyValue } = options\n const chakraProps = getChakra({ uiSchema })\n\n const _onMultiChange = (e: any) => {\n return onChange(\n enumOptionsValueForIndex(\n e.map((v: { value: any }) => {\n return v.value\n }),\n enumOptions,\n emptyValue\n )\n )\n }\n\n const _onChange = (e: any) => {\n return onChange(enumOptionsValueForIndex(e.value, enumOptions, emptyValue))\n }\n\n const _onBlur = ({ target: { value } }: FocusEvent) =>\n onBlur(id, enumOptionsValueForIndex(value, enumOptions, emptyValue))\n\n const _onFocus = ({ target: { value } }: FocusEvent) =>\n onFocus(id, enumOptionsValueForIndex(value, enumOptions, emptyValue))\n\n const _valueLabelMap: any = {}\n const displayEnumOptions: OptionsOrGroups = Array.isArray(enumOptions)\n ? enumOptions.map((option: EnumOptionsType, index: number) => {\n const { value, label } = option\n _valueLabelMap[index] = label || String(value)\n return {\n label,\n value: String(index),\n isDisabled: Array.isArray(enumDisabled) && enumDisabled.indexOf(value) !== -1\n }\n })\n : []\n\n const isMultiple = typeof multiple !== 'undefined' && multiple !== false && Boolean(enumOptions)\n const selectedIndex = enumOptionsIndexForValue(value, enumOptions, isMultiple)\n const formValue: any = isMultiple\n ? ((selectedIndex as string[]) || []).map((i: string) => {\n return {\n label: _valueLabelMap[i],\n value: i\n }\n })\n : {\n label: _valueLabelMap[selectedIndex as string] || '',\n selectedIndex\n }\n\n return (\n 0}\n >\n {labelValue(\n \n {labelWithTooltip(label, schema?.description)}\n ,\n hideLabel || !label\n )}\n (id)}\n />\n \n )\n}\nexport function RangeWidget({\n value,\n readonly,\n disabled,\n onBlur,\n onFocus,\n options,\n uiSchema,\n onChange,\n label,\n hideLabel,\n schema,\n id\n}: WidgetProps) {\n const chakraProps = getChakra({ uiSchema })\n\n const sliderWidgetProps = { value, label, id, ...rangeSpec(schema) }\n\n const _onChange = (value: undefined | number) => onChange(value === undefined ? options.emptyValue : value)\n const _onBlur = ({ target: { value } }: FocusEvent) => onBlur(id, value)\n const _onFocus = ({ target: { value } }: FocusEvent) => onFocus(id, value)\n\n return (\n \n {labelValue(\n {labelWithTooltip(label, schema?.description)},\n hideLabel || !label\n )}\n (id)}\n >\n \n \n \n \n \n \n )\n}\n\nexport function CheckboxWidget(\n props: WidgetProps\n) {\n const {\n id,\n value,\n disabled,\n readonly,\n onChange,\n onBlur,\n onFocus,\n label,\n hideLabel,\n registry,\n options,\n uiSchema,\n schema\n } = props\n const chakraProps = getChakra({ uiSchema })\n // Because an unchecked checkbox will cause html5 validation to fail, only add\n // the \"required\" attribute if the field value must be \"true\", due to the\n // \"const\" or \"enum\" keywords\n const required = schemaRequiresTrueValue(schema)\n const DescriptionFieldTemplate = getTemplate<'DescriptionFieldTemplate', T, S, F>(\n 'DescriptionFieldTemplate',\n registry,\n options\n )\n const description = options.description || schema.description\n\n const _onChange = ({ target: { checked } }: ChangeEvent) => onChange(checked)\n const _onBlur = ({ target: { value } }: FocusEvent) => onBlur(id, value)\n const _onFocus = ({ target: { value } }: FocusEvent) => onFocus(id, value)\n\n return (\n \n {!hideLabel && !!description && (\n (id)}\n description={description}\n schema={schema}\n uiSchema={uiSchema}\n registry={registry}\n />\n )}\n (id)}\n >\n {labelValue({labelWithTooltip(label, schema?.description)}, hideLabel || !label)}\n \n \n )\n}\n\nexport function UpDownWidget(\n props: WidgetProps\n) {\n const {\n id,\n schema,\n uiSchema,\n readonly,\n disabled,\n label,\n hideLabel,\n value,\n onChange,\n onBlur,\n onFocus,\n rawErrors,\n required\n } = props\n\n const chakraProps = getChakra({ uiSchema })\n\n const _onChange = (value: string | number) => onChange(value)\n const _onBlur = ({ target: { value } }: FocusEvent) => onBlur(id, value)\n const _onFocus = ({ target: { value } }: FocusEvent) => onFocus(id, value)\n\n return (\n 0}\n >\n {labelValue(\n {labelWithTooltip(label, schema?.description)},\n hideLabel || !label\n )}\n (id)}\n >\n \n \n \n \n \n \n \n )\n}\n\nexport function BaseInputTemplate(\n props: BaseInputTemplateProps\n) {\n const {\n id,\n type,\n value,\n label,\n hideLabel,\n schema,\n uiSchema,\n onChange,\n onChangeOverride,\n onBlur,\n onFocus,\n options,\n required,\n readonly,\n rawErrors,\n autofocus,\n placeholder,\n description,\n rawDescription,\n disabled\n } = props\n const inputProps = getInputProps(schema, type, options)\n const chakraProps = getChakra({ uiSchema })\n\n const _onChange = ({ target: { value } }: ChangeEvent) =>\n onChange(value === '' ? options.emptyValue : value)\n const _onBlur = ({ target: { value } }: FocusEvent) => onBlur(id, value)\n const _onFocus = ({ target: { value } }: FocusEvent) => onFocus(id, value)\n\n return (\n 0}\n >\n {labelValue(\n \n {labelWithTooltip(label, schema?.description)}\n ,\n hideLabel || !label\n )}\n (id) : undefined}\n aria-describedby={ariaDescribedByIds(id, !!schema.examples)}\n />\n {Array.isArray(schema.examples) ? (\n (id)}>\n {(schema.examples as string[])\n .concat(schema.default && !schema.examples.includes(schema.default) ? ([schema.default] as string[]) : [])\n .map((example: any) => {\n return \n ) : null}\n \n )\n}\nexport function FieldTemplate(\n props: FieldTemplateProps\n) {\n const {\n id,\n children,\n classNames,\n style,\n disabled,\n displayLabel,\n hidden,\n label,\n onDropPropertyClick,\n onKeyChange,\n readonly,\n registry,\n required,\n rawErrors = [],\n errors,\n help,\n description,\n rawDescription,\n schema,\n uiSchema\n } = props\n const uiOptions = getUiOptions(uiSchema)\n const WrapIfAdditionalTemplate = getTemplate<'WrapIfAdditionalTemplate', T, S, F>(\n 'WrapIfAdditionalTemplate',\n registry,\n uiOptions\n )\n\n if (hidden) {\n return
{children}
\n }\n\n return (\n \n 0}>\n {children}\n {displayLabel && rawDescription ? {description} : null}\n {errors}\n {help}\n \n \n )\n}\n/**\n * The `FieldHelpTemplate` component renders any help desired for a field.\n *\n * @param props - The `FieldHelpProps` to be rendered.\n */\nexport function FieldHelpTemplate(\n props: FieldHelpProps\n) {\n const { idSchema, help } = props\n if (!help) {\n return null\n }\n const id = helpId(idSchema)\n return {help}\n}\n\nconst RJSFTemplates: FormProps['templates'] = {\n BaseInputTemplate: BaseInputTemplate,\n ObjectFieldTemplate: ObjectFieldTemplate,\n FieldTemplate: FieldTemplate,\n FieldHelpTemplate: FieldHelpTemplate,\n ArrayFieldItemTemplate: ArrayFieldItemTemplate,\n ArrayFieldTemplate: ArrayFieldTemplate,\n DescriptionFieldTemplate: () => <>,\n ButtonTemplates: {\n AddButton,\n CopyButton,\n MoveDownButton,\n MoveUpButton,\n RemoveButton\n }\n}\nconst RJSFWidgets: FormProps['widgets'] = {\n CheckboxWidget: CheckboxWidget,\n RadioWidget: RadioWidget,\n UpDownWidget: UpDownWidget,\n SelectWidget: SelectWidget,\n CheckboxesWidget: CheckboxesWidget,\n TextareaWidget: TextareaWidget,\n RangeWidget: RangeWidget\n}\nexport const SchemaForm: typeof Form = (props) => {\n return \n}\n\nexport default SchemaForm\n","import { Button, Flex } from '@chakra-ui/react'\nimport type { RJSFSchema, UiSchema } from '@rjsf/utils'\nimport validator from '@rjsf/validator-ajv8'\nimport { ExternalComponent } from '@sitecore-feaas/sdk'\nexport type { ExternalComponent } from '@sitecore-feaas/sdk'\nimport { objectKeysToKebabCase } from '@sitecore/byoc'\nimport { SchemaForm } from '../../SchemaForm.js'\nconst DialogAttributesExternalSchema = ({\n attributes,\n embed,\n onChange\n}: {\n attributes: any\n embed: ExternalComponent\n onChange: (data: any, attribute: string) => void\n}) => {\n return (\n {\n onChange(JSON.stringify(objectKeysToKebabCase(data)), 'data-attributes')\n }}\n />\n )\n}\n\nconst DialogAttributesExternalSchemaForm = ({\n embed,\n defaultData,\n onChange\n}: {\n embed: ExternalComponent\n defaultData: any\n onChange: (data: any) => any\n}) => {\n return (\n <>\n {embed && (\n {\n onChange(formData)\n }}\n >\n \n \n \n \n )}\n \n )\n}\n\nexport default DialogAttributesExternalSchema\n","import { Box, Button, HStack, Icon, Spacer, Text, Tooltip, VStack } from '@chakra-ui/react'\nimport { mdiChevronRight } from '@mdi/js'\nimport { Dialog, DialogMenuItem } from './Dialog.js'\nimport { PickerProps } from '../../picker/Picker.js'\n\nexport function DialogMenu({\n items = [],\n title,\n children,\n onNavigate,\n variant\n}: React.PropsWithChildren<{\n items?: T[]\n title: string\n onNavigate?: (id: Dialog['id']) => void\n variant?: PickerProps['variant']\n}>) {\n return (\n \n \n {title}\n \n \n {children}\n {items.map((item, index) =>\n item.preview ? (\n /**\n * When we pass onNavigate, it overrides items own onNavigate. We use the following syntax to make sure\n * that if navigate is not available (eg. in pages), the items own method will be used\n * and not overwritten by undefined\n */\n \n ) : (\n \n )\n )}\n \n \n )\n}\n\nexport function DialogMenuPane(props: DialogMenuItem) {\n const { id, onNavigate, tooltip, preview, label, badge, ariaLabel, isDisabled } = props\n const renderedBadge = badge?.(props)\n return (\n \n onNavigate(id)}\n as={Button}\n aria-label={ariaLabel}\n variant='dialogPane'\n borderRadius={'4px'}\n color='blackAlpha.500'\n height='auto'\n padding={'3'}\n spacing={2}\n lineHeight='18px'\n isDisabled={isDisabled}\n sx={{\n _disabled: {\n opacity: 1,\n pointerEvents: 'none'\n }\n }}\n >\n {label && (\n \n \n \n {preview?.(props)}\n \n \n \n {label}\n \n \n )}\n {!label && preview?.(props)}\n {(renderedBadge || !isDisabled) && (\n \n {renderedBadge}\n {!isDisabled && (\n \n \n \n )}\n \n )}\n \n \n )\n}\n\nexport function DialogMenuItem(props: React.PropsWithChildren) {\n const { onNavigate, id, icon, label, badge, ariaLabel, isDisabled, className, children, level } = props\n return (\n onNavigate(id)}\n aria-label={ariaLabel}\n justifyContent={'stretch'}\n variant='dialogItem'\n size='md'\n isDisabled={!!isDisabled}\n rightIcon={\n isDisabled ? null : (\n \n \n \n )\n }\n >\n \n {label}\n \n \n {badge?.(props)}\n {children}\n \n )\n}\n","import { ExternalComponent, Style } from '@sitecore-feaas/sdk'\nimport { PickerProps } from '../../picker/Picker.js'\nimport { DialogMenu } from './DialogMenu.js'\nimport { Divider, HStack } from '@chakra-ui/react'\nimport { Text } from '@chakra-ui/react'\nimport { titleize } from 'inflection'\nimport { getSchemaProperties } from '@sitecore/byoc'\nexport default function DialogMenuAttributes({\n setDialogName,\n variant,\n options,\n externalComponent\n}: {\n setDialogName: (dialog: string) => void\n variant: PickerProps['variant']\n options: any\n externalComponent: ExternalComponent\n}) {\n const keys = Object.keys(externalComponent.schema.properties || {})\n .sort((a, b) => Number(!!options[b]) - Number(!!options[a]))\n .filter((k) => !externalComponent.schema.properties[k]?.isHidden)\n const values = getSchemaProperties(externalComponent.schema, options)\n\n return (\n setDialogName('schema')}\n items={[\n {\n onNavigate: () => setDialogName('schema'),\n id: 'schema',\n label: null,\n icon: null,\n preview: () => {\n return (\n <>\n {keys.slice(0, 3).map((key) => {\n const definition = externalComponent.schema.properties[key]\n return (\n \n \n {definition.title || titleize(key)}\n \n \n {values[key]}\n \n \n )\n })}\n {keys.length > 3 && (\n <>\n \n \n Has {keys.length - 3} more options\n \n \n )}\n \n )\n },\n\n badge: () => {\n return (\n \n Update options\n \n )\n }\n }\n ]}\n />\n )\n}\n","import { checkerboard } from './styles/previews/index.js'\nimport { Flex, FlexProps } from '@chakra-ui/react'\nimport { ReactNode } from 'react'\nimport { css } from '@emotion/react'\n\nexport const Wrapper: FlexProps = {\n borderRadius: 'base',\n overflowY: 'hidden',\n position: 'relative',\n width: 'auto',\n cursor: 'pointer',\n padding: '5',\n background: 'white'\n}\n\nexport const Shadow: FlexProps = {\n display: 'none',\n position: 'absolute',\n bottom: '-2px',\n border: '1px solid transparent',\n boxShadow: '0px -2px 4px rgba(0, 0, 0, 0.15)'\n}\n\nconst wrapperCSS = (hasCheckerboard: boolean) => css`\n &.overflowing .shadow {\n display: block;\n }\n\n & {\n ${hasCheckerboard ? checkerboard : null}\n }\n`\n\nconst ComponentVersionThumbnailWrapper = ({\n children,\n hasCheckerboard,\n shadowExtent = 0,\n height = 220,\n className,\n ...props\n}: {\n children: ReactNode\n shadowExtent?: any\n hasCheckerboard?: boolean\n className?: string\n height?: number\n} & FlexProps) => (\n \n {children}\n\n \n \n)\n\nexport default ComponentVersionThumbnailWrapper\n","import { Box, BoxProps, Flex, FlexProps, Skeleton, SkeletonProps, Text } from '@chakra-ui/react'\nimport { renderComponent, Thumbnail } from '@sitecore-feaas/clientside/headless'\nimport { ComponentModel, Style, StylesheetModel, VersionModel } from '@sitecore-feaas/sdk'\nimport { useLayoutEffect, useMemo, useRef, useState } from 'react'\nimport { EnvironmentVariables } from './providers/EnvironmentProvider.js'\n\nconst ThumbnailEmpty = (status: string): FlexProps => ({\n justifyContent: 'center',\n alignItems: 'center',\n pointerEvents: 'none',\n display: 'flex',\n background: 'gray.50',\n position: 'absolute',\n inset: 0,\n flexDirection: 'column'\n})\n\nexport const ThumbnailEmptyIcon = {\n width: '100px',\n height: '100px'\n}\n\nexport const Wrapper = (overflow: number, hovered: boolean): BoxProps => ({\n justifyContent: 'center',\n pointerEvents: 'none',\n userSelect: 'none',\n alignItems: 'center',\n width: 'full',\n padding: 0,\n transitionTimingFunction: 'linear',\n willChange: 'transform',\n transition: hovered ? `transform ${overflow * 0.009}s linear` : `transform ${overflow * 0.002}s`,\n transform: hovered && `translateY(-${overflow - 10}px)`\n})\n\nexport const ThumbnailSkeleton = (status: any): SkeletonProps => ({\n height: 'full',\n pointerEvents: 'none',\n opacity: 0,\n position: 'absolute',\n top: 0,\n bottom: 0,\n left: 0,\n right: 0\n})\n\ntype ImgRef = React.MutableRefObject & {\n setImage: (img: HTMLImageElement) => void\n}\n\nconst ComponentVersionThumbnail = ({\n children,\n component: original,\n version,\n targetHeight = 200,\n onLoad,\n stylesheet,\n ...props\n}: {\n children?: any\n component: ComponentModel\n version?: VersionModel\n targetHeight?: number\n stylesheet?: StylesheetModel\n onLoad?: (image: HTMLImageElement) => any\n\n [key: string]: any\n}) => {\n const component = useMemo(() => original.clone(), [original])\n const [status, setNextStatus] = useState<'fetching' | 'showing' | 'cached' | 'empty'>(\n component.isNew || version?.isViewEmpty() ? 'empty' : 'fetching'\n )\n const imgRef = useRef(null) as ImgRef\n\n function setStatus(state: typeof status = status) {\n setNextStatus(state)\n const skeleton = imgRef.current?.closest('.scroll-wrapper')?.nextElementSibling as HTMLElement\n if (skeleton) {\n Object.assign(skeleton.style, {\n opacity: state !== 'fetching' ? 0 : 0.3,\n transition: state == 'cached' ? 'opacity .0s' : 'opacity 0.3s'\n })\n }\n const empty = skeleton?.nextElementSibling as HTMLElement\n if (empty) {\n Object.assign(empty.style, {\n transition: state == 'fetching' || state == 'cached' ? 'opacity .0s' : 'opacity 0.3s',\n opacity: state == 'empty' ? '1' : '0'\n })\n }\n }\n useLayoutEffect(() => {\n if (stylesheet) {\n Thumbnail.generate(component, version, stylesheet).then((img) => {\n if (img) {\n imgRef.setImage(img)\n onLoad?.(imgRef.current)\n }\n setStatus(!img ? 'empty' : 'showing')\n })\n } else {\n Thumbnail.get(component, version, (img, isCached) => {\n if (img) {\n imgRef.setImage(img)\n onLoad?.(imgRef.current)\n }\n setStatus(!img ? 'empty' : isCached ? 'cached' : 'showing')\n })\n }\n }, [component, version])\n\n useLayoutEffect(() => {\n setStatus(status)\n }, [])\n\n return (\n \n \n \n {children}\n \n \n )\n}\n\ntype ThumbnailStatus = 'fetching' | 'showing' | 'cached' | 'empty'\n\nexport const ScrollableThumbnail = ({\n imgRef,\n src,\n targetHeight = 200,\n status,\n children,\n ...props\n}: {\n imgRef?: ImgRef\n src?: string\n children?: any\n targetHeight?: number\n status?: ThumbnailStatus\n [key: string]: any\n}) => {\n const [overflow, setOverflow] = useState(0)\n const [hovered, setHovered] = useState(false)\n\n const ownRef = useRef(null) as ImgRef\n imgRef ||= ownRef\n\n if (!status) {\n status = imgRef.current?.src ? 'showing' : 'fetching'\n }\n\n const setImage = (img: HTMLImageElement) => {\n if (!imgRef.current) return\n imgRef.current.src = img.src\n\n const wrapper = imgRef.current.closest('.thumbnail-wrapper') as HTMLElement\n const height = (img.height / img.width) * wrapper.offsetWidth\n wrapper.classList.toggle('overflowing', height > targetHeight)\n setOverflow(Math.max(0, height - targetHeight))\n imgRef.current.style.opacity = '1'\n // important to do it here to avoid flashing\n ;(imgRef.current.closest('.scroll-wrapper') as HTMLElement).style.alignSelf =\n height > targetHeight ? 'flex-start' : 'center'\n }\n if (imgRef) {\n imgRef.setImage = setImage\n }\n\n useLayoutEffect(() => {\n if (src) {\n const img = new Image()\n img.src = src\n img.onload = () => {\n setImage(img)\n }\n }\n }, [])\n\n useLayoutEffect(() => {\n const enable = () => setHovered(true)\n const disable = () => setHovered(false)\n const wrapper = imgRef.current.closest('.thumbnail-wrapper')\n wrapper.addEventListener('mouseenter', enable)\n wrapper.addEventListener('mouseleave', disable)\n\n return () => {\n wrapper.removeEventListener('mouseenter', enable)\n wrapper.removeEventListener('mouseleave', disable)\n }\n }, [])\n\n return (\n <>\n \n \n \n \n {children}\n \n )\n}\n\nexport default ComponentVersionThumbnail\n","import { Box, BoxProps, Divider, HStack, Icon, IconButton, Text } from '@chakra-ui/react'\nimport { mdiChevronLeft, mdiChevronRight, mdiClose, mdiDelete } from '@mdi/js'\nimport { PropsWithChildren } from 'react'\n\nexport function PickerWrapper({\n title,\n children,\n onBack,\n onClose,\n iconRight,\n variant,\n ...props\n}: PropsWithChildren<\n BoxProps & {\n onBack?: () => void\n iconRight?: any\n onClose?: () => void\n title: string\n variant?: string\n }\n>) {\n return (\n \n }\n position={'relative'}\n >\n {onBack && (\n <>\n \n \n \n }\n aria-label='Back'\n />\n \n )}\n \n {title}\n \n\n {onClose && (\n <>\n \n \n \n }\n aria-label='Back'\n />\n \n )}\n {iconRight}\n \n {children}\n \n )\n}\n","import {\n Box,\n Button,\n Card,\n CardBody,\n FormControl,\n FormErrorMessage,\n FormLabel,\n HStack,\n Icon,\n Input,\n Spacer,\n Text,\n VStack\n} from '@chakra-ui/react'\nimport React, { useState } from 'react'\nimport { mdiBookOpenPageVariantOutline, mdiOpenInNew } from '@mdi/js'\nimport { EmbeddableComponent } from '@sitecore-feaas/sdk'\n\nconst PickerLibraryCreateWebComponent = ({\n onCreate\n}: {\n onCreate: (component: EmbeddableComponent, attributes?: any) => void\n}) => {\n const [name, setName] = useState('')\n const [url, setUrl] = useState('')\n\n const handleNameChange = (e: React.ChangeEvent) => setName(e.target.value)\n const handleURLChange = (e: React.ChangeEvent) => setUrl(e.target.value)\n const [errors, setErrors] = useState([])\n const validate = () => {\n const errors = []\n if (name === '') errors.push('name')\n if (url === '') errors.push('url')\n return errors\n }\n\n const handleCreate = () => {\n const errors = validate()\n if (!errors.length) {\n onCreate(null, { 'data-embed-as': name, 'data-embed-src': url })\n } else {\n setErrors(errors)\n }\n }\n\n return (\n <>\n \n \n \n \n \n \n \n \n \n \n \n \n Web component\n \n \n Web components allow adding clientside interactive features to the design. One-off web component can\n be created using this form, alternatively it can be made reusable through BYOC mechanism\n \n \n \n \n \n Documentation{' '}\n \n \n \n \n \n \n \n \n Name\n \n {errors.includes('name') && Name is required.}\n \n \n Javascript source URL\n \n {errors.includes('url') && URL is required.}\n \n \n {/* footer */}\n \n \n \n \n \n \n )\n}\n\nexport default PickerLibraryCreateWebComponent\n","import {\n Accordion,\n AccordionButton,\n AccordionIcon,\n AccordionItem,\n AccordionPanel,\n Box,\n Button,\n HStack,\n StackProps,\n Text,\n VStack\n} from '@chakra-ui/react'\nimport { css } from '@emotion/react'\nimport {\n CollectionModel,\n ComponentModel,\n EmbeddableComponent,\n ExternalComponentModel,\n getEmbedDefinition\n} from '@sitecore-feaas/sdk'\nimport React, { useMemo, useState } from 'react'\nimport ComponentVersionThumbnail, { ScrollableThumbnail } from '../ComponentVersionThumbnail.js'\nimport ComponentVersionThumbnailWrapper from '../ComponentVersionThumbnailWrapper.js'\nimport type { PickerProps } from './Picker.js'\nimport { PickerWrapper } from './PickerWrapper.js'\nimport PickerLibraryCreateWebComponent from './PickerLibraryCreateWebComponent.js'\n\nexport function EmbeddableComponentThumbnail({\n component,\n height,\n ...props\n}: { component: EmbeddableComponent; height?: number } & StackProps) {\n return (\n \n {!ExternalComponentModel.isExternalComponent(component) ? (\n component && \n ) : (\n \n )}\n \n )\n}\nexport function EmbeddableComponentList({\n collection,\n onChange,\n value,\n ...props\n}: {\n collection: EmbeddableComponent[]\n value: EmbeddableComponent\n onChange: (component: EmbeddableComponent) => void\n} & Omit) {\n return (\n \n {collection.map((component: EmbeddableComponent) => (\n {\n onChange(component)\n }}\n >\n \n \n \n {'title' in component ? component.title : component.name}\n \n \n \n ))}\n \n )\n}\n\nconst PickerLibrary = ({\n externalComponents,\n component,\n context,\n embed,\n variant,\n onChange,\n onModeChange,\n collections\n}: {\n externalComponents: EmbeddableComponent[]\n context: PickerProps['context']\n embed: PickerProps['embed']\n component: ComponentModel\n variant?: PickerProps['variant']\n onModeChange: PickerProps['onModeChange']\n onChange: (component: EmbeddableComponent, attributes?: any) => void\n collections: CollectionModel[]\n}) => {\n const [isWebComponentView, setIsWebComponentView] = useState(false)\n const stagedComponents = collections.flatMap((c) => c.components).filter((comp) => comp.stagedAt)\n const allComponents = [...stagedComponents, ...externalComponents] as EmbeddableComponent[]\n const embedDefinition = getEmbedDefinition(context)\n const pickerMode = useMemo(() => {\n return embedDefinition.type == 'form' ? 'form' : null\n }, [])\n const filteredComponents = allComponents.filter((c) => {\n return pickerMode == 'form'\n ? ExternalComponentModel.isExternalComponent(c) && ExternalComponentModel.isComponentForm(c)\n : true\n })\n\n const groups = filteredComponents.reduce((groups, comp) => {\n if (comp instanceof ComponentModel) {\n // avoid nesting components into themselves\n if (comp.id == component?.id) return groups\n var groupName = comp.collection.name\n } else {\n var groupName = comp.group\n }\n ;(groups[groupName] ||= []).push(comp)\n return groups\n }, {} as Record)\n\n const groupNames = Object.keys(groups)\n const activeIndex = groupNames.findIndex((groupName) => groups[groupName].some((c) => c.id == embed?.id))\n return (\n setIsWebComponentView(false) : !embed ? null : () => onModeChange()}\n title={pickerMode == 'form' ? 'Sitecore Forms' : 'Components'}\n >\n {!isWebComponentView ? (\n <>\n \n {filteredComponents.length} component{filteredComponents.length == 1 ? '' : 's'} available\n \n {groupNames.length > 1 && (\n groups[groupName].some((c) => c.id == embed?.id))}\n >\n {groupNames.map((groupName) => (\n \n {({ isExpanded }: { isExpanded: boolean }) => (\n <>\n \n \n \n {groupName}\n \n \n \n \n \n {isExpanded && (\n \n )}\n \n \n )}\n \n ))}\n \n )}\n {groupNames.length <= 1 && (\n <>\n \n \n )}\n\n {/* footer */}\n {variant != 'pages' && embedDefinition?.type !== 'form' && (\n <>\n \n \n \n or\n \n \n \n \n )}\n \n ) : (\n \n )}\n \n )\n}\n\nexport default PickerLibrary\n","import {\n ComponentModel,\n EmbeddableComponent,\n ExternalComponentModel,\n VersionModel,\n getEmbedDefinition\n} from '@sitecore-feaas/sdk'\nimport { DialogMenu } from './DialogMenu.js'\nimport { PickerProps } from '../../picker/Picker.js'\nimport ComponentVersionThumbnailWrapper from '../../ComponentVersionThumbnailWrapper.js'\nimport ComponentVersionThumbnail from '../../ComponentVersionThumbnail.js'\nimport { Badge, Text } from '@chakra-ui/react'\nimport { EmbeddableComponentThumbnail } from '../../picker/PickerLibrary.js'\nimport { mdiListBox, mdiListBoxOutline, mdiSelect } from '@mdi/js'\n\nexport default function DialogMenuComponent({\n variant,\n version,\n collections,\n embed,\n context,\n externalComponents,\n onModeChange\n}: {\n version: VersionModel\n variant: PickerProps['variant']\n context: PickerProps['context']\n collections: PickerProps['collections']\n externalComponents: PickerProps['externalComponents']\n embed: PickerProps['embed']\n onModeChange: PickerProps['onModeChange']\n}) {\n const externalComponent = ExternalComponentModel.isExternalComponent(embed) ? embed : null\n const component = embed && !ExternalComponentModel.isExternalComponent(embed) ? embed : null\n const embedDefinition = getEmbedDefinition(context)\n const stagedComponents = collections.flatMap((c) => c.components).filter((comp) => comp.stagedAt)\n const allComponents = [...stagedComponents, ...externalComponents] as EmbeddableComponent[]\n const choices = !embedDefinition\n ? []\n : embedDefinition.type == 'form'\n ? allComponents.filter(ExternalComponentModel.isComponentForm)\n : allComponents\n version ||= component?.getBundles()[0].aggregate('staged')\n\n return component && variant == 'pages' ? (\n onModeChange('versions')}\n items={[\n {\n onNavigate: () => onModeChange('versions'),\n id: 'versions',\n label: version ? version?.name : 'Responsive' + component.stagedVersionCount,\n icon: null,\n isDisabled: component.stagedVersionCount < 2,\n preview: () => {\n return (\n \n \n \n )\n },\n badge:\n component.embeddableVersionCount > 1\n ? () => {\n return (\n \n {component.embeddableVersionCount} versions\n \n )\n }\n : null\n }\n ]}\n />\n ) : (\n onModeChange('library')}\n items={[\n {\n onNavigate: () => onModeChange('library'),\n id: 'versions',\n label: embed ? ('title' in embed ? embed.title : embed.name) : 'Unknown component',\n icon: null,\n isDisabled: choices.length < 2,\n preview: () => {\n return (\n \n \n \n )\n },\n badge: () => {\n return (\n \n {embedDefinition.type == 'form' ? choices.length + ' forms' : choices.length + ' components'}\n \n )\n }\n },\n (component?.stagedVersionCount > 1 || version) && {\n onNavigate: () => onModeChange('versions'),\n id: 'versions',\n label: 'Version',\n icon: mdiListBoxOutline,\n badge: () => (\n \n {version.name}\n \n )\n }\n ].filter(Boolean)}\n />\n )\n}\n","import { Box, Flex, HStack, Icon, IconButton, Text, VStack } from '@chakra-ui/react'\nimport { DialogMenu } from './DialogMenu.js'\nimport { DataOptionsById, Datasource, DatasourceModel } from '@sitecore-feaas/sdk'\nimport { DataPath, DataSettings } from '@sitecore-feaas/clientside/headless'\nimport { PickerProps } from '../../picker/Picker.js'\nimport DataItem from '../../DataItem.js'\nimport DatasourceBadge from '../../DatasourceBadge.js'\nimport { mdiConnection, mdiTrashCan } from '@mdi/js'\n\nexport default function DialogMenuDatasources({\n data,\n variant,\n datasources,\n onModeChange,\n onDeleteItem\n}: {\n data: DataOptionsById\n datasources: DatasourceModel[]\n onModeChange: PickerProps['onModeChange']\n variant: PickerProps['variant']\n onDeleteItem: (datasourceId: Datasource['id']) => void\n}) {\n return (\n onModeChange('datasources'),\n id: 'attributes',\n label: null,\n icon: null,\n preview: () => (\n \n \n \n \n \n \n No data available\n \n ),\n badge: () => (\n \n Unconfigured\n \n )\n }\n ]\n : datasources.map((datasource) => {\n const jsonpath = (data?.[datasource?.id] as DataSettings)?.jsonpath\n const qualifier = jsonpath ? DataPath.getQualifier(jsonpath) : null\n const repeating = DataPath.parseLimit(qualifier)\n ? 'limit'\n : DataPath.parseRange(qualifier)\n ? 'range'\n : 'no-limit'\n const sample = data?.[datasource.id]\n return {\n onNavigate: () => onModeChange('datasources', datasource.id),\n id: 'attributes',\n label: null,\n icon: null,\n preview: () => (\n \n \n \n \n \n {onDeleteItem && (\n {\n e.stopPropagation()\n onDeleteItem(datasource.id)\n }}\n color={'red.600'}\n size={'sm'}\n icon={\n \n \n \n }\n />\n )}\n \n \n \n ),\n badge: () => (\n \n {repeating === 'limit' ? 'Limited' : repeating === 'range' ? 'Specific' : 'All'}\n \n )\n }\n })\n }\n >\n )\n}\n","import { Box } from '@chakra-ui/react'\nimport Preview, { PreviewFontsStylesheet } from '../../styles/previews/index.js'\nimport { DialogMenu } from './DialogMenu.js'\nimport { PickerProps } from '../../picker/Picker.js'\nimport { Style } from '@sitecore-feaas/sdk'\nimport { Text } from '@chakra-ui/react'\n\nexport function DialogMenuTheme({\n onModeChange,\n variant,\n theme,\n rules\n}: { theme: Style.Rule<'theme'> } & Pick) {\n const themes = Style.Set.filterByType(rules, 'theme')\n return (\n onModeChange('themes')}\n items={[\n {\n onNavigate: () => onModeChange('themes'),\n id: 'themes',\n label: theme.details.title,\n icon: null,\n isDisabled: themes.length < 2,\n preview: () => {\n return (\n <>\n \n \n \n \n \n )\n },\n badge: () => {\n return (\n themes.length > 1 && (\n \n {themes.length} themes\n \n )\n )\n }\n }\n ]}\n />\n )\n}\n","import { Divider, Img, Tooltip, VStack } from '@chakra-ui/react'\nimport { ExternalComponentModel, Style, getEmbedDefinition, DatasourceModel, Datasource } from '@sitecore-feaas/sdk'\nimport { useContext, useEffect, useMemo, useState } from 'react'\nimport {\n AttributeCallback,\n AttributeGetter,\n ContextCallback,\n Dialog,\n DialogAttribute,\n DialogStyle,\n RuleCallback,\n dialogs\n} from '../editor/dialog/Dialog.js'\nimport DialogAttributesExternalSchema from '../editor/dialog/DialogAttributesExternalSchema.js'\nimport { DialogMenu } from '../editor/dialog/DialogMenu.js'\nimport DialogMenuAttributes from '../editor/dialog/DialogMenuAttrbutes.js'\nimport DialogMenuComponent from '../editor/dialog/DialogMenuComponent.js'\nimport DialogMenuDatasources from '../editor/dialog/DialogMenuDatasources.js'\nimport { DialogMenuTheme } from '../editor/dialog/DialogMenuTheme.js'\nimport type { PickerProps } from './Picker.js'\nimport { PickerWrapper } from './PickerWrapper.js'\nimport { Link } from '@chakra-ui/react'\nimport { getComponentConfigurablePropertyNames, objectKeysToCamelCase } from '@sitecore/byoc'\nimport { EnvironmentContext } from '../providers/EnvironmentProvider.js'\nimport { useSDK } from '../../exports.js'\nimport { mdiPlus } from '@mdi/js'\n\nexport type PickerContextProps = {\n onBack?: () => void\n data: PickerProps['data']\n rules: Style.Rule[]\n customRules: Style.Rule[]\n themeClassList: string[]\n classList: string[]\n context: Style.Context\n contextLink: Style.Context\n contextVariable: Style.Context\n getAttribute: AttributeGetter\n onAttributeChange: AttributeCallback\n onRuleChange: RuleCallback\n onSelect: ContextCallback\n variant: PickerProps['variant']\n theme: Style.Rule<'theme'>\n embed: PickerProps['embed']\n collections: PickerProps['collections']\n externalComponents: PickerProps['externalComponents']\n datasources: DatasourceModel[]\n onModeChange: (mode?: PickerProps['mode'], dialog?: string) => void\n dialog: string\n}\nexport default function PickerContext(props: PickerContextProps) {\n const {\n context,\n onBack,\n onModeChange,\n rules,\n variant,\n customRules,\n data,\n embed,\n theme,\n dialog: dialogName,\n collections,\n externalComponents,\n datasources,\n onAttributeChange,\n getAttribute\n } = props\n const setDialogName = (dialog: string) => onModeChange('context', dialog)\n\n const [index, setIndex] = useState(0)\n const definition = Style.Context.getDefinition(context)\n const environment = {\n ...props,\n onNavigate: setDialogName,\n definition,\n index,\n setIndex\n }\n const env = useContext(EnvironmentContext)\n const sdk = useSDK()\n\n const applicableDialogs = dialogs\n .filter((definition) => context && definition.condition(environment))\n .map((definition) => ({\n ...definition,\n ...environment,\n ...('prepare' in definition ? definition.prepare(environment) : {})\n })) as Dialog[]\n const dialog = applicableDialogs.find((d) => d.id == dialogName)\n const styleOverviewDialogs = applicableDialogs.filter((d) => d.group == 'style' && d.id == 'style') as DialogStyle[]\n const styleDialogs = applicableDialogs.filter((d) => d.group == 'style' && d.id != 'style') as DialogStyle[]\n const contentDialogs = applicableDialogs.filter(\n (d) => d.group == 'attribute' && d.id != 'repeating'\n ) as DialogAttribute[]\n const dataDialogs = applicableDialogs.filter(\n (d) => d.group == 'attribute' && d.id == 'repeating'\n ) as DialogAttribute[]\n\n const customDefinition = Style.Set.getContextDefinition(rules, context, false)\n try {\n var defaultData = objectKeysToCamelCase(JSON.parse((getAttribute(context, 'data-attributes') || '{}') as string))\n } catch (e) {\n defaultData = {}\n }\n const externalComponent = ExternalComponentModel.isExternalComponent(embed) ? embed : null\n const embedDefinition = getEmbedDefinition(context)\n const title = !embed\n ? embedDefinition\n ? embedDefinition?.type == 'html'\n ? 'HTML Block'\n : 'Unknown component'\n : customDefinition?.label\n : ExternalComponentModel.isExternalComponent(embed)\n ? embed.title\n : embed.name\n const component = embed && !ExternalComponentModel.isExternalComponent(embed) ? embed : null\n const versionId = getAttribute(context, 'version')\n const version = versionId\n ? component?.getEmbeddableVersions('saved').find((version) => {\n return versionId == version.id\n })\n : null\n const configurableProperties = externalComponent && getComponentConfigurablePropertyNames(externalComponent)\n\n // TODO: THIS IS JUST AN EXAMPLE. GET RID OF THIS ONCE IMPLEMENTATION HAS BEEN DONE FROM PAGES SIDE\n // useEffect(() => {\n // if (externalComponent && !data) {\n // const externalComponentDefaultData = externalComponents.find((c) => c.id === externalComponent.id)?.getDataSettings()\n // if (externalComponentDefaultData) onAttributeChange('data', externalComponentDefaultData, context)\n // }\n // }, [])\n\n return (\n setDialogName(null) : onBack}\n variant={variant}\n iconRight={\n (component && location.pathname != component.getBuilderPath() && (\n \n \n \n \n \n )) ||\n (embedDefinition?.type == 'form' && (\n <>\n \n \n \n \n \n \n ))\n }\n >\n {dialogName == null && (\n } py={6}>\n {embedDefinition && embedDefinition.type != 'html' && embedDefinition.type != 'web' && (\n \n )}\n {component?.getDatasources()?.length > 0 && (\n // It is not possible to change data source settings for nested FEAAS component yet\n {\n const newData = { ...data }\n delete newData[datasourceId]\n onAttributeChange('data', newData, context)\n }\n : null\n }\n />\n )}\n {configurableProperties?.length > 0 && (\n }>\n \n \n )}\n {variant == 'pages' && externalComponent && (\n <>\n {\n const newData = { ...data }\n delete newData[datasourceId]\n onAttributeChange('data', newData, context)\n }}\n />\n {DatasourceModel.getExternalComponentDatasources(data, datasources)?.length > 0 && (\n onModeChange('datasources'),\n id: 'add-datasource',\n label: 'Add datasource',\n icon: mdiPlus\n }\n ]}\n />\n )}\n \n )}\n {variant != 'pages' && styleOverviewDialogs.length > 0 && (\n onModeChange('element')}\n items={styleOverviewDialogs}\n />\n )}\n {variant != 'pages' && styleDialogs.length > 0 && (\n \n )}\n {variant == 'pages' &&\n (!ExternalComponentModel.isExternalComponent(embed) || !ExternalComponentModel.isComponentForm(embed)) && (\n <>\n \n \n )}\n {variant != 'pages' && contentDialogs.length > 0 && (\n \n )}\n {dataDialogs.length > 0 && (\n d.group == 'attribute' && d.id == 'repeating')}\n onNavigate={setDialogName}\n title='Data scope'\n >\n )}\n \n )}\n {dialogName == 'schema' && ExternalComponentModel.isExternalComponent(embed) ? (\n \n {\n onAttributeChange(attribute, value)\n }}\n />\n \n ) : (\n dialogName != null && \n )}\n \n )\n}\n\nexport function PickerContextDialog(props: Dialog) {\n // reember components to avoid react reinsertion\n const { component } = useMemo(() => props, [])\n return (\n \n {component?.(props)}\n \n )\n}\n","import { createContext } from 'react'\n\nexport const EntityContext = createContext<{\n isActive: boolean\n onToggleEntity: (event?: any, force?: boolean) => void\n ref: any\n isNew: boolean\n onSafeDelete: () => void\n onDiscard: () => void\n hasChanges: boolean\n isBordered?: boolean\n onUnsafeDelete: () => void\n onDelete: () => void\n onSave: () => void\n hasErrors: boolean\n onCopy: () => void\n isNonEditable: boolean\n activityAttribute: any\n onMouseEnterUpper?: () => void\n onMouseLeaveUpper?: () => void\n wrapperClassname?: string\n preventSaveToast?: boolean\n selectRef: any\n invalidNonEmptyFields: string[]\n emptyRequiredFields: string[]\n name: string\n modalHeader?: any\n modalFooter?: any\n type?: string\n id: string\n getClassname: any\n withModal?: boolean\n}>({\n isActive: false,\n preventSaveToast: false,\n onToggleEntity: () => {},\n ref: null,\n isNew: false,\n onSafeDelete: () => {},\n id: '',\n onDiscard: () => {},\n isBordered: true,\n hasChanges: false,\n onUnsafeDelete: () => {},\n onDelete: () => {},\n invalidNonEmptyFields: [],\n emptyRequiredFields: [],\n onSave: () => {},\n hasErrors: false,\n onCopy: () => {},\n selectRef: null,\n isNonEditable: false,\n onMouseEnterUpper: () => {},\n onMouseLeaveUpper: () => {},\n activityAttribute: '',\n wrapperClassname: '',\n getClassname: () => {},\n name: '',\n modalHeader: '',\n modalFooter: '',\n type: '',\n withModal: false\n})\n","import {\n Box,\n Icon,\n IconButton,\n Menu,\n MenuButton,\n MenuDivider,\n MenuItem,\n MenuItemProps,\n MenuList,\n Tooltip\n} from '@chakra-ui/react'\nimport { mdiContentCopy, mdiDotsHorizontal, mdiPencilOutline, mdiTrashCanOutline } from '@mdi/js'\nimport { useContext } from 'react'\nimport { EntityContext } from '../../contexts/EntityContext.js'\n\nconst IconXL = ({ d, className }: { d: string; className?: string }) => (\n \n \n \n)\n\nconst DeleteButton: MenuItemProps = {\n color: 'red.400'\n}\n\nconst EntityActionsMenu = ({ extraMenuActions, menuDetails, className, isHidden }: any) => {\n const { isNew, onSafeDelete, hasChanges, name, id, onCopy, onToggleEntity, isActive, isNonEditable, onDelete } =\n useContext(EntityContext)\n\n const hasNoMenuItems = !onSafeDelete && !onCopy && !extraMenuActions && !menuDetails\n\n if (hasNoMenuItems && (isNonEditable || isActive)) return null\n\n const suffix = `entity ${name} with id: ${id}`\n\n return (\n \n \n \n }\n />\n \n\n \n {extraMenuActions}\n\n {!isNonEditable && (\n onToggleEntity(e, true)}\n aria-label={`Toggle ${suffix}`}\n icon={}\n >\n Edit {name}\n \n )}\n\n {onCopy && (\n }\n >\n Duplicate\n \n )}\n\n {(extraMenuActions || onDelete) && }\n\n {onDelete && (\n \n \n \n }\n >\n Delete\n \n )}\n\n {menuDetails}\n \n \n \n )\n}\n\nexport default EntityActionsMenu\n","import { Button } from '@chakra-ui/react'\nimport { useContext } from 'react'\nimport EntityActionsMenu from './EntityActionsMenu.js'\nimport { EntityContext } from '../../contexts/EntityContext.js'\n\nconst EntityBlockActions = ({ extraMenuActions, extraActions, menuDetails }: any) => {\n const {\n isActive,\n onToggleEntity,\n isNew,\n onSafeDelete,\n onDiscard,\n name,\n hasChanges,\n onUnsafeDelete,\n onSave,\n hasErrors,\n id,\n withModal\n } = useContext(EntityContext)\n\n const suffix = `entity ${name} with id: ${id}`\n\n return (\n <>\n {extraActions}\n\n {isActive && (\n <>\n {!withModal && isNew && onSafeDelete && (\n \n )}\n\n {!withModal && hasChanges && !isNew && (\n \n )}\n\n {!withModal &&\n (hasChanges || isNew ? (\n \n Save\n \n ) : (\n onToggleEntity(e, true)}\n >\n Close\n \n ))}\n \n )}\n\n {(withModal || (!isNew && !isActive)) && (\n \n )}\n \n )\n}\n\nexport default EntityBlockActions\n","import { createContext, Dispatch } from 'react'\n\nexport const EntitiesContext = createContext<{\n activeEntityId: string\n editedEntityId: string\n setEditedEntityId: Dispatch\n onToggle: (id: string, force?: boolean) => void\n editingAlert: {\n onDiscard: () => void\n invalidNonEmptyFields: string[]\n emptyRequiredFields: string[]\n }\n setEditingAlert: Dispatch<{\n onDiscard: () => void\n invalidNonEmptyFields: string[]\n emptyRequiredFields: string[]\n }>\n newEntityId: string\n setNewEntityId: Dispatch\n}>({\n activeEntityId: null,\n editedEntityId: null,\n setEditedEntityId: () => {},\n onToggle: () => {},\n editingAlert: null,\n setEditingAlert: () => {},\n newEntityId: null,\n setNewEntityId: () => {}\n})\n","import { Button, Modal, ModalContent, ModalHeader, ModalFooter, ModalBody, Box } from '@chakra-ui/react'\nimport { useContext } from 'react'\n\nimport { EntityContext } from '../../contexts/EntityContext.js'\nimport { EntitiesContext } from '../../contexts/EntitiesContext.js'\nimport { css } from '@emotion/react'\nimport { ModalOverlay } from '@chakra-ui/react'\n\nconst LG_MODAL = ['font', 'text', 'inline', 'block', 'theme']\nconst MD_MODAL = ['typography', 'decoration', 'spacing']\nconst SM_MODAL = ['fill']\n\nconst ModalContentStyle = css`\n .chakra-form__label {\n font-weight: var(--chakra-fontWeights-medium);\n color: var(--chakra-colors-black);\n font-size: var(--chakra-fontSizes-md);\n }\n`\n\nconst EntityModal = ({ children }: { children: any }) => {\n const {\n id,\n name,\n type,\n isActive,\n getClassname,\n onToggleEntity,\n isNew,\n onSafeDelete,\n onUnsafeDelete,\n hasChanges,\n onDiscard,\n onSave,\n hasErrors,\n modalHeader,\n modalFooter,\n invalidNonEmptyFields,\n emptyRequiredFields\n } = useContext(EntityContext)\n\n const { setEditingAlert } = useContext(EntitiesContext)\n\n const suffix = `entity ${name} with id: ${id}`\n\n const maxWidth = LG_MODAL.includes(type) ? '55vw' : MD_MODAL.includes(type) ? '36vw' : '392px'\n\n const onClose = () => {\n if (isNew && onSafeDelete) {\n onUnsafeDelete()\n return\n }\n if (!isNew && hasChanges) {\n setEditingAlert({\n onDiscard: onDiscard,\n invalidNonEmptyFields,\n emptyRequiredFields\n })\n return\n }\n onToggleEntity(null, true)\n }\n\n return (\n \n \n \n \n {modalHeader}\n \n \n \n {children}\n \n \n\n \n {modalFooter || (\n <>\n \n Cancel\n \n\n {\n onSave()\n onToggleEntity(e, true)\n }}\n >\n Save\n \n \n )}\n \n \n \n )\n}\n\nexport default EntityModal\n","import { Box, Flex } from '@chakra-ui/react'\nimport { useContext } from 'react'\nimport { EntityContext } from '../../contexts/EntityContext.js'\nimport { useSlots } from '../../hooks/useSlots.js'\nimport EntityActions from './EntityActions.js'\nimport EntityModal from './EntityModal.js'\nimport EntityActionsMenu from './EntityActionsMenu.js'\n\nconst EntityBlock = ({ children, className }: { children: any; className?: string }) => {\n const {\n isActive,\n isNonEditable,\n ref,\n id,\n getClassname,\n activityAttribute,\n onToggleEntity,\n onMouseEnterUpper,\n wrapperClassname,\n onMouseLeaveUpper,\n withModal,\n isNew\n } = useContext(EntityContext)\n\n if (withModal) {\n return useSlots(children, ({ preview, details, form, extraMenuActions, menuDetails, children }) => (\n \n \n {preview && {preview}}\n \n\n \n {details && {details}}\n\n {!isNew && (\n \n \n \n )}\n \n\n \n {form}\n \n\n {children}\n \n ))\n }\n\n return useSlots(children, ({ preview, details, form, extraActions, extraMenuActions, children }) => (\n \n \n \n {preview && {preview}}\n\n {details && (\n \n {details}\n \n )}\n \n\n \n \n \n \n\n {isActive && (\n \n {form}\n \n )}\n\n {children}\n \n ))\n}\n\nexport default EntityBlock\n","import { Box, Flex } from '@chakra-ui/react'\nimport { useContext } from 'react'\nimport { EntityContext } from '../../contexts/EntityContext.js'\nimport { useSlots } from '../../hooks/useSlots.js'\nimport EntityActions from './EntityActions.js'\nimport EntityActionsMenu from './EntityActionsMenu.js'\n\nconst EntityOverlay = ({ children, className }: { children: any; className?: string }) => {\n const {\n isActive,\n ref,\n id,\n getClassname,\n activityAttribute,\n isNonEditable,\n onToggleEntity,\n onMouseEnterUpper,\n onMouseLeaveUpper,\n wrapperClassname\n } = useContext(EntityContext)\n\n return useSlots(children, ({ preview, details, form, extraActions, menuDetails, extraMenuActions, children }) => (\n \n \n {preview && {preview}}\n\n \n {details}\n\n {!isActive && (\n \n )}\n \n \n\n {isActive && (\n \n \n {form}\n\n \n \n \n \n \n )}\n \n ))\n}\n\nexport default EntityOverlay\n","import { useEffect, RefObject } from 'react'\n\ntype Event = MouseEvent | TouchEvent\n\nconst useOnClickOutside = (ref: RefObject, handler: (event: Event) => void) => {\n useEffect(() => {\n const listener = (event: Event) => {\n const el = ref?.current\n if (!el || el.contains((event?.target as Node) || null)) {\n return\n }\n\n handler(event) // Call the handler only if the click is outside of the element passed.\n }\n\n document.addEventListener('mousedown', listener, true)\n\n return () => {\n document.removeEventListener('mousedown', listener, true)\n }\n }, [ref, handler]) // Reload only if ref or handler changes\n}\n\nexport default useOnClickOutside\n","import { Box, Flex } from '@chakra-ui/react'\nimport { useContext } from 'react'\nimport { useSlots } from '../../hooks/useSlots.js'\nimport EntityActions from './EntityActions.js'\nimport { EntityContext } from '../../contexts/EntityContext.js'\nimport EntityModal from './EntityModal.js'\n\nconst EntityCollection = ({ children, className }: any) => {\n const {\n isActive,\n isNonEditable,\n ref,\n id,\n getClassname,\n activityAttribute,\n onToggleEntity,\n wrapperClassname,\n withModal\n } = useContext(EntityContext)\n\n return useSlots(children, ({ preview, details, form, extraActions, extraMenuActions, children }) => {\n if (!preview && !details && !extraActions && !extraMenuActions) return children\n\n return (\n \n \n \n {preview && {preview}}\n\n {details && (\n \n {details}\n \n )}\n \n\n \n \n \n \n\n {withModal && {form}}\n {!withModal && isActive && {form}}\n\n {children}\n \n )\n })\n}\n\nexport default EntityCollection\n","import { Box, Flex } from '@chakra-ui/react'\nimport { useContext } from 'react'\nimport { EntityContext } from '../../contexts/EntityContext.js'\nimport { useSlots } from '../../hooks/useSlots.js'\nimport EntityActions from './EntityActions.js'\n\nconst EntityBlockOpen = ({ children, className }: { children: any; className?: string }) => {\n const {\n isActive,\n isNonEditable,\n ref,\n id,\n getClassname,\n activityAttribute,\n onToggleEntity,\n onMouseEnterUpper,\n wrapperClassname,\n onMouseLeaveUpper\n } = useContext(EntityContext)\n\n return useSlots(children, ({ preview, details, form, extraActions, extraMenuActions, children }) => (\n \n \n \n {preview && {preview}}\n\n {details && (\n \n {details}\n \n )}\n \n\n \n \n \n \n\n \n {form}\n \n\n {children}\n \n ))\n}\n\nexport default EntityBlockOpen\n","import React, { createContext, forwardRef, useContext, useEffect, useRef, useState } from 'react'\nimport EntityBlock from './EntityBlock.js'\nimport EntityOverlay from './EntityOverlay.js'\nimport useOnClickOutside from '../../hooks/useOnClickOutside.js'\nimport useConfirmation from '../../hooks/useConfirmation.js'\nimport { Text, useToast } from '@chakra-ui/react'\nimport { EntitiesContext } from '../../contexts/EntitiesContext.js'\nimport { EntityContext } from '../../contexts/EntityContext.js'\nimport { scrollForTogglingCard } from '../../utils/dom.js'\nimport * as inflection from 'inflection'\nimport EntityCollection from './EntityCollection.js'\nimport EntityBlockOpen from './EntityBlockOpen.js'\n\nconst EntityProvider = forwardRef(\n (\n {\n mode = 'block',\n id,\n isNew = false,\n className,\n onDelete,\n onDiscard,\n hasChanges,\n isBordered = true,\n onSave,\n hasErrors = false,\n onCopy,\n isNonEditable,\n safeDeleteLabel,\n onMouseEnterUpper,\n onMouseLeaveUpper,\n name,\n modalHeader,\n modalFooter,\n type,\n preventSaveToast,\n invalidNonEmptyFields = [],\n emptyRequiredFields = [],\n withModal = false,\n children\n }: {\n className?: string\n mode?: 'block' | 'overlay' | 'collection' | 'open'\n id: string\n isNew?: boolean\n name: string\n modalHeader?: any\n modalFooter?: any\n type?: string\n isBordered?: boolean\n onDelete?: () => void\n onDiscard: () => void\n hasChanges: boolean\n safeDeleteLabel?: any\n onSave: () => void\n hasErrors?: boolean\n preventSaveToast?: boolean\n invalidNonEmptyFields?: string[]\n emptyRequiredFields?: string[]\n onCopy?: () => void\n onMouseEnterUpper?: () => void\n onMouseLeaveUpper?: () => void\n isNonEditable?: boolean\n withModal?: boolean\n children: any\n },\n passedRef: any\n ) => {\n const {\n editedEntityId,\n setEditedEntityId,\n activeEntityId,\n onToggle,\n setEditingAlert,\n setNewEntityId,\n newEntityId\n } = useContext(EntitiesContext)\n\n const isActive = activeEntityId === id\n\n const ref = passedRef || useRef(null)\n\n const selectRef = useRef(null)\n\n useEffect(() => {\n setEditedEntityId(isActive && hasChanges ? id : null)\n }, [hasChanges])\n\n useEffect(() => {\n setNewEntityId(isNew ? id : null)\n }, [isNew])\n\n useOnClickOutside(ref, (e) => {\n if (!isActive || withModal) return\n\n const isClickOnAllowable = (e.target as HTMLElement).closest('.confirm-dialog')\n const isClickOnOtherEntity = (e.target as HTMLElement).closest('.entity-wrapper')\n\n if (isClickOnAllowable) return\n\n if (isNew && isUnsafeDeletable) {\n onUnsafeDelete()\n\n return\n }\n\n if (!hasChanges && !isNew) {\n // onToggleEntity(isClickOnOtherEntity && isClickOnOtherEntity.id.split('entity-')[1])\n\n return\n }\n\n setEditingAlert({\n onDiscard: _onDiscard,\n invalidNonEmptyFields,\n emptyRequiredFields\n })\n e.preventDefault()\n e.stopImmediatePropagation()\n e.stopPropagation()\n })\n\n const onToggleEntity = (e?: any, force?: boolean) => {\n if (isNonEditable) return\n\n if (\n e &&\n !force &&\n (e?.target?.type === 'button' ||\n e.target?.classList?.includes?.('clickable') ||\n e.target?.closest('.clickable'))\n )\n return\n\n onToggle(id, force)\n }\n\n const onUnsafeDelete = () => {\n if (isActive) {\n onToggleEntity(null, true)\n }\n setEditedEntityId(null)\n setNewEntityId(null)\n onDelete()\n }\n\n const _onDiscard = () => {\n onDiscard()\n\n if (isNew) {\n onDelete()\n }\n\n onToggleEntity(null, true)\n }\n\n const toast = useToast()\n\n const _onSave = () => {\n onSave()\n\n if (preventSaveToast) return\n\n toast({\n duration: 4000,\n status: 'success',\n title: isNew ? `${inflection.titleize(name)} added` : 'Changes saved'\n })\n }\n\n const onSafeDelete = useConfirmation(\n onUnsafeDelete,\n onDelete\n ? {\n title: `Delete ${name}`,\n button: 'Delete',\n body: {safeDeleteLabel || `Are you sure you want to delete this ${name}?`},\n variant: 'danger'\n }\n : null\n )\n\n const isUnsafeDeletable = isNew && !hasChanges\n\n const onDeleteComputed = !onDelete\n ? null\n : (): any => {\n if (isActive) {\n onToggleEntity(null, true)\n }\n\n if (isUnsafeDeletable) {\n onUnsafeDelete()\n return\n }\n\n onSafeDelete()\n }\n\n useEffect(() => {\n if (!isActive) return\n\n return scrollForTogglingCard(ref.current)\n }, [isActive])\n\n const computeClassnames = () => {\n const classNamesArray = [className, `entity-${mode}`]\n\n if (isNew) {\n classNamesArray.push('entity-new')\n }\n\n if (hasChanges) {\n classNamesArray.push('entity-changed')\n }\n\n if (isActive) {\n classNamesArray.push('entity-active')\n }\n\n return classNamesArray.filter(Boolean)\n }\n\n const getClassname = (suffix: string, clickable?: boolean) =>\n `entity-${mode}-${suffix}${clickable ? ' clickable' : ''}`\n\n const activityAttribute = isActive ? { 'data-active': true } : {}\n\n const wrapperClassname = [\n className,\n 'entity-wrapper',\n `entity-${mode}`,\n isActive && 'entity-is-active',\n ...computeClassnames()\n ]\n .filter(Boolean)\n .join(' ')\n\n useEffect(() => {\n document.body.classList.toggle('has-edited-entity', !!editedEntityId && !withModal)\n }, [editedEntityId])\n\n useEffect(() => {\n document.body.classList.toggle('has-edited-entity', !!newEntityId && !withModal)\n }, [newEntityId])\n\n useEffect(() => {\n if (typeof activeEntityId === 'boolean') return\n\n document.body.classList.toggle('has-active-entity', !!activeEntityId && !withModal)\n }, [activeEntityId])\n\n return (\n \n {mode === 'block' && {children}}\n {mode === 'overlay' && {children}}\n {mode === 'collection' && {children}}\n {mode === 'open' && {children}}\n \n )\n }\n)\n\nexport default EntityProvider\n","export function capitalizeFirstLetter(string: string) {\n return string.charAt(0).toUpperCase() + string.slice(1)\n}\n\nexport function isValidHttpUrl(value: string) {\n let url\n\n try {\n url = new URL(value)\n } catch (_) {\n return false\n }\n\n return !!(url.protocol === 'http:' || url.protocol === 'https:')\n}\n\nexport function isValidJSON(value: string) {\n try {\n const json = JSON.parse(value)\n\n if(json === null) return false\n\n return typeof json === 'object'\n } catch (e) {\n return false\n }\n}\n\nexport function strip(string: string) {\n return string.replace(/(\\r\\n|\\n|\\r)/gm, '').replace(/ /g, '')\n}\n\nexport function stringToOption(string: string) {\n return { value: string, label: string }\n}\n\nexport const stringify = (objectOrNull: object) => (objectOrNull ? JSON.stringify(objectOrNull) : '')\n","import { Box, Button, useToast } from '@chakra-ui/react'\nimport { useState } from 'react'\nimport { DatasourceModel } from '@sitecore-feaas/sdk'\n\nconst DatasourceFetchButton = ({\n currentDatasource,\n onChange,\n isBlock\n}: {\n currentDatasource: DatasourceModel\n onChange: (datasource: DatasourceModel) => void\n isBlock: boolean\n}) => {\n const toast = useToast()\n const [isFetching, setIsFetching] = useState(false)\n\n const onStart = async () => {\n setIsFetching(true)\n\n try {\n onChange(await currentDatasource.fetchUpdates())\n } catch (e) {\n console.log(e)\n toast({\n isClosable: true,\n duration: 4000,\n status: 'error',\n title: 'Data is not valid JSON',\n description: 'Please specify a correct JSON file'\n })\n } finally {\n setIsFetching(false)\n }\n }\n\n return (\n \n \n Fetch\n \n \n )\n}\n\nexport default DatasourceFetchButton\n","import FieldsetField from '../FieldsetField.js'\nimport { DatasourceModel } from '@sitecore-feaas/sdk'\nimport { stringify } from '../../utils/string.js'\nimport { Alert, AlertDescription, AlertIcon, AlertTitle, Box, HStack, VStack, Text, Textarea } from '@chakra-ui/react'\nimport DatasourceFetchButton from './DatasourceFetchButton.js'\nimport React from 'react'\n\nconst DatasourceConflictDefinition = ({\n currentDatasource,\n onChange\n}: {\n currentDatasource: DatasourceModel\n onChange: (datasource: DatasourceModel) => void\n}) => {\n return (\n \n \n \n \n \n \n There are conflicts between the fields of remote datasource and the current one\n\n \n Fetch to preview changes\n \n \n \n\n \n \n \n\n