{"version":3,"file":"main.B9dExAvR.js","sources":["../../../node_modules/object-assign/index.js","../../../node_modules/react/cjs/react.production.min.js","../../../node_modules/react/index.js","../../../node_modules/react/cjs/react-jsx-runtime.production.min.js","../../../node_modules/react/jsx-runtime.js","../../../node_modules/asap/browser-raw.js","../../../node_modules/promise/lib/core.js","../../../node_modules/promise/lib/rejection-tracking.js","../../../node_modules/promise/lib/es6-extensions.js","../../../node_modules/whatwg-fetch/fetch.js","../../../node_modules/core-js/internals/global-this.js","../../../node_modules/core-js/internals/fails.js","../../../node_modules/core-js/internals/descriptors.js","../../../node_modules/core-js/internals/function-bind-native.js","../../../node_modules/core-js/internals/function-call.js","../../../node_modules/core-js/internals/object-property-is-enumerable.js","../../../node_modules/core-js/internals/create-property-descriptor.js","../../../node_modules/core-js/internals/function-uncurry-this.js","../../../node_modules/core-js/internals/classof-raw.js","../../../node_modules/core-js/internals/indexed-object.js","../../../node_modules/core-js/internals/is-null-or-undefined.js","../../../node_modules/core-js/internals/require-object-coercible.js","../../../node_modules/core-js/internals/to-indexed-object.js","../../../node_modules/core-js/internals/is-callable.js","../../../node_modules/core-js/internals/is-object.js","../../../node_modules/core-js/internals/get-built-in.js","../../../node_modules/core-js/internals/object-is-prototype-of.js","../../../node_modules/core-js/internals/environment-user-agent.js","../../../node_modules/core-js/internals/environment-v8-version.js","../../../node_modules/core-js/internals/symbol-constructor-detection.js","../../../node_modules/core-js/internals/use-symbol-as-uid.js","../../../node_modules/core-js/internals/is-symbol.js","../../../node_modules/core-js/internals/try-to-string.js","../../../node_modules/core-js/internals/a-callable.js","../../../node_modules/core-js/internals/get-method.js","../../../node_modules/core-js/internals/ordinary-to-primitive.js","../../../node_modules/core-js/internals/define-global-property.js","../../../node_modules/core-js/internals/shared-store.js","../../../node_modules/core-js/internals/shared.js","../../../node_modules/core-js/internals/to-object.js","../../../node_modules/core-js/internals/has-own-property.js","../../../node_modules/core-js/internals/uid.js","../../../node_modules/core-js/internals/well-known-symbol.js","../../../node_modules/core-js/internals/to-primitive.js","../../../node_modules/core-js/internals/to-property-key.js","../../../node_modules/core-js/internals/document-create-element.js","../../../node_modules/core-js/internals/ie8-dom-define.js","../../../node_modules/core-js/internals/object-get-own-property-descriptor.js","../../../node_modules/core-js/internals/v8-prototype-define-bug.js","../../../node_modules/core-js/internals/an-object.js","../../../node_modules/core-js/internals/object-define-property.js","../../../node_modules/core-js/internals/create-non-enumerable-property.js","../../../node_modules/core-js/internals/function-name.js","../../../node_modules/core-js/internals/inspect-source.js","../../../node_modules/core-js/internals/weak-map-basic-detection.js","../../../node_modules/core-js/internals/shared-key.js","../../../node_modules/core-js/internals/hidden-keys.js","../../../node_modules/core-js/internals/internal-state.js","../../../node_modules/core-js/internals/make-built-in.js","../../../node_modules/core-js/internals/define-built-in.js","../../../node_modules/core-js/internals/math-trunc.js","../../../node_modules/core-js/internals/to-integer-or-infinity.js","../../../node_modules/core-js/internals/to-absolute-index.js","../../../node_modules/core-js/internals/to-length.js","../../../node_modules/core-js/internals/length-of-array-like.js","../../../node_modules/core-js/internals/array-includes.js","../../../node_modules/core-js/internals/object-keys-internal.js","../../../node_modules/core-js/internals/enum-bug-keys.js","../../../node_modules/core-js/internals/object-get-own-property-names.js","../../../node_modules/core-js/internals/object-get-own-property-symbols.js","../../../node_modules/core-js/internals/own-keys.js","../../../node_modules/core-js/internals/copy-constructor-properties.js","../../../node_modules/core-js/internals/is-forced.js","../../../node_modules/core-js/internals/export.js","../../../node_modules/core-js/internals/is-array.js","../../../node_modules/core-js/internals/does-not-exceed-safe-integer.js","../../../node_modules/core-js/internals/create-property.js","../../../node_modules/core-js/internals/to-string-tag-support.js","../../../node_modules/core-js/internals/classof.js","../../../node_modules/core-js/internals/is-constructor.js","../../../node_modules/core-js/internals/array-species-constructor.js","../../../node_modules/core-js/internals/array-species-create.js","../../../node_modules/core-js/internals/array-method-has-species-support.js","../../../node_modules/core-js/modules/es.array.concat.js","../../../node_modules/core-js/internals/object-to-string.js","../../../node_modules/core-js/modules/es.object.to-string.js","../../../node_modules/core-js/internals/to-string.js","../../../node_modules/core-js/internals/object-keys.js","../../../node_modules/core-js/internals/object-define-properties.js","../../../node_modules/core-js/internals/html.js","../../../node_modules/core-js/internals/object-create.js","../../../node_modules/core-js/internals/array-slice.js","../../../node_modules/core-js/internals/object-get-own-property-names-external.js","../../../node_modules/core-js/internals/define-built-in-accessor.js","../../../node_modules/core-js/internals/well-known-symbol-wrapped.js","../../../node_modules/core-js/internals/path.js","../../../node_modules/core-js/internals/well-known-symbol-define.js","../../../node_modules/core-js/internals/symbol-define-to-primitive.js","../../../node_modules/core-js/internals/set-to-string-tag.js","../../../node_modules/core-js/internals/function-uncurry-this-clause.js","../../../node_modules/core-js/internals/function-bind-context.js","../../../node_modules/core-js/internals/array-iteration.js","../../../node_modules/core-js/modules/es.symbol.constructor.js","../../../node_modules/core-js/internals/symbol-registry-detection.js","../../../node_modules/core-js/modules/es.symbol.for.js","../../../node_modules/core-js/modules/es.symbol.key-for.js","../../../node_modules/core-js/internals/function-apply.js","../../../node_modules/core-js/internals/get-json-replacer-function.js","../../../node_modules/core-js/modules/es.json.stringify.js","../../../node_modules/core-js/modules/es.object.get-own-property-symbols.js","../../../node_modules/core-js/modules/es.symbol.async-iterator.js","../../../node_modules/core-js/modules/es.symbol.description.js","../../../node_modules/core-js/modules/es.symbol.has-instance.js","../../../node_modules/core-js/modules/es.symbol.is-concat-spreadable.js","../../../node_modules/core-js/modules/es.symbol.iterator.js","../../../node_modules/core-js/modules/es.symbol.match.js","../../../node_modules/core-js/modules/es.symbol.match-all.js","../../../node_modules/core-js/modules/es.symbol.replace.js","../../../node_modules/core-js/modules/es.symbol.search.js","../../../node_modules/core-js/modules/es.symbol.species.js","../../../node_modules/core-js/modules/es.symbol.split.js","../../../node_modules/core-js/modules/es.symbol.to-primitive.js","../../../node_modules/core-js/modules/es.symbol.to-string-tag.js","../../../node_modules/core-js/modules/es.symbol.unscopables.js","../../../node_modules/core-js/modules/es.json.to-string-tag.js","../../../node_modules/core-js/modules/es.math.to-string-tag.js","../../../node_modules/core-js/modules/es.reflect.to-string-tag.js","../../../node_modules/core-js/es/symbol/index.js","../../../node_modules/core-js/internals/dom-iterables.js","../../../node_modules/core-js/internals/dom-token-list-prototype.js","../../../node_modules/core-js/internals/add-to-unscopables.js","../../../node_modules/core-js/internals/iterators.js","../../../node_modules/core-js/internals/correct-prototype-getter.js","../../../node_modules/core-js/internals/object-get-prototype-of.js","../../../node_modules/core-js/internals/iterators-core.js","../../../node_modules/core-js/internals/iterator-create-constructor.js","../../../node_modules/core-js/internals/function-uncurry-this-accessor.js","../../../node_modules/core-js/internals/is-possible-prototype.js","../../../node_modules/core-js/internals/a-possible-prototype.js","../../../node_modules/core-js/internals/object-set-prototype-of.js","../../../node_modules/core-js/internals/iterator-define.js","../../../node_modules/core-js/internals/create-iter-result-object.js","../../../node_modules/core-js/modules/es.array.iterator.js","../../../node_modules/core-js/modules/web.dom-collections.iterator.js","../../../node_modules/core-js/modules/esnext.function.metadata.js","../../../node_modules/core-js/modules/esnext.symbol.async-dispose.js","../../../node_modules/core-js/modules/esnext.symbol.dispose.js","../../../node_modules/core-js/modules/esnext.symbol.metadata.js","../../../node_modules/core-js/internals/symbol-is-registered.js","../../../node_modules/core-js/modules/esnext.symbol.is-registered-symbol.js","../../../node_modules/core-js/internals/symbol-is-well-known.js","../../../node_modules/core-js/modules/esnext.symbol.is-well-known-symbol.js","../../../node_modules/core-js/modules/esnext.symbol.custom-matcher.js","../../../node_modules/core-js/modules/esnext.symbol.observable.js","../../../node_modules/core-js/modules/esnext.symbol.is-registered.js","../../../node_modules/core-js/modules/esnext.symbol.is-well-known.js","../../../node_modules/core-js/modules/esnext.symbol.matcher.js","../../../node_modules/core-js/modules/esnext.symbol.metadata-key.js","../../../node_modules/core-js/modules/esnext.symbol.pattern-match.js","../../../node_modules/core-js/modules/esnext.symbol.replace-all.js","../../../node_modules/core-js/internals/string-multibyte.js","../../../node_modules/core-js/modules/es.string.iterator.js","../../../node_modules/core-js/internals/iterator-close.js","../../../node_modules/core-js/internals/call-with-safe-iteration-closing.js","../../../node_modules/core-js/internals/is-array-iterator-method.js","../../../node_modules/core-js/internals/get-iterator-method.js","../../../node_modules/core-js/internals/get-iterator.js","../../../node_modules/core-js/internals/array-from.js","../../../node_modules/core-js/internals/check-correctness-of-iteration.js","../../../node_modules/core-js/modules/es.array.from.js","../../../node_modules/core-js/es/array/from.js","../../../node_modules/react-app-polyfill/ie11.js","../../../node_modules/scheduler/cjs/scheduler.production.min.js","../../../node_modules/scheduler/index.js","../../../node_modules/react-dom/cjs/react-dom.production.min.js","../../../node_modules/react-dom/index.js","../../../src/services/BaseService.ts","../../../src/services/UiLanguageService.ts","../../../src/services/SessionService.ts","../../../src/libs/SMELPOClient/runtime.ts","../../../src/libs/SMELPOClient/models/AimType.ts","../../../src/libs/SMELPOClient/models/ApplicantEmployed.ts","../../../src/libs/SMELPOClient/models/ApplicantLPEmployment.ts","../../../src/libs/SMELPOClient/models/ApplicantType.ts","../../../src/libs/SMELPOClient/models/BudgetType.ts","../../../src/libs/SMELPOClient/models/BudgetYearType.ts","../../../src/libs/SMELPOClient/models/BusinessCategoryType.ts","../../../src/libs/SMELPOClient/models/CaseIdStatus.ts","../../../src/libs/SMELPOClient/models/ChildType.ts","../../../src/libs/SMELPOClient/models/CollateralAge.ts","../../../src/libs/SMELPOClient/models/CollateralType.ts","../../../src/libs/SMELPOClient/models/CompanyEconomyType.ts","../../../src/libs/SMELPOClient/models/CompanyType.ts","../../../src/libs/SMELPOClient/models/ContactInformationType.ts","../../../src/libs/SMELPOClient/models/CustomerIdType.ts","../../../src/libs/SMELPOClient/models/DownPaymentType.ts","../../../src/libs/SMELPOClient/models/EUSupportType.ts","../../../src/libs/SMELPOClient/models/EUType.ts","../../../src/libs/SMELPOClient/models/ExtLoanType.ts","../../../src/libs/SMELPOClient/models/GuarantorType.ts","../../../src/libs/SMELPOClient/models/HouseholdMemberType.ts","../../../src/libs/SMELPOClient/models/HouseholdType.ts","../../../src/libs/SMELPOClient/models/KycInformationType.ts","../../../src/libs/SMELPOClient/models/LinksAll.ts","../../../src/libs/SMELPOClient/models/LoanOwnerType.ts","../../../src/libs/SMELPOClient/models/LoanType.ts","../../../src/libs/SMELPOClient/models/MaintenanceCostType.ts","../../../src/libs/SMELPOClient/models/MaintenanceHouseType.ts","../../../src/libs/SMELPOClient/models/PersonalEconomyType.ts","../../../src/libs/SMELPOClient/models/PrincipalType.ts","../../../src/libs/SMELPOClient/models/ProcessType.ts","../../../src/libs/SMELPOClient/models/ProcessesType.ts","../../../src/libs/SMELPOClient/models/RevenueType.ts","../../../src/libs/SMELPOClient/models/StakeholderType.ts","../../../src/libs/SMELPOClient/models/TakeoverLoanType.ts","../../../src/libs/SMELPOClient/models/TaxedOwnerType.ts","../../../src/libs/SMELPOClient/models/TypeOfCollateral.ts","../../../src/libs/SMELPOClient/models/TypeOfEmployeement.ts","../../../src/libs/SMELPOClient/models/TypeOfHouse.ts","../../../src/libs/SMELPOClient/models/TypeOfLoan.ts","../../../src/libs/SMELPOClient/models/ValueType.ts","../../../src/libs/SMELPOClient/apis/ProcessesApi.ts","../../../src/services/SMELPOService.ts","../../../src/services/TextService.ts","../../../src/services/ConfigurationService.ts","../../../src/services/GuardService.ts","../../../src/utils/Objserver.ts","../../../src/services/StateService.ts","../../../src/utils/ValidationResult.ts","../../../src/models/selmamodels/Loan.ts","../../../src/models/selmamodels/Applicant.ts","../../../src/models/selmamodels/Collateral.ts","../../../src/models/SmeModelConverter.ts","../../../src/services/IdService.ts","../../../src/models/LpoModelConverter.ts","../../../src/services/CaseService.ts","../../../src/services/ApplicantService.ts","../../../src/services/StepService.ts","../../../src/services/CompanyEconomyService.ts","../../../src/models/UiModelConverter.ts","../../../src/services/CompanyService.ts","../../../src/models/uimodels/UIBusinessCategory.ts","../../../src/models/uimodels/UIEUSupport.ts","../../../src/models/uimodels/UIEstateType.ts","../../../src/models/uimodels/UIHighRiskCategory.ts","../../../src/models/uimodels/UIMunicipality.ts","../../../src/models/uimodels/UILoanAimCategory.ts","../../../src/models/uimodels/UIExtLoanType.ts","../../../src/models/uimodels/UILoanDownpaymentType.ts","../../../src/models/uimodels/UIEmploymentType.ts","../../../src/models/uimodels/UIBank.ts","../../../src/services/LoanService.ts","../../../src/services/HouseholdService.ts","../../../src/services/CollateralService.ts","../../../src/services/ArrayService.ts","../../../src/services/PersonalEconomyService.ts","../../../src/services/GuarantorService.ts","../../../src/models/uimodels/UINamed.ts","../../../src/services/EuSupportService.ts","../../../src/services/ExtLoanService.ts","../../../src/services/MaintenanceCostService.ts","../../../src/models/uimodels/UIAttachmentType.ts","../../../src/services/AttachmentService.ts","../../../src/services/BudgetService.ts","../../../src/services/SummaryService.ts","../../../src/services/ConvertService.ts","../../../src/services/KycService.ts","../../../src/services/OidcService.ts","../../../src/models/AppModels.ts","../../../node_modules/react-flexbox-grid/lib/classNames.js","../../../node_modules/prop-types/lib/ReactPropTypesSecret.js","../../../node_modules/prop-types/factoryWithThrowingShims.js","../../../node_modules/prop-types/index.js","../../../node_modules/react-flexbox-grid/lib/createProps.js","../../../node_modules/react-flexbox-grid/lib/types.js","../../../node_modules/react-flexbox-grid/lib/components/Row.js","../../../node_modules/react-flexbox-grid/lib/components/Col.js","../../../node_modules/react-flexbox-grid/lib/components/Grid.js","../../../node_modules/react-flexbox-grid/lib/index.js","../../../src/components/BaseComponent.ts","../../../src/components/AppComponent.ts","../../../src/components/widget/display/THtml.tsx","../../../node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","../../../node_modules/@babel/runtime/helpers/esm/inheritsLoose.js","../../../node_modules/@babel/runtime/helpers/esm/extends.js","../../../node_modules/resolve-pathname/esm/resolve-pathname.js","../../../node_modules/value-equal/esm/value-equal.js","../../../node_modules/tiny-invariant/dist/esm/tiny-invariant.js","../../../node_modules/history/esm/history.js","../../../node_modules/isarray/index.js","../../../node_modules/path-to-regexp/index.js","../../../node_modules/react-is/cjs/react-is.production.min.js","../../../node_modules/react-is/index.js","../../../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../../../node_modules/react-router/node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../../../node_modules/react-router/esm/react-router.js","../../../node_modules/react-router-dom/esm/react-router-dom.js","../../../src/components/widget/display/T.tsx","../../../src/components/layout/Bottom/Bottom.tsx","../../../node_modules/react-browser-detection/lib/index.js","../../../src/components/widget/display/BirdLoader/BirdLoader.tsx","../../../src/components/app/LoadingPage.tsx","../../../node_modules/classnames/index.js","../../../src/components/widget/input/Button/Button.tsx","../../../node_modules/react-spring/web.js","../../../src/components/widget/display/StatusIndicator/StatusIndicator.tsx","../../../src/components/layout/Modal/Modal.tsx","../../../src/components/widget/input/ButtonGroup/ButtonGroup.tsx","../../../src/components/widget/input/DeleteButton/DeleteButton.tsx","../../../src/components/home/HomeCase/HomeCase.tsx","../../../src/components/layout/PageContent/PageContent.tsx","../../../src/components/widget/display/Required/Required.tsx","../../../node_modules/react-tooltip-lite/dist/Portal.js","../../../node_modules/react-tooltip-lite/dist/functions.js","../../../node_modules/react-tooltip-lite/dist/getDirection.js","../../../node_modules/react-tooltip-lite/dist/position.js","../../../node_modules/react-tooltip-lite/dist/index.js","../../../src/components/widget/display/Help/Help.tsx","../../../src/components/widget/display/Heading/Heading.tsx","../../../src/components/home/HomePage/HomePage.tsx","../../../src/components/AccessDenied/AccessDenied.tsx","../../../src/components/case/StepHeader.tsx","../../../src/components/widget/display/Label/Label.tsx","../../../src/components/layout/FormUnit/FormUnit.tsx","../../../src/components/widget/display/Messages/Messages.tsx","../../../src/components/case/StepFooter.tsx","../../../node_modules/lodash/lodash.js","../../../src/components/widget/input/Checkbox/Checkbox.tsx","../../../src/components/widget/input/CheckboxText/CheckboxText.tsx","../../../src/components/widget/display/StepForm/StepForm.tsx","../../../src/components/widget/display/Validation/Validation.tsx","../../../src/components/case/steps/StepLoan/ApplicantApproval.tsx","../../../node_modules/react-number-format/dist/react-number-format.es.js","../../../src/components/layout/FormUnitRow/FormUnitRow.tsx","../../../src/models/uimodels/UIBudgetYearItem.ts","../../../src/components/widget/input/Money/Money.tsx","../../../node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js","../../../node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","../../../node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","../../../node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","../../../node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","../../../node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","../../../node_modules/@babel/runtime/helpers/esm/slicedToArray.js","../../../node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","../../../node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../../../node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","../../../node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","../../../node_modules/@babel/runtime/helpers/esm/typeof.js","../../../node_modules/@babel/runtime/helpers/esm/toPrimitive.js","../../../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","../../../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../../../node_modules/@babel/runtime/helpers/esm/classCallCheck.js","../../../node_modules/@babel/runtime/helpers/esm/createClass.js","../../../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../../../node_modules/@babel/runtime/helpers/esm/inherits.js","../../../node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js","../../../node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js","../../../node_modules/memoize-one/dist/memoize-one.esm.js","../../../node_modules/@emotion/sheet/dist/sheet.browser.esm.js","../../../node_modules/@emotion/stylis/dist/stylis.browser.esm.js","../../../node_modules/@emotion/cache/dist/cache.browser.esm.js","../../../node_modules/@emotion/utils/dist/utils.browser.esm.js","../../../node_modules/@emotion/hash/dist/hash.browser.esm.js","../../../node_modules/@emotion/unitless/dist/unitless.browser.esm.js","../../../node_modules/@emotion/memoize/dist/memoize.browser.esm.js","../../../node_modules/@emotion/serialize/dist/serialize.browser.esm.js","../../../node_modules/@emotion/core/dist/emotion-element-04d85134.browser.esm.js","../../../node_modules/@emotion/css/dist/css.browser.esm.js","../../../node_modules/@emotion/core/dist/core.browser.esm.js","../../../node_modules/@babel/runtime/helpers/esm/taggedTemplateLiteral.js","../../../node_modules/react-input-autosize/lib/AutosizeInput.js","../../../node_modules/react-select/dist/index-75b02bac.browser.esm.js","../../../node_modules/react-select/dist/Select-e1cf49ae.browser.esm.js","../../../node_modules/react-select/dist/stateManager-2f2b6f5b.browser.esm.js","../../../node_modules/react-select/dist/react-select.browser.esm.js","../../../src/components/widget/input/Select/SelectCustomStyles.tsx","../../../src/components/widget/input/Select/Select.tsx","../../../src/components/case/steps/StepLoan/LoanNewAim.tsx","../../../src/components/case/steps/StepLoan/LoanNewAims.tsx","../../../src/components/widget/input/Textbox/Textbox.tsx","../../../src/components/case/steps/StepLoan/LoanDownpayment.tsx","../../../src/components/widget/input/CheckboxGroup/CheckboxGroup.tsx","../../../src/components/case/steps/StepLoan/LoanTakeOver.tsx","../../../src/components/case/steps/StepLoan/LoanTakeOvers.tsx","../../../src/components/widget/input/Textarea/Textarea.tsx","../../../src/components/case/steps/StepLoan/StepLoan.tsx","../../../src/components/case/steps/StepApplicant/ApplicantContact.tsx","../../../src/components/widget/input/Radiobutton/Radiobutton.tsx","../../../src/components/widget/input/RadiobuttonGroup/RadiobuttonGroup.tsx","../../../src/components/case/steps/StepApplicant/ApplicantPep.tsx","../../../src/models/uimodels/UIMonths.ts","../../../src/components/widget/input/SelectMonth/SelectMonth.tsx","../../../src/components/case/steps/StepApplicant/ApplicantIncome.tsx","../../../src/components/case/steps/StepApplicant/PersonApplicantItem.tsx","../../../src/components/case/steps/StepCompany/CompanyHasRevenue.tsx","../../../src/components/case/steps/StepCompany/ApplicantRiskBusiness.tsx","../../../src/components/case/steps/StepCompany/CompanyRevenue.tsx","../../../src/components/widget/input/Percent/Percent.tsx","../../../src/components/case/steps/StepCompany/CompanyBusinessFocuses.tsx","../../../src/components/case/steps/StepCompany/CompanyRevenueChunk.tsx","../../../src/components/layout/HeaderButton/HeaderButton.tsx","../../../src/components/case/steps/StepApplicant/PersonalCompanyApplicantItem.tsx","../../../src/components/case/steps/StepApplicant/IncorporatedCompanyApplicantItem.tsx","../../../src/components/case/steps/StepApplicant/ApplicantItem.tsx","../../../src/components/widget/display/ScrollOverflowIndicator/ScrollOverflowIndicator.tsx","../../../src/components/widget/input/RadiobuttonTable/RadiobuttonTable.tsx","../../../src/components/case/steps/StepCompany/CompanySelect.tsx","../../../src/components/layout/FormUnitFieldAndButton/FormUnitFieldAndButton.tsx","../../../src/components/case/steps/StepApplicant/AddApplicant.tsx","../../../src/components/widget/display/TabPanels/TabPanels.tsx","../../../src/components/case/steps/StepApplicant/StepApplicant.tsx","../../../src/components/widget/display/Loader/Loader.tsx","../../../src/components/case/steps/StepCompany/StepCompany.tsx","../../../src/components/case/steps/StepCollateral/CollateralCollaterals.tsx","../../../src/components/case/steps/StepCollateral/CollateralEUSupports.tsx","../../../src/components/widget/input/SSN/SSN.tsx","../../../src/components/case/steps/StepCollateral/CollateralGuarantors.tsx","../../../src/components/case/steps/StepCollateral/StepCollateral.tsx","../../../src/components/layout/Panel/Panel.tsx","../../../src/components/case/steps/StepHousehold/ApplicantSelect.tsx","../../../src/components/case/steps/StepHousehold/HouseholdExtLoan.tsx","../../../src/components/case/steps/StepHousehold/HouseholdExtLoans.tsx","../../../src/components/case/steps/StepHousehold/HouseholdMaintenanceHouse.tsx","../../../src/components/case/steps/StepHousehold/HouseholdMaintenanceCost.tsx","../../../src/components/case/steps/StepHousehold/HouseholdMaintenanceCosts.tsx","../../../src/components/case/steps/StepHousehold/ChildTimePart.tsx","../../../src/components/widget/input/Age/Age.tsx","../../../src/components/case/steps/StepHousehold/HouseholdEdit.tsx","../../../src/components/case/steps/StepHousehold/Households.tsx","../../../src/components/case/steps/StepHousehold/StepHousehold.tsx","../../../src/components/widget/display/Icon/Icon.tsx","../../../src/components/case/steps/StepBudget/ProvidedAttachment.tsx","../../../src/components/case/steps/StepBudget/ProvidedAttachments.tsx","../../../node_modules/tslib/tslib.es6.mjs","../../../node_modules/file-selector/dist/es5/file.js","../../../node_modules/file-selector/dist/es5/file-selector.js","../../../node_modules/attr-accept/dist/es/index.js","../../../node_modules/react-dropzone/dist/es/utils/index.js","../../../node_modules/react-dropzone/dist/es/index.js","../../../src/components/widget/input/Upload/Upload.tsx","../../../src/components/case/steps/StepBudget/RequestedAttachment.tsx","../../../src/components/case/steps/StepBudget/RequestedAttachments.tsx","../../../src/components/case/steps/StepBudget/ManualBudget.tsx","../../../node_modules/resize-observer-polyfill/dist/ResizeObserver.es.js","../../../node_modules/use-measure/use-measure.js","../../../src/components/layout/Accordion/AccordionElements.tsx","../../../src/components/layout/Accordion/Accordion.tsx","../../../src/components/case/steps/StepBudget/StepBudget.tsx","../../../src/components/widget/display/Table/Table.tsx","../../../src/components/case/steps/StepSummary/CompanySummary/SelectedCompanySummary.tsx","../../../src/components/widget/display/KeyValueList/KeyValueList.tsx","../../../src/components/case/steps/StepSummary/CompanySummary/CompanyHasRevenueSummary.tsx","../../../src/components/case/steps/StepSummary/CompanySummary/CompanyHighRiskBusinessSummary.tsx","../../../src/components/case/steps/StepSummary/CompanySummary/CompanyRevenueSummary.tsx","../../../src/components/case/steps/StepSummary/CompanySummary/CompanyBusinessFocusesSummary.tsx","../../../src/components/case/steps/StepSummary/CompanySummary/CompanySummary.tsx","../../../src/components/case/steps/StepSummary/LoanSummary/LoanAmountSummary.tsx","../../../src/components/case/steps/StepSummary/LoanSummary/LoanTakeOverSummary.tsx","../../../src/components/case/steps/StepSummary/LoanSummary/LoanAimsSummary.tsx","../../../src/components/case/steps/StepSummary/LoanSummary/LoanDownpaymentSummary.tsx","../../../src/components/case/steps/StepSummary/LoanSummary/LoanSummary.tsx","../../../src/components/case/steps/StepSummary/ApplicantsSummary/ApplicantContactSummary.tsx","../../../src/components/case/steps/StepSummary/ApplicantsSummary/ApplicantIncomeSummary.tsx","../../../src/components/case/steps/StepSummary/ApplicantsSummary/ApplicantPepSummary.tsx","../../../src/components/case/steps/StepSummary/ApplicantsSummary/PersonApplicantItemSummary.tsx","../../../src/components/case/steps/StepSummary/ApplicantsSummary/PersonalCompanyApplicantItemSummary.tsx","../../../src/components/case/steps/StepSummary/ApplicantsSummary/IncorporatedCompanyApplicantItemSummary.tsx","../../../src/components/case/steps/StepSummary/ApplicantsSummary/ApplicantItemSummary.tsx","../../../src/components/case/steps/StepSummary/ApplicantsSummary/ApplicantsSummary.tsx","../../../src/components/case/steps/StepSummary/CollateralSummary/CollateralRealEstateSummary.tsx","../../../src/components/case/steps/StepSummary/CollateralSummary/CollateralEUSupportSummary.tsx","../../../src/components/case/steps/StepSummary/CollateralSummary/CollateralGurantorsSummary.tsx","../../../src/components/case/steps/StepSummary/CollateralSummary/CollateralSummary.tsx","../../../src/components/case/steps/StepSummary/HouseholdSummary/HouseholdMembersSummary.tsx","../../../src/components/case/steps/StepSummary/HouseholdSummary/HouseholdChildrenSummary.tsx","../../../src/components/case/steps/StepSummary/HouseholdSummary/HouseholdChildMaintenanceSummary.tsx","../../../src/components/case/steps/StepSummary/HouseholdSummary/HouseholdMaintenanceCostsSummary.tsx","../../../src/components/case/steps/StepSummary/HouseholdSummary/HouseholdExtLoansSummary.tsx","../../../src/components/case/steps/StepSummary/HouseholdSummary/HouseholdSummary.tsx","../../../src/components/case/steps/StepSummary/BudgetSummary/ManualBudgetSummary.tsx","../../../src/components/case/steps/StepSummary/BudgetSummary/BudgetSummary.tsx","../../../src/components/case/steps/StepSummary/ApproveApplication.tsx","../../../src/components/case/steps/StepSummary/StepSummary.tsx","../../../src/components/case/steps/StepDone/StepDone.tsx","../../../src/components/case/CaseSteps.tsx","../../../node_modules/gud/index.js","../../../node_modules/fbjs/lib/emptyFunction.js","../../../node_modules/fbjs/lib/warning.js","../../../node_modules/create-react-context/lib/implementation.js","../../../node_modules/create-react-context/lib/index.js","../../../node_modules/react-breakpoints/lib/BreakpointsContext.js","../../../node_modules/lodash.debounce/index.js","../../../node_modules/react-breakpoints/lib/utils/index.js","../../../node_modules/react-breakpoints/lib/messages.js","../../../node_modules/react-breakpoints/lib/ReactBreakpoints.js","../../../node_modules/hoist-non-react-statics/index.js","../../../node_modules/react-breakpoints/lib/withBreakpoints.js","../../../node_modules/react-breakpoints/lib/index.js","../../../src/components/widget/display/StatusBar/StatusBar.tsx","../../../src/components/case/StepState.ts","../../../src/components/case/CasePage.tsx","../../../src/components/app/MaintenancePage.tsx","../../../src/components/admin/AdminCaseStatus/AdminCaseStatus.tsx","../../../src/components/admin/AttachmentSection/AttachmentSection.tsx","../../../src/components/admin/AdminCasePage/AdminCasePage.tsx","../../../src/components/admin/AdminPage/AdminPage.tsx","../../../src/components/login/Local/Locallogin.tsx","../../../src/components/app/PageRouter.tsx","../../../node_modules/jquery/dist/jquery.js","../../../src/components/widget/display/MobileNav/MobileNav.tsx","../../../src/components/layout/SaveModal/SaveModal.tsx","../../../node_modules/jwt-decode/build/esm/index.js","../../../node_modules/oidc-client-ts/dist/esm/oidc-client-ts.js","../../../node_modules/react-oidc-context/dist/esm/react-oidc-context.js","../../../src/components/layout/Top/Top.tsx","../../../src/components/app/ScrollToTop.tsx","../../../src/components/app/App/EbbotChat.tsx","../../../src/components/layout/StatusBar/StatusBar.tsx","../../../src/components/login/Oidc.tsx","../../../src/components/app/App/App.tsx","../../../src/index.jsx"],"sourcesContent":["/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","/** @license React v16.14.0\n * react.production.min.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';var l=require(\"object-assign\"),n=\"function\"===typeof Symbol&&Symbol.for,p=n?Symbol.for(\"react.element\"):60103,q=n?Symbol.for(\"react.portal\"):60106,r=n?Symbol.for(\"react.fragment\"):60107,t=n?Symbol.for(\"react.strict_mode\"):60108,u=n?Symbol.for(\"react.profiler\"):60114,v=n?Symbol.for(\"react.provider\"):60109,w=n?Symbol.for(\"react.context\"):60110,x=n?Symbol.for(\"react.forward_ref\"):60112,y=n?Symbol.for(\"react.suspense\"):60113,z=n?Symbol.for(\"react.memo\"):60115,A=n?Symbol.for(\"react.lazy\"):\n60116,B=\"function\"===typeof Symbol&&Symbol.iterator;function C(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;cQ.length&&Q.push(a)}\nfunction T(a,b,c,e){var d=typeof a;if(\"undefined\"===d||\"boolean\"===d)a=null;var g=!1;if(null===a)g=!0;else switch(d){case \"string\":case \"number\":g=!0;break;case \"object\":switch(a.$$typeof){case p:case q:g=!0}}if(g)return c(e,a,\"\"===b?\".\"+U(a,0):b),1;g=0;b=\"\"===b?\".\":b+\":\";if(Array.isArray(a))for(var k=0;k capacity) {\n // Manually shift all values starting at the index back to the\n // beginning of the queue.\n for (var scan = 0, newLength = queue.length - index; scan < newLength; scan++) {\n queue[scan] = queue[scan + index];\n }\n queue.length -= index;\n index = 0;\n }\n }\n queue.length = 0;\n index = 0;\n flushing = false;\n}\n\n// `requestFlush` is implemented using a strategy based on data collected from\n// every available SauceLabs Selenium web driver worker at time of writing.\n// https://docs.google.com/spreadsheets/d/1mG-5UYGup5qxGdEMWkhP6BWCz053NUb2E1QoUTU16uA/edit#gid=783724593\n\n// Safari 6 and 6.1 for desktop, iPad, and iPhone are the only browsers that\n// have WebKitMutationObserver but not un-prefixed MutationObserver.\n// Must use `global` or `self` instead of `window` to work in both frames and web\n// workers. `global` is a provision of Browserify, Mr, Mrs, or Mop.\n\n/* globals self */\nvar scope = typeof global !== \"undefined\" ? global : self;\nvar BrowserMutationObserver = scope.MutationObserver || scope.WebKitMutationObserver;\n\n// MutationObservers are desirable because they have high priority and work\n// reliably everywhere they are implemented.\n// They are implemented in all modern browsers.\n//\n// - Android 4-4.3\n// - Chrome 26-34\n// - Firefox 14-29\n// - Internet Explorer 11\n// - iPad Safari 6-7.1\n// - iPhone Safari 7-7.1\n// - Safari 6-7\nif (typeof BrowserMutationObserver === \"function\") {\n requestFlush = makeRequestCallFromMutationObserver(flush);\n\n// MessageChannels are desirable because they give direct access to the HTML\n// task queue, are implemented in Internet Explorer 10, Safari 5.0-1, and Opera\n// 11-12, and in web workers in many engines.\n// Although message channels yield to any queued rendering and IO tasks, they\n// would be better than imposing the 4ms delay of timers.\n// However, they do not work reliably in Internet Explorer or Safari.\n\n// Internet Explorer 10 is the only browser that has setImmediate but does\n// not have MutationObservers.\n// Although setImmediate yields to the browser's renderer, it would be\n// preferrable to falling back to setTimeout since it does not have\n// the minimum 4ms penalty.\n// Unfortunately there appears to be a bug in Internet Explorer 10 Mobile (and\n// Desktop to a lesser extent) that renders both setImmediate and\n// MessageChannel useless for the purposes of ASAP.\n// https://github.com/kriskowal/q/issues/396\n\n// Timers are implemented universally.\n// We fall back to timers in workers in most engines, and in foreground\n// contexts in the following browsers.\n// However, note that even this simple case requires nuances to operate in a\n// broad spectrum of browsers.\n//\n// - Firefox 3-13\n// - Internet Explorer 6-9\n// - iPad Safari 4.3\n// - Lynx 2.8.7\n} else {\n requestFlush = makeRequestCallFromTimer(flush);\n}\n\n// `requestFlush` requests that the high priority event queue be flushed as\n// soon as possible.\n// This is useful to prevent an error thrown in a task from stalling the event\n// queue if the exception handled by Node.js’s\n// `process.on(\"uncaughtException\")` or by a domain.\nrawAsap.requestFlush = requestFlush;\n\n// To request a high priority event, we induce a mutation observer by toggling\n// the text of a text node between \"1\" and \"-1\".\nfunction makeRequestCallFromMutationObserver(callback) {\n var toggle = 1;\n var observer = new BrowserMutationObserver(callback);\n var node = document.createTextNode(\"\");\n observer.observe(node, {characterData: true});\n return function requestCall() {\n toggle = -toggle;\n node.data = toggle;\n };\n}\n\n// The message channel technique was discovered by Malte Ubl and was the\n// original foundation for this library.\n// http://www.nonblocking.io/2011/06/windownexttick.html\n\n// Safari 6.0.5 (at least) intermittently fails to create message ports on a\n// page's first load. Thankfully, this version of Safari supports\n// MutationObservers, so we don't need to fall back in that case.\n\n// function makeRequestCallFromMessageChannel(callback) {\n// var channel = new MessageChannel();\n// channel.port1.onmessage = callback;\n// return function requestCall() {\n// channel.port2.postMessage(0);\n// };\n// }\n\n// For reasons explained above, we are also unable to use `setImmediate`\n// under any circumstances.\n// Even if we were, there is another bug in Internet Explorer 10.\n// It is not sufficient to assign `setImmediate` to `requestFlush` because\n// `setImmediate` must be called *by name* and therefore must be wrapped in a\n// closure.\n// Never forget.\n\n// function makeRequestCallFromSetImmediate(callback) {\n// return function requestCall() {\n// setImmediate(callback);\n// };\n// }\n\n// Safari 6.0 has a problem where timers will get lost while the user is\n// scrolling. This problem does not impact ASAP because Safari 6.0 supports\n// mutation observers, so that implementation is used instead.\n// However, if we ever elect to use timers in Safari, the prevalent work-around\n// is to add a scroll event listener that calls for a flush.\n\n// `setTimeout` does not call the passed callback if the delay is less than\n// approximately 7 in web workers in Firefox 8 through 18, and sometimes not\n// even then.\n\nfunction makeRequestCallFromTimer(callback) {\n return function requestCall() {\n // We dispatch a timeout with a specified delay of 0 for engines that\n // can reliably accommodate that request. This will usually be snapped\n // to a 4 milisecond delay, but once we're flushing, there's no delay\n // between events.\n var timeoutHandle = setTimeout(handleTimer, 0);\n // However, since this timer gets frequently dropped in Firefox\n // workers, we enlist an interval handle that will try to fire\n // an event 20 times per second until it succeeds.\n var intervalHandle = setInterval(handleTimer, 50);\n\n function handleTimer() {\n // Whichever timer succeeds will cancel both timers and\n // execute the callback.\n clearTimeout(timeoutHandle);\n clearInterval(intervalHandle);\n callback();\n }\n };\n}\n\n// This is for `asap.js` only.\n// Its name will be periodically randomized to break any code that depends on\n// its existence.\nrawAsap.makeRequestCallFromTimer = makeRequestCallFromTimer;\n\n// ASAP was originally a nextTick shim included in Q. This was factored out\n// into this ASAP package. It was later adapted to RSVP which made further\n// amendments. These decisions, particularly to marginalize MessageChannel and\n// to capture the MutationObserver implementation in a closure, were integrated\n// back into ASAP proper.\n// https://github.com/tildeio/rsvp.js/blob/cddf7232546a9cf858524b75cde6f9edf72620a7/lib/rsvp/asap.js\n","'use strict';\n\nvar asap = require('asap/raw');\n\nfunction noop() {}\n\n// States:\n//\n// 0 - pending\n// 1 - fulfilled with _value\n// 2 - rejected with _value\n// 3 - adopted the state of another promise, _value\n//\n// once the state is no longer pending (0) it is immutable\n\n// All `_` prefixed properties will be reduced to `_{random number}`\n// at build time to obfuscate them and discourage their use.\n// We don't use symbols or Object.defineProperty to fully hide them\n// because the performance isn't good enough.\n\n\n// to avoid using try/catch inside critical functions, we\n// extract them to here.\nvar LAST_ERROR = null;\nvar IS_ERROR = {};\nfunction getThen(obj) {\n try {\n return obj.then;\n } catch (ex) {\n LAST_ERROR = ex;\n return IS_ERROR;\n }\n}\n\nfunction tryCallOne(fn, a) {\n try {\n return fn(a);\n } catch (ex) {\n LAST_ERROR = ex;\n return IS_ERROR;\n }\n}\nfunction tryCallTwo(fn, a, b) {\n try {\n fn(a, b);\n } catch (ex) {\n LAST_ERROR = ex;\n return IS_ERROR;\n }\n}\n\nmodule.exports = Promise;\n\nfunction Promise(fn) {\n if (typeof this !== 'object') {\n throw new TypeError('Promises must be constructed via new');\n }\n if (typeof fn !== 'function') {\n throw new TypeError('Promise constructor\\'s argument is not a function');\n }\n this._x = 0;\n this._y = 0;\n this._z = null;\n this._A = null;\n if (fn === noop) return;\n doResolve(fn, this);\n}\nPromise._B = null;\nPromise._C = null;\nPromise._D = noop;\n\nPromise.prototype.then = function(onFulfilled, onRejected) {\n if (this.constructor !== Promise) {\n return safeThen(this, onFulfilled, onRejected);\n }\n var res = new Promise(noop);\n handle(this, new Handler(onFulfilled, onRejected, res));\n return res;\n};\n\nfunction safeThen(self, onFulfilled, onRejected) {\n return new self.constructor(function (resolve, reject) {\n var res = new Promise(noop);\n res.then(resolve, reject);\n handle(self, new Handler(onFulfilled, onRejected, res));\n });\n}\nfunction handle(self, deferred) {\n while (self._y === 3) {\n self = self._z;\n }\n if (Promise._B) {\n Promise._B(self);\n }\n if (self._y === 0) {\n if (self._x === 0) {\n self._x = 1;\n self._A = deferred;\n return;\n }\n if (self._x === 1) {\n self._x = 2;\n self._A = [self._A, deferred];\n return;\n }\n self._A.push(deferred);\n return;\n }\n handleResolved(self, deferred);\n}\n\nfunction handleResolved(self, deferred) {\n asap(function() {\n var cb = self._y === 1 ? deferred.onFulfilled : deferred.onRejected;\n if (cb === null) {\n if (self._y === 1) {\n resolve(deferred.promise, self._z);\n } else {\n reject(deferred.promise, self._z);\n }\n return;\n }\n var ret = tryCallOne(cb, self._z);\n if (ret === IS_ERROR) {\n reject(deferred.promise, LAST_ERROR);\n } else {\n resolve(deferred.promise, ret);\n }\n });\n}\nfunction resolve(self, newValue) {\n // Promise Resolution Procedure: https://github.com/promises-aplus/promises-spec#the-promise-resolution-procedure\n if (newValue === self) {\n return reject(\n self,\n new TypeError('A promise cannot be resolved with itself.')\n );\n }\n if (\n newValue &&\n (typeof newValue === 'object' || typeof newValue === 'function')\n ) {\n var then = getThen(newValue);\n if (then === IS_ERROR) {\n return reject(self, LAST_ERROR);\n }\n if (\n then === self.then &&\n newValue instanceof Promise\n ) {\n self._y = 3;\n self._z = newValue;\n finale(self);\n return;\n } else if (typeof then === 'function') {\n doResolve(then.bind(newValue), self);\n return;\n }\n }\n self._y = 1;\n self._z = newValue;\n finale(self);\n}\n\nfunction reject(self, newValue) {\n self._y = 2;\n self._z = newValue;\n if (Promise._C) {\n Promise._C(self, newValue);\n }\n finale(self);\n}\nfunction finale(self) {\n if (self._x === 1) {\n handle(self, self._A);\n self._A = null;\n }\n if (self._x === 2) {\n for (var i = 0; i < self._A.length; i++) {\n handle(self, self._A[i]);\n }\n self._A = null;\n }\n}\n\nfunction Handler(onFulfilled, onRejected, promise){\n this.onFulfilled = typeof onFulfilled === 'function' ? onFulfilled : null;\n this.onRejected = typeof onRejected === 'function' ? onRejected : null;\n this.promise = promise;\n}\n\n/**\n * Take a potentially misbehaving resolver function and make sure\n * onFulfilled and onRejected are only called once.\n *\n * Makes no guarantees about asynchrony.\n */\nfunction doResolve(fn, promise) {\n var done = false;\n var res = tryCallTwo(fn, function (value) {\n if (done) return;\n done = true;\n resolve(promise, value);\n }, function (reason) {\n if (done) return;\n done = true;\n reject(promise, reason);\n });\n if (!done && res === IS_ERROR) {\n done = true;\n reject(promise, LAST_ERROR);\n }\n}\n","'use strict';\n\nvar Promise = require('./core');\n\nvar DEFAULT_WHITELIST = [\n ReferenceError,\n TypeError,\n RangeError\n];\n\nvar enabled = false;\nexports.disable = disable;\nfunction disable() {\n enabled = false;\n Promise._B = null;\n Promise._C = null;\n}\n\nexports.enable = enable;\nfunction enable(options) {\n options = options || {};\n if (enabled) disable();\n enabled = true;\n var id = 0;\n var displayId = 0;\n var rejections = {};\n Promise._B = function (promise) {\n if (\n promise._y === 2 && // IS REJECTED\n rejections[promise._E]\n ) {\n if (rejections[promise._E].logged) {\n onHandled(promise._E);\n } else {\n clearTimeout(rejections[promise._E].timeout);\n }\n delete rejections[promise._E];\n }\n };\n Promise._C = function (promise, err) {\n if (promise._x === 0) { // not yet handled\n promise._E = id++;\n rejections[promise._E] = {\n displayId: null,\n error: err,\n timeout: setTimeout(\n onUnhandled.bind(null, promise._E),\n // For reference errors and type errors, this almost always\n // means the programmer made a mistake, so log them after just\n // 100ms\n // otherwise, wait 2 seconds to see if they get handled\n matchWhitelist(err, DEFAULT_WHITELIST)\n ? 100\n : 2000\n ),\n logged: false\n };\n }\n };\n function onUnhandled(id) {\n if (\n options.allRejections ||\n matchWhitelist(\n rejections[id].error,\n options.whitelist || DEFAULT_WHITELIST\n )\n ) {\n rejections[id].displayId = displayId++;\n if (options.onUnhandled) {\n rejections[id].logged = true;\n options.onUnhandled(\n rejections[id].displayId,\n rejections[id].error\n );\n } else {\n rejections[id].logged = true;\n logError(\n rejections[id].displayId,\n rejections[id].error\n );\n }\n }\n }\n function onHandled(id) {\n if (rejections[id].logged) {\n if (options.onHandled) {\n options.onHandled(rejections[id].displayId, rejections[id].error);\n } else if (!rejections[id].onUnhandled) {\n console.warn(\n 'Promise Rejection Handled (id: ' + rejections[id].displayId + '):'\n );\n console.warn(\n ' This means you can ignore any previous messages of the form \"Possible Unhandled Promise Rejection\" with id ' +\n rejections[id].displayId + '.'\n );\n }\n }\n }\n}\n\nfunction logError(id, error) {\n console.warn('Possible Unhandled Promise Rejection (id: ' + id + '):');\n var errStr = (error && (error.stack || error)) + '';\n errStr.split('\\n').forEach(function (line) {\n console.warn(' ' + line);\n });\n}\n\nfunction matchWhitelist(error, list) {\n return list.some(function (cls) {\n return error instanceof cls;\n });\n}","'use strict';\n\n//This file contains the ES6 extensions to the core Promises/A+ API\n\nvar Promise = require('./core.js');\n\nmodule.exports = Promise;\n\n/* Static Functions */\n\nvar TRUE = valuePromise(true);\nvar FALSE = valuePromise(false);\nvar NULL = valuePromise(null);\nvar UNDEFINED = valuePromise(undefined);\nvar ZERO = valuePromise(0);\nvar EMPTYSTRING = valuePromise('');\n\nfunction valuePromise(value) {\n var p = new Promise(Promise._D);\n p._y = 1;\n p._z = value;\n return p;\n}\nPromise.resolve = function (value) {\n if (value instanceof Promise) return value;\n\n if (value === null) return NULL;\n if (value === undefined) return UNDEFINED;\n if (value === true) return TRUE;\n if (value === false) return FALSE;\n if (value === 0) return ZERO;\n if (value === '') return EMPTYSTRING;\n\n if (typeof value === 'object' || typeof value === 'function') {\n try {\n var then = value.then;\n if (typeof then === 'function') {\n return new Promise(then.bind(value));\n }\n } catch (ex) {\n return new Promise(function (resolve, reject) {\n reject(ex);\n });\n }\n }\n return valuePromise(value);\n};\n\nvar iterableToArray = function (iterable) {\n if (typeof Array.from === 'function') {\n // ES2015+, iterables exist\n iterableToArray = Array.from;\n return Array.from(iterable);\n }\n\n // ES5, only arrays and array-likes exist\n iterableToArray = function (x) { return Array.prototype.slice.call(x); };\n return Array.prototype.slice.call(iterable);\n}\n\nPromise.all = function (arr) {\n var args = iterableToArray(arr);\n\n return new Promise(function (resolve, reject) {\n if (args.length === 0) return resolve([]);\n var remaining = args.length;\n function res(i, val) {\n if (val && (typeof val === 'object' || typeof val === 'function')) {\n if (val instanceof Promise && val.then === Promise.prototype.then) {\n while (val._y === 3) {\n val = val._z;\n }\n if (val._y === 1) return res(i, val._z);\n if (val._y === 2) reject(val._z);\n val.then(function (val) {\n res(i, val);\n }, reject);\n return;\n } else {\n var then = val.then;\n if (typeof then === 'function') {\n var p = new Promise(then.bind(val));\n p.then(function (val) {\n res(i, val);\n }, reject);\n return;\n }\n }\n }\n args[i] = val;\n if (--remaining === 0) {\n resolve(args);\n }\n }\n for (var i = 0; i < args.length; i++) {\n res(i, args[i]);\n }\n });\n};\n\nfunction onSettledFulfill(value) {\n return { status: 'fulfilled', value: value };\n}\nfunction onSettledReject(reason) {\n return { status: 'rejected', reason: reason };\n}\nfunction mapAllSettled(item) {\n if(item && (typeof item === 'object' || typeof item === 'function')){\n if(item instanceof Promise && item.then === Promise.prototype.then){\n return item.then(onSettledFulfill, onSettledReject);\n }\n var then = item.then;\n if (typeof then === 'function') {\n return new Promise(then.bind(item)).then(onSettledFulfill, onSettledReject)\n }\n }\n\n return onSettledFulfill(item);\n}\nPromise.allSettled = function (iterable) {\n return Promise.all(iterableToArray(iterable).map(mapAllSettled));\n};\n\nPromise.reject = function (value) {\n return new Promise(function (resolve, reject) {\n reject(value);\n });\n};\n\nPromise.race = function (values) {\n return new Promise(function (resolve, reject) {\n iterableToArray(values).forEach(function(value){\n Promise.resolve(value).then(resolve, reject);\n });\n });\n};\n\n/* Prototype Methods */\n\nPromise.prototype['catch'] = function (onRejected) {\n return this.then(null, onRejected);\n};\n\nfunction getAggregateError(errors){\n if(typeof AggregateError === 'function'){\n return new AggregateError(errors,'All promises were rejected');\n }\n\n var error = new Error('All promises were rejected');\n\n error.name = 'AggregateError';\n error.errors = errors;\n\n return error;\n}\n\nPromise.any = function promiseAny(values) {\n return new Promise(function(resolve, reject) {\n var promises = iterableToArray(values);\n var hasResolved = false;\n var rejectionReasons = [];\n\n function resolveOnce(value) {\n if (!hasResolved) {\n hasResolved = true;\n resolve(value);\n }\n }\n\n function rejectionCheck(reason) {\n rejectionReasons.push(reason);\n\n if (rejectionReasons.length === promises.length) {\n reject(getAggregateError(rejectionReasons));\n }\n }\n\n if(promises.length === 0){\n reject(getAggregateError(rejectionReasons));\n } else {\n promises.forEach(function(value){\n Promise.resolve(value).then(resolveOnce, rejectionCheck);\n });\n }\n });\n};\n","/* eslint-disable no-prototype-builtins */\nvar g =\n (typeof globalThis !== 'undefined' && globalThis) ||\n (typeof self !== 'undefined' && self) ||\n // eslint-disable-next-line no-undef\n (typeof global !== 'undefined' && global) ||\n {}\n\nvar support = {\n searchParams: 'URLSearchParams' in g,\n iterable: 'Symbol' in g && 'iterator' in Symbol,\n blob:\n 'FileReader' in g &&\n 'Blob' in g &&\n (function() {\n try {\n new Blob()\n return true\n } catch (e) {\n return false\n }\n })(),\n formData: 'FormData' in g,\n arrayBuffer: 'ArrayBuffer' in g\n}\n\nfunction isDataView(obj) {\n return obj && DataView.prototype.isPrototypeOf(obj)\n}\n\nif (support.arrayBuffer) {\n var viewClasses = [\n '[object Int8Array]',\n '[object Uint8Array]',\n '[object Uint8ClampedArray]',\n '[object Int16Array]',\n '[object Uint16Array]',\n '[object Int32Array]',\n '[object Uint32Array]',\n '[object Float32Array]',\n '[object Float64Array]'\n ]\n\n var isArrayBufferView =\n ArrayBuffer.isView ||\n function(obj) {\n return obj && viewClasses.indexOf(Object.prototype.toString.call(obj)) > -1\n }\n}\n\nfunction normalizeName(name) {\n if (typeof name !== 'string') {\n name = String(name)\n }\n if (/[^a-z0-9\\-#$%&'*+.^_`|~!]/i.test(name) || name === '') {\n throw new TypeError('Invalid character in header field name: \"' + name + '\"')\n }\n return name.toLowerCase()\n}\n\nfunction normalizeValue(value) {\n if (typeof value !== 'string') {\n value = String(value)\n }\n return value\n}\n\n// Build a destructive iterator for the value list\nfunction iteratorFor(items) {\n var iterator = {\n next: function() {\n var value = items.shift()\n return {done: value === undefined, value: value}\n }\n }\n\n if (support.iterable) {\n iterator[Symbol.iterator] = function() {\n return iterator\n }\n }\n\n return iterator\n}\n\nexport function Headers(headers) {\n this.map = {}\n\n if (headers instanceof Headers) {\n headers.forEach(function(value, name) {\n this.append(name, value)\n }, this)\n } else if (Array.isArray(headers)) {\n headers.forEach(function(header) {\n if (header.length != 2) {\n throw new TypeError('Headers constructor: expected name/value pair to be length 2, found' + header.length)\n }\n this.append(header[0], header[1])\n }, this)\n } else if (headers) {\n Object.getOwnPropertyNames(headers).forEach(function(name) {\n this.append(name, headers[name])\n }, this)\n }\n}\n\nHeaders.prototype.append = function(name, value) {\n name = normalizeName(name)\n value = normalizeValue(value)\n var oldValue = this.map[name]\n this.map[name] = oldValue ? oldValue + ', ' + value : value\n}\n\nHeaders.prototype['delete'] = function(name) {\n delete this.map[normalizeName(name)]\n}\n\nHeaders.prototype.get = function(name) {\n name = normalizeName(name)\n return this.has(name) ? this.map[name] : null\n}\n\nHeaders.prototype.has = function(name) {\n return this.map.hasOwnProperty(normalizeName(name))\n}\n\nHeaders.prototype.set = function(name, value) {\n this.map[normalizeName(name)] = normalizeValue(value)\n}\n\nHeaders.prototype.forEach = function(callback, thisArg) {\n for (var name in this.map) {\n if (this.map.hasOwnProperty(name)) {\n callback.call(thisArg, this.map[name], name, this)\n }\n }\n}\n\nHeaders.prototype.keys = function() {\n var items = []\n this.forEach(function(value, name) {\n items.push(name)\n })\n return iteratorFor(items)\n}\n\nHeaders.prototype.values = function() {\n var items = []\n this.forEach(function(value) {\n items.push(value)\n })\n return iteratorFor(items)\n}\n\nHeaders.prototype.entries = function() {\n var items = []\n this.forEach(function(value, name) {\n items.push([name, value])\n })\n return iteratorFor(items)\n}\n\nif (support.iterable) {\n Headers.prototype[Symbol.iterator] = Headers.prototype.entries\n}\n\nfunction consumed(body) {\n if (body._noBody) return\n if (body.bodyUsed) {\n return Promise.reject(new TypeError('Already read'))\n }\n body.bodyUsed = true\n}\n\nfunction fileReaderReady(reader) {\n return new Promise(function(resolve, reject) {\n reader.onload = function() {\n resolve(reader.result)\n }\n reader.onerror = function() {\n reject(reader.error)\n }\n })\n}\n\nfunction readBlobAsArrayBuffer(blob) {\n var reader = new FileReader()\n var promise = fileReaderReady(reader)\n reader.readAsArrayBuffer(blob)\n return promise\n}\n\nfunction readBlobAsText(blob) {\n var reader = new FileReader()\n var promise = fileReaderReady(reader)\n var match = /charset=([A-Za-z0-9_-]+)/.exec(blob.type)\n var encoding = match ? match[1] : 'utf-8'\n reader.readAsText(blob, encoding)\n return promise\n}\n\nfunction readArrayBufferAsText(buf) {\n var view = new Uint8Array(buf)\n var chars = new Array(view.length)\n\n for (var i = 0; i < view.length; i++) {\n chars[i] = String.fromCharCode(view[i])\n }\n return chars.join('')\n}\n\nfunction bufferClone(buf) {\n if (buf.slice) {\n return buf.slice(0)\n } else {\n var view = new Uint8Array(buf.byteLength)\n view.set(new Uint8Array(buf))\n return view.buffer\n }\n}\n\nfunction Body() {\n this.bodyUsed = false\n\n this._initBody = function(body) {\n /*\n fetch-mock wraps the Response object in an ES6 Proxy to\n provide useful test harness features such as flush. However, on\n ES5 browsers without fetch or Proxy support pollyfills must be used;\n the proxy-pollyfill is unable to proxy an attribute unless it exists\n on the object before the Proxy is created. This change ensures\n Response.bodyUsed exists on the instance, while maintaining the\n semantic of setting Request.bodyUsed in the constructor before\n _initBody is called.\n */\n // eslint-disable-next-line no-self-assign\n this.bodyUsed = this.bodyUsed\n this._bodyInit = body\n if (!body) {\n this._noBody = true;\n this._bodyText = ''\n } else if (typeof body === 'string') {\n this._bodyText = body\n } else if (support.blob && Blob.prototype.isPrototypeOf(body)) {\n this._bodyBlob = body\n } else if (support.formData && FormData.prototype.isPrototypeOf(body)) {\n this._bodyFormData = body\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this._bodyText = body.toString()\n } else if (support.arrayBuffer && support.blob && isDataView(body)) {\n this._bodyArrayBuffer = bufferClone(body.buffer)\n // IE 10-11 can't handle a DataView body.\n this._bodyInit = new Blob([this._bodyArrayBuffer])\n } else if (support.arrayBuffer && (ArrayBuffer.prototype.isPrototypeOf(body) || isArrayBufferView(body))) {\n this._bodyArrayBuffer = bufferClone(body)\n } else {\n this._bodyText = body = Object.prototype.toString.call(body)\n }\n\n if (!this.headers.get('content-type')) {\n if (typeof body === 'string') {\n this.headers.set('content-type', 'text/plain;charset=UTF-8')\n } else if (this._bodyBlob && this._bodyBlob.type) {\n this.headers.set('content-type', this._bodyBlob.type)\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8')\n }\n }\n }\n\n if (support.blob) {\n this.blob = function() {\n var rejected = consumed(this)\n if (rejected) {\n return rejected\n }\n\n if (this._bodyBlob) {\n return Promise.resolve(this._bodyBlob)\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(new Blob([this._bodyArrayBuffer]))\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as blob')\n } else {\n return Promise.resolve(new Blob([this._bodyText]))\n }\n }\n }\n\n this.arrayBuffer = function() {\n if (this._bodyArrayBuffer) {\n var isConsumed = consumed(this)\n if (isConsumed) {\n return isConsumed\n } else if (ArrayBuffer.isView(this._bodyArrayBuffer)) {\n return Promise.resolve(\n this._bodyArrayBuffer.buffer.slice(\n this._bodyArrayBuffer.byteOffset,\n this._bodyArrayBuffer.byteOffset + this._bodyArrayBuffer.byteLength\n )\n )\n } else {\n return Promise.resolve(this._bodyArrayBuffer)\n }\n } else if (support.blob) {\n return this.blob().then(readBlobAsArrayBuffer)\n } else {\n throw new Error('could not read as ArrayBuffer')\n }\n }\n\n this.text = function() {\n var rejected = consumed(this)\n if (rejected) {\n return rejected\n }\n\n if (this._bodyBlob) {\n return readBlobAsText(this._bodyBlob)\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(readArrayBufferAsText(this._bodyArrayBuffer))\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as text')\n } else {\n return Promise.resolve(this._bodyText)\n }\n }\n\n if (support.formData) {\n this.formData = function() {\n return this.text().then(decode)\n }\n }\n\n this.json = function() {\n return this.text().then(JSON.parse)\n }\n\n return this\n}\n\n// HTTP methods whose capitalization should be normalized\nvar methods = ['CONNECT', 'DELETE', 'GET', 'HEAD', 'OPTIONS', 'PATCH', 'POST', 'PUT', 'TRACE']\n\nfunction normalizeMethod(method) {\n var upcased = method.toUpperCase()\n return methods.indexOf(upcased) > -1 ? upcased : method\n}\n\nexport function Request(input, options) {\n if (!(this instanceof Request)) {\n throw new TypeError('Please use the \"new\" operator, this DOM object constructor cannot be called as a function.')\n }\n\n options = options || {}\n var body = options.body\n\n if (input instanceof Request) {\n if (input.bodyUsed) {\n throw new TypeError('Already read')\n }\n this.url = input.url\n this.credentials = input.credentials\n if (!options.headers) {\n this.headers = new Headers(input.headers)\n }\n this.method = input.method\n this.mode = input.mode\n this.signal = input.signal\n if (!body && input._bodyInit != null) {\n body = input._bodyInit\n input.bodyUsed = true\n }\n } else {\n this.url = String(input)\n }\n\n this.credentials = options.credentials || this.credentials || 'same-origin'\n if (options.headers || !this.headers) {\n this.headers = new Headers(options.headers)\n }\n this.method = normalizeMethod(options.method || this.method || 'GET')\n this.mode = options.mode || this.mode || null\n this.signal = options.signal || this.signal || (function () {\n if ('AbortController' in g) {\n var ctrl = new AbortController();\n return ctrl.signal;\n }\n }());\n this.referrer = null\n\n if ((this.method === 'GET' || this.method === 'HEAD') && body) {\n throw new TypeError('Body not allowed for GET or HEAD requests')\n }\n this._initBody(body)\n\n if (this.method === 'GET' || this.method === 'HEAD') {\n if (options.cache === 'no-store' || options.cache === 'no-cache') {\n // Search for a '_' parameter in the query string\n var reParamSearch = /([?&])_=[^&]*/\n if (reParamSearch.test(this.url)) {\n // If it already exists then set the value with the current time\n this.url = this.url.replace(reParamSearch, '$1_=' + new Date().getTime())\n } else {\n // Otherwise add a new '_' parameter to the end with the current time\n var reQueryString = /\\?/\n this.url += (reQueryString.test(this.url) ? '&' : '?') + '_=' + new Date().getTime()\n }\n }\n }\n}\n\nRequest.prototype.clone = function() {\n return new Request(this, {body: this._bodyInit})\n}\n\nfunction decode(body) {\n var form = new FormData()\n body\n .trim()\n .split('&')\n .forEach(function(bytes) {\n if (bytes) {\n var split = bytes.split('=')\n var name = split.shift().replace(/\\+/g, ' ')\n var value = split.join('=').replace(/\\+/g, ' ')\n form.append(decodeURIComponent(name), decodeURIComponent(value))\n }\n })\n return form\n}\n\nfunction parseHeaders(rawHeaders) {\n var headers = new Headers()\n // Replace instances of \\r\\n and \\n followed by at least one space or horizontal tab with a space\n // https://tools.ietf.org/html/rfc7230#section-3.2\n var preProcessedHeaders = rawHeaders.replace(/\\r?\\n[\\t ]+/g, ' ')\n // Avoiding split via regex to work around a common IE11 bug with the core-js 3.6.0 regex polyfill\n // https://github.com/github/fetch/issues/748\n // https://github.com/zloirock/core-js/issues/751\n preProcessedHeaders\n .split('\\r')\n .map(function(header) {\n return header.indexOf('\\n') === 0 ? header.substr(1, header.length) : header\n })\n .forEach(function(line) {\n var parts = line.split(':')\n var key = parts.shift().trim()\n if (key) {\n var value = parts.join(':').trim()\n try {\n headers.append(key, value)\n } catch (error) {\n console.warn('Response ' + error.message)\n }\n }\n })\n return headers\n}\n\nBody.call(Request.prototype)\n\nexport function Response(bodyInit, options) {\n if (!(this instanceof Response)) {\n throw new TypeError('Please use the \"new\" operator, this DOM object constructor cannot be called as a function.')\n }\n if (!options) {\n options = {}\n }\n\n this.type = 'default'\n this.status = options.status === undefined ? 200 : options.status\n if (this.status < 200 || this.status > 599) {\n throw new RangeError(\"Failed to construct 'Response': The status provided (0) is outside the range [200, 599].\")\n }\n this.ok = this.status >= 200 && this.status < 300\n this.statusText = options.statusText === undefined ? '' : '' + options.statusText\n this.headers = new Headers(options.headers)\n this.url = options.url || ''\n this._initBody(bodyInit)\n}\n\nBody.call(Response.prototype)\n\nResponse.prototype.clone = function() {\n return new Response(this._bodyInit, {\n status: this.status,\n statusText: this.statusText,\n headers: new Headers(this.headers),\n url: this.url\n })\n}\n\nResponse.error = function() {\n var response = new Response(null, {status: 200, statusText: ''})\n response.ok = false\n response.status = 0\n response.type = 'error'\n return response\n}\n\nvar redirectStatuses = [301, 302, 303, 307, 308]\n\nResponse.redirect = function(url, status) {\n if (redirectStatuses.indexOf(status) === -1) {\n throw new RangeError('Invalid status code')\n }\n\n return new Response(null, {status: status, headers: {location: url}})\n}\n\nexport var DOMException = g.DOMException\ntry {\n new DOMException()\n} catch (err) {\n DOMException = function(message, name) {\n this.message = message\n this.name = name\n var error = Error(message)\n this.stack = error.stack\n }\n DOMException.prototype = Object.create(Error.prototype)\n DOMException.prototype.constructor = DOMException\n}\n\nexport function fetch(input, init) {\n return new Promise(function(resolve, reject) {\n var request = new Request(input, init)\n\n if (request.signal && request.signal.aborted) {\n return reject(new DOMException('Aborted', 'AbortError'))\n }\n\n var xhr = new XMLHttpRequest()\n\n function abortXhr() {\n xhr.abort()\n }\n\n xhr.onload = function() {\n var options = {\n statusText: xhr.statusText,\n headers: parseHeaders(xhr.getAllResponseHeaders() || '')\n }\n // This check if specifically for when a user fetches a file locally from the file system\n // Only if the status is out of a normal range\n if (request.url.indexOf('file://') === 0 && (xhr.status < 200 || xhr.status > 599)) {\n options.status = 200;\n } else {\n options.status = xhr.status;\n }\n options.url = 'responseURL' in xhr ? xhr.responseURL : options.headers.get('X-Request-URL')\n var body = 'response' in xhr ? xhr.response : xhr.responseText\n setTimeout(function() {\n resolve(new Response(body, options))\n }, 0)\n }\n\n xhr.onerror = function() {\n setTimeout(function() {\n reject(new TypeError('Network request failed'))\n }, 0)\n }\n\n xhr.ontimeout = function() {\n setTimeout(function() {\n reject(new TypeError('Network request timed out'))\n }, 0)\n }\n\n xhr.onabort = function() {\n setTimeout(function() {\n reject(new DOMException('Aborted', 'AbortError'))\n }, 0)\n }\n\n function fixUrl(url) {\n try {\n return url === '' && g.location.href ? g.location.href : url\n } catch (e) {\n return url\n }\n }\n\n xhr.open(request.method, fixUrl(request.url), true)\n\n if (request.credentials === 'include') {\n xhr.withCredentials = true\n } else if (request.credentials === 'omit') {\n xhr.withCredentials = false\n }\n\n if ('responseType' in xhr) {\n if (support.blob) {\n xhr.responseType = 'blob'\n } else if (\n support.arrayBuffer\n ) {\n xhr.responseType = 'arraybuffer'\n }\n }\n\n if (init && typeof init.headers === 'object' && !(init.headers instanceof Headers || (g.Headers && init.headers instanceof g.Headers))) {\n var names = [];\n Object.getOwnPropertyNames(init.headers).forEach(function(name) {\n names.push(normalizeName(name))\n xhr.setRequestHeader(name, normalizeValue(init.headers[name]))\n })\n request.headers.forEach(function(value, name) {\n if (names.indexOf(name) === -1) {\n xhr.setRequestHeader(name, value)\n }\n })\n } else {\n request.headers.forEach(function(value, name) {\n xhr.setRequestHeader(name, value)\n })\n }\n\n if (request.signal) {\n request.signal.addEventListener('abort', abortXhr)\n\n xhr.onreadystatechange = function() {\n // DONE (success or failure)\n if (xhr.readyState === 4) {\n request.signal.removeEventListener('abort', abortXhr)\n }\n }\n }\n\n xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit)\n })\n}\n\nfetch.polyfill = true\n\nif (!g.fetch) {\n g.fetch = fetch\n g.Headers = Headers\n g.Request = Request\n g.Response = Response\n}\n","'use strict';\nvar check = function (it) {\n return it && it.Math === Math && it;\n};\n\n// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nmodule.exports =\n // eslint-disable-next-line es/no-global-this -- safe\n check(typeof globalThis == 'object' && globalThis) ||\n check(typeof window == 'object' && window) ||\n // eslint-disable-next-line no-restricted-globals -- safe\n check(typeof self == 'object' && self) ||\n check(typeof global == 'object' && global) ||\n check(typeof this == 'object' && this) ||\n // eslint-disable-next-line no-new-func -- fallback\n (function () { return this; })() || Function('return this')();\n","'use strict';\nmodule.exports = function (exec) {\n try {\n return !!exec();\n } catch (error) {\n return true;\n }\n};\n","'use strict';\nvar fails = require('../internals/fails');\n\n// Detect IE8's incomplete defineProperty implementation\nmodule.exports = !fails(function () {\n // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n return Object.defineProperty({}, 1, { get: function () { return 7; } })[1] !== 7;\n});\n","'use strict';\nvar fails = require('../internals/fails');\n\nmodule.exports = !fails(function () {\n // eslint-disable-next-line es/no-function-prototype-bind -- safe\n var test = (function () { /* empty */ }).bind();\n // eslint-disable-next-line no-prototype-builtins -- safe\n return typeof test != 'function' || test.hasOwnProperty('prototype');\n});\n","'use strict';\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar call = Function.prototype.call;\n\nmodule.exports = NATIVE_BIND ? call.bind(call) : function () {\n return call.apply(call, arguments);\n};\n","'use strict';\nvar $propertyIsEnumerable = {}.propertyIsEnumerable;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// Nashorn ~ JDK8 bug\nvar NASHORN_BUG = getOwnPropertyDescriptor && !$propertyIsEnumerable.call({ 1: 2 }, 1);\n\n// `Object.prototype.propertyIsEnumerable` method implementation\n// https://tc39.es/ecma262/#sec-object.prototype.propertyisenumerable\nexports.f = NASHORN_BUG ? function propertyIsEnumerable(V) {\n var descriptor = getOwnPropertyDescriptor(this, V);\n return !!descriptor && descriptor.enumerable;\n} : $propertyIsEnumerable;\n","'use strict';\nmodule.exports = function (bitmap, value) {\n return {\n enumerable: !(bitmap & 1),\n configurable: !(bitmap & 2),\n writable: !(bitmap & 4),\n value: value\n };\n};\n","'use strict';\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar FunctionPrototype = Function.prototype;\nvar call = FunctionPrototype.call;\nvar uncurryThisWithBind = NATIVE_BIND && FunctionPrototype.bind.bind(call, call);\n\nmodule.exports = NATIVE_BIND ? uncurryThisWithBind : function (fn) {\n return function () {\n return call.apply(fn, arguments);\n };\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar toString = uncurryThis({}.toString);\nvar stringSlice = uncurryThis(''.slice);\n\nmodule.exports = function (it) {\n return stringSlice(toString(it), 8, -1);\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar classof = require('../internals/classof-raw');\n\nvar $Object = Object;\nvar split = uncurryThis(''.split);\n\n// fallback for non-array-like ES3 and non-enumerable old V8 strings\nmodule.exports = fails(function () {\n // throws an error in rhino, see https://github.com/mozilla/rhino/issues/346\n // eslint-disable-next-line no-prototype-builtins -- safe\n return !$Object('z').propertyIsEnumerable(0);\n}) ? function (it) {\n return classof(it) === 'String' ? split(it, '') : $Object(it);\n} : $Object;\n","'use strict';\n// we can't use just `it == null` since of `document.all` special case\n// https://tc39.es/ecma262/#sec-IsHTMLDDA-internal-slot-aec\nmodule.exports = function (it) {\n return it === null || it === undefined;\n};\n","'use strict';\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\n\nvar $TypeError = TypeError;\n\n// `RequireObjectCoercible` abstract operation\n// https://tc39.es/ecma262/#sec-requireobjectcoercible\nmodule.exports = function (it) {\n if (isNullOrUndefined(it)) throw new $TypeError(\"Can't call method on \" + it);\n return it;\n};\n","'use strict';\n// toObject with fallback for non-array-like ES3 strings\nvar IndexedObject = require('../internals/indexed-object');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nmodule.exports = function (it) {\n return IndexedObject(requireObjectCoercible(it));\n};\n","'use strict';\n// https://tc39.es/ecma262/#sec-IsHTMLDDA-internal-slot\nvar documentAll = typeof document == 'object' && document.all;\n\n// `IsCallable` abstract operation\n// https://tc39.es/ecma262/#sec-iscallable\n// eslint-disable-next-line unicorn/no-typeof-undefined -- required for testing\nmodule.exports = typeof documentAll == 'undefined' && documentAll !== undefined ? function (argument) {\n return typeof argument == 'function' || argument === documentAll;\n} : function (argument) {\n return typeof argument == 'function';\n};\n","'use strict';\nvar isCallable = require('../internals/is-callable');\n\nmodule.exports = function (it) {\n return typeof it == 'object' ? it !== null : isCallable(it);\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar isCallable = require('../internals/is-callable');\n\nvar aFunction = function (argument) {\n return isCallable(argument) ? argument : undefined;\n};\n\nmodule.exports = function (namespace, method) {\n return arguments.length < 2 ? aFunction(globalThis[namespace]) : globalThis[namespace] && globalThis[namespace][method];\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = uncurryThis({}.isPrototypeOf);\n","'use strict';\nvar globalThis = require('../internals/global-this');\n\nvar navigator = globalThis.navigator;\nvar userAgent = navigator && navigator.userAgent;\n\nmodule.exports = userAgent ? String(userAgent) : '';\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar userAgent = require('../internals/environment-user-agent');\n\nvar process = globalThis.process;\nvar Deno = globalThis.Deno;\nvar versions = process && process.versions || Deno && Deno.version;\nvar v8 = versions && versions.v8;\nvar match, version;\n\nif (v8) {\n match = v8.split('.');\n // in old Chrome, versions of V8 isn't V8 = Chrome / 10\n // but their correct versions are not interesting for us\n version = match[0] > 0 && match[0] < 4 ? 1 : +(match[0] + match[1]);\n}\n\n// BrowserFS NodeJS `process` polyfill incorrectly set `.v8` to `0.0`\n// so check `userAgent` even if `.v8` exists, but 0\nif (!version && userAgent) {\n match = userAgent.match(/Edge\\/(\\d+)/);\n if (!match || match[1] >= 74) {\n match = userAgent.match(/Chrome\\/(\\d+)/);\n if (match) version = +match[1];\n }\n}\n\nmodule.exports = version;\n","'use strict';\n/* eslint-disable es/no-symbol -- required for testing */\nvar V8_VERSION = require('../internals/environment-v8-version');\nvar fails = require('../internals/fails');\nvar globalThis = require('../internals/global-this');\n\nvar $String = globalThis.String;\n\n// eslint-disable-next-line es/no-object-getownpropertysymbols -- required for testing\nmodule.exports = !!Object.getOwnPropertySymbols && !fails(function () {\n var symbol = Symbol('symbol detection');\n // Chrome 38 Symbol has incorrect toString conversion\n // `get-own-property-symbols` polyfill symbols converted to object are not Symbol instances\n // nb: Do not call `String` directly to avoid this being optimized out to `symbol+''` which will,\n // of course, fail.\n return !$String(symbol) || !(Object(symbol) instanceof Symbol) ||\n // Chrome 38-40 symbols are not inherited from DOM collections prototypes to instances\n !Symbol.sham && V8_VERSION && V8_VERSION < 41;\n});\n","'use strict';\n/* eslint-disable es/no-symbol -- required for testing */\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\n\nmodule.exports = NATIVE_SYMBOL &&\n !Symbol.sham &&\n typeof Symbol.iterator == 'symbol';\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar isCallable = require('../internals/is-callable');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar USE_SYMBOL_AS_UID = require('../internals/use-symbol-as-uid');\n\nvar $Object = Object;\n\nmodule.exports = USE_SYMBOL_AS_UID ? function (it) {\n return typeof it == 'symbol';\n} : function (it) {\n var $Symbol = getBuiltIn('Symbol');\n return isCallable($Symbol) && isPrototypeOf($Symbol.prototype, $Object(it));\n};\n","'use strict';\nvar $String = String;\n\nmodule.exports = function (argument) {\n try {\n return $String(argument);\n } catch (error) {\n return 'Object';\n }\n};\n","'use strict';\nvar isCallable = require('../internals/is-callable');\nvar tryToString = require('../internals/try-to-string');\n\nvar $TypeError = TypeError;\n\n// `Assert: IsCallable(argument) is true`\nmodule.exports = function (argument) {\n if (isCallable(argument)) return argument;\n throw new $TypeError(tryToString(argument) + ' is not a function');\n};\n","'use strict';\nvar aCallable = require('../internals/a-callable');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\n\n// `GetMethod` abstract operation\n// https://tc39.es/ecma262/#sec-getmethod\nmodule.exports = function (V, P) {\n var func = V[P];\n return isNullOrUndefined(func) ? undefined : aCallable(func);\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\n\nvar $TypeError = TypeError;\n\n// `OrdinaryToPrimitive` abstract operation\n// https://tc39.es/ecma262/#sec-ordinarytoprimitive\nmodule.exports = function (input, pref) {\n var fn, val;\n if (pref === 'string' && isCallable(fn = input.toString) && !isObject(val = call(fn, input))) return val;\n if (isCallable(fn = input.valueOf) && !isObject(val = call(fn, input))) return val;\n if (pref !== 'string' && isCallable(fn = input.toString) && !isObject(val = call(fn, input))) return val;\n throw new $TypeError(\"Can't convert object to primitive value\");\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\n\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar defineProperty = Object.defineProperty;\n\nmodule.exports = function (key, value) {\n try {\n defineProperty(globalThis, key, { value: value, configurable: true, writable: true });\n } catch (error) {\n globalThis[key] = value;\n } return value;\n};\n","'use strict';\nvar IS_PURE = require('../internals/is-pure');\nvar globalThis = require('../internals/global-this');\nvar defineGlobalProperty = require('../internals/define-global-property');\n\nvar SHARED = '__core-js_shared__';\nvar store = module.exports = globalThis[SHARED] || defineGlobalProperty(SHARED, {});\n\n(store.versions || (store.versions = [])).push({\n version: '3.39.0',\n mode: IS_PURE ? 'pure' : 'global',\n copyright: '© 2014-2024 Denis Pushkarev (zloirock.ru)',\n license: 'https://github.com/zloirock/core-js/blob/v3.39.0/LICENSE',\n source: 'https://github.com/zloirock/core-js'\n});\n","'use strict';\nvar store = require('../internals/shared-store');\n\nmodule.exports = function (key, value) {\n return store[key] || (store[key] = value || {});\n};\n","'use strict';\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nvar $Object = Object;\n\n// `ToObject` abstract operation\n// https://tc39.es/ecma262/#sec-toobject\nmodule.exports = function (argument) {\n return $Object(requireObjectCoercible(argument));\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toObject = require('../internals/to-object');\n\nvar hasOwnProperty = uncurryThis({}.hasOwnProperty);\n\n// `HasOwnProperty` abstract operation\n// https://tc39.es/ecma262/#sec-hasownproperty\n// eslint-disable-next-line es/no-object-hasown -- safe\nmodule.exports = Object.hasOwn || function hasOwn(it, key) {\n return hasOwnProperty(toObject(it), key);\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar id = 0;\nvar postfix = Math.random();\nvar toString = uncurryThis(1.0.toString);\n\nmodule.exports = function (key) {\n return 'Symbol(' + (key === undefined ? '' : key) + ')_' + toString(++id + postfix, 36);\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar shared = require('../internals/shared');\nvar hasOwn = require('../internals/has-own-property');\nvar uid = require('../internals/uid');\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\nvar USE_SYMBOL_AS_UID = require('../internals/use-symbol-as-uid');\n\nvar Symbol = globalThis.Symbol;\nvar WellKnownSymbolsStore = shared('wks');\nvar createWellKnownSymbol = USE_SYMBOL_AS_UID ? Symbol['for'] || Symbol : Symbol && Symbol.withoutSetter || uid;\n\nmodule.exports = function (name) {\n if (!hasOwn(WellKnownSymbolsStore, name)) {\n WellKnownSymbolsStore[name] = NATIVE_SYMBOL && hasOwn(Symbol, name)\n ? Symbol[name]\n : createWellKnownSymbol('Symbol.' + name);\n } return WellKnownSymbolsStore[name];\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar isObject = require('../internals/is-object');\nvar isSymbol = require('../internals/is-symbol');\nvar getMethod = require('../internals/get-method');\nvar ordinaryToPrimitive = require('../internals/ordinary-to-primitive');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar $TypeError = TypeError;\nvar TO_PRIMITIVE = wellKnownSymbol('toPrimitive');\n\n// `ToPrimitive` abstract operation\n// https://tc39.es/ecma262/#sec-toprimitive\nmodule.exports = function (input, pref) {\n if (!isObject(input) || isSymbol(input)) return input;\n var exoticToPrim = getMethod(input, TO_PRIMITIVE);\n var result;\n if (exoticToPrim) {\n if (pref === undefined) pref = 'default';\n result = call(exoticToPrim, input, pref);\n if (!isObject(result) || isSymbol(result)) return result;\n throw new $TypeError(\"Can't convert object to primitive value\");\n }\n if (pref === undefined) pref = 'number';\n return ordinaryToPrimitive(input, pref);\n};\n","'use strict';\nvar toPrimitive = require('../internals/to-primitive');\nvar isSymbol = require('../internals/is-symbol');\n\n// `ToPropertyKey` abstract operation\n// https://tc39.es/ecma262/#sec-topropertykey\nmodule.exports = function (argument) {\n var key = toPrimitive(argument, 'string');\n return isSymbol(key) ? key : key + '';\n};\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar isObject = require('../internals/is-object');\n\nvar document = globalThis.document;\n// typeof document.createElement is 'object' in old IE\nvar EXISTS = isObject(document) && isObject(document.createElement);\n\nmodule.exports = function (it) {\n return EXISTS ? document.createElement(it) : {};\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar fails = require('../internals/fails');\nvar createElement = require('../internals/document-create-element');\n\n// Thanks to IE8 for its funny defineProperty\nmodule.exports = !DESCRIPTORS && !fails(function () {\n // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n return Object.defineProperty(createElement('div'), 'a', {\n get: function () { return 7; }\n }).a !== 7;\n});\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar call = require('../internals/function-call');\nvar propertyIsEnumerableModule = require('../internals/object-property-is-enumerable');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar toPropertyKey = require('../internals/to-property-key');\nvar hasOwn = require('../internals/has-own-property');\nvar IE8_DOM_DEFINE = require('../internals/ie8-dom-define');\n\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar $getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// `Object.getOwnPropertyDescriptor` method\n// https://tc39.es/ecma262/#sec-object.getownpropertydescriptor\nexports.f = DESCRIPTORS ? $getOwnPropertyDescriptor : function getOwnPropertyDescriptor(O, P) {\n O = toIndexedObject(O);\n P = toPropertyKey(P);\n if (IE8_DOM_DEFINE) try {\n return $getOwnPropertyDescriptor(O, P);\n } catch (error) { /* empty */ }\n if (hasOwn(O, P)) return createPropertyDescriptor(!call(propertyIsEnumerableModule.f, O, P), O[P]);\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar fails = require('../internals/fails');\n\n// V8 ~ Chrome 36-\n// https://bugs.chromium.org/p/v8/issues/detail?id=3334\nmodule.exports = DESCRIPTORS && fails(function () {\n // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n return Object.defineProperty(function () { /* empty */ }, 'prototype', {\n value: 42,\n writable: false\n }).prototype !== 42;\n});\n","'use strict';\nvar isObject = require('../internals/is-object');\n\nvar $String = String;\nvar $TypeError = TypeError;\n\n// `Assert: Type(argument) is Object`\nmodule.exports = function (argument) {\n if (isObject(argument)) return argument;\n throw new $TypeError($String(argument) + ' is not an object');\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar IE8_DOM_DEFINE = require('../internals/ie8-dom-define');\nvar V8_PROTOTYPE_DEFINE_BUG = require('../internals/v8-prototype-define-bug');\nvar anObject = require('../internals/an-object');\nvar toPropertyKey = require('../internals/to-property-key');\n\nvar $TypeError = TypeError;\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar $defineProperty = Object.defineProperty;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar $getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar ENUMERABLE = 'enumerable';\nvar CONFIGURABLE = 'configurable';\nvar WRITABLE = 'writable';\n\n// `Object.defineProperty` method\n// https://tc39.es/ecma262/#sec-object.defineproperty\nexports.f = DESCRIPTORS ? V8_PROTOTYPE_DEFINE_BUG ? function defineProperty(O, P, Attributes) {\n anObject(O);\n P = toPropertyKey(P);\n anObject(Attributes);\n if (typeof O === 'function' && P === 'prototype' && 'value' in Attributes && WRITABLE in Attributes && !Attributes[WRITABLE]) {\n var current = $getOwnPropertyDescriptor(O, P);\n if (current && current[WRITABLE]) {\n O[P] = Attributes.value;\n Attributes = {\n configurable: CONFIGURABLE in Attributes ? Attributes[CONFIGURABLE] : current[CONFIGURABLE],\n enumerable: ENUMERABLE in Attributes ? Attributes[ENUMERABLE] : current[ENUMERABLE],\n writable: false\n };\n }\n } return $defineProperty(O, P, Attributes);\n} : $defineProperty : function defineProperty(O, P, Attributes) {\n anObject(O);\n P = toPropertyKey(P);\n anObject(Attributes);\n if (IE8_DOM_DEFINE) try {\n return $defineProperty(O, P, Attributes);\n } catch (error) { /* empty */ }\n if ('get' in Attributes || 'set' in Attributes) throw new $TypeError('Accessors not supported');\n if ('value' in Attributes) O[P] = Attributes.value;\n return O;\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar definePropertyModule = require('../internals/object-define-property');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\n\nmodule.exports = DESCRIPTORS ? function (object, key, value) {\n return definePropertyModule.f(object, key, createPropertyDescriptor(1, value));\n} : function (object, key, value) {\n object[key] = value;\n return object;\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar hasOwn = require('../internals/has-own-property');\n\nvar FunctionPrototype = Function.prototype;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getDescriptor = DESCRIPTORS && Object.getOwnPropertyDescriptor;\n\nvar EXISTS = hasOwn(FunctionPrototype, 'name');\n// additional protection from minified / mangled / dropped function names\nvar PROPER = EXISTS && (function something() { /* empty */ }).name === 'something';\nvar CONFIGURABLE = EXISTS && (!DESCRIPTORS || (DESCRIPTORS && getDescriptor(FunctionPrototype, 'name').configurable));\n\nmodule.exports = {\n EXISTS: EXISTS,\n PROPER: PROPER,\n CONFIGURABLE: CONFIGURABLE\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isCallable = require('../internals/is-callable');\nvar store = require('../internals/shared-store');\n\nvar functionToString = uncurryThis(Function.toString);\n\n// this helper broken in `core-js@3.4.1-3.4.4`, so we can't use `shared` helper\nif (!isCallable(store.inspectSource)) {\n store.inspectSource = function (it) {\n return functionToString(it);\n };\n}\n\nmodule.exports = store.inspectSource;\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar isCallable = require('../internals/is-callable');\n\nvar WeakMap = globalThis.WeakMap;\n\nmodule.exports = isCallable(WeakMap) && /native code/.test(String(WeakMap));\n","'use strict';\nvar shared = require('../internals/shared');\nvar uid = require('../internals/uid');\n\nvar keys = shared('keys');\n\nmodule.exports = function (key) {\n return keys[key] || (keys[key] = uid(key));\n};\n","'use strict';\nmodule.exports = {};\n","'use strict';\nvar NATIVE_WEAK_MAP = require('../internals/weak-map-basic-detection');\nvar globalThis = require('../internals/global-this');\nvar isObject = require('../internals/is-object');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar hasOwn = require('../internals/has-own-property');\nvar shared = require('../internals/shared-store');\nvar sharedKey = require('../internals/shared-key');\nvar hiddenKeys = require('../internals/hidden-keys');\n\nvar OBJECT_ALREADY_INITIALIZED = 'Object already initialized';\nvar TypeError = globalThis.TypeError;\nvar WeakMap = globalThis.WeakMap;\nvar set, get, has;\n\nvar enforce = function (it) {\n return has(it) ? get(it) : set(it, {});\n};\n\nvar getterFor = function (TYPE) {\n return function (it) {\n var state;\n if (!isObject(it) || (state = get(it)).type !== TYPE) {\n throw new TypeError('Incompatible receiver, ' + TYPE + ' required');\n } return state;\n };\n};\n\nif (NATIVE_WEAK_MAP || shared.state) {\n var store = shared.state || (shared.state = new WeakMap());\n /* eslint-disable no-self-assign -- prototype methods protection */\n store.get = store.get;\n store.has = store.has;\n store.set = store.set;\n /* eslint-enable no-self-assign -- prototype methods protection */\n set = function (it, metadata) {\n if (store.has(it)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);\n metadata.facade = it;\n store.set(it, metadata);\n return metadata;\n };\n get = function (it) {\n return store.get(it) || {};\n };\n has = function (it) {\n return store.has(it);\n };\n} else {\n var STATE = sharedKey('state');\n hiddenKeys[STATE] = true;\n set = function (it, metadata) {\n if (hasOwn(it, STATE)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);\n metadata.facade = it;\n createNonEnumerableProperty(it, STATE, metadata);\n return metadata;\n };\n get = function (it) {\n return hasOwn(it, STATE) ? it[STATE] : {};\n };\n has = function (it) {\n return hasOwn(it, STATE);\n };\n}\n\nmodule.exports = {\n set: set,\n get: get,\n has: has,\n enforce: enforce,\n getterFor: getterFor\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar hasOwn = require('../internals/has-own-property');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar CONFIGURABLE_FUNCTION_NAME = require('../internals/function-name').CONFIGURABLE;\nvar inspectSource = require('../internals/inspect-source');\nvar InternalStateModule = require('../internals/internal-state');\n\nvar enforceInternalState = InternalStateModule.enforce;\nvar getInternalState = InternalStateModule.get;\nvar $String = String;\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar defineProperty = Object.defineProperty;\nvar stringSlice = uncurryThis(''.slice);\nvar replace = uncurryThis(''.replace);\nvar join = uncurryThis([].join);\n\nvar CONFIGURABLE_LENGTH = DESCRIPTORS && !fails(function () {\n return defineProperty(function () { /* empty */ }, 'length', { value: 8 }).length !== 8;\n});\n\nvar TEMPLATE = String(String).split('String');\n\nvar makeBuiltIn = module.exports = function (value, name, options) {\n if (stringSlice($String(name), 0, 7) === 'Symbol(') {\n name = '[' + replace($String(name), /^Symbol\\(([^)]*)\\).*$/, '$1') + ']';\n }\n if (options && options.getter) name = 'get ' + name;\n if (options && options.setter) name = 'set ' + name;\n if (!hasOwn(value, 'name') || (CONFIGURABLE_FUNCTION_NAME && value.name !== name)) {\n if (DESCRIPTORS) defineProperty(value, 'name', { value: name, configurable: true });\n else value.name = name;\n }\n if (CONFIGURABLE_LENGTH && options && hasOwn(options, 'arity') && value.length !== options.arity) {\n defineProperty(value, 'length', { value: options.arity });\n }\n try {\n if (options && hasOwn(options, 'constructor') && options.constructor) {\n if (DESCRIPTORS) defineProperty(value, 'prototype', { writable: false });\n // in V8 ~ Chrome 53, prototypes of some methods, like `Array.prototype.values`, are non-writable\n } else if (value.prototype) value.prototype = undefined;\n } catch (error) { /* empty */ }\n var state = enforceInternalState(value);\n if (!hasOwn(state, 'source')) {\n state.source = join(TEMPLATE, typeof name == 'string' ? name : '');\n } return value;\n};\n\n// add fake Function#toString for correct work wrapped methods / constructors with methods like LoDash isNative\n// eslint-disable-next-line no-extend-native -- required\nFunction.prototype.toString = makeBuiltIn(function toString() {\n return isCallable(this) && getInternalState(this).source || inspectSource(this);\n}, 'toString');\n","'use strict';\nvar isCallable = require('../internals/is-callable');\nvar definePropertyModule = require('../internals/object-define-property');\nvar makeBuiltIn = require('../internals/make-built-in');\nvar defineGlobalProperty = require('../internals/define-global-property');\n\nmodule.exports = function (O, key, value, options) {\n if (!options) options = {};\n var simple = options.enumerable;\n var name = options.name !== undefined ? options.name : key;\n if (isCallable(value)) makeBuiltIn(value, name, options);\n if (options.global) {\n if (simple) O[key] = value;\n else defineGlobalProperty(key, value);\n } else {\n try {\n if (!options.unsafe) delete O[key];\n else if (O[key]) simple = true;\n } catch (error) { /* empty */ }\n if (simple) O[key] = value;\n else definePropertyModule.f(O, key, {\n value: value,\n enumerable: false,\n configurable: !options.nonConfigurable,\n writable: !options.nonWritable\n });\n } return O;\n};\n","'use strict';\nvar ceil = Math.ceil;\nvar floor = Math.floor;\n\n// `Math.trunc` method\n// https://tc39.es/ecma262/#sec-math.trunc\n// eslint-disable-next-line es/no-math-trunc -- safe\nmodule.exports = Math.trunc || function trunc(x) {\n var n = +x;\n return (n > 0 ? floor : ceil)(n);\n};\n","'use strict';\nvar trunc = require('../internals/math-trunc');\n\n// `ToIntegerOrInfinity` abstract operation\n// https://tc39.es/ecma262/#sec-tointegerorinfinity\nmodule.exports = function (argument) {\n var number = +argument;\n // eslint-disable-next-line no-self-compare -- NaN check\n return number !== number || number === 0 ? 0 : trunc(number);\n};\n","'use strict';\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\n\nvar max = Math.max;\nvar min = Math.min;\n\n// Helper for a popular repeating case of the spec:\n// Let integer be ? ToInteger(index).\n// If integer < 0, let result be max((length + integer), 0); else let result be min(integer, length).\nmodule.exports = function (index, length) {\n var integer = toIntegerOrInfinity(index);\n return integer < 0 ? max(integer + length, 0) : min(integer, length);\n};\n","'use strict';\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\n\nvar min = Math.min;\n\n// `ToLength` abstract operation\n// https://tc39.es/ecma262/#sec-tolength\nmodule.exports = function (argument) {\n var len = toIntegerOrInfinity(argument);\n return len > 0 ? min(len, 0x1FFFFFFFFFFFFF) : 0; // 2 ** 53 - 1 == 9007199254740991\n};\n","'use strict';\nvar toLength = require('../internals/to-length');\n\n// `LengthOfArrayLike` abstract operation\n// https://tc39.es/ecma262/#sec-lengthofarraylike\nmodule.exports = function (obj) {\n return toLength(obj.length);\n};\n","'use strict';\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar toAbsoluteIndex = require('../internals/to-absolute-index');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\n\n// `Array.prototype.{ indexOf, includes }` methods implementation\nvar createMethod = function (IS_INCLUDES) {\n return function ($this, el, fromIndex) {\n var O = toIndexedObject($this);\n var length = lengthOfArrayLike(O);\n if (length === 0) return !IS_INCLUDES && -1;\n var index = toAbsoluteIndex(fromIndex, length);\n var value;\n // Array#includes uses SameValueZero equality algorithm\n // eslint-disable-next-line no-self-compare -- NaN check\n if (IS_INCLUDES && el !== el) while (length > index) {\n value = O[index++];\n // eslint-disable-next-line no-self-compare -- NaN check\n if (value !== value) return true;\n // Array#indexOf ignores holes, Array#includes - not\n } else for (;length > index; index++) {\n if ((IS_INCLUDES || index in O) && O[index] === el) return IS_INCLUDES || index || 0;\n } return !IS_INCLUDES && -1;\n };\n};\n\nmodule.exports = {\n // `Array.prototype.includes` method\n // https://tc39.es/ecma262/#sec-array.prototype.includes\n includes: createMethod(true),\n // `Array.prototype.indexOf` method\n // https://tc39.es/ecma262/#sec-array.prototype.indexof\n indexOf: createMethod(false)\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar hasOwn = require('../internals/has-own-property');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar indexOf = require('../internals/array-includes').indexOf;\nvar hiddenKeys = require('../internals/hidden-keys');\n\nvar push = uncurryThis([].push);\n\nmodule.exports = function (object, names) {\n var O = toIndexedObject(object);\n var i = 0;\n var result = [];\n var key;\n for (key in O) !hasOwn(hiddenKeys, key) && hasOwn(O, key) && push(result, key);\n // Don't enum bug & hidden keys\n while (names.length > i) if (hasOwn(O, key = names[i++])) {\n ~indexOf(result, key) || push(result, key);\n }\n return result;\n};\n","'use strict';\n// IE8- don't enum bug keys\nmodule.exports = [\n 'constructor',\n 'hasOwnProperty',\n 'isPrototypeOf',\n 'propertyIsEnumerable',\n 'toLocaleString',\n 'toString',\n 'valueOf'\n];\n","'use strict';\nvar internalObjectKeys = require('../internals/object-keys-internal');\nvar enumBugKeys = require('../internals/enum-bug-keys');\n\nvar hiddenKeys = enumBugKeys.concat('length', 'prototype');\n\n// `Object.getOwnPropertyNames` method\n// https://tc39.es/ecma262/#sec-object.getownpropertynames\n// eslint-disable-next-line es/no-object-getownpropertynames -- safe\nexports.f = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {\n return internalObjectKeys(O, hiddenKeys);\n};\n","'use strict';\n// eslint-disable-next-line es/no-object-getownpropertysymbols -- safe\nexports.f = Object.getOwnPropertySymbols;\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar getOwnPropertyNamesModule = require('../internals/object-get-own-property-names');\nvar getOwnPropertySymbolsModule = require('../internals/object-get-own-property-symbols');\nvar anObject = require('../internals/an-object');\n\nvar concat = uncurryThis([].concat);\n\n// all object keys, includes non-enumerable and symbols\nmodule.exports = getBuiltIn('Reflect', 'ownKeys') || function ownKeys(it) {\n var keys = getOwnPropertyNamesModule.f(anObject(it));\n var getOwnPropertySymbols = getOwnPropertySymbolsModule.f;\n return getOwnPropertySymbols ? concat(keys, getOwnPropertySymbols(it)) : keys;\n};\n","'use strict';\nvar hasOwn = require('../internals/has-own-property');\nvar ownKeys = require('../internals/own-keys');\nvar getOwnPropertyDescriptorModule = require('../internals/object-get-own-property-descriptor');\nvar definePropertyModule = require('../internals/object-define-property');\n\nmodule.exports = function (target, source, exceptions) {\n var keys = ownKeys(source);\n var defineProperty = definePropertyModule.f;\n var getOwnPropertyDescriptor = getOwnPropertyDescriptorModule.f;\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n if (!hasOwn(target, key) && !(exceptions && hasOwn(exceptions, key))) {\n defineProperty(target, key, getOwnPropertyDescriptor(source, key));\n }\n }\n};\n","'use strict';\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\n\nvar replacement = /#|\\.prototype\\./;\n\nvar isForced = function (feature, detection) {\n var value = data[normalize(feature)];\n return value === POLYFILL ? true\n : value === NATIVE ? false\n : isCallable(detection) ? fails(detection)\n : !!detection;\n};\n\nvar normalize = isForced.normalize = function (string) {\n return String(string).replace(replacement, '.').toLowerCase();\n};\n\nvar data = isForced.data = {};\nvar NATIVE = isForced.NATIVE = 'N';\nvar POLYFILL = isForced.POLYFILL = 'P';\n\nmodule.exports = isForced;\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar getOwnPropertyDescriptor = require('../internals/object-get-own-property-descriptor').f;\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar defineGlobalProperty = require('../internals/define-global-property');\nvar copyConstructorProperties = require('../internals/copy-constructor-properties');\nvar isForced = require('../internals/is-forced');\n\n/*\n options.target - name of the target object\n options.global - target is the global object\n options.stat - export as static methods of target\n options.proto - export as prototype methods of target\n options.real - real prototype method for the `pure` version\n options.forced - export even if the native feature is available\n options.bind - bind methods to the target, required for the `pure` version\n options.wrap - wrap constructors to preventing global pollution, required for the `pure` version\n options.unsafe - use the simple assignment of property instead of delete + defineProperty\n options.sham - add a flag to not completely full polyfills\n options.enumerable - export as enumerable property\n options.dontCallGetSet - prevent calling a getter on target\n options.name - the .name of the function if it does not match the key\n*/\nmodule.exports = function (options, source) {\n var TARGET = options.target;\n var GLOBAL = options.global;\n var STATIC = options.stat;\n var FORCED, target, key, targetProperty, sourceProperty, descriptor;\n if (GLOBAL) {\n target = globalThis;\n } else if (STATIC) {\n target = globalThis[TARGET] || defineGlobalProperty(TARGET, {});\n } else {\n target = globalThis[TARGET] && globalThis[TARGET].prototype;\n }\n if (target) for (key in source) {\n sourceProperty = source[key];\n if (options.dontCallGetSet) {\n descriptor = getOwnPropertyDescriptor(target, key);\n targetProperty = descriptor && descriptor.value;\n } else targetProperty = target[key];\n FORCED = isForced(GLOBAL ? key : TARGET + (STATIC ? '.' : '#') + key, options.forced);\n // contained in target\n if (!FORCED && targetProperty !== undefined) {\n if (typeof sourceProperty == typeof targetProperty) continue;\n copyConstructorProperties(sourceProperty, targetProperty);\n }\n // add a flag to not completely full polyfills\n if (options.sham || (targetProperty && targetProperty.sham)) {\n createNonEnumerableProperty(sourceProperty, 'sham', true);\n }\n defineBuiltIn(target, key, sourceProperty, options);\n }\n};\n","'use strict';\nvar classof = require('../internals/classof-raw');\n\n// `IsArray` abstract operation\n// https://tc39.es/ecma262/#sec-isarray\n// eslint-disable-next-line es/no-array-isarray -- safe\nmodule.exports = Array.isArray || function isArray(argument) {\n return classof(argument) === 'Array';\n};\n","'use strict';\nvar $TypeError = TypeError;\nvar MAX_SAFE_INTEGER = 0x1FFFFFFFFFFFFF; // 2 ** 53 - 1 == 9007199254740991\n\nmodule.exports = function (it) {\n if (it > MAX_SAFE_INTEGER) throw $TypeError('Maximum allowed index exceeded');\n return it;\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar definePropertyModule = require('../internals/object-define-property');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\n\nmodule.exports = function (object, key, value) {\n if (DESCRIPTORS) definePropertyModule.f(object, key, createPropertyDescriptor(0, value));\n else object[key] = value;\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\nvar test = {};\n\ntest[TO_STRING_TAG] = 'z';\n\nmodule.exports = String(test) === '[object z]';\n","'use strict';\nvar TO_STRING_TAG_SUPPORT = require('../internals/to-string-tag-support');\nvar isCallable = require('../internals/is-callable');\nvar classofRaw = require('../internals/classof-raw');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\nvar $Object = Object;\n\n// ES3 wrong here\nvar CORRECT_ARGUMENTS = classofRaw(function () { return arguments; }()) === 'Arguments';\n\n// fallback for IE11 Script Access Denied error\nvar tryGet = function (it, key) {\n try {\n return it[key];\n } catch (error) { /* empty */ }\n};\n\n// getting tag from ES6+ `Object.prototype.toString`\nmodule.exports = TO_STRING_TAG_SUPPORT ? classofRaw : function (it) {\n var O, tag, result;\n return it === undefined ? 'Undefined' : it === null ? 'Null'\n // @@toStringTag case\n : typeof (tag = tryGet(O = $Object(it), TO_STRING_TAG)) == 'string' ? tag\n // builtinTag case\n : CORRECT_ARGUMENTS ? classofRaw(O)\n // ES3 arguments fallback\n : (result = classofRaw(O)) === 'Object' && isCallable(O.callee) ? 'Arguments' : result;\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar classof = require('../internals/classof');\nvar getBuiltIn = require('../internals/get-built-in');\nvar inspectSource = require('../internals/inspect-source');\n\nvar noop = function () { /* empty */ };\nvar construct = getBuiltIn('Reflect', 'construct');\nvar constructorRegExp = /^\\s*(?:class|function)\\b/;\nvar exec = uncurryThis(constructorRegExp.exec);\nvar INCORRECT_TO_STRING = !constructorRegExp.test(noop);\n\nvar isConstructorModern = function isConstructor(argument) {\n if (!isCallable(argument)) return false;\n try {\n construct(noop, [], argument);\n return true;\n } catch (error) {\n return false;\n }\n};\n\nvar isConstructorLegacy = function isConstructor(argument) {\n if (!isCallable(argument)) return false;\n switch (classof(argument)) {\n case 'AsyncFunction':\n case 'GeneratorFunction':\n case 'AsyncGeneratorFunction': return false;\n }\n try {\n // we can't check .prototype since constructors produced by .bind haven't it\n // `Function#toString` throws on some built-it function in some legacy engines\n // (for example, `DOMQuad` and similar in FF41-)\n return INCORRECT_TO_STRING || !!exec(constructorRegExp, inspectSource(argument));\n } catch (error) {\n return true;\n }\n};\n\nisConstructorLegacy.sham = true;\n\n// `IsConstructor` abstract operation\n// https://tc39.es/ecma262/#sec-isconstructor\nmodule.exports = !construct || fails(function () {\n var called;\n return isConstructorModern(isConstructorModern.call)\n || !isConstructorModern(Object)\n || !isConstructorModern(function () { called = true; })\n || called;\n}) ? isConstructorLegacy : isConstructorModern;\n","'use strict';\nvar isArray = require('../internals/is-array');\nvar isConstructor = require('../internals/is-constructor');\nvar isObject = require('../internals/is-object');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar SPECIES = wellKnownSymbol('species');\nvar $Array = Array;\n\n// a part of `ArraySpeciesCreate` abstract operation\n// https://tc39.es/ecma262/#sec-arrayspeciescreate\nmodule.exports = function (originalArray) {\n var C;\n if (isArray(originalArray)) {\n C = originalArray.constructor;\n // cross-realm fallback\n if (isConstructor(C) && (C === $Array || isArray(C.prototype))) C = undefined;\n else if (isObject(C)) {\n C = C[SPECIES];\n if (C === null) C = undefined;\n }\n } return C === undefined ? $Array : C;\n};\n","'use strict';\nvar arraySpeciesConstructor = require('../internals/array-species-constructor');\n\n// `ArraySpeciesCreate` abstract operation\n// https://tc39.es/ecma262/#sec-arrayspeciescreate\nmodule.exports = function (originalArray, length) {\n return new (arraySpeciesConstructor(originalArray))(length === 0 ? 0 : length);\n};\n","'use strict';\nvar fails = require('../internals/fails');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar V8_VERSION = require('../internals/environment-v8-version');\n\nvar SPECIES = wellKnownSymbol('species');\n\nmodule.exports = function (METHOD_NAME) {\n // We can't use this feature detection in V8 since it causes\n // deoptimization and serious performance degradation\n // https://github.com/zloirock/core-js/issues/677\n return V8_VERSION >= 51 || !fails(function () {\n var array = [];\n var constructor = array.constructor = {};\n constructor[SPECIES] = function () {\n return { foo: 1 };\n };\n return array[METHOD_NAME](Boolean).foo !== 1;\n });\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar fails = require('../internals/fails');\nvar isArray = require('../internals/is-array');\nvar isObject = require('../internals/is-object');\nvar toObject = require('../internals/to-object');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar doesNotExceedSafeInteger = require('../internals/does-not-exceed-safe-integer');\nvar createProperty = require('../internals/create-property');\nvar arraySpeciesCreate = require('../internals/array-species-create');\nvar arrayMethodHasSpeciesSupport = require('../internals/array-method-has-species-support');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar V8_VERSION = require('../internals/environment-v8-version');\n\nvar IS_CONCAT_SPREADABLE = wellKnownSymbol('isConcatSpreadable');\n\n// We can't use this feature detection in V8 since it causes\n// deoptimization and serious performance degradation\n// https://github.com/zloirock/core-js/issues/679\nvar IS_CONCAT_SPREADABLE_SUPPORT = V8_VERSION >= 51 || !fails(function () {\n var array = [];\n array[IS_CONCAT_SPREADABLE] = false;\n return array.concat()[0] !== array;\n});\n\nvar isConcatSpreadable = function (O) {\n if (!isObject(O)) return false;\n var spreadable = O[IS_CONCAT_SPREADABLE];\n return spreadable !== undefined ? !!spreadable : isArray(O);\n};\n\nvar FORCED = !IS_CONCAT_SPREADABLE_SUPPORT || !arrayMethodHasSpeciesSupport('concat');\n\n// `Array.prototype.concat` method\n// https://tc39.es/ecma262/#sec-array.prototype.concat\n// with adding support of @@isConcatSpreadable and @@species\n$({ target: 'Array', proto: true, arity: 1, forced: FORCED }, {\n // eslint-disable-next-line no-unused-vars -- required for `.length`\n concat: function concat(arg) {\n var O = toObject(this);\n var A = arraySpeciesCreate(O, 0);\n var n = 0;\n var i, k, length, len, E;\n for (i = -1, length = arguments.length; i < length; i++) {\n E = i === -1 ? O : arguments[i];\n if (isConcatSpreadable(E)) {\n len = lengthOfArrayLike(E);\n doesNotExceedSafeInteger(n + len);\n for (k = 0; k < len; k++, n++) if (k in E) createProperty(A, n, E[k]);\n } else {\n doesNotExceedSafeInteger(n + 1);\n createProperty(A, n++, E);\n }\n }\n A.length = n;\n return A;\n }\n});\n","'use strict';\nvar TO_STRING_TAG_SUPPORT = require('../internals/to-string-tag-support');\nvar classof = require('../internals/classof');\n\n// `Object.prototype.toString` method implementation\n// https://tc39.es/ecma262/#sec-object.prototype.tostring\nmodule.exports = TO_STRING_TAG_SUPPORT ? {}.toString : function toString() {\n return '[object ' + classof(this) + ']';\n};\n","'use strict';\nvar TO_STRING_TAG_SUPPORT = require('../internals/to-string-tag-support');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar toString = require('../internals/object-to-string');\n\n// `Object.prototype.toString` method\n// https://tc39.es/ecma262/#sec-object.prototype.tostring\nif (!TO_STRING_TAG_SUPPORT) {\n defineBuiltIn(Object.prototype, 'toString', toString, { unsafe: true });\n}\n","'use strict';\nvar classof = require('../internals/classof');\n\nvar $String = String;\n\nmodule.exports = function (argument) {\n if (classof(argument) === 'Symbol') throw new TypeError('Cannot convert a Symbol value to a string');\n return $String(argument);\n};\n","'use strict';\nvar internalObjectKeys = require('../internals/object-keys-internal');\nvar enumBugKeys = require('../internals/enum-bug-keys');\n\n// `Object.keys` method\n// https://tc39.es/ecma262/#sec-object.keys\n// eslint-disable-next-line es/no-object-keys -- safe\nmodule.exports = Object.keys || function keys(O) {\n return internalObjectKeys(O, enumBugKeys);\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar V8_PROTOTYPE_DEFINE_BUG = require('../internals/v8-prototype-define-bug');\nvar definePropertyModule = require('../internals/object-define-property');\nvar anObject = require('../internals/an-object');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar objectKeys = require('../internals/object-keys');\n\n// `Object.defineProperties` method\n// https://tc39.es/ecma262/#sec-object.defineproperties\n// eslint-disable-next-line es/no-object-defineproperties -- safe\nexports.f = DESCRIPTORS && !V8_PROTOTYPE_DEFINE_BUG ? Object.defineProperties : function defineProperties(O, Properties) {\n anObject(O);\n var props = toIndexedObject(Properties);\n var keys = objectKeys(Properties);\n var length = keys.length;\n var index = 0;\n var key;\n while (length > index) definePropertyModule.f(O, key = keys[index++], props[key]);\n return O;\n};\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\n\nmodule.exports = getBuiltIn('document', 'documentElement');\n","'use strict';\n/* global ActiveXObject -- old IE, WSH */\nvar anObject = require('../internals/an-object');\nvar definePropertiesModule = require('../internals/object-define-properties');\nvar enumBugKeys = require('../internals/enum-bug-keys');\nvar hiddenKeys = require('../internals/hidden-keys');\nvar html = require('../internals/html');\nvar documentCreateElement = require('../internals/document-create-element');\nvar sharedKey = require('../internals/shared-key');\n\nvar GT = '>';\nvar LT = '<';\nvar PROTOTYPE = 'prototype';\nvar SCRIPT = 'script';\nvar IE_PROTO = sharedKey('IE_PROTO');\n\nvar EmptyConstructor = function () { /* empty */ };\n\nvar scriptTag = function (content) {\n return LT + SCRIPT + GT + content + LT + '/' + SCRIPT + GT;\n};\n\n// Create object with fake `null` prototype: use ActiveX Object with cleared prototype\nvar NullProtoObjectViaActiveX = function (activeXDocument) {\n activeXDocument.write(scriptTag(''));\n activeXDocument.close();\n var temp = activeXDocument.parentWindow.Object;\n // eslint-disable-next-line no-useless-assignment -- avoid memory leak\n activeXDocument = null;\n return temp;\n};\n\n// Create object with fake `null` prototype: use iframe Object with cleared prototype\nvar NullProtoObjectViaIFrame = function () {\n // Thrash, waste and sodomy: IE GC bug\n var iframe = documentCreateElement('iframe');\n var JS = 'java' + SCRIPT + ':';\n var iframeDocument;\n iframe.style.display = 'none';\n html.appendChild(iframe);\n // https://github.com/zloirock/core-js/issues/475\n iframe.src = String(JS);\n iframeDocument = iframe.contentWindow.document;\n iframeDocument.open();\n iframeDocument.write(scriptTag('document.F=Object'));\n iframeDocument.close();\n return iframeDocument.F;\n};\n\n// Check for document.domain and active x support\n// No need to use active x approach when document.domain is not set\n// see https://github.com/es-shims/es5-shim/issues/150\n// variation of https://github.com/kitcambridge/es5-shim/commit/4f738ac066346\n// avoid IE GC bug\nvar activeXDocument;\nvar NullProtoObject = function () {\n try {\n activeXDocument = new ActiveXObject('htmlfile');\n } catch (error) { /* ignore */ }\n NullProtoObject = typeof document != 'undefined'\n ? document.domain && activeXDocument\n ? NullProtoObjectViaActiveX(activeXDocument) // old IE\n : NullProtoObjectViaIFrame()\n : NullProtoObjectViaActiveX(activeXDocument); // WSH\n var length = enumBugKeys.length;\n while (length--) delete NullProtoObject[PROTOTYPE][enumBugKeys[length]];\n return NullProtoObject();\n};\n\nhiddenKeys[IE_PROTO] = true;\n\n// `Object.create` method\n// https://tc39.es/ecma262/#sec-object.create\n// eslint-disable-next-line es/no-object-create -- safe\nmodule.exports = Object.create || function create(O, Properties) {\n var result;\n if (O !== null) {\n EmptyConstructor[PROTOTYPE] = anObject(O);\n result = new EmptyConstructor();\n EmptyConstructor[PROTOTYPE] = null;\n // add \"__proto__\" for Object.getPrototypeOf polyfill\n result[IE_PROTO] = O;\n } else result = NullProtoObject();\n return Properties === undefined ? result : definePropertiesModule.f(result, Properties);\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = uncurryThis([].slice);\n","'use strict';\n/* eslint-disable es/no-object-getownpropertynames -- safe */\nvar classof = require('../internals/classof-raw');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar $getOwnPropertyNames = require('../internals/object-get-own-property-names').f;\nvar arraySlice = require('../internals/array-slice');\n\nvar windowNames = typeof window == 'object' && window && Object.getOwnPropertyNames\n ? Object.getOwnPropertyNames(window) : [];\n\nvar getWindowNames = function (it) {\n try {\n return $getOwnPropertyNames(it);\n } catch (error) {\n return arraySlice(windowNames);\n }\n};\n\n// fallback for IE11 buggy Object.getOwnPropertyNames with iframe and window\nmodule.exports.f = function getOwnPropertyNames(it) {\n return windowNames && classof(it) === 'Window'\n ? getWindowNames(it)\n : $getOwnPropertyNames(toIndexedObject(it));\n};\n","'use strict';\nvar makeBuiltIn = require('../internals/make-built-in');\nvar defineProperty = require('../internals/object-define-property');\n\nmodule.exports = function (target, name, descriptor) {\n if (descriptor.get) makeBuiltIn(descriptor.get, name, { getter: true });\n if (descriptor.set) makeBuiltIn(descriptor.set, name, { setter: true });\n return defineProperty.f(target, name, descriptor);\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nexports.f = wellKnownSymbol;\n","'use strict';\nvar globalThis = require('../internals/global-this');\n\nmodule.exports = globalThis;\n","'use strict';\nvar path = require('../internals/path');\nvar hasOwn = require('../internals/has-own-property');\nvar wrappedWellKnownSymbolModule = require('../internals/well-known-symbol-wrapped');\nvar defineProperty = require('../internals/object-define-property').f;\n\nmodule.exports = function (NAME) {\n var Symbol = path.Symbol || (path.Symbol = {});\n if (!hasOwn(Symbol, NAME)) defineProperty(Symbol, NAME, {\n value: wrappedWellKnownSymbolModule.f(NAME)\n });\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar getBuiltIn = require('../internals/get-built-in');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar defineBuiltIn = require('../internals/define-built-in');\n\nmodule.exports = function () {\n var Symbol = getBuiltIn('Symbol');\n var SymbolPrototype = Symbol && Symbol.prototype;\n var valueOf = SymbolPrototype && SymbolPrototype.valueOf;\n var TO_PRIMITIVE = wellKnownSymbol('toPrimitive');\n\n if (SymbolPrototype && !SymbolPrototype[TO_PRIMITIVE]) {\n // `Symbol.prototype[@@toPrimitive]` method\n // https://tc39.es/ecma262/#sec-symbol.prototype-@@toprimitive\n // eslint-disable-next-line no-unused-vars -- required for .length\n defineBuiltIn(SymbolPrototype, TO_PRIMITIVE, function (hint) {\n return call(valueOf, this);\n }, { arity: 1 });\n }\n};\n","'use strict';\nvar defineProperty = require('../internals/object-define-property').f;\nvar hasOwn = require('../internals/has-own-property');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\n\nmodule.exports = function (target, TAG, STATIC) {\n if (target && !STATIC) target = target.prototype;\n if (target && !hasOwn(target, TO_STRING_TAG)) {\n defineProperty(target, TO_STRING_TAG, { configurable: true, value: TAG });\n }\n};\n","'use strict';\nvar classofRaw = require('../internals/classof-raw');\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = function (fn) {\n // Nashorn bug:\n // https://github.com/zloirock/core-js/issues/1128\n // https://github.com/zloirock/core-js/issues/1130\n if (classofRaw(fn) === 'Function') return uncurryThis(fn);\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this-clause');\nvar aCallable = require('../internals/a-callable');\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar bind = uncurryThis(uncurryThis.bind);\n\n// optional / simple context binding\nmodule.exports = function (fn, that) {\n aCallable(fn);\n return that === undefined ? fn : NATIVE_BIND ? bind(fn, that) : function (/* ...args */) {\n return fn.apply(that, arguments);\n };\n};\n","'use strict';\nvar bind = require('../internals/function-bind-context');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar IndexedObject = require('../internals/indexed-object');\nvar toObject = require('../internals/to-object');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar arraySpeciesCreate = require('../internals/array-species-create');\n\nvar push = uncurryThis([].push);\n\n// `Array.prototype.{ forEach, map, filter, some, every, find, findIndex, filterReject }` methods implementation\nvar createMethod = function (TYPE) {\n var IS_MAP = TYPE === 1;\n var IS_FILTER = TYPE === 2;\n var IS_SOME = TYPE === 3;\n var IS_EVERY = TYPE === 4;\n var IS_FIND_INDEX = TYPE === 6;\n var IS_FILTER_REJECT = TYPE === 7;\n var NO_HOLES = TYPE === 5 || IS_FIND_INDEX;\n return function ($this, callbackfn, that, specificCreate) {\n var O = toObject($this);\n var self = IndexedObject(O);\n var length = lengthOfArrayLike(self);\n var boundFunction = bind(callbackfn, that);\n var index = 0;\n var create = specificCreate || arraySpeciesCreate;\n var target = IS_MAP ? create($this, length) : IS_FILTER || IS_FILTER_REJECT ? create($this, 0) : undefined;\n var value, result;\n for (;length > index; index++) if (NO_HOLES || index in self) {\n value = self[index];\n result = boundFunction(value, index, O);\n if (TYPE) {\n if (IS_MAP) target[index] = result; // map\n else if (result) switch (TYPE) {\n case 3: return true; // some\n case 5: return value; // find\n case 6: return index; // findIndex\n case 2: push(target, value); // filter\n } else switch (TYPE) {\n case 4: return false; // every\n case 7: push(target, value); // filterReject\n }\n }\n }\n return IS_FIND_INDEX ? -1 : IS_SOME || IS_EVERY ? IS_EVERY : target;\n };\n};\n\nmodule.exports = {\n // `Array.prototype.forEach` method\n // https://tc39.es/ecma262/#sec-array.prototype.foreach\n forEach: createMethod(0),\n // `Array.prototype.map` method\n // https://tc39.es/ecma262/#sec-array.prototype.map\n map: createMethod(1),\n // `Array.prototype.filter` method\n // https://tc39.es/ecma262/#sec-array.prototype.filter\n filter: createMethod(2),\n // `Array.prototype.some` method\n // https://tc39.es/ecma262/#sec-array.prototype.some\n some: createMethod(3),\n // `Array.prototype.every` method\n // https://tc39.es/ecma262/#sec-array.prototype.every\n every: createMethod(4),\n // `Array.prototype.find` method\n // https://tc39.es/ecma262/#sec-array.prototype.find\n find: createMethod(5),\n // `Array.prototype.findIndex` method\n // https://tc39.es/ecma262/#sec-array.prototype.findIndex\n findIndex: createMethod(6),\n // `Array.prototype.filterReject` method\n // https://github.com/tc39/proposal-array-filtering\n filterReject: createMethod(7)\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar globalThis = require('../internals/global-this');\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar IS_PURE = require('../internals/is-pure');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\nvar fails = require('../internals/fails');\nvar hasOwn = require('../internals/has-own-property');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar anObject = require('../internals/an-object');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar toPropertyKey = require('../internals/to-property-key');\nvar $toString = require('../internals/to-string');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\nvar nativeObjectCreate = require('../internals/object-create');\nvar objectKeys = require('../internals/object-keys');\nvar getOwnPropertyNamesModule = require('../internals/object-get-own-property-names');\nvar getOwnPropertyNamesExternal = require('../internals/object-get-own-property-names-external');\nvar getOwnPropertySymbolsModule = require('../internals/object-get-own-property-symbols');\nvar getOwnPropertyDescriptorModule = require('../internals/object-get-own-property-descriptor');\nvar definePropertyModule = require('../internals/object-define-property');\nvar definePropertiesModule = require('../internals/object-define-properties');\nvar propertyIsEnumerableModule = require('../internals/object-property-is-enumerable');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar shared = require('../internals/shared');\nvar sharedKey = require('../internals/shared-key');\nvar hiddenKeys = require('../internals/hidden-keys');\nvar uid = require('../internals/uid');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar wrappedWellKnownSymbolModule = require('../internals/well-known-symbol-wrapped');\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\nvar defineSymbolToPrimitive = require('../internals/symbol-define-to-primitive');\nvar setToStringTag = require('../internals/set-to-string-tag');\nvar InternalStateModule = require('../internals/internal-state');\nvar $forEach = require('../internals/array-iteration').forEach;\n\nvar HIDDEN = sharedKey('hidden');\nvar SYMBOL = 'Symbol';\nvar PROTOTYPE = 'prototype';\n\nvar setInternalState = InternalStateModule.set;\nvar getInternalState = InternalStateModule.getterFor(SYMBOL);\n\nvar ObjectPrototype = Object[PROTOTYPE];\nvar $Symbol = globalThis.Symbol;\nvar SymbolPrototype = $Symbol && $Symbol[PROTOTYPE];\nvar RangeError = globalThis.RangeError;\nvar TypeError = globalThis.TypeError;\nvar QObject = globalThis.QObject;\nvar nativeGetOwnPropertyDescriptor = getOwnPropertyDescriptorModule.f;\nvar nativeDefineProperty = definePropertyModule.f;\nvar nativeGetOwnPropertyNames = getOwnPropertyNamesExternal.f;\nvar nativePropertyIsEnumerable = propertyIsEnumerableModule.f;\nvar push = uncurryThis([].push);\n\nvar AllSymbols = shared('symbols');\nvar ObjectPrototypeSymbols = shared('op-symbols');\nvar WellKnownSymbolsStore = shared('wks');\n\n// Don't use setters in Qt Script, https://github.com/zloirock/core-js/issues/173\nvar USE_SETTER = !QObject || !QObject[PROTOTYPE] || !QObject[PROTOTYPE].findChild;\n\n// fallback for old Android, https://code.google.com/p/v8/issues/detail?id=687\nvar fallbackDefineProperty = function (O, P, Attributes) {\n var ObjectPrototypeDescriptor = nativeGetOwnPropertyDescriptor(ObjectPrototype, P);\n if (ObjectPrototypeDescriptor) delete ObjectPrototype[P];\n nativeDefineProperty(O, P, Attributes);\n if (ObjectPrototypeDescriptor && O !== ObjectPrototype) {\n nativeDefineProperty(ObjectPrototype, P, ObjectPrototypeDescriptor);\n }\n};\n\nvar setSymbolDescriptor = DESCRIPTORS && fails(function () {\n return nativeObjectCreate(nativeDefineProperty({}, 'a', {\n get: function () { return nativeDefineProperty(this, 'a', { value: 7 }).a; }\n })).a !== 7;\n}) ? fallbackDefineProperty : nativeDefineProperty;\n\nvar wrap = function (tag, description) {\n var symbol = AllSymbols[tag] = nativeObjectCreate(SymbolPrototype);\n setInternalState(symbol, {\n type: SYMBOL,\n tag: tag,\n description: description\n });\n if (!DESCRIPTORS) symbol.description = description;\n return symbol;\n};\n\nvar $defineProperty = function defineProperty(O, P, Attributes) {\n if (O === ObjectPrototype) $defineProperty(ObjectPrototypeSymbols, P, Attributes);\n anObject(O);\n var key = toPropertyKey(P);\n anObject(Attributes);\n if (hasOwn(AllSymbols, key)) {\n if (!Attributes.enumerable) {\n if (!hasOwn(O, HIDDEN)) nativeDefineProperty(O, HIDDEN, createPropertyDescriptor(1, nativeObjectCreate(null)));\n O[HIDDEN][key] = true;\n } else {\n if (hasOwn(O, HIDDEN) && O[HIDDEN][key]) O[HIDDEN][key] = false;\n Attributes = nativeObjectCreate(Attributes, { enumerable: createPropertyDescriptor(0, false) });\n } return setSymbolDescriptor(O, key, Attributes);\n } return nativeDefineProperty(O, key, Attributes);\n};\n\nvar $defineProperties = function defineProperties(O, Properties) {\n anObject(O);\n var properties = toIndexedObject(Properties);\n var keys = objectKeys(properties).concat($getOwnPropertySymbols(properties));\n $forEach(keys, function (key) {\n if (!DESCRIPTORS || call($propertyIsEnumerable, properties, key)) $defineProperty(O, key, properties[key]);\n });\n return O;\n};\n\nvar $create = function create(O, Properties) {\n return Properties === undefined ? nativeObjectCreate(O) : $defineProperties(nativeObjectCreate(O), Properties);\n};\n\nvar $propertyIsEnumerable = function propertyIsEnumerable(V) {\n var P = toPropertyKey(V);\n var enumerable = call(nativePropertyIsEnumerable, this, P);\n if (this === ObjectPrototype && hasOwn(AllSymbols, P) && !hasOwn(ObjectPrototypeSymbols, P)) return false;\n return enumerable || !hasOwn(this, P) || !hasOwn(AllSymbols, P) || hasOwn(this, HIDDEN) && this[HIDDEN][P]\n ? enumerable : true;\n};\n\nvar $getOwnPropertyDescriptor = function getOwnPropertyDescriptor(O, P) {\n var it = toIndexedObject(O);\n var key = toPropertyKey(P);\n if (it === ObjectPrototype && hasOwn(AllSymbols, key) && !hasOwn(ObjectPrototypeSymbols, key)) return;\n var descriptor = nativeGetOwnPropertyDescriptor(it, key);\n if (descriptor && hasOwn(AllSymbols, key) && !(hasOwn(it, HIDDEN) && it[HIDDEN][key])) {\n descriptor.enumerable = true;\n }\n return descriptor;\n};\n\nvar $getOwnPropertyNames = function getOwnPropertyNames(O) {\n var names = nativeGetOwnPropertyNames(toIndexedObject(O));\n var result = [];\n $forEach(names, function (key) {\n if (!hasOwn(AllSymbols, key) && !hasOwn(hiddenKeys, key)) push(result, key);\n });\n return result;\n};\n\nvar $getOwnPropertySymbols = function (O) {\n var IS_OBJECT_PROTOTYPE = O === ObjectPrototype;\n var names = nativeGetOwnPropertyNames(IS_OBJECT_PROTOTYPE ? ObjectPrototypeSymbols : toIndexedObject(O));\n var result = [];\n $forEach(names, function (key) {\n if (hasOwn(AllSymbols, key) && (!IS_OBJECT_PROTOTYPE || hasOwn(ObjectPrototype, key))) {\n push(result, AllSymbols[key]);\n }\n });\n return result;\n};\n\n// `Symbol` constructor\n// https://tc39.es/ecma262/#sec-symbol-constructor\nif (!NATIVE_SYMBOL) {\n $Symbol = function Symbol() {\n if (isPrototypeOf(SymbolPrototype, this)) throw new TypeError('Symbol is not a constructor');\n var description = !arguments.length || arguments[0] === undefined ? undefined : $toString(arguments[0]);\n var tag = uid(description);\n var setter = function (value) {\n var $this = this === undefined ? globalThis : this;\n if ($this === ObjectPrototype) call(setter, ObjectPrototypeSymbols, value);\n if (hasOwn($this, HIDDEN) && hasOwn($this[HIDDEN], tag)) $this[HIDDEN][tag] = false;\n var descriptor = createPropertyDescriptor(1, value);\n try {\n setSymbolDescriptor($this, tag, descriptor);\n } catch (error) {\n if (!(error instanceof RangeError)) throw error;\n fallbackDefineProperty($this, tag, descriptor);\n }\n };\n if (DESCRIPTORS && USE_SETTER) setSymbolDescriptor(ObjectPrototype, tag, { configurable: true, set: setter });\n return wrap(tag, description);\n };\n\n SymbolPrototype = $Symbol[PROTOTYPE];\n\n defineBuiltIn(SymbolPrototype, 'toString', function toString() {\n return getInternalState(this).tag;\n });\n\n defineBuiltIn($Symbol, 'withoutSetter', function (description) {\n return wrap(uid(description), description);\n });\n\n propertyIsEnumerableModule.f = $propertyIsEnumerable;\n definePropertyModule.f = $defineProperty;\n definePropertiesModule.f = $defineProperties;\n getOwnPropertyDescriptorModule.f = $getOwnPropertyDescriptor;\n getOwnPropertyNamesModule.f = getOwnPropertyNamesExternal.f = $getOwnPropertyNames;\n getOwnPropertySymbolsModule.f = $getOwnPropertySymbols;\n\n wrappedWellKnownSymbolModule.f = function (name) {\n return wrap(wellKnownSymbol(name), name);\n };\n\n if (DESCRIPTORS) {\n // https://github.com/tc39/proposal-Symbol-description\n defineBuiltInAccessor(SymbolPrototype, 'description', {\n configurable: true,\n get: function description() {\n return getInternalState(this).description;\n }\n });\n if (!IS_PURE) {\n defineBuiltIn(ObjectPrototype, 'propertyIsEnumerable', $propertyIsEnumerable, { unsafe: true });\n }\n }\n}\n\n$({ global: true, constructor: true, wrap: true, forced: !NATIVE_SYMBOL, sham: !NATIVE_SYMBOL }, {\n Symbol: $Symbol\n});\n\n$forEach(objectKeys(WellKnownSymbolsStore), function (name) {\n defineWellKnownSymbol(name);\n});\n\n$({ target: SYMBOL, stat: true, forced: !NATIVE_SYMBOL }, {\n useSetter: function () { USE_SETTER = true; },\n useSimple: function () { USE_SETTER = false; }\n});\n\n$({ target: 'Object', stat: true, forced: !NATIVE_SYMBOL, sham: !DESCRIPTORS }, {\n // `Object.create` method\n // https://tc39.es/ecma262/#sec-object.create\n create: $create,\n // `Object.defineProperty` method\n // https://tc39.es/ecma262/#sec-object.defineproperty\n defineProperty: $defineProperty,\n // `Object.defineProperties` method\n // https://tc39.es/ecma262/#sec-object.defineproperties\n defineProperties: $defineProperties,\n // `Object.getOwnPropertyDescriptor` method\n // https://tc39.es/ecma262/#sec-object.getownpropertydescriptors\n getOwnPropertyDescriptor: $getOwnPropertyDescriptor\n});\n\n$({ target: 'Object', stat: true, forced: !NATIVE_SYMBOL }, {\n // `Object.getOwnPropertyNames` method\n // https://tc39.es/ecma262/#sec-object.getownpropertynames\n getOwnPropertyNames: $getOwnPropertyNames\n});\n\n// `Symbol.prototype[@@toPrimitive]` method\n// https://tc39.es/ecma262/#sec-symbol.prototype-@@toprimitive\ndefineSymbolToPrimitive();\n\n// `Symbol.prototype[@@toStringTag]` property\n// https://tc39.es/ecma262/#sec-symbol.prototype-@@tostringtag\nsetToStringTag($Symbol, SYMBOL);\n\nhiddenKeys[HIDDEN] = true;\n","'use strict';\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\n\n/* eslint-disable es/no-symbol -- safe */\nmodule.exports = NATIVE_SYMBOL && !!Symbol['for'] && !!Symbol.keyFor;\n","'use strict';\nvar $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar hasOwn = require('../internals/has-own-property');\nvar toString = require('../internals/to-string');\nvar shared = require('../internals/shared');\nvar NATIVE_SYMBOL_REGISTRY = require('../internals/symbol-registry-detection');\n\nvar StringToSymbolRegistry = shared('string-to-symbol-registry');\nvar SymbolToStringRegistry = shared('symbol-to-string-registry');\n\n// `Symbol.for` method\n// https://tc39.es/ecma262/#sec-symbol.for\n$({ target: 'Symbol', stat: true, forced: !NATIVE_SYMBOL_REGISTRY }, {\n 'for': function (key) {\n var string = toString(key);\n if (hasOwn(StringToSymbolRegistry, string)) return StringToSymbolRegistry[string];\n var symbol = getBuiltIn('Symbol')(string);\n StringToSymbolRegistry[string] = symbol;\n SymbolToStringRegistry[symbol] = string;\n return symbol;\n }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar hasOwn = require('../internals/has-own-property');\nvar isSymbol = require('../internals/is-symbol');\nvar tryToString = require('../internals/try-to-string');\nvar shared = require('../internals/shared');\nvar NATIVE_SYMBOL_REGISTRY = require('../internals/symbol-registry-detection');\n\nvar SymbolToStringRegistry = shared('symbol-to-string-registry');\n\n// `Symbol.keyFor` method\n// https://tc39.es/ecma262/#sec-symbol.keyfor\n$({ target: 'Symbol', stat: true, forced: !NATIVE_SYMBOL_REGISTRY }, {\n keyFor: function keyFor(sym) {\n if (!isSymbol(sym)) throw new TypeError(tryToString(sym) + ' is not a symbol');\n if (hasOwn(SymbolToStringRegistry, sym)) return SymbolToStringRegistry[sym];\n }\n});\n","'use strict';\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar FunctionPrototype = Function.prototype;\nvar apply = FunctionPrototype.apply;\nvar call = FunctionPrototype.call;\n\n// eslint-disable-next-line es/no-reflect -- safe\nmodule.exports = typeof Reflect == 'object' && Reflect.apply || (NATIVE_BIND ? call.bind(apply) : function () {\n return call.apply(apply, arguments);\n});\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isArray = require('../internals/is-array');\nvar isCallable = require('../internals/is-callable');\nvar classof = require('../internals/classof-raw');\nvar toString = require('../internals/to-string');\n\nvar push = uncurryThis([].push);\n\nmodule.exports = function (replacer) {\n if (isCallable(replacer)) return replacer;\n if (!isArray(replacer)) return;\n var rawLength = replacer.length;\n var keys = [];\n for (var i = 0; i < rawLength; i++) {\n var element = replacer[i];\n if (typeof element == 'string') push(keys, element);\n else if (typeof element == 'number' || classof(element) === 'Number' || classof(element) === 'String') push(keys, toString(element));\n }\n var keysLength = keys.length;\n var root = true;\n return function (key, value) {\n if (root) {\n root = false;\n return value;\n }\n if (isArray(this)) return value;\n for (var j = 0; j < keysLength; j++) if (keys[j] === key) return value;\n };\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar apply = require('../internals/function-apply');\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar isSymbol = require('../internals/is-symbol');\nvar arraySlice = require('../internals/array-slice');\nvar getReplacerFunction = require('../internals/get-json-replacer-function');\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\n\nvar $String = String;\nvar $stringify = getBuiltIn('JSON', 'stringify');\nvar exec = uncurryThis(/./.exec);\nvar charAt = uncurryThis(''.charAt);\nvar charCodeAt = uncurryThis(''.charCodeAt);\nvar replace = uncurryThis(''.replace);\nvar numberToString = uncurryThis(1.0.toString);\n\nvar tester = /[\\uD800-\\uDFFF]/g;\nvar low = /^[\\uD800-\\uDBFF]$/;\nvar hi = /^[\\uDC00-\\uDFFF]$/;\n\nvar WRONG_SYMBOLS_CONVERSION = !NATIVE_SYMBOL || fails(function () {\n var symbol = getBuiltIn('Symbol')('stringify detection');\n // MS Edge converts symbol values to JSON as {}\n return $stringify([symbol]) !== '[null]'\n // WebKit converts symbol values to JSON as null\n || $stringify({ a: symbol }) !== '{}'\n // V8 throws on boxed symbols\n || $stringify(Object(symbol)) !== '{}';\n});\n\n// https://github.com/tc39/proposal-well-formed-stringify\nvar ILL_FORMED_UNICODE = fails(function () {\n return $stringify('\\uDF06\\uD834') !== '\"\\\\udf06\\\\ud834\"'\n || $stringify('\\uDEAD') !== '\"\\\\udead\"';\n});\n\nvar stringifyWithSymbolsFix = function (it, replacer) {\n var args = arraySlice(arguments);\n var $replacer = getReplacerFunction(replacer);\n if (!isCallable($replacer) && (it === undefined || isSymbol(it))) return; // IE8 returns string on undefined\n args[1] = function (key, value) {\n // some old implementations (like WebKit) could pass numbers as keys\n if (isCallable($replacer)) value = call($replacer, this, $String(key), value);\n if (!isSymbol(value)) return value;\n };\n return apply($stringify, null, args);\n};\n\nvar fixIllFormed = function (match, offset, string) {\n var prev = charAt(string, offset - 1);\n var next = charAt(string, offset + 1);\n if ((exec(low, match) && !exec(hi, next)) || (exec(hi, match) && !exec(low, prev))) {\n return '\\\\u' + numberToString(charCodeAt(match, 0), 16);\n } return match;\n};\n\nif ($stringify) {\n // `JSON.stringify` method\n // https://tc39.es/ecma262/#sec-json.stringify\n $({ target: 'JSON', stat: true, arity: 3, forced: WRONG_SYMBOLS_CONVERSION || ILL_FORMED_UNICODE }, {\n // eslint-disable-next-line no-unused-vars -- required for `.length`\n stringify: function stringify(it, replacer, space) {\n var args = arraySlice(arguments);\n var result = apply(WRONG_SYMBOLS_CONVERSION ? stringifyWithSymbolsFix : $stringify, null, args);\n return ILL_FORMED_UNICODE && typeof result == 'string' ? replace(result, tester, fixIllFormed) : result;\n }\n });\n}\n","'use strict';\nvar $ = require('../internals/export');\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\nvar fails = require('../internals/fails');\nvar getOwnPropertySymbolsModule = require('../internals/object-get-own-property-symbols');\nvar toObject = require('../internals/to-object');\n\n// V8 ~ Chrome 38 and 39 `Object.getOwnPropertySymbols` fails on primitives\n// https://bugs.chromium.org/p/v8/issues/detail?id=3443\nvar FORCED = !NATIVE_SYMBOL || fails(function () { getOwnPropertySymbolsModule.f(1); });\n\n// `Object.getOwnPropertySymbols` method\n// https://tc39.es/ecma262/#sec-object.getownpropertysymbols\n$({ target: 'Object', stat: true, forced: FORCED }, {\n getOwnPropertySymbols: function getOwnPropertySymbols(it) {\n var $getOwnPropertySymbols = getOwnPropertySymbolsModule.f;\n return $getOwnPropertySymbols ? $getOwnPropertySymbols(toObject(it)) : [];\n }\n});\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.asyncIterator` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.asynciterator\ndefineWellKnownSymbol('asyncIterator');\n","// `Symbol.prototype.description` getter\n// https://tc39.es/ecma262/#sec-symbol.prototype.description\n'use strict';\nvar $ = require('../internals/export');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar globalThis = require('../internals/global-this');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar hasOwn = require('../internals/has-own-property');\nvar isCallable = require('../internals/is-callable');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar toString = require('../internals/to-string');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar copyConstructorProperties = require('../internals/copy-constructor-properties');\n\nvar NativeSymbol = globalThis.Symbol;\nvar SymbolPrototype = NativeSymbol && NativeSymbol.prototype;\n\nif (DESCRIPTORS && isCallable(NativeSymbol) && (!('description' in SymbolPrototype) ||\n // Safari 12 bug\n NativeSymbol().description !== undefined\n)) {\n var EmptyStringDescriptionStore = {};\n // wrap Symbol constructor for correct work with undefined description\n var SymbolWrapper = function Symbol() {\n var description = arguments.length < 1 || arguments[0] === undefined ? undefined : toString(arguments[0]);\n var result = isPrototypeOf(SymbolPrototype, this)\n // eslint-disable-next-line sonarjs/inconsistent-function-call -- ok\n ? new NativeSymbol(description)\n // in Edge 13, String(Symbol(undefined)) === 'Symbol(undefined)'\n : description === undefined ? NativeSymbol() : NativeSymbol(description);\n if (description === '') EmptyStringDescriptionStore[result] = true;\n return result;\n };\n\n copyConstructorProperties(SymbolWrapper, NativeSymbol);\n SymbolWrapper.prototype = SymbolPrototype;\n SymbolPrototype.constructor = SymbolWrapper;\n\n var NATIVE_SYMBOL = String(NativeSymbol('description detection')) === 'Symbol(description detection)';\n var thisSymbolValue = uncurryThis(SymbolPrototype.valueOf);\n var symbolDescriptiveString = uncurryThis(SymbolPrototype.toString);\n var regexp = /^Symbol\\((.*)\\)[^)]+$/;\n var replace = uncurryThis(''.replace);\n var stringSlice = uncurryThis(''.slice);\n\n defineBuiltInAccessor(SymbolPrototype, 'description', {\n configurable: true,\n get: function description() {\n var symbol = thisSymbolValue(this);\n if (hasOwn(EmptyStringDescriptionStore, symbol)) return '';\n var string = symbolDescriptiveString(symbol);\n var desc = NATIVE_SYMBOL ? stringSlice(string, 7, -1) : replace(string, regexp, '$1');\n return desc === '' ? undefined : desc;\n }\n });\n\n $({ global: true, constructor: true, forced: true }, {\n Symbol: SymbolWrapper\n });\n}\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.hasInstance` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.hasinstance\ndefineWellKnownSymbol('hasInstance');\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.isConcatSpreadable` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.isconcatspreadable\ndefineWellKnownSymbol('isConcatSpreadable');\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.iterator` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.iterator\ndefineWellKnownSymbol('iterator');\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.match` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.match\ndefineWellKnownSymbol('match');\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.matchAll` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.matchall\ndefineWellKnownSymbol('matchAll');\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.replace` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.replace\ndefineWellKnownSymbol('replace');\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.search` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.search\ndefineWellKnownSymbol('search');\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.species` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.species\ndefineWellKnownSymbol('species');\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.split` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.split\ndefineWellKnownSymbol('split');\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\nvar defineSymbolToPrimitive = require('../internals/symbol-define-to-primitive');\n\n// `Symbol.toPrimitive` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.toprimitive\ndefineWellKnownSymbol('toPrimitive');\n\n// `Symbol.prototype[@@toPrimitive]` method\n// https://tc39.es/ecma262/#sec-symbol.prototype-@@toprimitive\ndefineSymbolToPrimitive();\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\nvar setToStringTag = require('../internals/set-to-string-tag');\n\n// `Symbol.toStringTag` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.tostringtag\ndefineWellKnownSymbol('toStringTag');\n\n// `Symbol.prototype[@@toStringTag]` property\n// https://tc39.es/ecma262/#sec-symbol.prototype-@@tostringtag\nsetToStringTag(getBuiltIn('Symbol'), 'Symbol');\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.unscopables` well-known symbol\n// https://tc39.es/ecma262/#sec-symbol.unscopables\ndefineWellKnownSymbol('unscopables');\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar setToStringTag = require('../internals/set-to-string-tag');\n\n// JSON[@@toStringTag] property\n// https://tc39.es/ecma262/#sec-json-@@tostringtag\nsetToStringTag(globalThis.JSON, 'JSON', true);\n","'use strict';\nvar setToStringTag = require('../internals/set-to-string-tag');\n\n// Math[@@toStringTag] property\n// https://tc39.es/ecma262/#sec-math-@@tostringtag\nsetToStringTag(Math, 'Math', true);\n","'use strict';\nvar $ = require('../internals/export');\nvar globalThis = require('../internals/global-this');\nvar setToStringTag = require('../internals/set-to-string-tag');\n\n$({ global: true }, { Reflect: {} });\n\n// Reflect[@@toStringTag] property\n// https://tc39.es/ecma262/#sec-reflect-@@tostringtag\nsetToStringTag(globalThis.Reflect, 'Reflect', true);\n","'use strict';\nrequire('../../modules/es.array.concat');\nrequire('../../modules/es.object.to-string');\nrequire('../../modules/es.symbol');\nrequire('../../modules/es.symbol.async-iterator');\nrequire('../../modules/es.symbol.description');\nrequire('../../modules/es.symbol.has-instance');\nrequire('../../modules/es.symbol.is-concat-spreadable');\nrequire('../../modules/es.symbol.iterator');\nrequire('../../modules/es.symbol.match');\nrequire('../../modules/es.symbol.match-all');\nrequire('../../modules/es.symbol.replace');\nrequire('../../modules/es.symbol.search');\nrequire('../../modules/es.symbol.species');\nrequire('../../modules/es.symbol.split');\nrequire('../../modules/es.symbol.to-primitive');\nrequire('../../modules/es.symbol.to-string-tag');\nrequire('../../modules/es.symbol.unscopables');\nrequire('../../modules/es.json.to-string-tag');\nrequire('../../modules/es.math.to-string-tag');\nrequire('../../modules/es.reflect.to-string-tag');\nvar path = require('../../internals/path');\n\nmodule.exports = path.Symbol;\n","'use strict';\n// iterable DOM collections\n// flag - `iterable` interface - 'entries', 'keys', 'values', 'forEach' methods\nmodule.exports = {\n CSSRuleList: 0,\n CSSStyleDeclaration: 0,\n CSSValueList: 0,\n ClientRectList: 0,\n DOMRectList: 0,\n DOMStringList: 0,\n DOMTokenList: 1,\n DataTransferItemList: 0,\n FileList: 0,\n HTMLAllCollection: 0,\n HTMLCollection: 0,\n HTMLFormElement: 0,\n HTMLSelectElement: 0,\n MediaList: 0,\n MimeTypeArray: 0,\n NamedNodeMap: 0,\n NodeList: 1,\n PaintRequestList: 0,\n Plugin: 0,\n PluginArray: 0,\n SVGLengthList: 0,\n SVGNumberList: 0,\n SVGPathSegList: 0,\n SVGPointList: 0,\n SVGStringList: 0,\n SVGTransformList: 0,\n SourceBufferList: 0,\n StyleSheetList: 0,\n TextTrackCueList: 0,\n TextTrackList: 0,\n TouchList: 0\n};\n","'use strict';\n// in old WebKit versions, `element.classList` is not an instance of global `DOMTokenList`\nvar documentCreateElement = require('../internals/document-create-element');\n\nvar classList = documentCreateElement('span').classList;\nvar DOMTokenListPrototype = classList && classList.constructor && classList.constructor.prototype;\n\nmodule.exports = DOMTokenListPrototype === Object.prototype ? undefined : DOMTokenListPrototype;\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar create = require('../internals/object-create');\nvar defineProperty = require('../internals/object-define-property').f;\n\nvar UNSCOPABLES = wellKnownSymbol('unscopables');\nvar ArrayPrototype = Array.prototype;\n\n// Array.prototype[@@unscopables]\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\nif (ArrayPrototype[UNSCOPABLES] === undefined) {\n defineProperty(ArrayPrototype, UNSCOPABLES, {\n configurable: true,\n value: create(null)\n });\n}\n\n// add a key to Array.prototype[@@unscopables]\nmodule.exports = function (key) {\n ArrayPrototype[UNSCOPABLES][key] = true;\n};\n","'use strict';\nmodule.exports = {};\n","'use strict';\nvar fails = require('../internals/fails');\n\nmodule.exports = !fails(function () {\n function F() { /* empty */ }\n F.prototype.constructor = null;\n // eslint-disable-next-line es/no-object-getprototypeof -- required for testing\n return Object.getPrototypeOf(new F()) !== F.prototype;\n});\n","'use strict';\nvar hasOwn = require('../internals/has-own-property');\nvar isCallable = require('../internals/is-callable');\nvar toObject = require('../internals/to-object');\nvar sharedKey = require('../internals/shared-key');\nvar CORRECT_PROTOTYPE_GETTER = require('../internals/correct-prototype-getter');\n\nvar IE_PROTO = sharedKey('IE_PROTO');\nvar $Object = Object;\nvar ObjectPrototype = $Object.prototype;\n\n// `Object.getPrototypeOf` method\n// https://tc39.es/ecma262/#sec-object.getprototypeof\n// eslint-disable-next-line es/no-object-getprototypeof -- safe\nmodule.exports = CORRECT_PROTOTYPE_GETTER ? $Object.getPrototypeOf : function (O) {\n var object = toObject(O);\n if (hasOwn(object, IE_PROTO)) return object[IE_PROTO];\n var constructor = object.constructor;\n if (isCallable(constructor) && object instanceof constructor) {\n return constructor.prototype;\n } return object instanceof $Object ? ObjectPrototype : null;\n};\n","'use strict';\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\nvar create = require('../internals/object-create');\nvar getPrototypeOf = require('../internals/object-get-prototype-of');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar IS_PURE = require('../internals/is-pure');\n\nvar ITERATOR = wellKnownSymbol('iterator');\nvar BUGGY_SAFARI_ITERATORS = false;\n\n// `%IteratorPrototype%` object\n// https://tc39.es/ecma262/#sec-%iteratorprototype%-object\nvar IteratorPrototype, PrototypeOfArrayIteratorPrototype, arrayIterator;\n\n/* eslint-disable es/no-array-prototype-keys -- safe */\nif ([].keys) {\n arrayIterator = [].keys();\n // Safari 8 has buggy iterators w/o `next`\n if (!('next' in arrayIterator)) BUGGY_SAFARI_ITERATORS = true;\n else {\n PrototypeOfArrayIteratorPrototype = getPrototypeOf(getPrototypeOf(arrayIterator));\n if (PrototypeOfArrayIteratorPrototype !== Object.prototype) IteratorPrototype = PrototypeOfArrayIteratorPrototype;\n }\n}\n\nvar NEW_ITERATOR_PROTOTYPE = !isObject(IteratorPrototype) || fails(function () {\n var test = {};\n // FF44- legacy iterators case\n return IteratorPrototype[ITERATOR].call(test) !== test;\n});\n\nif (NEW_ITERATOR_PROTOTYPE) IteratorPrototype = {};\nelse if (IS_PURE) IteratorPrototype = create(IteratorPrototype);\n\n// `%IteratorPrototype%[@@iterator]()` method\n// https://tc39.es/ecma262/#sec-%iteratorprototype%-@@iterator\nif (!isCallable(IteratorPrototype[ITERATOR])) {\n defineBuiltIn(IteratorPrototype, ITERATOR, function () {\n return this;\n });\n}\n\nmodule.exports = {\n IteratorPrototype: IteratorPrototype,\n BUGGY_SAFARI_ITERATORS: BUGGY_SAFARI_ITERATORS\n};\n","'use strict';\nvar IteratorPrototype = require('../internals/iterators-core').IteratorPrototype;\nvar create = require('../internals/object-create');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\nvar setToStringTag = require('../internals/set-to-string-tag');\nvar Iterators = require('../internals/iterators');\n\nvar returnThis = function () { return this; };\n\nmodule.exports = function (IteratorConstructor, NAME, next, ENUMERABLE_NEXT) {\n var TO_STRING_TAG = NAME + ' Iterator';\n IteratorConstructor.prototype = create(IteratorPrototype, { next: createPropertyDescriptor(+!ENUMERABLE_NEXT, next) });\n setToStringTag(IteratorConstructor, TO_STRING_TAG, false, true);\n Iterators[TO_STRING_TAG] = returnThis;\n return IteratorConstructor;\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar aCallable = require('../internals/a-callable');\n\nmodule.exports = function (object, key, method) {\n try {\n // eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\n return uncurryThis(aCallable(Object.getOwnPropertyDescriptor(object, key)[method]));\n } catch (error) { /* empty */ }\n};\n","'use strict';\nvar isObject = require('../internals/is-object');\n\nmodule.exports = function (argument) {\n return isObject(argument) || argument === null;\n};\n","'use strict';\nvar isPossiblePrototype = require('../internals/is-possible-prototype');\n\nvar $String = String;\nvar $TypeError = TypeError;\n\nmodule.exports = function (argument) {\n if (isPossiblePrototype(argument)) return argument;\n throw new $TypeError(\"Can't set \" + $String(argument) + ' as a prototype');\n};\n","'use strict';\n/* eslint-disable no-proto -- safe */\nvar uncurryThisAccessor = require('../internals/function-uncurry-this-accessor');\nvar isObject = require('../internals/is-object');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\nvar aPossiblePrototype = require('../internals/a-possible-prototype');\n\n// `Object.setPrototypeOf` method\n// https://tc39.es/ecma262/#sec-object.setprototypeof\n// Works with __proto__ only. Old v8 can't work with null proto objects.\n// eslint-disable-next-line es/no-object-setprototypeof -- safe\nmodule.exports = Object.setPrototypeOf || ('__proto__' in {} ? function () {\n var CORRECT_SETTER = false;\n var test = {};\n var setter;\n try {\n setter = uncurryThisAccessor(Object.prototype, '__proto__', 'set');\n setter(test, []);\n CORRECT_SETTER = test instanceof Array;\n } catch (error) { /* empty */ }\n return function setPrototypeOf(O, proto) {\n requireObjectCoercible(O);\n aPossiblePrototype(proto);\n if (!isObject(O)) return O;\n if (CORRECT_SETTER) setter(O, proto);\n else O.__proto__ = proto;\n return O;\n };\n}() : undefined);\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar IS_PURE = require('../internals/is-pure');\nvar FunctionName = require('../internals/function-name');\nvar isCallable = require('../internals/is-callable');\nvar createIteratorConstructor = require('../internals/iterator-create-constructor');\nvar getPrototypeOf = require('../internals/object-get-prototype-of');\nvar setPrototypeOf = require('../internals/object-set-prototype-of');\nvar setToStringTag = require('../internals/set-to-string-tag');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar Iterators = require('../internals/iterators');\nvar IteratorsCore = require('../internals/iterators-core');\n\nvar PROPER_FUNCTION_NAME = FunctionName.PROPER;\nvar CONFIGURABLE_FUNCTION_NAME = FunctionName.CONFIGURABLE;\nvar IteratorPrototype = IteratorsCore.IteratorPrototype;\nvar BUGGY_SAFARI_ITERATORS = IteratorsCore.BUGGY_SAFARI_ITERATORS;\nvar ITERATOR = wellKnownSymbol('iterator');\nvar KEYS = 'keys';\nvar VALUES = 'values';\nvar ENTRIES = 'entries';\n\nvar returnThis = function () { return this; };\n\nmodule.exports = function (Iterable, NAME, IteratorConstructor, next, DEFAULT, IS_SET, FORCED) {\n createIteratorConstructor(IteratorConstructor, NAME, next);\n\n var getIterationMethod = function (KIND) {\n if (KIND === DEFAULT && defaultIterator) return defaultIterator;\n if (!BUGGY_SAFARI_ITERATORS && KIND && KIND in IterablePrototype) return IterablePrototype[KIND];\n\n switch (KIND) {\n case KEYS: return function keys() { return new IteratorConstructor(this, KIND); };\n case VALUES: return function values() { return new IteratorConstructor(this, KIND); };\n case ENTRIES: return function entries() { return new IteratorConstructor(this, KIND); };\n }\n\n return function () { return new IteratorConstructor(this); };\n };\n\n var TO_STRING_TAG = NAME + ' Iterator';\n var INCORRECT_VALUES_NAME = false;\n var IterablePrototype = Iterable.prototype;\n var nativeIterator = IterablePrototype[ITERATOR]\n || IterablePrototype['@@iterator']\n || DEFAULT && IterablePrototype[DEFAULT];\n var defaultIterator = !BUGGY_SAFARI_ITERATORS && nativeIterator || getIterationMethod(DEFAULT);\n var anyNativeIterator = NAME === 'Array' ? IterablePrototype.entries || nativeIterator : nativeIterator;\n var CurrentIteratorPrototype, methods, KEY;\n\n // fix native\n if (anyNativeIterator) {\n CurrentIteratorPrototype = getPrototypeOf(anyNativeIterator.call(new Iterable()));\n if (CurrentIteratorPrototype !== Object.prototype && CurrentIteratorPrototype.next) {\n if (!IS_PURE && getPrototypeOf(CurrentIteratorPrototype) !== IteratorPrototype) {\n if (setPrototypeOf) {\n setPrototypeOf(CurrentIteratorPrototype, IteratorPrototype);\n } else if (!isCallable(CurrentIteratorPrototype[ITERATOR])) {\n defineBuiltIn(CurrentIteratorPrototype, ITERATOR, returnThis);\n }\n }\n // Set @@toStringTag to native iterators\n setToStringTag(CurrentIteratorPrototype, TO_STRING_TAG, true, true);\n if (IS_PURE) Iterators[TO_STRING_TAG] = returnThis;\n }\n }\n\n // fix Array.prototype.{ values, @@iterator }.name in V8 / FF\n if (PROPER_FUNCTION_NAME && DEFAULT === VALUES && nativeIterator && nativeIterator.name !== VALUES) {\n if (!IS_PURE && CONFIGURABLE_FUNCTION_NAME) {\n createNonEnumerableProperty(IterablePrototype, 'name', VALUES);\n } else {\n INCORRECT_VALUES_NAME = true;\n defaultIterator = function values() { return call(nativeIterator, this); };\n }\n }\n\n // export additional methods\n if (DEFAULT) {\n methods = {\n values: getIterationMethod(VALUES),\n keys: IS_SET ? defaultIterator : getIterationMethod(KEYS),\n entries: getIterationMethod(ENTRIES)\n };\n if (FORCED) for (KEY in methods) {\n if (BUGGY_SAFARI_ITERATORS || INCORRECT_VALUES_NAME || !(KEY in IterablePrototype)) {\n defineBuiltIn(IterablePrototype, KEY, methods[KEY]);\n }\n } else $({ target: NAME, proto: true, forced: BUGGY_SAFARI_ITERATORS || INCORRECT_VALUES_NAME }, methods);\n }\n\n // define iterator\n if ((!IS_PURE || FORCED) && IterablePrototype[ITERATOR] !== defaultIterator) {\n defineBuiltIn(IterablePrototype, ITERATOR, defaultIterator, { name: DEFAULT });\n }\n Iterators[NAME] = defaultIterator;\n\n return methods;\n};\n","'use strict';\n// `CreateIterResultObject` abstract operation\n// https://tc39.es/ecma262/#sec-createiterresultobject\nmodule.exports = function (value, done) {\n return { value: value, done: done };\n};\n","'use strict';\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar addToUnscopables = require('../internals/add-to-unscopables');\nvar Iterators = require('../internals/iterators');\nvar InternalStateModule = require('../internals/internal-state');\nvar defineProperty = require('../internals/object-define-property').f;\nvar defineIterator = require('../internals/iterator-define');\nvar createIterResultObject = require('../internals/create-iter-result-object');\nvar IS_PURE = require('../internals/is-pure');\nvar DESCRIPTORS = require('../internals/descriptors');\n\nvar ARRAY_ITERATOR = 'Array Iterator';\nvar setInternalState = InternalStateModule.set;\nvar getInternalState = InternalStateModule.getterFor(ARRAY_ITERATOR);\n\n// `Array.prototype.entries` method\n// https://tc39.es/ecma262/#sec-array.prototype.entries\n// `Array.prototype.keys` method\n// https://tc39.es/ecma262/#sec-array.prototype.keys\n// `Array.prototype.values` method\n// https://tc39.es/ecma262/#sec-array.prototype.values\n// `Array.prototype[@@iterator]` method\n// https://tc39.es/ecma262/#sec-array.prototype-@@iterator\n// `CreateArrayIterator` internal method\n// https://tc39.es/ecma262/#sec-createarrayiterator\nmodule.exports = defineIterator(Array, 'Array', function (iterated, kind) {\n setInternalState(this, {\n type: ARRAY_ITERATOR,\n target: toIndexedObject(iterated), // target\n index: 0, // next index\n kind: kind // kind\n });\n// `%ArrayIteratorPrototype%.next` method\n// https://tc39.es/ecma262/#sec-%arrayiteratorprototype%.next\n}, function () {\n var state = getInternalState(this);\n var target = state.target;\n var index = state.index++;\n if (!target || index >= target.length) {\n state.target = null;\n return createIterResultObject(undefined, true);\n }\n switch (state.kind) {\n case 'keys': return createIterResultObject(index, false);\n case 'values': return createIterResultObject(target[index], false);\n } return createIterResultObject([index, target[index]], false);\n}, 'values');\n\n// argumentsList[@@iterator] is %ArrayProto_values%\n// https://tc39.es/ecma262/#sec-createunmappedargumentsobject\n// https://tc39.es/ecma262/#sec-createmappedargumentsobject\nvar values = Iterators.Arguments = Iterators.Array;\n\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\naddToUnscopables('keys');\naddToUnscopables('values');\naddToUnscopables('entries');\n\n// V8 ~ Chrome 45- bug\nif (!IS_PURE && DESCRIPTORS && values.name !== 'values') try {\n defineProperty(values, 'name', { value: 'values' });\n} catch (error) { /* empty */ }\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar DOMIterables = require('../internals/dom-iterables');\nvar DOMTokenListPrototype = require('../internals/dom-token-list-prototype');\nvar ArrayIteratorMethods = require('../modules/es.array.iterator');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar setToStringTag = require('../internals/set-to-string-tag');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar ITERATOR = wellKnownSymbol('iterator');\nvar ArrayValues = ArrayIteratorMethods.values;\n\nvar handlePrototype = function (CollectionPrototype, COLLECTION_NAME) {\n if (CollectionPrototype) {\n // some Chrome versions have non-configurable methods on DOMTokenList\n if (CollectionPrototype[ITERATOR] !== ArrayValues) try {\n createNonEnumerableProperty(CollectionPrototype, ITERATOR, ArrayValues);\n } catch (error) {\n CollectionPrototype[ITERATOR] = ArrayValues;\n }\n setToStringTag(CollectionPrototype, COLLECTION_NAME, true);\n if (DOMIterables[COLLECTION_NAME]) for (var METHOD_NAME in ArrayIteratorMethods) {\n // some Chrome versions have non-configurable methods on DOMTokenList\n if (CollectionPrototype[METHOD_NAME] !== ArrayIteratorMethods[METHOD_NAME]) try {\n createNonEnumerableProperty(CollectionPrototype, METHOD_NAME, ArrayIteratorMethods[METHOD_NAME]);\n } catch (error) {\n CollectionPrototype[METHOD_NAME] = ArrayIteratorMethods[METHOD_NAME];\n }\n }\n }\n};\n\nfor (var COLLECTION_NAME in DOMIterables) {\n handlePrototype(globalThis[COLLECTION_NAME] && globalThis[COLLECTION_NAME].prototype, COLLECTION_NAME);\n}\n\nhandlePrototype(DOMTokenListPrototype, 'DOMTokenList');\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar defineProperty = require('../internals/object-define-property').f;\n\nvar METADATA = wellKnownSymbol('metadata');\nvar FunctionPrototype = Function.prototype;\n\n// Function.prototype[@@metadata]\n// https://github.com/tc39/proposal-decorator-metadata\nif (FunctionPrototype[METADATA] === undefined) {\n defineProperty(FunctionPrototype, METADATA, {\n value: null\n });\n}\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\nvar defineProperty = require('../internals/object-define-property').f;\nvar getOwnPropertyDescriptor = require('../internals/object-get-own-property-descriptor').f;\n\nvar Symbol = globalThis.Symbol;\n\n// `Symbol.asyncDispose` well-known symbol\n// https://github.com/tc39/proposal-async-explicit-resource-management\ndefineWellKnownSymbol('asyncDispose');\n\nif (Symbol) {\n var descriptor = getOwnPropertyDescriptor(Symbol, 'asyncDispose');\n // workaround of NodeJS 20.4 bug\n // https://github.com/nodejs/node/issues/48699\n // and incorrect descriptor from some transpilers and userland helpers\n if (descriptor.enumerable && descriptor.configurable && descriptor.writable) {\n defineProperty(Symbol, 'asyncDispose', { value: descriptor.value, enumerable: false, configurable: false, writable: false });\n }\n}\n","'use strict';\nvar globalThis = require('../internals/global-this');\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\nvar defineProperty = require('../internals/object-define-property').f;\nvar getOwnPropertyDescriptor = require('../internals/object-get-own-property-descriptor').f;\n\nvar Symbol = globalThis.Symbol;\n\n// `Symbol.dispose` well-known symbol\n// https://github.com/tc39/proposal-explicit-resource-management\ndefineWellKnownSymbol('dispose');\n\nif (Symbol) {\n var descriptor = getOwnPropertyDescriptor(Symbol, 'dispose');\n // workaround of NodeJS 20.4 bug\n // https://github.com/nodejs/node/issues/48699\n // and incorrect descriptor from some transpilers and userland helpers\n if (descriptor.enumerable && descriptor.configurable && descriptor.writable) {\n defineProperty(Symbol, 'dispose', { value: descriptor.value, enumerable: false, configurable: false, writable: false });\n }\n}\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.metadata` well-known symbol\n// https://github.com/tc39/proposal-decorators\ndefineWellKnownSymbol('metadata');\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar Symbol = getBuiltIn('Symbol');\nvar keyFor = Symbol.keyFor;\nvar thisSymbolValue = uncurryThis(Symbol.prototype.valueOf);\n\n// `Symbol.isRegisteredSymbol` method\n// https://tc39.es/proposal-symbol-predicates/#sec-symbol-isregisteredsymbol\nmodule.exports = Symbol.isRegisteredSymbol || function isRegisteredSymbol(value) {\n try {\n return keyFor(thisSymbolValue(value)) !== undefined;\n } catch (error) {\n return false;\n }\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar isRegisteredSymbol = require('../internals/symbol-is-registered');\n\n// `Symbol.isRegisteredSymbol` method\n// https://tc39.es/proposal-symbol-predicates/#sec-symbol-isregisteredsymbol\n$({ target: 'Symbol', stat: true }, {\n isRegisteredSymbol: isRegisteredSymbol\n});\n","'use strict';\nvar shared = require('../internals/shared');\nvar getBuiltIn = require('../internals/get-built-in');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isSymbol = require('../internals/is-symbol');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar Symbol = getBuiltIn('Symbol');\nvar $isWellKnownSymbol = Symbol.isWellKnownSymbol;\nvar getOwnPropertyNames = getBuiltIn('Object', 'getOwnPropertyNames');\nvar thisSymbolValue = uncurryThis(Symbol.prototype.valueOf);\nvar WellKnownSymbolsStore = shared('wks');\n\nfor (var i = 0, symbolKeys = getOwnPropertyNames(Symbol), symbolKeysLength = symbolKeys.length; i < symbolKeysLength; i++) {\n // some old engines throws on access to some keys like `arguments` or `caller`\n try {\n var symbolKey = symbolKeys[i];\n if (isSymbol(Symbol[symbolKey])) wellKnownSymbol(symbolKey);\n } catch (error) { /* empty */ }\n}\n\n// `Symbol.isWellKnownSymbol` method\n// https://tc39.es/proposal-symbol-predicates/#sec-symbol-iswellknownsymbol\n// We should patch it for newly added well-known symbols. If it's not required, this module just will not be injected\nmodule.exports = function isWellKnownSymbol(value) {\n if ($isWellKnownSymbol && $isWellKnownSymbol(value)) return true;\n try {\n var symbol = thisSymbolValue(value);\n for (var j = 0, keys = getOwnPropertyNames(WellKnownSymbolsStore), keysLength = keys.length; j < keysLength; j++) {\n // eslint-disable-next-line eqeqeq -- polyfilled symbols case\n if (WellKnownSymbolsStore[keys[j]] == symbol) return true;\n }\n } catch (error) { /* empty */ }\n return false;\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar isWellKnownSymbol = require('../internals/symbol-is-well-known');\n\n// `Symbol.isWellKnownSymbol` method\n// https://tc39.es/proposal-symbol-predicates/#sec-symbol-iswellknownsymbol\n// We should patch it for newly added well-known symbols. If it's not required, this module just will not be injected\n$({ target: 'Symbol', stat: true, forced: true }, {\n isWellKnownSymbol: isWellKnownSymbol\n});\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.customMatcher` well-known symbol\n// https://github.com/tc39/proposal-pattern-matching\ndefineWellKnownSymbol('customMatcher');\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.observable` well-known symbol\n// https://github.com/tc39/proposal-observable\ndefineWellKnownSymbol('observable');\n","'use strict';\nvar $ = require('../internals/export');\nvar isRegisteredSymbol = require('../internals/symbol-is-registered');\n\n// `Symbol.isRegistered` method\n// obsolete version of https://tc39.es/proposal-symbol-predicates/#sec-symbol-isregisteredsymbol\n$({ target: 'Symbol', stat: true, name: 'isRegisteredSymbol' }, {\n isRegistered: isRegisteredSymbol\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar isWellKnownSymbol = require('../internals/symbol-is-well-known');\n\n// `Symbol.isWellKnown` method\n// obsolete version of https://tc39.es/proposal-symbol-predicates/#sec-symbol-iswellknownsymbol\n// We should patch it for newly added well-known symbols. If it's not required, this module just will not be injected\n$({ target: 'Symbol', stat: true, name: 'isWellKnownSymbol', forced: true }, {\n isWellKnown: isWellKnownSymbol\n});\n","'use strict';\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.matcher` well-known symbol\n// https://github.com/tc39/proposal-pattern-matching\ndefineWellKnownSymbol('matcher');\n","'use strict';\n// TODO: Remove from `core-js@4`\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.metadataKey` well-known symbol\n// https://github.com/tc39/proposal-decorator-metadata\ndefineWellKnownSymbol('metadataKey');\n","'use strict';\n// TODO: remove from `core-js@4`\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\n// `Symbol.patternMatch` well-known symbol\n// https://github.com/tc39/proposal-pattern-matching\ndefineWellKnownSymbol('patternMatch');\n","'use strict';\n// TODO: remove from `core-js@4`\nvar defineWellKnownSymbol = require('../internals/well-known-symbol-define');\n\ndefineWellKnownSymbol('replaceAll');\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\nvar toString = require('../internals/to-string');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nvar charAt = uncurryThis(''.charAt);\nvar charCodeAt = uncurryThis(''.charCodeAt);\nvar stringSlice = uncurryThis(''.slice);\n\nvar createMethod = function (CONVERT_TO_STRING) {\n return function ($this, pos) {\n var S = toString(requireObjectCoercible($this));\n var position = toIntegerOrInfinity(pos);\n var size = S.length;\n var first, second;\n if (position < 0 || position >= size) return CONVERT_TO_STRING ? '' : undefined;\n first = charCodeAt(S, position);\n return first < 0xD800 || first > 0xDBFF || position + 1 === size\n || (second = charCodeAt(S, position + 1)) < 0xDC00 || second > 0xDFFF\n ? CONVERT_TO_STRING\n ? charAt(S, position)\n : first\n : CONVERT_TO_STRING\n ? stringSlice(S, position, position + 2)\n : (first - 0xD800 << 10) + (second - 0xDC00) + 0x10000;\n };\n};\n\nmodule.exports = {\n // `String.prototype.codePointAt` method\n // https://tc39.es/ecma262/#sec-string.prototype.codepointat\n codeAt: createMethod(false),\n // `String.prototype.at` method\n // https://github.com/mathiasbynens/String.prototype.at\n charAt: createMethod(true)\n};\n","'use strict';\nvar charAt = require('../internals/string-multibyte').charAt;\nvar toString = require('../internals/to-string');\nvar InternalStateModule = require('../internals/internal-state');\nvar defineIterator = require('../internals/iterator-define');\nvar createIterResultObject = require('../internals/create-iter-result-object');\n\nvar STRING_ITERATOR = 'String Iterator';\nvar setInternalState = InternalStateModule.set;\nvar getInternalState = InternalStateModule.getterFor(STRING_ITERATOR);\n\n// `String.prototype[@@iterator]` method\n// https://tc39.es/ecma262/#sec-string.prototype-@@iterator\ndefineIterator(String, 'String', function (iterated) {\n setInternalState(this, {\n type: STRING_ITERATOR,\n string: toString(iterated),\n index: 0\n });\n// `%StringIteratorPrototype%.next` method\n// https://tc39.es/ecma262/#sec-%stringiteratorprototype%.next\n}, function next() {\n var state = getInternalState(this);\n var string = state.string;\n var index = state.index;\n var point;\n if (index >= string.length) return createIterResultObject(undefined, true);\n point = charAt(string, index);\n state.index += point.length;\n return createIterResultObject(point, false);\n});\n","'use strict';\nvar call = require('../internals/function-call');\nvar anObject = require('../internals/an-object');\nvar getMethod = require('../internals/get-method');\n\nmodule.exports = function (iterator, kind, value) {\n var innerResult, innerError;\n anObject(iterator);\n try {\n innerResult = getMethod(iterator, 'return');\n if (!innerResult) {\n if (kind === 'throw') throw value;\n return value;\n }\n innerResult = call(innerResult, iterator);\n } catch (error) {\n innerError = true;\n innerResult = error;\n }\n if (kind === 'throw') throw value;\n if (innerError) throw innerResult;\n anObject(innerResult);\n return value;\n};\n","'use strict';\nvar anObject = require('../internals/an-object');\nvar iteratorClose = require('../internals/iterator-close');\n\n// call something on iterator step with safe closing on error\nmodule.exports = function (iterator, fn, value, ENTRIES) {\n try {\n return ENTRIES ? fn(anObject(value)[0], value[1]) : fn(value);\n } catch (error) {\n iteratorClose(iterator, 'throw', error);\n }\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar Iterators = require('../internals/iterators');\n\nvar ITERATOR = wellKnownSymbol('iterator');\nvar ArrayPrototype = Array.prototype;\n\n// check on default Array iterator\nmodule.exports = function (it) {\n return it !== undefined && (Iterators.Array === it || ArrayPrototype[ITERATOR] === it);\n};\n","'use strict';\nvar classof = require('../internals/classof');\nvar getMethod = require('../internals/get-method');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\nvar Iterators = require('../internals/iterators');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar ITERATOR = wellKnownSymbol('iterator');\n\nmodule.exports = function (it) {\n if (!isNullOrUndefined(it)) return getMethod(it, ITERATOR)\n || getMethod(it, '@@iterator')\n || Iterators[classof(it)];\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar tryToString = require('../internals/try-to-string');\nvar getIteratorMethod = require('../internals/get-iterator-method');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (argument, usingIterator) {\n var iteratorMethod = arguments.length < 2 ? getIteratorMethod(argument) : usingIterator;\n if (aCallable(iteratorMethod)) return anObject(call(iteratorMethod, argument));\n throw new $TypeError(tryToString(argument) + ' is not iterable');\n};\n","'use strict';\nvar bind = require('../internals/function-bind-context');\nvar call = require('../internals/function-call');\nvar toObject = require('../internals/to-object');\nvar callWithSafeIterationClosing = require('../internals/call-with-safe-iteration-closing');\nvar isArrayIteratorMethod = require('../internals/is-array-iterator-method');\nvar isConstructor = require('../internals/is-constructor');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar createProperty = require('../internals/create-property');\nvar getIterator = require('../internals/get-iterator');\nvar getIteratorMethod = require('../internals/get-iterator-method');\n\nvar $Array = Array;\n\n// `Array.from` method implementation\n// https://tc39.es/ecma262/#sec-array.from\nmodule.exports = function from(arrayLike /* , mapfn = undefined, thisArg = undefined */) {\n var O = toObject(arrayLike);\n var IS_CONSTRUCTOR = isConstructor(this);\n var argumentsLength = arguments.length;\n var mapfn = argumentsLength > 1 ? arguments[1] : undefined;\n var mapping = mapfn !== undefined;\n if (mapping) mapfn = bind(mapfn, argumentsLength > 2 ? arguments[2] : undefined);\n var iteratorMethod = getIteratorMethod(O);\n var index = 0;\n var length, result, step, iterator, next, value;\n // if the target is not iterable or it's an array with the default iterator - use a simple case\n if (iteratorMethod && !(this === $Array && isArrayIteratorMethod(iteratorMethod))) {\n result = IS_CONSTRUCTOR ? new this() : [];\n iterator = getIterator(O, iteratorMethod);\n next = iterator.next;\n for (;!(step = call(next, iterator)).done; index++) {\n value = mapping ? callWithSafeIterationClosing(iterator, mapfn, [step.value, index], true) : step.value;\n createProperty(result, index, value);\n }\n } else {\n length = lengthOfArrayLike(O);\n result = IS_CONSTRUCTOR ? new this(length) : $Array(length);\n for (;length > index; index++) {\n value = mapping ? mapfn(O[index], index) : O[index];\n createProperty(result, index, value);\n }\n }\n result.length = index;\n return result;\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar ITERATOR = wellKnownSymbol('iterator');\nvar SAFE_CLOSING = false;\n\ntry {\n var called = 0;\n var iteratorWithReturn = {\n next: function () {\n return { done: !!called++ };\n },\n 'return': function () {\n SAFE_CLOSING = true;\n }\n };\n iteratorWithReturn[ITERATOR] = function () {\n return this;\n };\n // eslint-disable-next-line es/no-array-from, no-throw-literal -- required for testing\n Array.from(iteratorWithReturn, function () { throw 2; });\n} catch (error) { /* empty */ }\n\nmodule.exports = function (exec, SKIP_CLOSING) {\n try {\n if (!SKIP_CLOSING && !SAFE_CLOSING) return false;\n } catch (error) { return false; } // workaround of old WebKit + `eval` bug\n var ITERATION_SUPPORT = false;\n try {\n var object = {};\n object[ITERATOR] = function () {\n return {\n next: function () {\n return { done: ITERATION_SUPPORT = true };\n }\n };\n };\n exec(object);\n } catch (error) { /* empty */ }\n return ITERATION_SUPPORT;\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar from = require('../internals/array-from');\nvar checkCorrectnessOfIteration = require('../internals/check-correctness-of-iteration');\n\nvar INCORRECT_ITERATION = !checkCorrectnessOfIteration(function (iterable) {\n // eslint-disable-next-line es/no-array-from -- required for testing\n Array.from(iterable);\n});\n\n// `Array.from` method\n// https://tc39.es/ecma262/#sec-array.from\n$({ target: 'Array', stat: true, forced: INCORRECT_ITERATION }, {\n from: from\n});\n","'use strict';\nrequire('../../modules/es.string.iterator');\nrequire('../../modules/es.array.from');\nvar path = require('../../internals/path');\n\nmodule.exports = path.Array.from;\n","/**\n * Copyright (c) 2015-present, Facebook, Inc.\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'use strict';\n\nif (typeof Promise === 'undefined') {\n // Rejection tracking prevents a common issue where React gets into an\n // inconsistent state due to an error, but it gets swallowed by a Promise,\n // and the user has no idea what causes React's erratic future behavior.\n require('promise/lib/rejection-tracking').enable();\n self.Promise = require('promise/lib/es6-extensions.js');\n}\n\n// Make sure we're in a Browser-like environment before importing polyfills\n// This prevents `fetch()` from being imported in a Node test environment\nif (typeof window !== 'undefined') {\n // fetch() polyfill for making API calls.\n require('whatwg-fetch');\n}\n\n// Object.assign() is commonly used with React.\n// It will use the native implementation if it's present and isn't buggy.\nObject.assign = require('object-assign');\n\n// Support for...of (a commonly used syntax feature that requires Symbols)\nrequire('core-js/features/symbol');\n// Support iterable spread (...Set, ...Map)\nrequire('core-js/features/array/from');\n","/** @license React v0.19.1\n * scheduler.production.min.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';var f,g,h,k,l;\nif(\"undefined\"===typeof window||\"function\"!==typeof MessageChannel){var p=null,q=null,t=function(){if(null!==p)try{var a=exports.unstable_now();p(!0,a);p=null}catch(b){throw setTimeout(t,0),b;}},u=Date.now();exports.unstable_now=function(){return Date.now()-u};f=function(a){null!==p?setTimeout(f,0,a):(p=a,setTimeout(t,0))};g=function(a,b){q=setTimeout(a,b)};h=function(){clearTimeout(q)};k=function(){return!1};l=exports.unstable_forceFrameRate=function(){}}else{var w=window.performance,x=window.Date,\ny=window.setTimeout,z=window.clearTimeout;if(\"undefined\"!==typeof console){var A=window.cancelAnimationFrame;\"function\"!==typeof window.requestAnimationFrame&&console.error(\"This browser doesn't support requestAnimationFrame. Make sure that you load a polyfill in older browsers. https://fb.me/react-polyfills\");\"function\"!==typeof A&&console.error(\"This browser doesn't support cancelAnimationFrame. Make sure that you load a polyfill in older browsers. https://fb.me/react-polyfills\")}if(\"object\"===\ntypeof w&&\"function\"===typeof w.now)exports.unstable_now=function(){return w.now()};else{var B=x.now();exports.unstable_now=function(){return x.now()-B}}var C=!1,D=null,E=-1,F=5,G=0;k=function(){return exports.unstable_now()>=G};l=function(){};exports.unstable_forceFrameRate=function(a){0>a||125>>1,e=a[d];if(void 0!==e&&0K(n,c))void 0!==r&&0>K(r,n)?(a[d]=r,a[v]=c,d=v):(a[d]=n,a[m]=c,d=m);else if(void 0!==r&&0>K(r,c))a[d]=r,a[v]=c,d=v;else break a}}return b}return null}function K(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}var N=[],O=[],P=1,Q=null,R=3,S=!1,T=!1,U=!1;\nfunction V(a){for(var b=L(O);null!==b;){if(null===b.callback)M(O);else if(b.startTime<=a)M(O),b.sortIndex=b.expirationTime,J(N,b);else break;b=L(O)}}function W(a){U=!1;V(a);if(!T)if(null!==L(N))T=!0,f(X);else{var b=L(O);null!==b&&g(W,b.startTime-a)}}\nfunction X(a,b){T=!1;U&&(U=!1,h());S=!0;var c=R;try{V(b);for(Q=L(N);null!==Q&&(!(Q.expirationTime>b)||a&&!k());){var d=Q.callback;if(null!==d){Q.callback=null;R=Q.priorityLevel;var e=d(Q.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?Q.callback=e:Q===L(N)&&M(N);V(b)}else M(N);Q=L(N)}if(null!==Q)var m=!0;else{var n=L(O);null!==n&&g(W,n.startTime-b);m=!1}return m}finally{Q=null,R=c,S=!1}}\nfunction Y(a){switch(a){case 1:return-1;case 2:return 250;case 5:return 1073741823;case 4:return 1E4;default:return 5E3}}var Z=l;exports.unstable_IdlePriority=5;exports.unstable_ImmediatePriority=1;exports.unstable_LowPriority=4;exports.unstable_NormalPriority=3;exports.unstable_Profiling=null;exports.unstable_UserBlockingPriority=2;exports.unstable_cancelCallback=function(a){a.callback=null};exports.unstable_continueExecution=function(){T||S||(T=!0,f(X))};\nexports.unstable_getCurrentPriorityLevel=function(){return R};exports.unstable_getFirstCallbackNode=function(){return L(N)};exports.unstable_next=function(a){switch(R){case 1:case 2:case 3:var b=3;break;default:b=R}var c=R;R=b;try{return a()}finally{R=c}};exports.unstable_pauseExecution=function(){};exports.unstable_requestPaint=Z;exports.unstable_runWithPriority=function(a,b){switch(a){case 1:case 2:case 3:case 4:case 5:break;default:a=3}var c=R;R=a;try{return b()}finally{R=c}};\nexports.unstable_scheduleCallback=function(a,b,c){var d=exports.unstable_now();if(\"object\"===typeof c&&null!==c){var e=c.delay;e=\"number\"===typeof e&&0d?(a.sortIndex=e,J(O,a),null===L(N)&&a===L(O)&&(U?h():U=!0,g(W,e-d))):(a.sortIndex=c,J(N,a),T||S||(T=!0,f(X)));return a};\nexports.unstable_shouldYield=function(){var a=exports.unstable_now();V(a);var b=L(N);return b!==Q&&null!==Q&&null!==b&&null!==b.callback&&b.startTime<=a&&b.expirationTimeb}return!1}function v(a,b,c,d,e,f){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f}var C={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){C[a]=new v(a,0,!1,a,null,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];C[b]=new v(b,1,!1,a[1],null,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){C[a]=new v(a,2,!1,a.toLowerCase(),null,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){C[a]=new v(a,2,!1,a,null,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){C[a]=new v(a,3,!1,a.toLowerCase(),null,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){C[a]=new v(a,3,!0,a,null,!1)});[\"capture\",\"download\"].forEach(function(a){C[a]=new v(a,4,!1,a,null,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){C[a]=new v(a,6,!1,a,null,!1)});[\"rowSpan\",\"start\"].forEach(function(a){C[a]=new v(a,5,!1,a.toLowerCase(),null,!1)});var Ua=/[\\-:]([a-z])/g;function Va(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(Ua,\nVa);C[b]=new v(b,1,!1,a,null,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(Ua,Va);C[b]=new v(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(Ua,Va);C[b]=new v(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){C[a]=new v(a,1,!1,a.toLowerCase(),null,!1)});\nC.xlinkHref=new v(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){C[a]=new v(a,1,!1,a.toLowerCase(),null,!0)});var Wa=aa.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;Wa.hasOwnProperty(\"ReactCurrentDispatcher\")||(Wa.ReactCurrentDispatcher={current:null});Wa.hasOwnProperty(\"ReactCurrentBatchConfig\")||(Wa.ReactCurrentBatchConfig={suspense:null});\nfunction Xa(a,b,c,d){var e=C.hasOwnProperty(b)?C[b]:null;var f=null!==e?0===e.type:d?!1:!(2=c.length))throw Error(u(93));c=c[0]}b=c}null==b&&(b=\"\");c=b}a._wrapperState={initialValue:rb(c)}}\nfunction Kb(a,b){var c=rb(b.value),d=rb(b.defaultValue);null!=c&&(c=\"\"+c,c!==a.value&&(a.value=c),null==b.defaultValue&&a.defaultValue!==c&&(a.defaultValue=c));null!=d&&(a.defaultValue=\"\"+d)}function Lb(a){var b=a.textContent;b===a._wrapperState.initialValue&&\"\"!==b&&null!==b&&(a.value=b)}var Mb={html:\"http://www.w3.org/1999/xhtml\",mathml:\"http://www.w3.org/1998/Math/MathML\",svg:\"http://www.w3.org/2000/svg\"};\nfunction Nb(a){switch(a){case \"svg\":return\"http://www.w3.org/2000/svg\";case \"math\":return\"http://www.w3.org/1998/Math/MathML\";default:return\"http://www.w3.org/1999/xhtml\"}}function Ob(a,b){return null==a||\"http://www.w3.org/1999/xhtml\"===a?Nb(b):\"http://www.w3.org/2000/svg\"===a&&\"foreignObject\"===b?\"http://www.w3.org/1999/xhtml\":a}\nvar Pb,Qb=function(a){return\"undefined\"!==typeof MSApp&&MSApp.execUnsafeLocalFunction?function(b,c,d,e){MSApp.execUnsafeLocalFunction(function(){return a(b,c,d,e)})}:a}(function(a,b){if(a.namespaceURI!==Mb.svg||\"innerHTML\"in a)a.innerHTML=b;else{Pb=Pb||document.createElement(\"div\");Pb.innerHTML=\"\"+b.valueOf().toString()+\"\";for(b=Pb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction Rb(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}function Sb(a,b){var c={};c[a.toLowerCase()]=b.toLowerCase();c[\"Webkit\"+a]=\"webkit\"+b;c[\"Moz\"+a]=\"moz\"+b;return c}var Tb={animationend:Sb(\"Animation\",\"AnimationEnd\"),animationiteration:Sb(\"Animation\",\"AnimationIteration\"),animationstart:Sb(\"Animation\",\"AnimationStart\"),transitionend:Sb(\"Transition\",\"TransitionEnd\")},Ub={},Vb={};\nya&&(Vb=document.createElement(\"div\").style,\"AnimationEvent\"in window||(delete Tb.animationend.animation,delete Tb.animationiteration.animation,delete Tb.animationstart.animation),\"TransitionEvent\"in window||delete Tb.transitionend.transition);function Wb(a){if(Ub[a])return Ub[a];if(!Tb[a])return a;var b=Tb[a],c;for(c in b)if(b.hasOwnProperty(c)&&c in Vb)return Ub[a]=b[c];return a}\nvar Xb=Wb(\"animationend\"),Yb=Wb(\"animationiteration\"),Zb=Wb(\"animationstart\"),$b=Wb(\"transitionend\"),ac=\"abort canplay canplaythrough durationchange emptied encrypted ended error loadeddata loadedmetadata loadstart pause play playing progress ratechange seeked seeking stalled suspend timeupdate volumechange waiting\".split(\" \"),bc=new (\"function\"===typeof WeakMap?WeakMap:Map);function cc(a){var b=bc.get(a);void 0===b&&(b=new Map,bc.set(a,b));return b}\nfunction dc(a){var b=a,c=a;if(a.alternate)for(;b.return;)b=b.return;else{a=b;do b=a,0!==(b.effectTag&1026)&&(c=b.return),a=b.return;while(a)}return 3===b.tag?c:null}function ec(a){if(13===a.tag){var b=a.memoizedState;null===b&&(a=a.alternate,null!==a&&(b=a.memoizedState));if(null!==b)return b.dehydrated}return null}function fc(a){if(dc(a)!==a)throw Error(u(188));}\nfunction gc(a){var b=a.alternate;if(!b){b=dc(a);if(null===b)throw Error(u(188));return b!==a?null:a}for(var c=a,d=b;;){var e=c.return;if(null===e)break;var f=e.alternate;if(null===f){d=e.return;if(null!==d){c=d;continue}break}if(e.child===f.child){for(f=e.child;f;){if(f===c)return fc(e),a;if(f===d)return fc(e),b;f=f.sibling}throw Error(u(188));}if(c.return!==d.return)c=e,d=f;else{for(var g=!1,h=e.child;h;){if(h===c){g=!0;c=e;d=f;break}if(h===d){g=!0;d=e;c=f;break}h=h.sibling}if(!g){for(h=f.child;h;){if(h===\nc){g=!0;c=f;d=e;break}if(h===d){g=!0;d=f;c=e;break}h=h.sibling}if(!g)throw Error(u(189));}}if(c.alternate!==d)throw Error(u(190));}if(3!==c.tag)throw Error(u(188));return c.stateNode.current===c?a:b}function hc(a){a=gc(a);if(!a)return null;for(var b=a;;){if(5===b.tag||6===b.tag)return b;if(b.child)b.child.return=b,b=b.child;else{if(b===a)break;for(;!b.sibling;){if(!b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}}return null}\nfunction ic(a,b){if(null==b)throw Error(u(30));if(null==a)return b;if(Array.isArray(a)){if(Array.isArray(b))return a.push.apply(a,b),a;a.push(b);return a}return Array.isArray(b)?[a].concat(b):[a,b]}function jc(a,b,c){Array.isArray(a)?a.forEach(b,c):a&&b.call(c,a)}var kc=null;\nfunction lc(a){if(a){var b=a._dispatchListeners,c=a._dispatchInstances;if(Array.isArray(b))for(var d=0;dpc.length&&pc.push(a)}\nfunction rc(a,b,c,d){if(pc.length){var e=pc.pop();e.topLevelType=a;e.eventSystemFlags=d;e.nativeEvent=b;e.targetInst=c;return e}return{topLevelType:a,eventSystemFlags:d,nativeEvent:b,targetInst:c,ancestors:[]}}\nfunction sc(a){var b=a.targetInst,c=b;do{if(!c){a.ancestors.push(c);break}var d=c;if(3===d.tag)d=d.stateNode.containerInfo;else{for(;d.return;)d=d.return;d=3!==d.tag?null:d.stateNode.containerInfo}if(!d)break;b=c.tag;5!==b&&6!==b||a.ancestors.push(c);c=tc(d)}while(c);for(c=0;c=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=ud(c)}}\nfunction wd(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?wd(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}function xd(){for(var a=window,b=td();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=td(a.document)}return b}\nfunction yd(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}var zd=\"$\",Ad=\"/$\",Bd=\"$?\",Cd=\"$!\",Dd=null,Ed=null;function Fd(a,b){switch(a){case \"button\":case \"input\":case \"select\":case \"textarea\":return!!b.autoFocus}return!1}\nfunction Gd(a,b){return\"textarea\"===a||\"option\"===a||\"noscript\"===a||\"string\"===typeof b.children||\"number\"===typeof b.children||\"object\"===typeof b.dangerouslySetInnerHTML&&null!==b.dangerouslySetInnerHTML&&null!=b.dangerouslySetInnerHTML.__html}var Hd=\"function\"===typeof setTimeout?setTimeout:void 0,Id=\"function\"===typeof clearTimeout?clearTimeout:void 0;function Jd(a){for(;null!=a;a=a.nextSibling){var b=a.nodeType;if(1===b||3===b)break}return a}\nfunction Kd(a){a=a.previousSibling;for(var b=0;a;){if(8===a.nodeType){var c=a.data;if(c===zd||c===Cd||c===Bd){if(0===b)return a;b--}else c===Ad&&b++}a=a.previousSibling}return null}var Ld=Math.random().toString(36).slice(2),Md=\"__reactInternalInstance$\"+Ld,Nd=\"__reactEventHandlers$\"+Ld,Od=\"__reactContainere$\"+Ld;\nfunction tc(a){var b=a[Md];if(b)return b;for(var c=a.parentNode;c;){if(b=c[Od]||c[Md]){c=b.alternate;if(null!==b.child||null!==c&&null!==c.child)for(a=Kd(a);null!==a;){if(c=a[Md])return c;a=Kd(a)}return b}a=c;c=a.parentNode}return null}function Nc(a){a=a[Md]||a[Od];return!a||5!==a.tag&&6!==a.tag&&13!==a.tag&&3!==a.tag?null:a}function Pd(a){if(5===a.tag||6===a.tag)return a.stateNode;throw Error(u(33));}function Qd(a){return a[Nd]||null}\nfunction Rd(a){do a=a.return;while(a&&5!==a.tag);return a?a:null}\nfunction Sd(a,b){var c=a.stateNode;if(!c)return null;var d=la(c);if(!d)return null;c=d[b];a:switch(b){case \"onClick\":case \"onClickCapture\":case \"onDoubleClick\":case \"onDoubleClickCapture\":case \"onMouseDown\":case \"onMouseDownCapture\":case \"onMouseMove\":case \"onMouseMoveCapture\":case \"onMouseUp\":case \"onMouseUpCapture\":case \"onMouseEnter\":(d=!d.disabled)||(a=a.type,d=!(\"button\"===a||\"input\"===a||\"select\"===a||\"textarea\"===a));a=!d;break a;default:a=!1}if(a)return null;if(c&&\"function\"!==typeof c)throw Error(u(231,\nb,typeof c));return c}function Td(a,b,c){if(b=Sd(a,c.dispatchConfig.phasedRegistrationNames[b]))c._dispatchListeners=ic(c._dispatchListeners,b),c._dispatchInstances=ic(c._dispatchInstances,a)}function Ud(a){if(a&&a.dispatchConfig.phasedRegistrationNames){for(var b=a._targetInst,c=[];b;)c.push(b),b=Rd(b);for(b=c.length;0this.eventPool.length&&this.eventPool.push(a)}function de(a){a.eventPool=[];a.getPooled=ee;a.release=fe}var ge=G.extend({data:null}),he=G.extend({data:null}),ie=[9,13,27,32],je=ya&&\"CompositionEvent\"in window,ke=null;ya&&\"documentMode\"in document&&(ke=document.documentMode);\nvar le=ya&&\"TextEvent\"in window&&!ke,me=ya&&(!je||ke&&8=ke),ne=String.fromCharCode(32),oe={beforeInput:{phasedRegistrationNames:{bubbled:\"onBeforeInput\",captured:\"onBeforeInputCapture\"},dependencies:[\"compositionend\",\"keypress\",\"textInput\",\"paste\"]},compositionEnd:{phasedRegistrationNames:{bubbled:\"onCompositionEnd\",captured:\"onCompositionEndCapture\"},dependencies:\"blur compositionend keydown keypress keyup mousedown\".split(\" \")},compositionStart:{phasedRegistrationNames:{bubbled:\"onCompositionStart\",\ncaptured:\"onCompositionStartCapture\"},dependencies:\"blur compositionstart keydown keypress keyup mousedown\".split(\" \")},compositionUpdate:{phasedRegistrationNames:{bubbled:\"onCompositionUpdate\",captured:\"onCompositionUpdateCapture\"},dependencies:\"blur compositionupdate keydown keypress keyup mousedown\".split(\" \")}},pe=!1;\nfunction qe(a,b){switch(a){case \"keyup\":return-1!==ie.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"blur\":return!0;default:return!1}}function re(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var se=!1;function te(a,b){switch(a){case \"compositionend\":return re(b);case \"keypress\":if(32!==b.which)return null;pe=!0;return ne;case \"textInput\":return a=b.data,a===ne&&pe?null:a;default:return null}}\nfunction ue(a,b){if(se)return\"compositionend\"===a||!je&&qe(a,b)?(a=ae(),$d=Zd=Yd=null,se=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1=document.documentMode,df={select:{phasedRegistrationNames:{bubbled:\"onSelect\",captured:\"onSelectCapture\"},dependencies:\"blur contextmenu dragend focus keydown keyup mousedown mouseup selectionchange\".split(\" \")}},ef=null,ff=null,gf=null,hf=!1;\nfunction jf(a,b){var c=b.window===b?b.document:9===b.nodeType?b:b.ownerDocument;if(hf||null==ef||ef!==td(c))return null;c=ef;\"selectionStart\"in c&&yd(c)?c={start:c.selectionStart,end:c.selectionEnd}:(c=(c.ownerDocument&&c.ownerDocument.defaultView||window).getSelection(),c={anchorNode:c.anchorNode,anchorOffset:c.anchorOffset,focusNode:c.focusNode,focusOffset:c.focusOffset});return gf&&bf(gf,c)?null:(gf=c,a=G.getPooled(df.select,ff,a,b),a.type=\"select\",a.target=ef,Xd(a),a)}\nvar kf={eventTypes:df,extractEvents:function(a,b,c,d,e,f){e=f||(d.window===d?d.document:9===d.nodeType?d:d.ownerDocument);if(!(f=!e)){a:{e=cc(e);f=wa.onSelect;for(var g=0;gzf||(a.current=yf[zf],yf[zf]=null,zf--)}\nfunction I(a,b){zf++;yf[zf]=a.current;a.current=b}var Af={},J={current:Af},K={current:!1},Bf=Af;function Cf(a,b){var c=a.type.contextTypes;if(!c)return Af;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}function L(a){a=a.childContextTypes;return null!==a&&void 0!==a}\nfunction Df(){H(K);H(J)}function Ef(a,b,c){if(J.current!==Af)throw Error(u(168));I(J,b);I(K,c)}function Ff(a,b,c){var d=a.stateNode;a=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in a))throw Error(u(108,pb(b)||\"Unknown\",e));return n({},c,{},d)}function Gf(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Af;Bf=J.current;I(J,a);I(K,K.current);return!0}\nfunction Hf(a,b,c){var d=a.stateNode;if(!d)throw Error(u(169));c?(a=Ff(a,b,Bf),d.__reactInternalMemoizedMergedChildContext=a,H(K),H(J),I(J,a)):H(K);I(K,c)}\nvar If=r.unstable_runWithPriority,Jf=r.unstable_scheduleCallback,Kf=r.unstable_cancelCallback,Lf=r.unstable_requestPaint,Mf=r.unstable_now,Nf=r.unstable_getCurrentPriorityLevel,Of=r.unstable_ImmediatePriority,Pf=r.unstable_UserBlockingPriority,Qf=r.unstable_NormalPriority,Rf=r.unstable_LowPriority,Sf=r.unstable_IdlePriority,Tf={},Uf=r.unstable_shouldYield,Vf=void 0!==Lf?Lf:function(){},Wf=null,Xf=null,Yf=!1,Zf=Mf(),$f=1E4>Zf?Mf:function(){return Mf()-Zf};\nfunction ag(){switch(Nf()){case Of:return 99;case Pf:return 98;case Qf:return 97;case Rf:return 96;case Sf:return 95;default:throw Error(u(332));}}function bg(a){switch(a){case 99:return Of;case 98:return Pf;case 97:return Qf;case 96:return Rf;case 95:return Sf;default:throw Error(u(332));}}function cg(a,b){a=bg(a);return If(a,b)}function dg(a,b,c){a=bg(a);return Jf(a,b,c)}function eg(a){null===Wf?(Wf=[a],Xf=Jf(Of,fg)):Wf.push(a);return Tf}function gg(){if(null!==Xf){var a=Xf;Xf=null;Kf(a)}fg()}\nfunction fg(){if(!Yf&&null!==Wf){Yf=!0;var a=0;try{var b=Wf;cg(99,function(){for(;a=b&&(rg=!0),a.firstContext=null)}\nfunction sg(a,b){if(mg!==a&&!1!==b&&0!==b){if(\"number\"!==typeof b||1073741823===b)mg=a,b=1073741823;b={context:a,observedBits:b,next:null};if(null===lg){if(null===kg)throw Error(u(308));lg=b;kg.dependencies={expirationTime:0,firstContext:b,responders:null}}else lg=lg.next=b}return a._currentValue}var tg=!1;function ug(a){a.updateQueue={baseState:a.memoizedState,baseQueue:null,shared:{pending:null},effects:null}}\nfunction vg(a,b){a=a.updateQueue;b.updateQueue===a&&(b.updateQueue={baseState:a.baseState,baseQueue:a.baseQueue,shared:a.shared,effects:a.effects})}function wg(a,b){a={expirationTime:a,suspenseConfig:b,tag:0,payload:null,callback:null,next:null};return a.next=a}function xg(a,b){a=a.updateQueue;if(null!==a){a=a.shared;var c=a.pending;null===c?b.next=b:(b.next=c.next,c.next=b);a.pending=b}}\nfunction yg(a,b){var c=a.alternate;null!==c&&vg(c,a);a=a.updateQueue;c=a.baseQueue;null===c?(a.baseQueue=b.next=b,b.next=b):(b.next=c.next,c.next=b)}\nfunction zg(a,b,c,d){var e=a.updateQueue;tg=!1;var f=e.baseQueue,g=e.shared.pending;if(null!==g){if(null!==f){var h=f.next;f.next=g.next;g.next=h}f=g;e.shared.pending=null;h=a.alternate;null!==h&&(h=h.updateQueue,null!==h&&(h.baseQueue=g))}if(null!==f){h=f.next;var k=e.baseState,l=0,m=null,p=null,x=null;if(null!==h){var z=h;do{g=z.expirationTime;if(gl&&(l=g)}else{null!==x&&(x=x.next={expirationTime:1073741823,suspenseConfig:z.suspenseConfig,tag:z.tag,payload:z.payload,callback:z.callback,next:null});Ag(g,z.suspenseConfig);a:{var D=a,t=z;g=b;ca=c;switch(t.tag){case 1:D=t.payload;if(\"function\"===typeof D){k=D.call(ca,k,g);break a}k=D;break a;case 3:D.effectTag=D.effectTag&-4097|64;case 0:D=t.payload;g=\"function\"===typeof D?D.call(ca,k,g):D;if(null===g||void 0===g)break a;k=n({},k,g);break a;case 2:tg=!0}}null!==z.callback&&\n(a.effectTag|=32,g=e.effects,null===g?e.effects=[z]:g.push(z))}z=z.next;if(null===z||z===h)if(g=e.shared.pending,null===g)break;else z=f.next=g.next,g.next=h,e.baseQueue=f=g,e.shared.pending=null}while(1)}null===x?m=k:x.next=p;e.baseState=m;e.baseQueue=x;Bg(l);a.expirationTime=l;a.memoizedState=k}}\nfunction Cg(a,b,c){a=b.effects;b.effects=null;if(null!==a)for(b=0;by?(A=m,m=null):A=m.sibling;var q=x(e,m,h[y],k);if(null===q){null===m&&(m=A);break}a&&\nm&&null===q.alternate&&b(e,m);g=f(q,g,y);null===t?l=q:t.sibling=q;t=q;m=A}if(y===h.length)return c(e,m),l;if(null===m){for(;yy?(A=t,t=null):A=t.sibling;var D=x(e,t,q.value,l);if(null===D){null===t&&(t=A);break}a&&t&&null===D.alternate&&b(e,t);g=f(D,g,y);null===m?k=D:m.sibling=D;m=D;t=A}if(q.done)return c(e,t),k;if(null===t){for(;!q.done;y++,q=h.next())q=p(e,q.value,l),null!==q&&(g=f(q,g,y),null===m?k=q:m.sibling=q,m=q);return k}for(t=d(e,t);!q.done;y++,q=h.next())q=z(t,e,y,q.value,l),null!==q&&(a&&null!==\nq.alternate&&t.delete(null===q.key?y:q.key),g=f(q,g,y),null===m?k=q:m.sibling=q,m=q);a&&t.forEach(function(a){return b(e,a)});return k}return function(a,d,f,h){var k=\"object\"===typeof f&&null!==f&&f.type===ab&&null===f.key;k&&(f=f.props.children);var l=\"object\"===typeof f&&null!==f;if(l)switch(f.$$typeof){case Za:a:{l=f.key;for(k=d;null!==k;){if(k.key===l){switch(k.tag){case 7:if(f.type===ab){c(a,k.sibling);d=e(k,f.props.children);d.return=a;a=d;break a}break;default:if(k.elementType===f.type){c(a,\nk.sibling);d=e(k,f.props);d.ref=Pg(a,k,f);d.return=a;a=d;break a}}c(a,k);break}else b(a,k);k=k.sibling}f.type===ab?(d=Wg(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=Ug(f.type,f.key,f.props,null,a.mode,h),h.ref=Pg(a,d,f),h.return=a,a=h)}return g(a);case $a:a:{for(k=f.key;null!==d;){if(d.key===k)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=\nd.sibling}d=Vg(f,a.mode,h);d.return=a;a=d}return g(a)}if(\"string\"===typeof f||\"number\"===typeof f)return f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):(c(a,d),d=Tg(f,a.mode,h),d.return=a,a=d),g(a);if(Og(f))return ca(a,d,f,h);if(nb(f))return D(a,d,f,h);l&&Qg(a,f);if(\"undefined\"===typeof f&&!k)switch(a.tag){case 1:case 0:throw a=a.type,Error(u(152,a.displayName||a.name||\"Component\"));}return c(a,d)}}var Xg=Rg(!0),Yg=Rg(!1),Zg={},$g={current:Zg},ah={current:Zg},bh={current:Zg};\nfunction ch(a){if(a===Zg)throw Error(u(174));return a}function dh(a,b){I(bh,b);I(ah,a);I($g,Zg);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:Ob(null,\"\");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=Ob(b,a)}H($g);I($g,b)}function eh(){H($g);H(ah);H(bh)}function fh(a){ch(bh.current);var b=ch($g.current);var c=Ob(b,a.type);b!==c&&(I(ah,a),I($g,c))}function gh(a){ah.current===a&&(H($g),H(ah))}var M={current:0};\nfunction hh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||c.data===Bd||c.data===Cd))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.effectTag&64))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}function ih(a,b){return{responder:a,props:b}}\nvar jh=Wa.ReactCurrentDispatcher,kh=Wa.ReactCurrentBatchConfig,lh=0,N=null,O=null,P=null,mh=!1;function Q(){throw Error(u(321));}function nh(a,b){if(null===b)return!1;for(var c=0;cf))throw Error(u(301));f+=1;P=O=null;b.updateQueue=null;jh.current=rh;a=c(d,e)}while(b.expirationTime===lh)}jh.current=sh;b=null!==O&&null!==O.next;lh=0;P=O=N=null;mh=!1;if(b)throw Error(u(300));return a}\nfunction th(){var a={memoizedState:null,baseState:null,baseQueue:null,queue:null,next:null};null===P?N.memoizedState=P=a:P=P.next=a;return P}function uh(){if(null===O){var a=N.alternate;a=null!==a?a.memoizedState:null}else a=O.next;var b=null===P?N.memoizedState:P.next;if(null!==b)P=b,O=a;else{if(null===a)throw Error(u(310));O=a;a={memoizedState:O.memoizedState,baseState:O.baseState,baseQueue:O.baseQueue,queue:O.queue,next:null};null===P?N.memoizedState=P=a:P=P.next=a}return P}\nfunction vh(a,b){return\"function\"===typeof b?b(a):b}\nfunction wh(a){var b=uh(),c=b.queue;if(null===c)throw Error(u(311));c.lastRenderedReducer=a;var d=O,e=d.baseQueue,f=c.pending;if(null!==f){if(null!==e){var g=e.next;e.next=f.next;f.next=g}d.baseQueue=e=f;c.pending=null}if(null!==e){e=e.next;d=d.baseState;var h=g=f=null,k=e;do{var l=k.expirationTime;if(lN.expirationTime&&\n(N.expirationTime=l,Bg(l))}else null!==h&&(h=h.next={expirationTime:1073741823,suspenseConfig:k.suspenseConfig,action:k.action,eagerReducer:k.eagerReducer,eagerState:k.eagerState,next:null}),Ag(l,k.suspenseConfig),d=k.eagerReducer===a?k.eagerState:a(d,k.action);k=k.next}while(null!==k&&k!==e);null===h?f=d:h.next=g;$e(d,b.memoizedState)||(rg=!0);b.memoizedState=d;b.baseState=f;b.baseQueue=h;c.lastRenderedState=d}return[b.memoizedState,c.dispatch]}\nfunction xh(a){var b=uh(),c=b.queue;if(null===c)throw Error(u(311));c.lastRenderedReducer=a;var d=c.dispatch,e=c.pending,f=b.memoizedState;if(null!==e){c.pending=null;var g=e=e.next;do f=a(f,g.action),g=g.next;while(g!==e);$e(f,b.memoizedState)||(rg=!0);b.memoizedState=f;null===b.baseQueue&&(b.baseState=f);c.lastRenderedState=f}return[f,d]}\nfunction yh(a){var b=th();\"function\"===typeof a&&(a=a());b.memoizedState=b.baseState=a;a=b.queue={pending:null,dispatch:null,lastRenderedReducer:vh,lastRenderedState:a};a=a.dispatch=zh.bind(null,N,a);return[b.memoizedState,a]}function Ah(a,b,c,d){a={tag:a,create:b,destroy:c,deps:d,next:null};b=N.updateQueue;null===b?(b={lastEffect:null},N.updateQueue=b,b.lastEffect=a.next=a):(c=b.lastEffect,null===c?b.lastEffect=a.next=a:(d=c.next,c.next=a,a.next=d,b.lastEffect=a));return a}\nfunction Bh(){return uh().memoizedState}function Ch(a,b,c,d){var e=th();N.effectTag|=a;e.memoizedState=Ah(1|b,c,void 0,void 0===d?null:d)}function Dh(a,b,c,d){var e=uh();d=void 0===d?null:d;var f=void 0;if(null!==O){var g=O.memoizedState;f=g.destroy;if(null!==d&&nh(d,g.deps)){Ah(b,c,f,d);return}}N.effectTag|=a;e.memoizedState=Ah(1|b,c,f,d)}function Eh(a,b){return Ch(516,4,a,b)}function Fh(a,b){return Dh(516,4,a,b)}function Gh(a,b){return Dh(4,2,a,b)}\nfunction Hh(a,b){if(\"function\"===typeof b)return a=a(),b(a),function(){b(null)};if(null!==b&&void 0!==b)return a=a(),b.current=a,function(){b.current=null}}function Ih(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return Dh(4,2,Hh.bind(null,b,a),c)}function Jh(){}function Kh(a,b){th().memoizedState=[a,void 0===b?null:b];return a}function Lh(a,b){var c=uh();b=void 0===b?null:b;var d=c.memoizedState;if(null!==d&&null!==b&&nh(b,d[1]))return d[0];c.memoizedState=[a,b];return a}\nfunction Mh(a,b){var c=uh();b=void 0===b?null:b;var d=c.memoizedState;if(null!==d&&null!==b&&nh(b,d[1]))return d[0];a=a();c.memoizedState=[a,b];return a}function Nh(a,b,c){var d=ag();cg(98>d?98:d,function(){a(!0)});cg(97\\x3c/script>\",a=a.removeChild(a.firstChild)):\"string\"===typeof d.is?a=g.createElement(e,{is:d.is}):(a=g.createElement(e),\"select\"===e&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,e);a[Md]=b;a[Nd]=d;ni(a,b,!1,!1);b.stateNode=a;g=pd(e,d);switch(e){case \"iframe\":case \"object\":case \"embed\":F(\"load\",\na);h=d;break;case \"video\":case \"audio\":for(h=0;hd.tailExpiration&&1b)&&tj.set(a,b)))}}\nfunction xj(a,b){a.expirationTimea?c:a;return 2>=a&&b!==a?0:a}\nfunction Z(a){if(0!==a.lastExpiredTime)a.callbackExpirationTime=1073741823,a.callbackPriority=99,a.callbackNode=eg(yj.bind(null,a));else{var b=zj(a),c=a.callbackNode;if(0===b)null!==c&&(a.callbackNode=null,a.callbackExpirationTime=0,a.callbackPriority=90);else{var d=Gg();1073741823===b?d=99:1===b||2===b?d=95:(d=10*(1073741821-b)-10*(1073741821-d),d=0>=d?99:250>=d?98:5250>=d?97:95);if(null!==c){var e=a.callbackPriority;if(a.callbackExpirationTime===b&&e>=d)return;c!==Tf&&Kf(c)}a.callbackExpirationTime=\nb;a.callbackPriority=d;b=1073741823===b?eg(yj.bind(null,a)):dg(d,Bj.bind(null,a),{timeout:10*(1073741821-b)-$f()});a.callbackNode=b}}}\nfunction Bj(a,b){wj=0;if(b)return b=Gg(),Cj(a,b),Z(a),null;var c=zj(a);if(0!==c){b=a.callbackNode;if((W&(fj|gj))!==V)throw Error(u(327));Dj();a===T&&c===U||Ej(a,c);if(null!==X){var d=W;W|=fj;var e=Fj();do try{Gj();break}catch(h){Hj(a,h)}while(1);ng();W=d;cj.current=e;if(S===hj)throw b=kj,Ej(a,c),xi(a,c),Z(a),b;if(null===X)switch(e=a.finishedWork=a.current.alternate,a.finishedExpirationTime=c,d=S,T=null,d){case ti:case hj:throw Error(u(345));case ij:Cj(a,2=c){a.lastPingedTime=c;Ej(a,c);break}}f=zj(a);if(0!==f&&f!==c)break;if(0!==d&&d!==c){a.lastPingedTime=d;break}a.timeoutHandle=Hd(Jj.bind(null,a),e);break}Jj(a);break;case vi:xi(a,c);d=a.lastSuspendedTime;c===d&&(a.nextKnownPendingLevel=Ij(e));if(oj&&(e=a.lastPingedTime,0===e||e>=c)){a.lastPingedTime=c;Ej(a,c);break}e=zj(a);if(0!==e&&e!==c)break;if(0!==d&&d!==c){a.lastPingedTime=\nd;break}1073741823!==mj?d=10*(1073741821-mj)-$f():1073741823===lj?d=0:(d=10*(1073741821-lj)-5E3,e=$f(),c=10*(1073741821-c)-e,d=e-d,0>d&&(d=0),d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*bj(d/1960))-d,c=d?d=0:(e=g.busyDelayMs|0,f=$f()-(10*(1073741821-f)-(g.timeoutMs|0||5E3)),d=f<=e?0:e+d-f);if(10 component higher in the tree to provide a loading indicator or placeholder to display.\"+qb(g))}S!==\njj&&(S=ij);h=Ai(h,g);p=f;do{switch(p.tag){case 3:k=h;p.effectTag|=4096;p.expirationTime=b;var B=Xi(p,k,b);yg(p,B);break a;case 1:k=h;var w=p.type,ub=p.stateNode;if(0===(p.effectTag&64)&&(\"function\"===typeof w.getDerivedStateFromError||null!==ub&&\"function\"===typeof ub.componentDidCatch&&(null===aj||!aj.has(ub)))){p.effectTag|=4096;p.expirationTime=b;var vb=$i(p,k,b);yg(p,vb);break a}}p=p.return}while(null!==p)}X=Pj(X)}catch(Xc){b=Xc;continue}break}while(1)}\nfunction Fj(){var a=cj.current;cj.current=sh;return null===a?sh:a}function Ag(a,b){awi&&(wi=a)}function Kj(){for(;null!==X;)X=Qj(X)}function Gj(){for(;null!==X&&!Uf();)X=Qj(X)}function Qj(a){var b=Rj(a.alternate,a,U);a.memoizedProps=a.pendingProps;null===b&&(b=Pj(a));dj.current=null;return b}\nfunction Pj(a){X=a;do{var b=X.alternate;a=X.return;if(0===(X.effectTag&2048)){b=si(b,X,U);if(1===U||1!==X.childExpirationTime){for(var c=0,d=X.child;null!==d;){var e=d.expirationTime,f=d.childExpirationTime;e>c&&(c=e);f>c&&(c=f);d=d.sibling}X.childExpirationTime=c}if(null!==b)return b;null!==a&&0===(a.effectTag&2048)&&(null===a.firstEffect&&(a.firstEffect=X.firstEffect),null!==X.lastEffect&&(null!==a.lastEffect&&(a.lastEffect.nextEffect=X.firstEffect),a.lastEffect=X.lastEffect),1a?b:a}function Jj(a){var b=ag();cg(99,Sj.bind(null,a,b));return null}\nfunction Sj(a,b){do Dj();while(null!==rj);if((W&(fj|gj))!==V)throw Error(u(327));var c=a.finishedWork,d=a.finishedExpirationTime;if(null===c)return null;a.finishedWork=null;a.finishedExpirationTime=0;if(c===a.current)throw Error(u(177));a.callbackNode=null;a.callbackExpirationTime=0;a.callbackPriority=90;a.nextKnownPendingLevel=0;var e=Ij(c);a.firstPendingTime=e;d<=a.lastSuspendedTime?a.firstSuspendedTime=a.lastSuspendedTime=a.nextKnownPendingLevel=0:d<=a.firstSuspendedTime&&(a.firstSuspendedTime=\nd-1);d<=a.lastPingedTime&&(a.lastPingedTime=0);d<=a.lastExpiredTime&&(a.lastExpiredTime=0);a===T&&(X=T=null,U=0);1h&&(l=h,h=g,g=l),l=vd(q,g),m=vd(q,h),l&&m&&(1!==w.rangeCount||w.anchorNode!==l.node||w.anchorOffset!==l.offset||w.focusNode!==m.node||w.focusOffset!==m.offset)&&(B=B.createRange(),B.setStart(l.node,l.offset),w.removeAllRanges(),g>h?(w.addRange(B),w.extend(m.node,m.offset)):(B.setEnd(m.node,m.offset),w.addRange(B))))));B=[];for(w=q;w=w.parentNode;)1===w.nodeType&&B.push({element:w,left:w.scrollLeft,\ntop:w.scrollTop});\"function\"===typeof q.focus&&q.focus();for(q=0;q=c)return ji(a,b,c);I(M,M.current&1);b=$h(a,b,c);return null!==b?b.sibling:null}I(M,M.current&1);break;case 19:d=b.childExpirationTime>=c;if(0!==(a.effectTag&64)){if(d)return mi(a,b,c);b.effectTag|=64}e=b.memoizedState;null!==e&&(e.rendering=null,e.tail=null);I(M,M.current);if(!d)return null}return $h(a,b,c)}rg=!1}}else rg=!1;b.expirationTime=0;switch(b.tag){case 2:d=b.type;null!==a&&(a.alternate=null,b.alternate=null,b.effectTag|=2);a=b.pendingProps;e=Cf(b,J.current);qg(b,c);e=oh(null,\nb,d,a,e,c);b.effectTag|=1;if(\"object\"===typeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof){b.tag=1;b.memoizedState=null;b.updateQueue=null;if(L(d)){var f=!0;Gf(b)}else f=!1;b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null;ug(b);var g=d.getDerivedStateFromProps;\"function\"===typeof g&&Fg(b,d,g,a);e.updater=Jg;b.stateNode=e;e._reactInternalFiber=b;Ng(b,d,a,c);b=gi(null,b,d,!0,f,c)}else b.tag=0,R(null,b,e,c),b=b.child;return b;case 16:a:{e=b.elementType;null!==a&&(a.alternate=\nnull,b.alternate=null,b.effectTag|=2);a=b.pendingProps;ob(e);if(1!==e._status)throw e._result;e=e._result;b.type=e;f=b.tag=Xj(e);a=ig(e,a);switch(f){case 0:b=di(null,b,e,a,c);break a;case 1:b=fi(null,b,e,a,c);break a;case 11:b=Zh(null,b,e,a,c);break a;case 14:b=ai(null,b,e,ig(e.type,a),d,c);break a}throw Error(u(306,e,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:ig(d,e),di(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:ig(d,e),fi(a,b,d,e,c);\ncase 3:hi(b);d=b.updateQueue;if(null===a||null===d)throw Error(u(282));d=b.pendingProps;e=b.memoizedState;e=null!==e?e.element:null;vg(a,b);zg(b,d,null,c);d=b.memoizedState.element;if(d===e)Xh(),b=$h(a,b,c);else{if(e=b.stateNode.hydrate)Ph=Jd(b.stateNode.containerInfo.firstChild),Oh=b,e=Qh=!0;if(e)for(c=Yg(b,null,d,c),b.child=c;c;)c.effectTag=c.effectTag&-3|1024,c=c.sibling;else R(a,b,d,c),Xh();b=b.child}return b;case 5:return fh(b),null===a&&Uh(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:\nnull,g=e.children,Gd(d,e)?g=null:null!==f&&Gd(d,f)&&(b.effectTag|=16),ei(a,b),b.mode&4&&1!==c&&e.hidden?(b.expirationTime=b.childExpirationTime=1,b=null):(R(a,b,g,c),b=b.child),b;case 6:return null===a&&Uh(b),null;case 13:return ji(a,b,c);case 4:return dh(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=Xg(b,null,d,c):R(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:ig(d,e),Zh(a,b,d,e,c);case 7:return R(a,b,b.pendingProps,c),b.child;case 8:return R(a,\nb,b.pendingProps.children,c),b.child;case 12:return R(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;e=b.pendingProps;g=b.memoizedProps;f=e.value;var h=b.type._context;I(jg,h._currentValue);h._currentValue=f;if(null!==g)if(h=g.value,f=$e(h,f)?0:(\"function\"===typeof d._calculateChangedBits?d._calculateChangedBits(h,f):1073741823)|0,0===f){if(g.children===e.children&&!K.current){b=$h(a,b,c);break a}}else for(h=b.child,null!==h&&(h.return=b);null!==h;){var k=h.dependencies;if(null!==\nk){g=h.child;for(var l=k.firstContext;null!==l;){if(l.context===d&&0!==(l.observedBits&f)){1===h.tag&&(l=wg(c,null),l.tag=2,xg(h,l));h.expirationTime=b&&a<=b}function xi(a,b){var c=a.firstSuspendedTime,d=a.lastSuspendedTime;cb||0===c)a.lastSuspendedTime=b;b<=a.lastPingedTime&&(a.lastPingedTime=0);b<=a.lastExpiredTime&&(a.lastExpiredTime=0)}\nfunction yi(a,b){b>a.firstPendingTime&&(a.firstPendingTime=b);var c=a.firstSuspendedTime;0!==c&&(b>=c?a.firstSuspendedTime=a.lastSuspendedTime=a.nextKnownPendingLevel=0:b>=a.lastSuspendedTime&&(a.lastSuspendedTime=b+1),b>a.nextKnownPendingLevel&&(a.nextKnownPendingLevel=b))}function Cj(a,b){var c=a.lastExpiredTime;if(0===c||c>b)a.lastExpiredTime=b}\nfunction bk(a,b,c,d){var e=b.current,f=Gg(),g=Dg.suspense;f=Hg(f,e,g);a:if(c){c=c._reactInternalFiber;b:{if(dc(c)!==c||1!==c.tag)throw Error(u(170));var h=c;do{switch(h.tag){case 3:h=h.stateNode.context;break b;case 1:if(L(h.type)){h=h.stateNode.__reactInternalMemoizedMergedChildContext;break b}}h=h.return}while(null!==h);throw Error(u(171));}if(1===c.tag){var k=c.type;if(L(k)){c=Ff(c,k,h);break a}}c=h}else c=Af;null===b.context?b.context=c:b.pendingContext=c;b=wg(f,g);b.payload={element:a};d=void 0===\nd?null:d;null!==d&&(b.callback=d);xg(e,b);Ig(e,f);return f}function ck(a){a=a.current;if(!a.child)return null;switch(a.child.tag){case 5:return a.child.stateNode;default:return a.child.stateNode}}function dk(a,b){a=a.memoizedState;null!==a&&null!==a.dehydrated&&a.retryTime;\r\n\r\n\tconstructor(code: string) {\r\n\t\tthis.code = code;\r\n\t\tthis.texts = new Map();\r\n\t}\r\n}\r\n\r\nexport class UiLanguageService extends BaseService {\r\n\turl: string; // override\r\n\tunderrideUrl: string; // underride\r\n\r\n\tconstructor(private configurationService: ConfigurationService) {\r\n\t\tsuper();\r\n\r\n\t\tconst config = configurationService.getConfiguration();\r\n\r\n\t\tthis.url = config.smeBaseUrl + '/System/GetUiTexts?lang={CODE}';\r\n\t\tthis.underrideUrl = '{CODE}.json';\r\n\t}\r\n\r\n\tprivate mapDataToUiLanguage = (code: string, result: any): UiLanguage => {\r\n\t\tlet uiLanguage = new UiLanguage(code);\r\n\t\tuiLanguage.texts = result.texts;\r\n\t\treturn uiLanguage;\r\n\t};\r\n\r\n\tload(code: string): Promise {\r\n\t\treturn Promise.all([\r\n\t\t\tthis.loadTexts(this.url, code),\r\n\t\t\tthis.loadTexts(this.underrideUrl, code),\r\n\t\t]).then((result) => {\r\n\t\t\tlet uiLanguage: UiLanguage = result[1];\r\n\t\t\tif (result[0].texts) {\r\n\t\t\t\tObject.assign(uiLanguage.texts, result[0].texts);\r\n\t\t\t}\r\n\t\t\treturn uiLanguage;\r\n\t\t});\r\n\t}\r\n\r\n\tloadTexts(urlPattern: string, code: string): Promise {\r\n\t\tlet url = urlPattern.replace('{CODE}', code);\r\n\t\tlet p = fetch(url);\r\n\t\tlet p2 = p.then((result) => {\r\n\t\t\treturn result.json();\r\n\t\t});\r\n\t\tlet p3 = p2.then((result) => {\r\n\t\t\treturn this.mapDataToUiLanguage(code, result);\r\n\t\t});\r\n\t\treturn p3;\r\n\t}\r\n}\r\n","import OidcService from \"../services/OidcService\";\r\nimport { BaseService } from './BaseService';\r\nimport { StateService } from './StateService';\r\nimport { ConfigurationService } from './ConfigurationService';\r\nimport { ServerSession } from \"./OidcService\"\r\n\r\nexport interface Session {\r\n\tlogin?: Login;\r\n\tlogout?: Logout;\r\n}\r\n\r\nexport interface Login {\r\n\ttime: Date;\r\n\tssn: string;\r\n\tadmin: boolean;\r\n\tfirstName?: string;\r\n\tlastName?: string;\r\n\tcanSignIn: boolean,\r\n\tisUnderAge: boolean\r\n}\r\n\r\nexport interface Logout {\r\n\ttime: Date;\r\n\treason: LogoutReason\r\n}\r\n\r\nexport enum LogoutReason {\r\n\tUser = 1, // User choose to logout\r\n\tTimeout = 2, // Session timed out.\r\n\tSystem = 3 // System forced logout b/c error or maintenance.\r\n}\r\n\r\nexport class SessionService extends BaseService {\r\n\tprivate stateService: StateService;\r\n\tprivate oidcService: OidcService;\r\n\r\n\tsessionLoopHandle: any | undefined;\r\n\r\n\tconstructor(stateService: StateService, oidcService: OidcService, private configurationService: ConfigurationService) {\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.oidcService = oidcService\r\n\t}\r\n\r\n\tprivate startSessionLoop() {\r\n\t\tif (this.sessionLoopHandle)\r\n\t\t\treturn; // already started.\r\n\t\tthis.sessionLoopHandle = setInterval(() => {\r\n\t\t\tthis.oidcService.getSession().then(result => {\r\n\t\t\t\tthis.handleServerSession(result);\r\n\t\t\t})\r\n\t\t}, 60 * 1000);\r\n\t}\r\n\r\n\tprivate stopSessionLoop() {\r\n\t\tif (this.sessionLoopHandle) {\r\n\t\t\tclearInterval(this.sessionLoopHandle);\r\n\t\t\tthis.sessionLoopHandle = undefined;\r\n\t\t}\r\n\t}\r\n\r\n\t// Call this after ok login.\r\n\tloadSession(): Promise {\r\n\t\treturn this.oidcService.getSession().then(result => {\r\n\t\t\tthis.handleServerSession(result);\r\n\t\t\tif (result.isLoggedIn) {\r\n\t\t\t\tthis.startSessionLoop();\r\n\t\t\t}\r\n\t\t\treturn result;\r\n\t\t})\r\n\t}\r\n\r\n\thandleServerSession(serverSession: ServerSession) {\r\n\t\tif (!serverSession.isLoggedIn) {\r\n\t\t\tif (this.isLoggedIn()) {\r\n\t\t\t\tthis.logout(LogoutReason.Timeout);\r\n\t\t\t\t//console.log('User was logged out via server session.');\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tif (!this.isLoggedIn()) {\r\n\t\t\t\t//console.log('User was logged in via server session.');\r\n\t\t\t\tlet newLogin = this.createNewLogin(serverSession);\r\n\t\t\t\tthis.setNewLogin(newLogin);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tisLoggedIn(): boolean {\r\n\t\treturn this.stateService.state.session.login !== undefined;\r\n\t}\r\n\r\n\tisAdmin(): boolean {\r\n\t\tif (!this.isLoggedIn())\r\n\t\t\treturn false;\r\n\r\n\t\tvar login = this.getLogin();\r\n\t\treturn login?.admin === true;\r\n\t}\r\n\r\n\tgetLogin(): Login {\r\n\t\tlet login = this.stateService.state.session.login;\r\n\t\tif (!login) {\r\n\t\t\tthrow new Error('Not logged in.');\r\n\t\t}\r\n\t\treturn login;\r\n\t}\r\n\r\n\tgetSsn(): string {\r\n\t\tconst login = this.getLogin();\r\n\t\tconst ssn = login.ssn;\r\n\t\treturn ssn;\r\n\t}\r\n\r\n\r\n\tgetLogout(): Logout | undefined {\r\n\t\tif (this.isLoggedIn())\r\n\t\t\tthrow new Error('Not logged out.');\r\n\r\n\t\tlet logout = this.stateService.state.session.logout;\r\n\t\treturn logout;\r\n\t}\r\n\r\n\tdidLogOut(): boolean {\r\n\t\treturn this.stateService.state.session.logout !== undefined;\r\n\t}\r\n\r\n\tlogout(reason: LogoutReason = LogoutReason.User): Promise {\r\n\t\tlet state = this.stateService.state;\r\n\t\tlet session = state.session;\r\n\t\tsession.login = undefined;\r\n\t\tsession.logout = {\r\n\t\t\ttime: new Date(),\r\n\t\t\treason: reason\r\n\t\t};\r\n\t\tstate.cases = undefined;\r\n\t\tstate.case = undefined;\r\n\t\tthis.stateService.update(session);\r\n\t\tthis.stateService.update(state);\r\n\t\tthis.stopSessionLoop();\r\n\t\treturn Promise.resolve(session);\r\n\t}\r\n\r\n\tprivate createNewLogin(serverSession: ServerSession): Login {\r\n\t\tconst ss = serverSession;\r\n\t\tlet login = {\r\n\t\t\ttime: new Date(),\r\n\t\t\tssn: ss.ssn,\r\n\t\t\tadmin: ss.isAdmin,\r\n\t\t\tfirstName: ss.firstName,\r\n\t\t\tlastName: ss.lastName,\r\n\t\t\tcanSignIn: ss.canSignIn,\r\n\t\t\tisUnderAge: ss.isUnderAge\r\n\t\t};\r\n\t\treturn login;\r\n\t}\r\n\r\n\tprivate setNewLogin(login: Login) {\r\n\t\tlet session = this.stateService.state.session;\r\n\t\tlet prevLogin = session.login;\r\n\t\tsession.login = login;\r\n\t\tsession.logout = undefined;\r\n\t\tthis.stateService.replace(prevLogin, login);\r\n\t\tthis.stateService.update(session);\r\n\t\treturn session;\r\n\t}\r\n\r\n\t// private handleLoginSuccess = (result: BidLoginResult): BidLoginResult => {\r\n\t// \tlet session = this.stateService.state.session;\r\n\t// \treturn result;\r\n\r\n\t// \t//todo här ska man inte sättas som inloggad, man har endast begärt att få börja bli inloggad och påbörat bankid-identifiering via externa bankid-applikationen\r\n\r\n\t// \t//let prevLogin = session.login;\r\n\t// \t// let login = session.login = {\r\n\t// \t// \ttime: new Date(),\r\n\t// \t// \tssn: result.ssn,\r\n\t// \t// \tadmin: true,\r\n\t// \t// \ttoken: result.token,\r\n\t// \t// \tfirstName: result.firstName,\r\n\t// \t// \tlastName: result.lastName\r\n\t// \t// };\r\n\t// \t//session.logout = undefined;\r\n\r\n\t// \t//this.stateService.replace(prevLogin, login);\r\n\t// \t//this.stateService.update(session);\r\n\t// \t//return session;\r\n\t// }\r\n\r\n\t// private handleLoginError = (result: BidLoginResult): BidLoginResult => {\r\n\t// \treturn result;\r\n\t// \t// let session = this.stateService.state.session;\r\n\t// \t// let prevLogin = session.login;\r\n\t// \t// return session;\r\n\t// }\r\n\r\n\t// loginMobile(ssn: string): Promise {\r\n\t// \treturn this.bidService.login(ssn, 'MOBILE')\r\n\t// \t\t.then(this.handleLoginSuccess, this.handleLoginError);\r\n\t// }\r\n\r\n\t// loginLocal(ssn: string): Promise {\r\n\t// \treturn this.bidService.login(ssn, 'SAME')\r\n\t// \t\t.then(this.handleLoginSuccess, this.handleLoginError);\r\n\t// }\r\n\t// checkLoginState(loginToken: string): Promise {\r\n\t// \treturn this.bidService.checkLogin(loginToken);\r\n\t// }\r\n\t// loginWithAutostartToken(autostartToken: string): void {\r\n\t// \treturn this.bidService.redirectToBankIDApp(autostartToken);\r\n\t// }\r\n\t// collect(startToken: string): Promise {\r\n\t// \treturn this.bidService.collect(startToken);\r\n\t// }\r\n}\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n\r\nexport const BASE_PATH = \"https://localhost:8443\".replace(/\\/+$/, \"\");\r\n\r\nconst isBlob = (value: any) => typeof Blob !== 'undefined' && value instanceof Blob;\r\n\r\n/**\r\n * This is the base class for all generated API classes.\r\n */\r\nexport class BaseAPI {\r\n\r\n private middleware: Middleware[];\r\n\r\n constructor(protected configuration = new Configuration()) {\r\n this.middleware = configuration.middleware;\r\n }\r\n\r\n withMiddleware(this: T, ...middlewares: Middleware[]) {\r\n const next = this.clone();\r\n next.middleware = next.middleware.concat(...middlewares);\r\n return next;\r\n }\r\n\r\n withPreMiddleware(this: T, ...preMiddlewares: Array) {\r\n const middlewares = preMiddlewares.map((pre) => ({ pre }));\r\n return this.withMiddleware(...middlewares);\r\n }\r\n\r\n withPostMiddleware(this: T, ...postMiddlewares: Array) {\r\n const middlewares = postMiddlewares.map((post) => ({ post }));\r\n return this.withMiddleware(...middlewares);\r\n }\r\n\r\n protected async request(context: RequestOpts): Promise {\r\n const { url, init } = this.createFetchParams(context);\r\n const response = await this.fetchApi(url, init);\r\n if (response.status >= 200 && response.status < 300) {\r\n return response;\r\n }\r\n throw response;\r\n }\r\n\r\n private createFetchParams(context: RequestOpts) {\r\n let url = this.configuration.basePath + context.path;\r\n if (context.query !== undefined && Object.keys(context.query).length !== 0) {\r\n // only add the querystring to the URL if there are query parameters.\r\n // this is done to avoid urls ending with a \"?\" character which buggy webservers\r\n // do not handle correctly sometimes.\r\n url += '?' + this.configuration.queryParamsStringify(context.query);\r\n }\r\n const body = (context.body instanceof FormData || context.body instanceof URLSearchParams || isBlob(context.body))\r\n\t ? context.body\r\n\t : JSON.stringify(context.body);\r\n\r\n const headers = Object.assign({}, this.configuration.headers, context.headers);\r\n const init = {\r\n method: context.method,\r\n headers: headers,\r\n body,\r\n credentials: this.configuration.credentials\r\n };\r\n return { url, init };\r\n }\r\n\r\n private fetchApi = async (url: string, init: RequestInit) => {\r\n let fetchParams = { url, init };\r\n for (const middleware of this.middleware) {\r\n if (middleware.pre) {\r\n fetchParams = await middleware.pre({\r\n fetch: this.fetchApi,\r\n ...fetchParams,\r\n }) || fetchParams;\r\n }\r\n }\r\n let response = await this.configuration.fetchApi(fetchParams.url, fetchParams.init);\r\n for (const middleware of this.middleware) {\r\n if (middleware.post) {\r\n response = await middleware.post({\r\n fetch: this.fetchApi,\r\n url,\r\n init,\r\n response: response.clone(),\r\n }) || response;\r\n }\r\n }\r\n return response;\r\n }\r\n\r\n /**\r\n * Create a shallow clone of `this` by constructing a new instance\r\n * and then shallow cloning data members.\r\n */\r\n private clone(this: T): T {\r\n const constructor = this.constructor as any;\r\n const next = new constructor(this.configuration);\r\n next.middleware = this.middleware.slice();\r\n return next;\r\n }\r\n};\r\n\r\nexport class RequiredError extends Error {\r\n name: \"RequiredError\" = \"RequiredError\";\r\n constructor(public field: string, msg?: string) {\r\n super(msg);\r\n }\r\n}\r\n\r\nexport const COLLECTION_FORMATS = {\r\n csv: \",\",\r\n ssv: \" \",\r\n tsv: \"\\t\",\r\n pipes: \"|\",\r\n};\r\n\r\nexport type FetchAPI = GlobalFetch['fetch'];\r\n\r\nexport interface ConfigurationParameters {\r\n basePath?: string; // override base path\r\n fetchApi?: FetchAPI; // override for fetch implementation\r\n middleware?: Middleware[]; // middleware to apply before/after fetch requests\r\n queryParamsStringify?: (params: HTTPQuery) => string; // stringify function for query strings\r\n username?: string; // parameter for basic security\r\n password?: string; // parameter for basic security\r\n apiKey?: string | ((name: string) => string); // parameter for apiKey security\r\n accessToken?: string | ((name?: string, scopes?: string[]) => string); // parameter for oauth2 security\r\n headers?: HTTPHeaders; //header params we want to use on every request\r\n credentials?: RequestCredentials; //value for the credentials param we want to use on each request\r\n}\r\n\r\nexport class Configuration {\r\n constructor(private configuration: ConfigurationParameters = {}) {}\r\n\r\n get basePath(): string {\r\n return this.configuration.basePath || BASE_PATH;\r\n }\r\n\r\n get fetchApi(): FetchAPI {\r\n return this.configuration.fetchApi || window.fetch.bind(window);\r\n }\r\n\r\n get middleware(): Middleware[] {\r\n return this.configuration.middleware || [];\r\n }\r\n\r\n get queryParamsStringify(): (params: HTTPQuery) => string {\r\n return this.configuration.queryParamsStringify || querystring;\r\n }\r\n\r\n get username(): string | undefined {\r\n return this.configuration.username;\r\n }\r\n\r\n get password(): string | undefined {\r\n return this.configuration.password;\r\n }\r\n\r\n get apiKey(): ((name: string) => string) | undefined {\r\n const apiKey = this.configuration.apiKey;\r\n if (apiKey) {\r\n return typeof apiKey === 'function' ? apiKey : () => apiKey;\r\n }\r\n return undefined;\r\n }\r\n\r\n get accessToken(): ((name: string, scopes?: string[]) => string) | undefined {\r\n const accessToken = this.configuration.accessToken;\r\n if (accessToken) {\r\n return typeof accessToken === 'function' ? accessToken : () => accessToken;\r\n }\r\n return undefined;\r\n }\r\n\r\n get headers(): HTTPHeaders | undefined {\r\n return this.configuration.headers;\r\n }\r\n\r\n get credentials(): RequestCredentials | undefined {\r\n return this.configuration.credentials;\r\n }\r\n}\r\n\r\nexport type Json = any;\r\nexport type HTTPMethod = 'GET' | 'POST' | 'PUT' | 'PATCH' | 'DELETE' | 'OPTIONS';\r\nexport type HTTPHeaders = { [key: string]: string };\r\nexport type HTTPQuery = { [key: string]: string | number | null | boolean | Array | HTTPQuery };\r\nexport type HTTPBody = Json | FormData | URLSearchParams;\r\nexport type ModelPropertyNaming = 'camelCase' | 'snake_case' | 'PascalCase' | 'original';\r\n\r\nexport interface FetchParams {\r\n url: string;\r\n init: RequestInit;\r\n}\r\n\r\nexport interface RequestOpts {\r\n path: string;\r\n method: HTTPMethod;\r\n headers: HTTPHeaders;\r\n query?: HTTPQuery;\r\n body?: HTTPBody;\r\n}\r\n\r\nexport function exists(json: any, key: string) {\r\n const value = json[key];\r\n return value !== null && value !== undefined;\r\n}\r\n\r\nexport function querystring(params: HTTPQuery, prefix: string = ''): string {\r\n return Object.keys(params)\r\n .map((key) => {\r\n const fullKey = prefix + (prefix.length ? `[${key}]` : key);\r\n const value = params[key];\r\n if (value instanceof Array) {\r\n const multiValue = value.map(singleValue => encodeURIComponent(String(singleValue)))\r\n .join(`&${encodeURIComponent(fullKey)}=`);\r\n return `${encodeURIComponent(fullKey)}=${multiValue}`;\r\n }\r\n if (value instanceof Object) {\r\n return querystring(value as HTTPQuery, fullKey);\r\n }\r\n return `${encodeURIComponent(fullKey)}=${encodeURIComponent(String(value))}`;\r\n })\r\n .filter(part => part.length > 0)\r\n .join('&');\r\n}\r\n\r\nexport function mapValues(data: any, fn: (item: any) => any) {\r\n return Object.keys(data).reduce(\r\n (acc, key) => ({ ...acc, [key]: fn(data[key]) }),\r\n {}\r\n );\r\n}\r\n\r\nexport function canConsumeForm(consumes: Consume[]): boolean {\r\n for (const consume of consumes) {\r\n if ('multipart/form-data' === consume.contentType) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n}\r\n\r\nexport interface Consume {\r\n contentType: string\r\n}\r\n\r\nexport interface RequestContext {\r\n fetch: FetchAPI;\r\n url: string;\r\n init: RequestInit;\r\n}\r\n\r\nexport interface ResponseContext {\r\n fetch: FetchAPI;\r\n url: string;\r\n init: RequestInit;\r\n response: Response;\r\n}\r\n\r\nexport interface Middleware {\r\n pre?(context: RequestContext): Promise;\r\n post?(context: ResponseContext): Promise;\r\n}\r\n\r\nexport interface ApiResponse {\r\n raw: Response;\r\n value(): Promise;\r\n}\r\n\r\nexport interface ResponseTransformer {\r\n (json: any): T;\r\n}\r\n\r\nexport class JSONApiResponse {\r\n constructor(public raw: Response, private transformer: ResponseTransformer = (jsonValue: any) => jsonValue) {}\r\n\r\n async value() {\r\n return this.transformer(await this.raw.json());\r\n }\r\n}\r\n\r\nexport class VoidApiResponse {\r\n constructor(public raw: Response) {}\r\n\r\n async value() {\r\n return undefined;\r\n }\r\n}\r\n\r\nexport class BlobApiResponse {\r\n constructor(public raw: Response) {}\r\n\r\n async value() {\r\n return await this.raw.blob();\r\n };\r\n}\r\n\r\nexport class TextApiResponse {\r\n constructor(public raw: Response) {}\r\n\r\n async value() {\r\n return await this.raw.text();\r\n };\r\n}\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * Syfte med respektive lånebelopp\r\n * @export\r\n * @interface AimType\r\n */\r\nexport interface AimType {\r\n /**\r\n * Unique identity for aims\r\n * @type {string}\r\n * @memberof AimType\r\n */\r\n aimId: string;\r\n /**\r\n * Ändamål och syfte ska sättas på respektive lån som går över till LP. I de fall där det inte specifiseras ska handläggaren göra det innan överföring till SAP. Detta för att de ska bli rätt i uppföljning ned i SAS och den finsiella rapporteringen.\r\n * @type {string}\r\n * @memberof AimType\r\n */\r\n purposeText?: string;\r\n /**\r\n * Delsyfte på respektive lån, läses från mainPurposes.json\r\n * @type {string}\r\n * @memberof AimType\r\n */\r\n aimText?: string;\r\n /**\r\n * Lånebelopp för part\r\n * @type {number}\r\n * @memberof AimType\r\n */\r\n loanAmountPart?: number;\r\n}\r\n\r\nexport function AimTypeFromJSON(json: any): AimType {\r\n return AimTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function AimTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): AimType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'aimId': json['aimId'],\r\n 'purposeText': !exists(json, 'purposeText') ? undefined : json['purposeText'],\r\n 'aimText': !exists(json, 'aimText') ? undefined : json['aimText'],\r\n 'loanAmountPart': !exists(json, 'loanAmountPart') ? undefined : json['loanAmountPart'],\r\n };\r\n}\r\n\r\nexport function AimTypeToJSON(value?: AimType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'aimId': value.aimId,\r\n 'purposeText': value.purposeText,\r\n 'aimText': value.aimText,\r\n 'loanAmountPart': value.loanAmountPart,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n/**\r\n * Employeed or Not Employeed, from SAP on existing customer and from UC? or entered by customer. employment mapping to Loan Process PERMANENT - Anställd, tills-vidare-anställd TEMPORARY - Tidbegränsad anställning PROBATIONARY - Provanställning UNEMPLOYMENT_INSURANCE - Arbetslöshetskassa SELF_EMPLOYED - Eget företag STUDENT_AID - Studiestöd PENSION - Inkomst av pension\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum ApplicantEmployed {\r\n PERMANENT = 'PERMANENT',\r\n TEMPORARY = 'TEMPORARY',\r\n PROBATIONARY = 'PROBATIONARY',\r\n UNEMPLOYMENTINSURANCE = 'UNEMPLOYMENT_INSURANCE',\r\n SELFEMPLOYED = 'SELF_EMPLOYED',\r\n STUDENTAID = 'STUDENT_AID',\r\n PENSION = 'PENSION'\r\n}\r\n\r\nexport function ApplicantEmployedFromJSON(json: any): ApplicantEmployed {\r\n return ApplicantEmployedFromJSONTyped(json, false);\r\n}\r\n\r\nexport function ApplicantEmployedFromJSONTyped(json: any, ignoreDiscriminator: boolean): ApplicantEmployed {\r\n return json as ApplicantEmployed;\r\n}\r\n\r\nexport function ApplicantEmployedToJSON(value?: ApplicantEmployed | null): any {\r\n return value as any;\r\n}\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n/**\r\n * employment mapping to Loan Process PERMANENT - Anställd, tills-vidare-anställd TEMPORARY - Tidbegränsad anställning PROBATIONARY - Provanställning UNEMPLOYMENT_INSURANCE - Arbetslöshetskassa SELF_EMPLOYED - Eget företag STUDENT_AID - Studiestöd PENSION - Inkomst av pension\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum ApplicantLPEmployment {\r\n PERMANENT = 'PERMANENT',\r\n TEMPORARY = 'TEMPORARY',\r\n PROBATIONARY = 'PROBATIONARY',\r\n UNEMPLOYMENTINSURANCE = 'UNEMPLOYMENT_INSURANCE',\r\n SELFEMPLOYED = 'SELF_EMPLOYED',\r\n STUDENTAID = 'STUDENT_AID',\r\n PENSION = 'PENSION'\r\n}\r\n\r\nexport function ApplicantLPEmploymentFromJSON(json: any): ApplicantLPEmployment {\r\n return ApplicantLPEmploymentFromJSONTyped(json, false);\r\n}\r\n\r\nexport function ApplicantLPEmploymentFromJSONTyped(json: any, ignoreDiscriminator: boolean): ApplicantLPEmployment {\r\n return json as ApplicantLPEmployment;\r\n}\r\n\r\nexport function ApplicantLPEmploymentToJSON(value?: ApplicantLPEmployment | null): any {\r\n return value as any;\r\n}\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n ApplicantEmployed,\r\n ApplicantEmployedFromJSON,\r\n ApplicantEmployedFromJSONTyped,\r\n ApplicantEmployedToJSON,\r\n ApplicantLPEmployment,\r\n ApplicantLPEmploymentFromJSON,\r\n ApplicantLPEmploymentFromJSONTyped,\r\n ApplicantLPEmploymentToJSON,\r\n ContactInformationType,\r\n ContactInformationTypeFromJSON,\r\n ContactInformationTypeFromJSONTyped,\r\n ContactInformationTypeToJSON,\r\n StakeholderType,\r\n StakeholderTypeFromJSON,\r\n StakeholderTypeFromJSONTyped,\r\n StakeholderTypeToJSON,\r\n} from './';\r\n\r\n/**\r\n * Type of applicant instance\r\n * @export\r\n * @interface ApplicantType\r\n */\r\nexport interface ApplicantType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof ApplicantType\r\n */\r\n processId: string;\r\n /**\r\n * customerId is swedish ssn or corporate organisation number\r\n * @type {string}\r\n * @memberof ApplicantType\r\n */\r\n customerId: string;\r\n /**\r\n * unique id for each applicant in the credit case\r\n * @type {string}\r\n * @memberof ApplicantType\r\n */\r\n applicantId: string;\r\n /**\r\n * Full name of the customer/applicant\r\n * @type {string}\r\n * @memberof ApplicantType\r\n */\r\n applicantName?: string;\r\n /**\r\n * Street address of Applicant\r\n * @type {string}\r\n * @memberof ApplicantType\r\n */\r\n applicantAddress?: string;\r\n /**\r\n * Postal code\r\n * @type {string}\r\n * @memberof ApplicantType\r\n */\r\n applicantPostalCode?: string;\r\n /**\r\n * Postal city\r\n * @type {string}\r\n * @memberof ApplicantType\r\n */\r\n applicantPostAddress?: string;\r\n /**\r\n * \r\n * @type {StakeholderType}\r\n * @memberof ApplicantType\r\n */\r\n stakeholderType?: StakeholderType;\r\n /**\r\n * \r\n * @type {ContactInformationType}\r\n * @memberof ApplicantType\r\n */\r\n contactInformation?: ContactInformationType;\r\n /**\r\n * \r\n * @type {ApplicantEmployed}\r\n * @memberof ApplicantType\r\n */\r\n applicantEmployed?: ApplicantEmployed;\r\n /**\r\n * \r\n * @type {ApplicantLPEmployment}\r\n * @memberof ApplicantType\r\n */\r\n applicantLPEmployment?: ApplicantLPEmployment;\r\n /**\r\n * Member in Landshypotek Ekonomiska förening (true/false). Tänkt som befitlig medlem, behöver koppling till SAP.\r\n * @type {boolean}\r\n * @memberof ApplicantType\r\n */\r\n applicantMember?: boolean;\r\n /**\r\n * Applicant want to be notified by sms (true/false)\r\n * @type {boolean}\r\n * @memberof ApplicantType\r\n */\r\n applicantBySms?: boolean;\r\n /**\r\n * Applicant want to be notified by eMail (true/false)\r\n * @type {boolean}\r\n * @memberof ApplicantType\r\n */\r\n applicantByeMail?: boolean;\r\n /**\r\n * Personens namn har eller avser köpa en jord och skogsbruksfastighet.\r\n * @type {boolean}\r\n * @memberof ApplicantType\r\n */\r\n applicantCollateralToBuy?: boolean;\r\n}\r\n\r\nexport function ApplicantTypeFromJSON(json: any): ApplicantType {\r\n return ApplicantTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function ApplicantTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): ApplicantType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'customerId': json['customerId'],\r\n 'applicantId': json['applicantId'],\r\n 'applicantName': !exists(json, 'applicantName') ? undefined : json['applicantName'],\r\n 'applicantAddress': !exists(json, 'applicantAddress') ? undefined : json['applicantAddress'],\r\n 'applicantPostalCode': !exists(json, 'applicantPostalCode') ? undefined : json['applicantPostalCode'],\r\n 'applicantPostAddress': !exists(json, 'applicantPostAddress') ? undefined : json['applicantPostAddress'],\r\n 'stakeholderType': !exists(json, 'stakeholderType') ? undefined : StakeholderTypeFromJSON(json['stakeholderType']),\r\n 'contactInformation': !exists(json, 'contactInformation') ? undefined : ContactInformationTypeFromJSON(json['contactInformation']),\r\n 'applicantEmployed': !exists(json, 'applicantEmployed') ? undefined : ApplicantEmployedFromJSON(json['applicantEmployed']),\r\n 'applicantLPEmployment': !exists(json, 'applicantLPEmployment') ? undefined : ApplicantLPEmploymentFromJSON(json['applicantLPEmployment']),\r\n 'applicantMember': !exists(json, 'applicantMember') ? undefined : json['applicantMember'],\r\n 'applicantBySms': !exists(json, 'applicantBySms') ? undefined : json['applicantBySms'],\r\n 'applicantByeMail': !exists(json, 'applicantByeMail') ? undefined : json['applicantByeMail'],\r\n 'applicantCollateralToBuy': !exists(json, 'applicantCollateralToBuy') ? undefined : json['applicantCollateralToBuy'],\r\n };\r\n}\r\n\r\nexport function ApplicantTypeToJSON(value?: ApplicantType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'customerId': value.customerId,\r\n 'applicantId': value.applicantId,\r\n 'applicantName': value.applicantName,\r\n 'applicantAddress': value.applicantAddress,\r\n 'applicantPostalCode': value.applicantPostalCode,\r\n 'applicantPostAddress': value.applicantPostAddress,\r\n 'stakeholderType': StakeholderTypeToJSON(value.stakeholderType),\r\n 'contactInformation': ContactInformationTypeToJSON(value.contactInformation),\r\n 'applicantEmployed': ApplicantEmployedToJSON(value.applicantEmployed),\r\n 'applicantLPEmployment': ApplicantLPEmploymentToJSON(value.applicantLPEmployment),\r\n 'applicantMember': value.applicantMember,\r\n 'applicantBySms': value.applicantBySms,\r\n 'applicantByeMail': value.applicantByeMail,\r\n 'applicantCollateralToBuy': value.applicantCollateralToBuy,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n BudgetYearType,\r\n BudgetYearTypeFromJSON,\r\n BudgetYearTypeFromJSONTyped,\r\n BudgetYearTypeToJSON,\r\n} from './';\r\n\r\n/**\r\n * Type definition for companyBudget\r\n * @export\r\n * @interface BudgetType\r\n */\r\nexport interface BudgetType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof BudgetType\r\n */\r\n processId: string;\r\n /**\r\n * Type definition for company economy\r\n * @type {string}\r\n * @memberof BudgetType\r\n */\r\n companyEconomyId?: string;\r\n /**\r\n * Budget years\r\n * @type {Array}\r\n * @memberof BudgetType\r\n */\r\n budgetYears?: Array;\r\n}\r\n\r\nexport function BudgetTypeFromJSON(json: any): BudgetType {\r\n return BudgetTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function BudgetTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): BudgetType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'companyEconomyId': !exists(json, 'companyEconomyId') ? undefined : json['companyEconomyId'],\r\n 'budgetYears': !exists(json, 'budgetYears') ? undefined : ((json['budgetYears'] as Array).map(BudgetYearTypeFromJSON)),\r\n };\r\n}\r\n\r\nexport function BudgetTypeToJSON(value?: BudgetType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'companyEconomyId': value.companyEconomyId,\r\n 'budgetYears': value.budgetYears === undefined ? undefined : ((value.budgetYears as Array).map(BudgetYearTypeToJSON)),\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n ValueType,\r\n ValueTypeFromJSON,\r\n ValueTypeFromJSONTyped,\r\n ValueTypeToJSON,\r\n} from './';\r\n\r\n/**\r\n * Avser ett enskilt budgetår\r\n * @export\r\n * @interface BudgetYearType\r\n */\r\nexport interface BudgetYearType {\r\n /**\r\n * unique identifier for a specifict budget\r\n * @type {string}\r\n * @memberof BudgetYearType\r\n */\r\n budgetId?: string;\r\n /**\r\n * Budget avser år, ska generas av API, föregående år - 2 år. Value1-7 är intäkter och summeras i Loan Process\r\n * @type {number}\r\n * @memberof BudgetYearType\r\n */\r\n budgetyear?: number;\r\n /**\r\n * \r\n * @type {ValueType}\r\n * @memberof BudgetYearType\r\n */\r\n budget?: ValueType;\r\n}\r\n\r\nexport function BudgetYearTypeFromJSON(json: any): BudgetYearType {\r\n return BudgetYearTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function BudgetYearTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): BudgetYearType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'budgetId': !exists(json, 'budgetId') ? undefined : json['budgetId'],\r\n 'budgetyear': !exists(json, 'budgetyear') ? undefined : json['budgetyear'],\r\n 'budget': !exists(json, 'budget') ? undefined : ValueTypeFromJSON(json['budget']),\r\n };\r\n}\r\n\r\nexport function BudgetYearTypeToJSON(value?: BudgetYearType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'budgetId': value.budgetId,\r\n 'budgetyear': value.budgetyear,\r\n 'budget': ValueTypeToJSON(value.budget),\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.6\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * TBD\r\n * @export\r\n * @interface BusinessCategoryType\r\n */\r\nexport interface BusinessCategoryType {\r\n /**\r\n * unique identity for businessCategoryType\r\n * @type {string}\r\n * @memberof BusinessCategoryType\r\n */\r\n businessId?: string;\r\n /**\r\n * Huvudrubrik för driftinriktning\r\n * @type {string}\r\n * @memberof BusinessCategoryType\r\n */\r\n businessCategory?: string;\r\n /**\r\n * Del av huvudsaklig driftinriktning\r\n * @type {number}\r\n * @memberof BusinessCategoryType\r\n */\r\n businessPart?: number;\r\n /**\r\n * Vald huvuddrifitinriktning av kund, kan vara vara ett val oavsett antal driftinriktningar.\r\n * @type {boolean}\r\n * @memberof BusinessCategoryType\r\n */\r\n mainBusiness?: boolean;\r\n}\r\n\r\n/**\r\n * Check if a given object implements the BusinessCategoryType interface.\r\n */\r\nexport function instanceOfBusinessCategoryType(value: object): boolean {\r\n let isInstance = true;\r\n\r\n return isInstance;\r\n}\r\n\r\nexport function BusinessCategoryTypeFromJSON(json: any): BusinessCategoryType {\r\n return BusinessCategoryTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function BusinessCategoryTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): BusinessCategoryType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'businessId': !exists(json, 'businessId') ? undefined : json['businessId'],\r\n 'businessCategory': !exists(json, 'businessCategory') ? undefined : json['businessCategory'],\r\n 'businessPart': !exists(json, 'businessPart') ? undefined : json['businessPart'],\r\n 'mainBusiness': !exists(json, 'mainBusiness') ? undefined : json['mainBusiness'],\r\n };\r\n}\r\n\r\nexport function BusinessCategoryTypeToJSON(value?: BusinessCategoryType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'businessId': value.businessId,\r\n 'businessCategory': value.businessCategory,\r\n 'businessPart': value.businessPart,\r\n 'mainBusiness': value.mainBusiness,\r\n };\r\n}\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n/**\r\n * Set status on the caseId or in the process (application)\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum CaseIdStatus {\r\n CLOSEDBYAPPLICANT = 'CLOSEDBYAPPLICANT',\r\n STARTEDBYAPPLICANT = 'STARTEDBYAPPLICANT',\r\n CLOSEDBYOFFICER = 'CLOSEDBYOFFICER',\r\n CLOSEDBYTHINNING = 'CLOSEDBYTHINNING',\r\n READYFOROFFICER = 'READYFOROFFICER'\r\n}\r\n\r\nexport function CaseIdStatusFromJSON(json: any): CaseIdStatus {\r\n return CaseIdStatusFromJSONTyped(json, false);\r\n}\r\n\r\nexport function CaseIdStatusFromJSONTyped(json: any, ignoreDiscriminator: boolean): CaseIdStatus {\r\n return json as CaseIdStatus;\r\n}\r\n\r\nexport function CaseIdStatusToJSON(value?: CaseIdStatus | null): any {\r\n return value as any;\r\n}\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * ChildType, belong to household\r\n * @export\r\n * @interface ChildType\r\n */\r\nexport interface ChildType {\r\n /**\r\n * identity for child\r\n * @type {string}\r\n * @memberof ChildType\r\n */\r\n childId: string;\r\n /**\r\n * Barns ålder i hushållet\r\n * @type {number}\r\n * @memberof ChildType\r\n */\r\n childsAge?: number;\r\n /**\r\n * barnet bor i hushållet heltid/deltid (true/false)\r\n * @type {boolean}\r\n * @memberof ChildType\r\n */\r\n partInHousehold?: boolean;\r\n}\r\n\r\nexport function ChildTypeFromJSON(json: any): ChildType {\r\n return ChildTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function ChildTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): ChildType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'childId': json['childId'],\r\n 'childsAge': !exists(json, 'childsAge') ? undefined : json['childsAge'],\r\n 'partInHousehold': !exists(json, 'partInHousehold') ? undefined : json['partInHousehold'],\r\n };\r\n}\r\n\r\nexport function ChildTypeToJSON(value?: ChildType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'childId': value.childId,\r\n 'childsAge': value.childsAge,\r\n 'partInHousehold': value.partInHousehold,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n/**\r\n * Ålder på skogen för säkerheten, behöver ses över, finns inte i GUI idag.\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum CollateralAge {\r\n _020R = '0-20 år',\r\n _2140R = '21-40 år',\r\n _4160R = '41-60 år',\r\n _6180R = '61-80 år',\r\n _81100R = '81-100 år'\r\n}\r\n\r\nexport function CollateralAgeFromJSON(json: any): CollateralAge {\r\n return CollateralAgeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function CollateralAgeFromJSONTyped(json: any, ignoreDiscriminator: boolean): CollateralAge {\r\n return json as CollateralAge;\r\n}\r\n\r\nexport function CollateralAgeToJSON(value?: CollateralAge | null): any {\r\n return value as any;\r\n}\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n CollateralAge,\r\n CollateralAgeFromJSON,\r\n CollateralAgeFromJSONTyped,\r\n CollateralAgeToJSON,\r\n TaxedOwnerType,\r\n TaxedOwnerTypeFromJSON,\r\n TaxedOwnerTypeFromJSONTyped,\r\n TaxedOwnerTypeToJSON,\r\n TypeOfCollateral,\r\n TypeOfCollateralFromJSON,\r\n TypeOfCollateralFromJSONTyped,\r\n TypeOfCollateralToJSON,\r\n} from './';\r\n\r\n/**\r\n * Säkerheter för lånet, om köp, även andra fastigheter kan användas som säkerhet för lånet\r\n * @export\r\n * @interface CollateralType\r\n */\r\nexport interface CollateralType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof CollateralType\r\n */\r\n processId: string;\r\n /**\r\n * customerId is swedish ssn or corporate organisation number\r\n * @type {string}\r\n * @memberof CollateralType\r\n */\r\n customerId?: string;\r\n /**\r\n * \r\n * @type {TypeOfCollateral}\r\n * @memberof CollateralType\r\n */\r\n typeOfCollateral?: TypeOfCollateral;\r\n /**\r\n * Collateral identity\r\n * @type {string}\r\n * @memberof CollateralType\r\n */\r\n collateralId?: string;\r\n /**\r\n * TBD - Fastighetskod (ska denna användas?)\r\n * @type {string}\r\n * @memberof CollateralType\r\n */\r\n collateralCode?: string;\r\n /**\r\n * Fastighetbeteckning\r\n * @type {string}\r\n * @memberof CollateralType\r\n */\r\n collateralName?: string;\r\n /**\r\n * En lista av taxerade fastighetsägare\r\n * @type {Array}\r\n * @memberof CollateralType\r\n */\r\n taxedOwners?: Array;\r\n /**\r\n * Kommun där fastigheten och/eller säkerheten finns registrerad\r\n * @type {string}\r\n * @memberof CollateralType\r\n */\r\n collateralMunicipality?: string;\r\n /**\r\n * Street address of the collateral\r\n * @type {string}\r\n * @memberof CollateralType\r\n */\r\n collateralStreet?: string;\r\n /**\r\n * Areal för skogen\r\n * @type {number}\r\n * @memberof CollateralType\r\n */\r\n collateralAreal?: number;\r\n /**\r\n * \r\n * @type {CollateralAge}\r\n * @memberof CollateralType\r\n */\r\n collateralAge?: CollateralAge;\r\n /**\r\n * Use this collateral as security in this application\r\n * @type {boolean}\r\n * @memberof CollateralType\r\n */\r\n useAsCollateral?: boolean;\r\n /**\r\n * Applicant has intention to by this collateral\r\n * @type {boolean}\r\n * @memberof CollateralType\r\n */\r\n buyCollateral?: boolean;\r\n}\r\n\r\nexport function CollateralTypeFromJSON(json: any): CollateralType {\r\n return CollateralTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function CollateralTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): CollateralType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'customerId': !exists(json, 'customerId') ? undefined : json['customerId'],\r\n 'typeOfCollateral': !exists(json, 'typeOfCollateral') ? undefined : TypeOfCollateralFromJSON(json['typeOfCollateral']),\r\n 'collateralId': !exists(json, 'collateralId') ? undefined : json['collateralId'],\r\n 'collateralCode': !exists(json, 'collateralCode') ? undefined : json['collateralCode'],\r\n 'collateralName': !exists(json, 'collateralName') ? undefined : json['collateralName'],\r\n 'taxedOwners': !exists(json, 'taxedOwners') ? undefined : ((json['taxedOwners'] as Array).map(TaxedOwnerTypeFromJSON)),\r\n 'collateralMunicipality': !exists(json, 'collateralMunicipality') ? undefined : json['collateralMunicipality'],\r\n 'collateralStreet': !exists(json, 'collateralStreet') ? undefined : json['collateralStreet'],\r\n 'collateralAreal': !exists(json, 'collateralAreal') ? undefined : json['collateralAreal'],\r\n 'collateralAge': !exists(json, 'collateralAge') ? undefined : CollateralAgeFromJSON(json['collateralAge']),\r\n 'useAsCollateral': !exists(json, 'useAsCollateral') ? undefined : json['useAsCollateral'],\r\n 'buyCollateral': !exists(json, 'buyCollateral') ? undefined : json['buyCollateral'],\r\n };\r\n}\r\n\r\nexport function CollateralTypeToJSON(value?: CollateralType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'customerId': value.customerId,\r\n 'typeOfCollateral': TypeOfCollateralToJSON(value.typeOfCollateral),\r\n 'collateralId': value.collateralId,\r\n 'collateralCode': value.collateralCode,\r\n 'collateralName': value.collateralName,\r\n 'taxedOwners': value.taxedOwners === undefined ? undefined : ((value.taxedOwners as Array).map(TaxedOwnerTypeToJSON)),\r\n 'collateralMunicipality': value.collateralMunicipality,\r\n 'collateralStreet': value.collateralStreet,\r\n 'collateralAreal': value.collateralAreal,\r\n 'collateralAge': CollateralAgeToJSON(value.collateralAge),\r\n 'useAsCollateral': value.useAsCollateral,\r\n 'buyCollateral': value.buyCollateral,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n RevenueType,\r\n RevenueTypeFromJSON,\r\n RevenueTypeFromJSONTyped,\r\n RevenueTypeToJSON,\r\n} from './';\r\n\r\n/**\r\n * Type definition for company economy\r\n * @export\r\n * @interface CompanyEconomyType\r\n */\r\nexport interface CompanyEconomyType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof CompanyEconomyType\r\n */\r\n processId: string;\r\n /**\r\n * generated uuid in the model\r\n * @type {string}\r\n * @memberof CompanyEconomyType\r\n */\r\n companyId: string;\r\n /**\r\n * Type definition for company economy\r\n * @type {string}\r\n * @memberof CompanyEconomyType\r\n */\r\n companyEconomyId: string;\r\n /**\r\n * Customer category return by SAS (kundklass Not V1)\r\n * @type {number}\r\n * @memberof CompanyEconomyType\r\n */\r\n customerCategory?: number;\r\n /**\r\n * Årsomsättning\r\n * @type {Array}\r\n * @memberof CompanyEconomyType\r\n */\r\n revenues?: Array;\r\n}\r\n\r\nexport function CompanyEconomyTypeFromJSON(json: any): CompanyEconomyType {\r\n return CompanyEconomyTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function CompanyEconomyTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): CompanyEconomyType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'companyId': json['companyId'],\r\n 'companyEconomyId': json['companyEconomyId'],\r\n 'customerCategory': !exists(json, 'customerCategory') ? undefined : json['customerCategory'],\r\n 'revenues': !exists(json, 'Revenues') ? undefined : ((json['Revenues'] as Array).map(RevenueTypeFromJSON)),\r\n };\r\n}\r\n\r\nexport function CompanyEconomyTypeToJSON(value?: CompanyEconomyType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'companyId': value.companyId,\r\n 'companyEconomyId': value.companyEconomyId,\r\n 'customerCategory': value.customerCategory,\r\n 'Revenues': value.revenues === undefined ? undefined : ((value.revenues as Array).map(RevenueTypeToJSON)),\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n BusinessCategoryType,\r\n BusinessCategoryTypeFromJSON,\r\n BusinessCategoryTypeFromJSONTyped,\r\n BusinessCategoryTypeToJSON,\r\n PrincipalType,\r\n PrincipalTypeFromJSON,\r\n PrincipalTypeFromJSONTyped,\r\n PrincipalTypeToJSON,\r\n} from './';\r\n\r\n/**\r\n * Type of company instance\r\n * @export\r\n * @interface CompanyType\r\n */\r\nexport interface CompanyType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof CompanyType\r\n */\r\n processId: string;\r\n /**\r\n * generated uuid in the model\r\n * @type {string}\r\n * @memberof CompanyType\r\n */\r\n companyId: string;\r\n /**\r\n * Organisation number from external service, swedish ssn (UC or SAP for existing companies)\r\n * @type {string}\r\n * @memberof CompanyType\r\n */\r\n orgNumber?: string;\r\n /**\r\n * Full name of the company from external services or BusinessName in SAP.\r\n * @type {string}\r\n * @memberof CompanyType\r\n */\r\n companyName?: string;\r\n /**\r\n * Status code from roaring API\r\n * @type {string}\r\n * @memberof CompanyType\r\n */\r\n statusCode?: string;\r\n /**\r\n * Status text high description\r\n * @type {string}\r\n * @memberof CompanyType\r\n */\r\n statusTextHigh?: string;\r\n /**\r\n * date when company was established, from external service or existing customer in SAP\r\n * @type {string}\r\n * @memberof CompanyType\r\n */\r\n created?: string;\r\n /**\r\n * Driftinriktning\r\n * @type {Array}\r\n * @memberof CompanyType\r\n */\r\n businessFocuses?: Array;\r\n /**\r\n * SNI-code from external company service roaring.io\r\n * @type {string}\r\n * @memberof CompanyType\r\n */\r\n industriCode?: string;\r\n /**\r\n * SNI-Text from external company service, category text\r\n * @type {string}\r\n * @memberof CompanyType\r\n */\r\n industriText?: string;\r\n /**\r\n * Legal Group code, available Legal Group codes for a company. The information is displayed as a code with a descriptive text. Source is roaring.io OVR Övriga Other HB/KB Handelsbolag Trading company AB Privat aktiebolag Limited company EF Enskild firma Sole proprietorship\r\n * @type {string}\r\n * @memberof CompanyType\r\n */\r\n leagalGroupCode?: string;\r\n /**\r\n * Legal Group Text, descriptive text\r\n * @type {string}\r\n * @memberof CompanyType\r\n */\r\n legalGroupText?: string;\r\n /**\r\n * Customer has selected this company for the loan to apply for\r\n * @type {boolean}\r\n * @memberof CompanyType\r\n */\r\n selectedCompany?: boolean;\r\n /**\r\n * list of huvudmän\r\n * @type {Array}\r\n * @memberof CompanyType\r\n */\r\n principals?: Array;\r\n /**\r\n * Broken fiscal year, brutet räkenskapsår (true/false) should only be visible for legalGroupCode AB\r\n * @type {boolean}\r\n * @memberof CompanyType\r\n */\r\n brokenFiscalYear?: boolean;\r\n /**\r\n * Bokslutsdatum\r\n * @type {string}\r\n * @memberof CompanyType\r\n */\r\n fiscalYearEndDate?: string;\r\n}\r\n\r\nexport function CompanyTypeFromJSON(json: any): CompanyType {\r\n return CompanyTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function CompanyTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): CompanyType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'companyId': json['companyId'],\r\n 'orgNumber': !exists(json, 'orgNumber') ? undefined : json['orgNumber'],\r\n 'companyName': !exists(json, 'companyName') ? undefined : json['companyName'],\r\n 'statusCode': !exists(json, 'statusCode') ? undefined : json['statusCode'],\r\n 'statusTextHigh': !exists(json, 'statusTextHigh') ? undefined : json['statusTextHigh'],\r\n 'created': !exists(json, 'created') ? undefined : json['created'],\r\n 'businessFocuses': !exists(json, 'businessFocuses') ? undefined : ((json['businessFocuses'] as Array).map(BusinessCategoryTypeFromJSON)),\r\n 'industriCode': !exists(json, 'industriCode') ? undefined : json['industriCode'],\r\n 'industriText': !exists(json, 'industriText') ? undefined : json['industriText'],\r\n 'leagalGroupCode': !exists(json, 'leagalGroupCode') ? undefined : json['leagalGroupCode'],\r\n 'legalGroupText': !exists(json, 'legalGroupText') ? undefined : json['legalGroupText'],\r\n 'selectedCompany': !exists(json, 'selectedCompany') ? undefined : json['selectedCompany'],\r\n 'principals': !exists(json, 'principals') ? undefined : ((json['principals'] as Array).map(PrincipalTypeFromJSON)),\r\n 'brokenFiscalYear': !exists(json, 'brokenFiscalYear') ? undefined : json['brokenFiscalYear'],\r\n 'fiscalYearEndDate': !exists(json, 'fiscalYearEndDate') ? undefined : json['fiscalYearEndDate'],\r\n };\r\n}\r\n\r\nexport function CompanyTypeToJSON(value?: CompanyType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'companyId': value.companyId,\r\n 'orgNumber': value.orgNumber,\r\n 'companyName': value.companyName,\r\n 'statusCode': value.statusCode,\r\n 'statusTextHigh': value.statusTextHigh,\r\n 'created': value.created,\r\n 'businessFocuses': value.businessFocuses === undefined ? undefined : ((value.businessFocuses as Array).map(BusinessCategoryTypeToJSON)),\r\n 'industriCode': value.industriCode,\r\n 'industriText': value.industriText,\r\n 'leagalGroupCode': value.leagalGroupCode,\r\n 'legalGroupText': value.legalGroupText,\r\n 'selectedCompany': value.selectedCompany,\r\n 'principals': value.principals === undefined ? undefined : ((value.principals as Array).map(PrincipalTypeToJSON)),\r\n 'brokenFiscalYear': value.brokenFiscalYear,\r\n 'fiscalYearEndDate': value.fiscalYearEndDate,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * Contact information definitions\r\n * @export\r\n * @interface ContactInformationType\r\n */\r\nexport interface ContactInformationType {\r\n /**\r\n * applicant enter email for notification\r\n * @type {string}\r\n * @memberof ContactInformationType\r\n */\r\n applicanteMail?: string;\r\n /**\r\n * applicant entered mobile number for notification\r\n * @type {string}\r\n * @memberof ContactInformationType\r\n */\r\n applicantMobileNumber?: string;\r\n}\r\n\r\nexport function ContactInformationTypeFromJSON(json: any): ContactInformationType {\r\n return ContactInformationTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function ContactInformationTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): ContactInformationType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'applicanteMail': !exists(json, 'applicanteMail') ? undefined : json['applicanteMail'],\r\n 'applicantMobileNumber': !exists(json, 'applicantMobileNumber') ? undefined : json['applicantMobileNumber'],\r\n };\r\n}\r\n\r\nexport function ContactInformationTypeToJSON(value?: ContactInformationType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'applicanteMail': value.applicanteMail,\r\n 'applicantMobileNumber': value.applicantMobileNumber,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * customers in a processid, a list array of customerId\r\n * @export\r\n * @interface CustomerIdType\r\n */\r\nexport interface CustomerIdType {\r\n /**\r\n * customerId is swedish ssn or corporate organisation number\r\n * @type {string}\r\n * @memberof CustomerIdType\r\n */\r\n customerId?: string;\r\n /**\r\n * timestamp when customer has been added to the application, to hold (huvudsökande, medsökande) order\r\n * @type {string}\r\n * @memberof CustomerIdType\r\n */\r\n customerAdded?: string;\r\n}\r\n\r\nexport function CustomerIdTypeFromJSON(json: any): CustomerIdType {\r\n return CustomerIdTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function CustomerIdTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): CustomerIdType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'customerId': !exists(json, 'customerId') ? undefined : json['customerId'],\r\n 'customerAdded': !exists(json, 'customerAdded') ? undefined : json['customerAdded'],\r\n };\r\n}\r\n\r\nexport function CustomerIdTypeToJSON(value?: CustomerIdType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'customerId': value.customerId,\r\n 'customerAdded': value.customerAdded,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n/**\r\n * type of downpayment \\'Övrigt\\', \\'Försäljning bostad\\', \\'Blanco\\', \\'Sparande\\'\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum DownPaymentType {\r\n Vrigt = 'Övrigt',\r\n FrsljningBostad = 'Försäljning bostad',\r\n Blanco = 'Blanco',\r\n Sparande = 'Sparande'\r\n}\r\n\r\nexport function DownPaymentTypeFromJSON(json: any): DownPaymentType {\r\n return DownPaymentTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function DownPaymentTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): DownPaymentType {\r\n return json as DownPaymentType;\r\n}\r\n\r\nexport function DownPaymentTypeToJSON(value?: DownPaymentType | null): any {\r\n return value as any;\r\n}\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n EUType,\r\n EUTypeFromJSON,\r\n EUTypeFromJSONTyped,\r\n EUTypeToJSON,\r\n} from './';\r\n\r\n/**\r\n * Type of EUSupport instance\r\n * @export\r\n * @interface EUSupportType\r\n */\r\nexport interface EUSupportType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof EUSupportType\r\n */\r\n processId: string;\r\n /**\r\n * Unique identifier for EU-Support\r\n * @type {string}\r\n * @memberof EUSupportType\r\n */\r\n euId: string;\r\n /**\r\n * \r\n * @type {EUType}\r\n * @memberof EUSupportType\r\n */\r\n euType?: EUType;\r\n /**\r\n * summerat EU-stöd\r\n * @type {number}\r\n * @memberof EUSupportType\r\n */\r\n supportAmount?: number;\r\n /**\r\n * EU-stödet gäller år\r\n * @type {string}\r\n * @memberof EUSupportType\r\n */\r\n supportYear?: string;\r\n}\r\n\r\nexport function EUSupportTypeFromJSON(json: any): EUSupportType {\r\n return EUSupportTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function EUSupportTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): EUSupportType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'euId': json['euId'],\r\n 'euType': !exists(json, 'euType') ? undefined : EUTypeFromJSON(json['euType']),\r\n 'supportAmount': !exists(json, 'supportAmount') ? undefined : json['supportAmount'],\r\n 'supportYear': !exists(json, 'supportYear') ? undefined : json['supportYear'],\r\n };\r\n}\r\n\r\nexport function EUSupportTypeToJSON(value?: EUSupportType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'euId': value.euId,\r\n 'euType': EUTypeToJSON(value.euType),\r\n 'supportAmount': value.supportAmount,\r\n 'supportYear': value.supportYear,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n/**\r\n * Typ av eu-stöd\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum EUType {\r\n EUStd = 'EU-stöd',\r\n EUStdOchNationelltStd = 'EU-stöd och nationellt stöd',\r\n EUStdOchNationelltStdUtanMjlk = 'EU-stöd och nationellt stöd, utan mjölk',\r\n NationellStdUtanMjlk = 'Nationell stöd, utan mjölk'\r\n}\r\n\r\nexport function EUTypeFromJSON(json: any): EUType {\r\n return EUTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function EUTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): EUType {\r\n return json as EUType;\r\n}\r\n\r\nexport function EUTypeToJSON(value?: EUType | null): any {\r\n return value as any;\r\n}\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n TypeOfLoan,\r\n TypeOfLoanFromJSON,\r\n TypeOfLoanFromJSONTyped,\r\n TypeOfLoanToJSON,\r\n} from './';\r\n\r\n/**\r\n * Externa lån kunden har i andra kreditinstitut, detta exkluderar LH-lån\r\n * @export\r\n * @interface ExtLoanType\r\n */\r\nexport interface ExtLoanType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof ExtLoanType\r\n */\r\n processId: string;\r\n /**\r\n * A list of external loan owners (cusotmerId)\r\n * @type {Array}\r\n * @memberof ExtLoanType\r\n */\r\n extLoanOwners?: Array;\r\n /**\r\n * Type definitions for external loans\r\n * @type {string}\r\n * @memberof ExtLoanType\r\n */\r\n extloanId: string;\r\n /**\r\n * \r\n * @type {TypeOfLoan}\r\n * @memberof ExtLoanType\r\n */\r\n typeOfLoan?: TypeOfLoan;\r\n /**\r\n * Kreditinstitut, Bank, Loan originator\r\n * @type {string}\r\n * @memberof ExtLoanType\r\n */\r\n extCreditInstitute?: string;\r\n /**\r\n * Clearing number (has been deprecated)\r\n * @type {string}\r\n * @memberof ExtLoanType\r\n */\r\n extloanClearing?: string;\r\n /**\r\n * Loan number\r\n * @type {string}\r\n * @memberof ExtLoanType\r\n */\r\n extloanNumber?: string;\r\n /**\r\n * externa loan, amount\r\n * @type {number}\r\n * @memberof ExtLoanType\r\n */\r\n extloanAmount?: number;\r\n /**\r\n * Redeem loans - Lösa lånet i annan bank\r\n * @type {boolean}\r\n * @memberof ExtLoanType\r\n */\r\n extRedeemLoan?: boolean;\r\n /**\r\n * Monthly cost for Studielån\r\n * @type {number}\r\n * @memberof ExtLoanType\r\n */\r\n extMonthlyCost?: number;\r\n}\r\n\r\nexport function ExtLoanTypeFromJSON(json: any): ExtLoanType {\r\n return ExtLoanTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function ExtLoanTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): ExtLoanType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'extLoanOwners': !exists(json, 'extLoanOwners') ? undefined : json['extLoanOwners'],\r\n 'extloanId': json['extloanId'],\r\n 'typeOfLoan': !exists(json, 'typeOfLoan') ? undefined : TypeOfLoanFromJSON(json['typeOfLoan']),\r\n 'extCreditInstitute': !exists(json, 'extCreditInstitute') ? undefined : json['extCreditInstitute'],\r\n 'extloanClearing': !exists(json, 'extloanClearing') ? undefined : json['extloanClearing'],\r\n 'extloanNumber': !exists(json, 'extloanNumber') ? undefined : json['extloanNumber'],\r\n 'extloanAmount': !exists(json, 'extloanAmount') ? undefined : json['extloanAmount'],\r\n 'extRedeemLoan': !exists(json, 'extRedeemLoan') ? undefined : json['extRedeemLoan'],\r\n 'extMonthlyCost': !exists(json, 'extMonthlyCost') ? undefined : json['extMonthlyCost'],\r\n };\r\n}\r\n\r\nexport function ExtLoanTypeToJSON(value?: ExtLoanType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'extLoanOwners': value.extLoanOwners,\r\n 'extloanId': value.extloanId,\r\n 'typeOfLoan': TypeOfLoanToJSON(value.typeOfLoan),\r\n 'extCreditInstitute': value.extCreditInstitute,\r\n 'extloanClearing': value.extloanClearing,\r\n 'extloanNumber': value.extloanNumber,\r\n 'extloanAmount': value.extloanAmount,\r\n 'extRedeemLoan': value.extRedeemLoan,\r\n 'extMonthlyCost': value.extMonthlyCost,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * Type of Guarantor instance\r\n * @export\r\n * @interface GuarantorType\r\n */\r\nexport interface GuarantorType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof GuarantorType\r\n */\r\n processId: string;\r\n /**\r\n * TBD\r\n * @type {string}\r\n * @memberof GuarantorType\r\n */\r\n guarantorId: string;\r\n /**\r\n * TBD\r\n * @type {string}\r\n * @memberof GuarantorType\r\n */\r\n guarantorName?: string;\r\n /**\r\n * TBD\r\n * @type {string}\r\n * @memberof GuarantorType\r\n */\r\n guarantorPhone?: string;\r\n /**\r\n * TBD\r\n * @type {string}\r\n * @memberof GuarantorType\r\n */\r\n guarantorCustomerId?: string;\r\n}\r\n\r\nexport function GuarantorTypeFromJSON(json: any): GuarantorType {\r\n return GuarantorTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function GuarantorTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): GuarantorType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'guarantorId': json['guarantorId'],\r\n 'guarantorName': !exists(json, 'guarantorName') ? undefined : json['guarantorName'],\r\n 'guarantorPhone': !exists(json, 'guarantorPhone') ? undefined : json['guarantorPhone'],\r\n 'guarantorCustomerId': !exists(json, 'guarantorCustomerId') ? undefined : json['guarantorCustomerId'],\r\n };\r\n}\r\n\r\nexport function GuarantorTypeToJSON(value?: GuarantorType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'guarantorId': value.guarantorId,\r\n 'guarantorName': value.guarantorName,\r\n 'guarantorPhone': value.guarantorPhone,\r\n 'guarantorCustomerId': value.guarantorCustomerId,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * Member in a household\r\n * @export\r\n * @interface HouseholdMemberType\r\n */\r\nexport interface HouseholdMemberType {\r\n /**\r\n * Member in a household (customerId) personnummer\r\n * @type {string}\r\n * @memberof HouseholdMemberType\r\n */\r\n householdMember?: string;\r\n}\r\n\r\nexport function HouseholdMemberTypeFromJSON(json: any): HouseholdMemberType {\r\n return HouseholdMemberTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function HouseholdMemberTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): HouseholdMemberType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'householdMember': !exists(json, 'householdMember') ? undefined : json['householdMember'],\r\n };\r\n}\r\n\r\nexport function HouseholdMemberTypeToJSON(value?: HouseholdMemberType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'householdMember': value.householdMember,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n ChildType,\r\n ChildTypeFromJSON,\r\n ChildTypeFromJSONTyped,\r\n ChildTypeToJSON,\r\n HouseholdMemberType,\r\n HouseholdMemberTypeFromJSON,\r\n HouseholdMemberTypeFromJSONTyped,\r\n HouseholdMemberTypeToJSON,\r\n} from './';\r\n\r\n/**\r\n * Household should be loosely coupled in the model. We have to support many customerId in a household, this is done by adding customerId to the array customerIds.\r\n * @export\r\n * @interface HouseholdType\r\n */\r\nexport interface HouseholdType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof HouseholdType\r\n */\r\n processId: string;\r\n /**\r\n * Hosuehold identity key\r\n * @type {string}\r\n * @memberof HouseholdType\r\n */\r\n householdId: string;\r\n /**\r\n * array of householdmembers\r\n * @type {Array}\r\n * @memberof HouseholdType\r\n */\r\n householdMembers?: Array;\r\n /**\r\n * Number of child in this household\r\n * @type {number}\r\n * @memberof HouseholdType\r\n */\r\n numberOfChildsAtHome?: number;\r\n /**\r\n * holds all child in a household\r\n * @type {Array}\r\n * @memberof HouseholdType\r\n */\r\n childs?: Array;\r\n /**\r\n * number of cars in this houshold.\r\n * @type {number}\r\n * @memberof HouseholdType\r\n */\r\n numberOfCars?: number;\r\n /**\r\n * Underhållskostnad för barn i annat hushåll betalande, underhållskostander barn\r\n * @type {number}\r\n * @memberof HouseholdType\r\n */\r\n childMaintenaceCost?: number;\r\n /**\r\n * Erhållen underhållskostnad för barn, erhållen underhållskostnad\r\n * @type {number}\r\n * @memberof HouseholdType\r\n */\r\n receiveChildMaintenanceCost?: number;\r\n /**\r\n * Totala barnomsorgskostnaden per månad.\r\n * @type {number}\r\n * @memberof HouseholdType\r\n */\r\n childCareAmount?: number;\r\n}\r\n\r\nexport function HouseholdTypeFromJSON(json: any): HouseholdType {\r\n return HouseholdTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function HouseholdTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): HouseholdType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'householdId': json['householdId'],\r\n 'householdMembers': !exists(json, 'householdMembers') ? undefined : ((json['householdMembers'] as Array).map(HouseholdMemberTypeFromJSON)),\r\n 'numberOfChildsAtHome': !exists(json, 'numberOfChildsAtHome') ? undefined : json['numberOfChildsAtHome'],\r\n 'childs': !exists(json, 'childs') ? undefined : ((json['childs'] as Array).map(ChildTypeFromJSON)),\r\n 'numberOfCars': !exists(json, 'numberOfCars') ? undefined : json['numberOfCars'],\r\n 'childMaintenaceCost': !exists(json, 'childMaintenaceCost') ? undefined : json['childMaintenaceCost'],\r\n 'receiveChildMaintenanceCost': !exists(json, 'receiveChildMaintenanceCost') ? undefined : json['receiveChildMaintenanceCost'],\r\n 'childCareAmount': !exists(json, 'childCareAmount') ? undefined : json['childCareAmount'],\r\n };\r\n}\r\n\r\nexport function HouseholdTypeToJSON(value?: HouseholdType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'householdId': value.householdId,\r\n 'householdMembers': value.householdMembers === undefined ? undefined : ((value.householdMembers as Array).map(HouseholdMemberTypeToJSON)),\r\n 'numberOfChildsAtHome': value.numberOfChildsAtHome,\r\n 'childs': value.childs === undefined ? undefined : ((value.childs as Array).map(ChildTypeToJSON)),\r\n 'numberOfCars': value.numberOfCars,\r\n 'childMaintenaceCost': value.childMaintenaceCost,\r\n 'receiveChildMaintenanceCost': value.receiveChildMaintenanceCost,\r\n 'childCareAmount': value.childCareAmount,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * KYC-Information\r\n * @export\r\n * @interface KycInformationType\r\n */\r\nexport interface KycInformationType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof KycInformationType\r\n */\r\n processId: string;\r\n /**\r\n * customerId is swedish ssn or corporate organisation number\r\n * @type {string}\r\n * @memberof KycInformationType\r\n */\r\n customerId: string;\r\n /**\r\n * Kyc-identity key\r\n * @type {string}\r\n * @memberof KycInformationType\r\n */\r\n kycId?: string;\r\n /**\r\n * Jag är medveten om att Landshypotek Bank inhämtar en kreditupplysning på mig och att det sker när jag går vidare från denna sida i nästa steg i ansökan.\r\n * @type {boolean}\r\n * @memberof KycInformationType\r\n */\r\n kycAcceptUC?: boolean;\r\n /**\r\n * Jag är medveten om att Landshypotek Bank behandlar mina personuppgifter i och med ansökan och att jag kan läsa mer om Landshypotek Banks personuppgiftsbehandling.\r\n * @type {boolean}\r\n * @memberof KycInformationType\r\n */\r\n kycAcceptGDPR?: boolean;\r\n /**\r\n * Jag är medveten om att de uppgifter jag lämnar och resultatet av kreditansökan även visas för medsökande, om en sådan läggs till senare i ansökan. Om jag äger andra fastigheter, som banken hämtar uppgifter om från externa källor, visas även de uppgifterna för medsökande.\r\n * @type {boolean}\r\n * @memberof KycInformationType\r\n */\r\n kycUCAware?: boolean;\r\n /**\r\n * Innehar eller har du de 18 senaste månaderna innehaft en viktig offentlig funnktion?\r\n * @type {boolean}\r\n * @memberof KycInformationType\r\n */\r\n kycPublicFunction?: boolean;\r\n /**\r\n * Är du familjemedlem eller medarbetare till en person som har, eller som under de senaste 18 månaderna innehaft en viktig offentlig funktion?\r\n * @type {boolean}\r\n * @memberof KycInformationType\r\n */\r\n kycRelatedPublicFunction?: boolean;\r\n /**\r\n * High risk industry, högriskbransch (true/false)\r\n * @type {boolean}\r\n * @memberof KycInformationType\r\n */\r\n kycHighRiskIndustry?: boolean;\r\n /**\r\n * High risk industry entered by customer\r\n * @type {string}\r\n * @memberof KycInformationType\r\n */\r\n kycHighRiskIndustryText?: string;\r\n /**\r\n * Är du skatteskyldig i USA genom medborgarskap eller annan anknytning till USA?\r\n * @type {boolean}\r\n * @memberof KycInformationType\r\n */\r\n kycAmericanCitizen?: boolean;\r\n /**\r\n * Är kund skattskyldig i ett annat land än Sverige och USA?\r\n * @type {boolean}\r\n * @memberof KycInformationType\r\n */\r\n kycCrsTaxObligation?: boolean; \r\n}\r\n\r\nexport function KycInformationTypeFromJSON(json: any): KycInformationType {\r\n return KycInformationTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function KycInformationTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): KycInformationType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'customerId': json['customerId'],\r\n 'kycId': !exists(json, 'kycId') ? undefined : json['kycId'],\r\n 'kycAcceptUC': !exists(json, 'kycAcceptUC') ? undefined : json['kycAcceptUC'],\r\n 'kycAcceptGDPR': !exists(json, 'kycAcceptGDPR') ? undefined : json['kycAcceptGDPR'],\r\n 'kycUCAware': !exists(json, 'kycUCAware') ? undefined : json['kycUCAware'],\r\n 'kycPublicFunction': !exists(json, 'kycPublicFunction') ? undefined : json['kycPublicFunction'],\r\n 'kycRelatedPublicFunction': !exists(json, 'kycRelatedPublicFunction') ? undefined : json['kycRelatedPublicFunction'],\r\n 'kycHighRiskIndustry': !exists(json, 'kycHighRiskIndustry') ? undefined : json['kycHighRiskIndustry'],\r\n 'kycHighRiskIndustryText': !exists(json, 'kycHighRiskIndustryText') ? undefined : json['kycHighRiskIndustryText'],\r\n 'kycAmericanCitizen': !exists(json, 'kycAmericanCitizen') ? undefined : json['kycAmericanCitizen'],\r\n 'kycCrsTaxObligation': !exists(json, 'kycCrsTaxObligation') ? undefined : json['kycCrsTaxObligation'],\r\n };\r\n}\r\n\r\nexport function KycInformationTypeToJSON(value?: KycInformationType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'customerId': value.customerId,\r\n 'kycId': value.kycId,\r\n 'kycAcceptUC': value.kycAcceptUC,\r\n 'kycAcceptGDPR': value.kycAcceptGDPR,\r\n 'kycUCAware': value.kycUCAware,\r\n 'kycPublicFunction': value.kycPublicFunction,\r\n 'kycRelatedPublicFunction': value.kycRelatedPublicFunction,\r\n 'kycHighRiskIndustry': value.kycHighRiskIndustry,\r\n 'kycHighRiskIndustryText': value.kycHighRiskIndustryText,\r\n 'kycAmericanCitizen': value.kycAmericanCitizen,\r\n 'kycCrsTaxObligation': value.kycCrsTaxObligation\r\n };\r\n}\r\n\r\n\r\n","// tslint:disable\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.5\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { Attachment, AttachmentRequest } from '../../../models/SelmaModels';\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n ApplicantType,\r\n ApplicantTypeFromJSON,\r\n ApplicantTypeToJSON,\r\n BudgetType,\r\n BudgetTypeFromJSON,\r\n BudgetTypeToJSON,\r\n CollateralType,\r\n CollateralTypeFromJSON,\r\n CollateralTypeToJSON,\r\n CompanyEconomyType,\r\n CompanyEconomyTypeFromJSON,\r\n CompanyEconomyTypeToJSON,\r\n CompanyType,\r\n CompanyTypeFromJSON,\r\n CompanyTypeToJSON,\r\n EUSupportType,\r\n EUSupportTypeFromJSON,\r\n EUSupportTypeToJSON,\r\n ExtLoanType,\r\n ExtLoanTypeFromJSON,\r\n ExtLoanTypeToJSON,\r\n GuarantorType,\r\n GuarantorTypeFromJSON,\r\n GuarantorTypeToJSON,\r\n HouseholdType,\r\n HouseholdTypeFromJSON,\r\n HouseholdTypeToJSON,\r\n KycInformationType,\r\n KycInformationTypeFromJSON,\r\n KycInformationTypeToJSON,\r\n LoanType,\r\n LoanTypeFromJSON,\r\n LoanTypeToJSON,\r\n MaintenanceCostType,\r\n MaintenanceCostTypeFromJSON,\r\n MaintenanceCostTypeToJSON,\r\n PersonalEconomyType,\r\n PersonalEconomyTypeFromJSON,\r\n PersonalEconomyTypeToJSON,\r\n ProcessType,\r\n ProcessTypeFromJSON,\r\n ProcessTypeToJSON,\r\n} from './';\r\n\r\n/**\r\n * Used for getprocessall and saveprocessall\r\n * @export\r\n * @interface LinksAll\r\n */\r\nexport interface LinksAll {\r\n /**\r\n * Return a list of type processType\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n processes?: Array;\r\n /**\r\n * List of applicantType\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n applicants?: Array;\r\n /**\r\n * Array list of loanType (Loan)\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n loans?: Array;\r\n /**\r\n * Type definition for external loans\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n extloans?: Array;\r\n /**\r\n * List of companyType\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n companies?: Array;\r\n /**\r\n * return all available households for a customer\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n households?: Array;\r\n /**\r\n * Array list of type collateralType\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n collaterals?: Array;\r\n /**\r\n * -> Get a list of PersonalEconomyType\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n personaleconomies?: Array;\r\n /**\r\n * -> Type definition for company economies, returns array of CompanyEconomyType\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n companyeconomies?: Array;\r\n /**\r\n * Array of budgetType for processId with dirrent companyEconomyID\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n budgets?: Array;\r\n /**\r\n * Return a list of type kycInformationType\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n kycinformations?: Array;\r\n /**\r\n * TBD\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n guarantors?: Array;\r\n /**\r\n * TBD\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n eusupports?: Array;\r\n /**\r\n * TBD\r\n * @type {Array}\r\n * @memberof LinksAll\r\n */\r\n maintenancecosts?: Array;\r\n\r\n // LIMETTA EXTENSION.\r\n attachments?: Attachment[];\r\n attachmentRequests?: AttachmentRequest[];\r\n}\r\n\r\nexport function LinksAllFromJSON(json: any): LinksAll {\r\n return {\r\n 'processes': !exists(json, 'processes') ? undefined : (json['processes'] as Array).map(ProcessTypeFromJSON),\r\n 'applicants': !exists(json, 'applicants') ? undefined : (json['applicants'] as Array).map(ApplicantTypeFromJSON),\r\n 'loans': !exists(json, 'loans') ? undefined : (json['loans'] as Array).map(LoanTypeFromJSON),\r\n 'extloans': !exists(json, 'extloans') ? undefined : (json['extloans'] as Array).map(ExtLoanTypeFromJSON),\r\n 'companies': !exists(json, 'companies') ? undefined : (json['companies'] as Array).map(CompanyTypeFromJSON),\r\n 'households': !exists(json, 'households') ? undefined : (json['households'] as Array).map(HouseholdTypeFromJSON),\r\n 'collaterals': !exists(json, 'collaterals') ? undefined : (json['collaterals'] as Array).map(CollateralTypeFromJSON),\r\n 'personaleconomies': !exists(json, 'personaleconomies') ? undefined : (json['personaleconomies'] as Array).map(PersonalEconomyTypeFromJSON),\r\n 'companyeconomies': !exists(json, 'companyeconomies') ? undefined : (json['companyeconomies'] as Array).map(CompanyEconomyTypeFromJSON),\r\n 'budgets': !exists(json, 'budgets') ? undefined : (json['budgets'] as Array).map(BudgetTypeFromJSON),\r\n 'kycinformations': !exists(json, 'kycinformations') ? undefined : (json['kycinformations'] as Array).map(KycInformationTypeFromJSON),\r\n 'guarantors': !exists(json, 'guarantors') ? undefined : (json['guarantors'] as Array).map(GuarantorTypeFromJSON),\r\n 'eusupports': !exists(json, 'eusupports') ? undefined : (json['eusupports'] as Array).map(EUSupportTypeFromJSON),\r\n 'maintenancecosts': !exists(json, 'maintenancecosts') ? undefined : (json['maintenancecosts'] as Array).map(MaintenanceCostTypeFromJSON),\r\n // LIMETTA EXTENSION.\r\n 'attachments': json.attachments,\r\n 'attachmentRequests': json.attachmentRequests\r\n };\r\n}\r\n\r\nexport function LinksAllToJSON(value?: LinksAll): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n return {\r\n 'processes': value.processes === undefined ? undefined : (value.processes as Array).map(ProcessTypeToJSON),\r\n 'applicants': value.applicants === undefined ? undefined : (value.applicants as Array).map(ApplicantTypeToJSON),\r\n 'loans': value.loans === undefined ? undefined : (value.loans as Array).map(LoanTypeToJSON),\r\n 'extloans': value.extloans === undefined ? undefined : (value.extloans as Array).map(ExtLoanTypeToJSON),\r\n 'companies': value.companies === undefined ? undefined : (value.companies as Array).map(CompanyTypeToJSON),\r\n 'households': value.households === undefined ? undefined : (value.households as Array).map(HouseholdTypeToJSON),\r\n 'collaterals': value.collaterals === undefined ? undefined : (value.collaterals as Array).map(CollateralTypeToJSON),\r\n 'personaleconomies': value.personaleconomies === undefined ? undefined : (value.personaleconomies as Array).map(PersonalEconomyTypeToJSON),\r\n 'companyeconomies': value.companyeconomies === undefined ? undefined : (value.companyeconomies as Array).map(CompanyEconomyTypeToJSON),\r\n 'budgets': value.budgets === undefined ? undefined : (value.budgets as Array).map(BudgetTypeToJSON),\r\n 'kycinformations': value.kycinformations === undefined ? undefined : (value.kycinformations as Array).map(KycInformationTypeToJSON),\r\n 'guarantors': value.guarantors === undefined ? undefined : (value.guarantors as Array).map(GuarantorTypeToJSON),\r\n 'eusupports': value.eusupports === undefined ? undefined : (value.eusupports as Array).map(EUSupportTypeToJSON),\r\n 'maintenancecosts': value.maintenancecosts === undefined ? undefined : (value.maintenancecosts as Array).map(MaintenanceCostTypeToJSON),\r\n // LIMETTA EXTENSION.\r\n 'attachments': value.attachments === undefined ? undefined : value.attachments,\r\n 'attachmentRequests': value.attachmentRequests === undefined ? undefined : value.attachmentRequests,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * loanOwnerType\r\n * @export\r\n * @interface LoanOwnerType\r\n */\r\nexport interface LoanOwnerType {\r\n /**\r\n * customerId is swedish ssn or corporate organisation number\r\n * @type {string}\r\n * @memberof LoanOwnerType\r\n */\r\n customerId?: string;\r\n /**\r\n * Andel kund har i huset (MaintenanceType), gäller inte hyresrätt.\r\n * @type {number}\r\n * @memberof LoanOwnerType\r\n */\r\n ownershipPart?: number;\r\n}\r\n\r\nexport function LoanOwnerTypeFromJSON(json: any): LoanOwnerType {\r\n return LoanOwnerTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function LoanOwnerTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): LoanOwnerType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'customerId': !exists(json, 'customerId') ? undefined : json['customerId'],\r\n 'ownershipPart': !exists(json, 'ownershipPart') ? undefined : json['ownershipPart'],\r\n };\r\n}\r\n\r\nexport function LoanOwnerTypeToJSON(value?: LoanOwnerType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'customerId': value.customerId,\r\n 'ownershipPart': value.ownershipPart,\r\n };\r\n}\r\n\r\n\r\n","// tslint:disable\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.5\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n AimType,\r\n AimTypeFromJSON,\r\n AimTypeToJSON,\r\n DownPaymentType,\r\n DownPaymentTypeFromJSON,\r\n DownPaymentTypeToJSON,\r\n TakeoverLoanType,\r\n TakeoverLoanTypeFromJSON,\r\n TakeoverLoanTypeToJSON,\r\n} from './';\r\n\r\n/**\r\n * This represent the customer loan structure\r\n * @export\r\n * @interface LoanType\r\n */\r\nexport interface LoanType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof LoanType\r\n */\r\n processId?: string;\r\n /**\r\n * Loan identity\r\n * @type {string}\r\n * @memberof LoanType\r\n */\r\n loanId: string;\r\n /**\r\n * This will only be a temporary loanNumber, when can we reserve a loan number in SAP\r\n * @type {string}\r\n * @memberof LoanType\r\n */\r\n loanNumber?: string;\r\n /**\r\n * Övertag från annan bank, fix för att övertag inte finns i LP (deprecated) moved to takeoverLoan\r\n * @type {boolean}\r\n * @memberof LoanType\r\n */\r\n loanTakeOver?: boolean;\r\n /**\r\n * Applicants want to loan this amount\r\n * @type {number}\r\n * @memberof LoanType\r\n */\r\n loanAmount?: number;\r\n /**\r\n * \r\n * @type {DownPaymentType}\r\n * @memberof LoanType\r\n */\r\n downPaymentType?: DownPaymentType;\r\n /**\r\n * Om val Övrigt på downPaymentType ska text anges i GUI och hamna i detta fält.\r\n * @type {string}\r\n * @memberof LoanType\r\n */\r\n downPaymentOther?: string;\r\n /**\r\n * Kontantinsats\r\n * @type {number}\r\n * @memberof LoanType\r\n */\r\n downPaymentAmount?: number;\r\n /**\r\n * Ansvarig handläggare skriver en ärende- och ändamålsbeskrvning. Icke obligatoriskt.\r\n * @type {string}\r\n * @memberof LoanType\r\n */\r\n purposeDescription?: string;\r\n /**\r\n * Each loan can have it\\'s own aim.\r\n * @type {Array}\r\n * @memberof LoanType\r\n */\r\n aims?: Array;\r\n /**\r\n * Array list of TakeoverLoanType (TakeoverLoan)\r\n * @type {Array}\r\n * @memberof LoanType\r\n */\r\n takeoverloans?: Array;\r\n}\r\n\r\nexport function LoanTypeFromJSON(json: any): LoanType {\r\n return {\r\n 'processId': !exists(json, 'processId') ? undefined : json['processId'],\r\n 'loanId': json['loanId'],\r\n 'loanNumber': !exists(json, 'loanNumber') ? undefined : json['loanNumber'],\r\n 'loanTakeOver': !exists(json, 'loanTakeOver') ? undefined : json['loanTakeOver'],\r\n 'loanAmount': !exists(json, 'loanAmount') ? undefined : json['loanAmount'],\r\n 'downPaymentType': !exists(json, 'downPaymentType') ? undefined : DownPaymentTypeFromJSON(json['downPaymentType']),\r\n 'downPaymentOther': !exists(json, 'downPaymentOther') ? undefined : json['downPaymentOther'],\r\n 'downPaymentAmount': !exists(json, 'downPaymentAmount') ? undefined : json['downPaymentAmount'],\r\n 'purposeDescription': !exists(json, 'purposeDescription') ? undefined : json['purposeDescription'],\r\n 'aims': !exists(json, 'aims') ? undefined : (json['aims'] as Array).map(AimTypeFromJSON),\r\n 'takeoverloans': !exists(json, 'takeoverloans') ? undefined : (json['takeoverloans'] as Array).map(TakeoverLoanTypeFromJSON),\r\n };\r\n}\r\n\r\nexport function LoanTypeToJSON(value?: LoanType): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n return {\r\n 'processId': value.processId,\r\n 'loanId': value.loanId,\r\n 'loanNumber': value.loanNumber,\r\n 'loanTakeOver': value.loanTakeOver,\r\n 'loanAmount': value.loanAmount,\r\n 'downPaymentType': DownPaymentTypeToJSON(value.downPaymentType),\r\n 'downPaymentOther': value.downPaymentOther,\r\n 'downPaymentAmount': value.downPaymentAmount,\r\n 'purposeDescription': value.purposeDescription,\r\n 'aims': value.aims === undefined ? undefined : (value.aims as Array).map(AimTypeToJSON),\r\n 'takeoverloans': value.takeoverloans === undefined ? undefined : (value.takeoverloans as Array).map(TakeoverLoanTypeToJSON),\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n MaintenanceHouseType,\r\n MaintenanceHouseTypeFromJSON,\r\n MaintenanceHouseTypeFromJSONTyped,\r\n MaintenanceHouseTypeToJSON,\r\n} from './';\r\n\r\n/**\r\n * Driftkostnader i övriga boenden\r\n * @export\r\n * @interface MaintenanceCostType\r\n */\r\nexport interface MaintenanceCostType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof MaintenanceCostType\r\n */\r\n processId: string;\r\n /**\r\n * Unique identifier for maintenace cost\r\n * @type {string}\r\n * @memberof MaintenanceCostType\r\n */\r\n maintenanceCostId: string;\r\n /**\r\n * customerId is swedish ssn or corporate organisation number\r\n * @type {string}\r\n * @memberof MaintenanceCostType\r\n */\r\n customerId: string;\r\n /**\r\n * TBD\r\n * @type {Array}\r\n * @memberof MaintenanceCostType\r\n */\r\n typeofhouses?: Array;\r\n}\r\n\r\nexport function MaintenanceCostTypeFromJSON(json: any): MaintenanceCostType {\r\n return MaintenanceCostTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function MaintenanceCostTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): MaintenanceCostType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'maintenanceCostId': json['maintenanceCostId'],\r\n 'customerId': json['customerId'],\r\n 'typeofhouses': !exists(json, 'typeofhouses') ? undefined : ((json['typeofhouses'] as Array).map(MaintenanceHouseTypeFromJSON)),\r\n };\r\n}\r\n\r\nexport function MaintenanceCostTypeToJSON(value?: MaintenanceCostType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'maintenanceCostId': value.maintenanceCostId,\r\n 'customerId': value.customerId,\r\n 'typeofhouses': value.typeofhouses === undefined ? undefined : ((value.typeofhouses as Array).map(MaintenanceHouseTypeToJSON)),\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n LoanOwnerType,\r\n LoanOwnerTypeFromJSON,\r\n LoanOwnerTypeFromJSONTyped,\r\n LoanOwnerTypeToJSON,\r\n TypeOfHouse,\r\n TypeOfHouseFromJSON,\r\n TypeOfHouseFromJSONTyped,\r\n TypeOfHouseToJSON,\r\n} from './';\r\n\r\n/**\r\n * Typ av hus\r\n * @export\r\n * @interface MaintenanceHouseType\r\n */\r\nexport interface MaintenanceHouseType {\r\n /**\r\n * \r\n * @type {TypeOfHouse}\r\n * @memberof MaintenanceHouseType\r\n */\r\n typeOfHouse?: TypeOfHouse;\r\n /**\r\n * Avser att behålla huset\r\n * @type {boolean}\r\n * @memberof MaintenanceHouseType\r\n */\r\n keepHouse?: boolean;\r\n /**\r\n * Avser att behålla huset\r\n * @type {boolean}\r\n * @memberof MaintenanceHouseType\r\n */\r\n loanInOtherInstitute?: boolean;\r\n /**\r\n * Lösa lånet\r\n * @type {boolean}\r\n * @memberof MaintenanceHouseType\r\n */\r\n redeemLoan?: boolean;\r\n /**\r\n * Lånet är hos kredit institut\r\n * @type {string}\r\n * @memberof MaintenanceHouseType\r\n */\r\n creditInstitute?: string;\r\n /**\r\n * Clearing number\r\n * @type {string}\r\n * @memberof MaintenanceHouseType\r\n */\r\n loanClearing?: string;\r\n /**\r\n * Lånenummer hos de kredit institut där lånet ska lösas\r\n * @type {string}\r\n * @memberof MaintenanceHouseType\r\n */\r\n instituteLoanNumber?: string;\r\n /**\r\n * list of customerId\r\n * @type {Array}\r\n * @memberof MaintenanceHouseType\r\n */\r\n loanOwners?: Array;\r\n /**\r\n * Lånet är på belopp\r\n * @type {number}\r\n * @memberof MaintenanceHouseType\r\n */\r\n houseLoanAmount?: number;\r\n /**\r\n * Driftkostnad\r\n * @type {number}\r\n * @memberof MaintenanceHouseType\r\n */\r\n maintenanceCost?: number;\r\n}\r\n\r\nexport function MaintenanceHouseTypeFromJSON(json: any): MaintenanceHouseType {\r\n return MaintenanceHouseTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function MaintenanceHouseTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): MaintenanceHouseType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'typeOfHouse': !exists(json, 'typeOfHouse') ? undefined : TypeOfHouseFromJSON(json['typeOfHouse']),\r\n 'keepHouse': !exists(json, 'keepHouse') ? undefined : json['keepHouse'],\r\n 'loanInOtherInstitute': !exists(json, 'loanInOtherInstitute') ? undefined : json['loanInOtherInstitute'],\r\n 'redeemLoan': !exists(json, 'redeemLoan') ? undefined : json['redeemLoan'],\r\n 'creditInstitute': !exists(json, 'creditInstitute') ? undefined : json['creditInstitute'],\r\n 'loanClearing': !exists(json, 'loanClearing') ? undefined : json['loanClearing'],\r\n 'instituteLoanNumber': !exists(json, 'instituteLoanNumber') ? undefined : json['instituteLoanNumber'],\r\n 'loanOwners': !exists(json, 'loanOwners') ? undefined : ((json['loanOwners'] as Array).map(LoanOwnerTypeFromJSON)),\r\n 'houseLoanAmount': !exists(json, 'houseLoanAmount') ? undefined : json['houseLoanAmount'],\r\n 'maintenanceCost': !exists(json, 'maintenanceCost') ? undefined : json['maintenanceCost'],\r\n };\r\n}\r\n\r\nexport function MaintenanceHouseTypeToJSON(value?: MaintenanceHouseType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'typeOfHouse': TypeOfHouseToJSON(value.typeOfHouse),\r\n 'keepHouse': value.keepHouse,\r\n 'loanInOtherInstitute': value.loanInOtherInstitute,\r\n 'redeemLoan': value.redeemLoan,\r\n 'creditInstitute': value.creditInstitute,\r\n 'loanClearing': value.loanClearing,\r\n 'instituteLoanNumber': value.instituteLoanNumber,\r\n 'loanOwners': value.loanOwners === undefined ? undefined : ((value.loanOwners as Array).map(LoanOwnerTypeToJSON)),\r\n 'houseLoanAmount': value.houseLoanAmount,\r\n 'maintenanceCost': value.maintenanceCost,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n TypeOfEmployeement,\r\n TypeOfEmployeementFromJSON,\r\n TypeOfEmployeementFromJSONTyped,\r\n TypeOfEmployeementToJSON,\r\n} from './';\r\n\r\n/**\r\n * personal economy for KALP us\r\n * @export\r\n * @interface PersonalEconomyType\r\n */\r\nexport interface PersonalEconomyType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof PersonalEconomyType\r\n */\r\n processId: string;\r\n /**\r\n * customerId is swedish ssn or corporate organisation number\r\n * @type {string}\r\n * @memberof PersonalEconomyType\r\n */\r\n customerId: string;\r\n /**\r\n * Type definitions for personal economy\r\n * @type {string}\r\n * @memberof PersonalEconomyType\r\n */\r\n personalEconomyId: string;\r\n /**\r\n * Årlig inkomst från näringsverksamhet\r\n * @type {number}\r\n * @memberof PersonalEconomyType\r\n */\r\n yearlyIncome?: number;\r\n /**\r\n * Angiven inkomst av tjänst\r\n * @type {number}\r\n * @memberof PersonalEconomyType\r\n */\r\n income?: number;\r\n /**\r\n * \r\n * @type {TypeOfEmployeement}\r\n * @memberof PersonalEconomyType\r\n */\r\n typeOfEmployeement?: TypeOfEmployeement;\r\n /**\r\n * -> Arbetsgivare\r\n * @type {string}\r\n * @memberof PersonalEconomyType\r\n */\r\n employeer?: string;\r\n /**\r\n * Anställd sedan år\r\n * @type {number}\r\n * @memberof PersonalEconomyType\r\n */\r\n yearOfEmployment?: number;\r\n /**\r\n * anställd i månad, om anställningen < 2 år.\r\n * @type {number}\r\n * @memberof PersonalEconomyType\r\n */\r\n monthOfEmployment?: number;\r\n}\r\n\r\nexport function PersonalEconomyTypeFromJSON(json: any): PersonalEconomyType {\r\n return PersonalEconomyTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function PersonalEconomyTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): PersonalEconomyType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'customerId': json['customerId'],\r\n 'personalEconomyId': json['personalEconomyId'],\r\n 'yearlyIncome': !exists(json, 'YearlyIncome') ? undefined : json['YearlyIncome'],\r\n 'income': !exists(json, 'Income') ? undefined : json['Income'],\r\n 'typeOfEmployeement': !exists(json, 'TypeOfEmployeement') ? undefined : TypeOfEmployeementFromJSON(json['TypeOfEmployeement']),\r\n 'employeer': !exists(json, 'Employeer') ? undefined : json['Employeer'],\r\n 'yearOfEmployment': !exists(json, 'yearOfEmployment') ? undefined : json['yearOfEmployment'],\r\n 'monthOfEmployment': !exists(json, 'monthOfEmployment') ? undefined : json['monthOfEmployment'],\r\n };\r\n}\r\n\r\nexport function PersonalEconomyTypeToJSON(value?: PersonalEconomyType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'customerId': value.customerId,\r\n 'personalEconomyId': value.personalEconomyId,\r\n 'YearlyIncome': value.yearlyIncome,\r\n 'Income': value.income,\r\n 'TypeOfEmployeement': TypeOfEmployeementToJSON(value.typeOfEmployeement),\r\n 'Employeer': value.employeer,\r\n 'yearOfEmployment': value.yearOfEmployment,\r\n 'monthOfEmployment': value.monthOfEmployment,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * huvudmän\r\n * @export\r\n * @interface PrincipalType\r\n */\r\nexport interface PrincipalType {\r\n /**\r\n * customerId is swedish ssn or corporate organisation number\r\n * @type {string}\r\n * @memberof PrincipalType\r\n */\r\n customerId?: string;\r\n /**\r\n * name of princple (huvudman i företaget)\r\n * @type {string}\r\n * @memberof PrincipalType\r\n */\r\n principalName?: string;\r\n}\r\n\r\nexport function PrincipalTypeFromJSON(json: any): PrincipalType {\r\n return PrincipalTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function PrincipalTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): PrincipalType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'customerId': !exists(json, 'customerId') ? undefined : json['customerId'],\r\n 'principalName': !exists(json, 'principalName') ? undefined : json['principalName'],\r\n };\r\n}\r\n\r\nexport function PrincipalTypeToJSON(value?: PrincipalType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'customerId': value.customerId,\r\n 'principalName': value.principalName,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n CaseIdStatus,\r\n CaseIdStatusFromJSON,\r\n CaseIdStatusFromJSONTyped,\r\n CaseIdStatusToJSON,\r\n CustomerIdType,\r\n CustomerIdTypeFromJSON,\r\n CustomerIdTypeFromJSONTyped,\r\n CustomerIdTypeToJSON,\r\n} from './';\r\n\r\n/**\r\n * Process definition\r\n * @export\r\n * @interface ProcessType\r\n */\r\nexport interface ProcessType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof ProcessType\r\n */\r\n processId: string;\r\n /**\r\n * Array of customer in a application (processid)\r\n * @type {Array}\r\n * @memberof ProcessType\r\n */\r\n customers?: Array;\r\n /**\r\n * reserved caseId in Loan Process (ignoreras i V1)\r\n * @type {string}\r\n * @memberof ProcessType\r\n */\r\n caseId?: string;\r\n /**\r\n * \r\n * @type {CaseIdStatus}\r\n * @memberof ProcessType\r\n */\r\n caseIdStatus?: CaseIdStatus;\r\n /**\r\n * model, processId created date\r\n * @type {string}\r\n * @memberof ProcessType\r\n */\r\n processCreatedDate?: string;\r\n /**\r\n * updated timestamp when customer login to the site\r\n * @type {string}\r\n * @memberof ProcessType\r\n */\r\n lastAccessed?: string;\r\n /**\r\n * Unique identity for each application to be use for conversation LH-->customer short number serie starting at 1000 and incrementing\r\n * @type {number}\r\n * @memberof ProcessType\r\n */\r\n referenceId?: number;\r\n /**\r\n * Version of the current process\r\n * @type {string}\r\n * @memberof ProcessType\r\n */\r\n processVersion?: string;\r\n}\r\n\r\nexport function ProcessTypeFromJSON(json: any): ProcessType {\r\n return ProcessTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function ProcessTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): ProcessType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': json['processId'],\r\n 'customers': !exists(json, 'Customers') ? undefined : ((json['Customers'] as Array).map(CustomerIdTypeFromJSON)),\r\n 'caseId': !exists(json, 'caseId') ? undefined : json['caseId'],\r\n 'caseIdStatus': !exists(json, 'caseIdStatus') ? undefined : CaseIdStatusFromJSON(json['caseIdStatus']),\r\n 'processCreatedDate': !exists(json, 'processCreatedDate') ? undefined : json['processCreatedDate'],\r\n 'lastAccessed': !exists(json, 'lastAccessed') ? undefined : json['lastAccessed'],\r\n 'referenceId': !exists(json, 'referenceId') ? undefined : json['referenceId'],\r\n 'processVersion': !exists(json, 'processVersion') ? undefined : json['processVersion'],\r\n };\r\n}\r\n\r\nexport function ProcessTypeToJSON(value?: ProcessType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'Customers': value.customers === undefined ? undefined : ((value.customers as Array).map(CustomerIdTypeToJSON)),\r\n 'caseId': value.caseId,\r\n 'caseIdStatus': CaseIdStatusToJSON(value.caseIdStatus),\r\n 'processCreatedDate': value.processCreatedDate,\r\n 'lastAccessed': value.lastAccessed,\r\n 'referenceId': value.referenceId,\r\n 'processVersion': value.processVersion,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\nimport {\r\n ProcessType,\r\n ProcessTypeFromJSON,\r\n ProcessTypeFromJSONTyped,\r\n ProcessTypeToJSON,\r\n} from './';\r\n\r\n/**\r\n * Get a list of processes and all associated customerId\r\n * @export\r\n * @interface ProcessesType\r\n */\r\nexport interface ProcessesType {\r\n /**\r\n * Return a list of type processType\r\n * @type {Array}\r\n * @memberof ProcessesType\r\n */\r\n processes?: Array;\r\n}\r\n\r\nexport function ProcessesTypeFromJSON(json: any): ProcessesType {\r\n return ProcessesTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function ProcessesTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): ProcessesType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processes': !exists(json, 'processes') ? undefined : ((json['processes'] as Array).map(ProcessTypeFromJSON)),\r\n };\r\n}\r\n\r\nexport function ProcessesTypeToJSON(value?: ProcessesType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processes': value.processes === undefined ? undefined : ((value.processes as Array).map(ProcessTypeToJSON)),\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * Omsättning sker på föråegående år och två år tillbaka\r\n * @export\r\n * @interface RevenueType\r\n */\r\nexport interface RevenueType {\r\n /**\r\n * year of revenue (bruttoomsättning), föregående år och 2 år tillbaka. Även om resultat inte fastställt så ber vi kunden registrera uppskattat. När vi väl kommer till LP så kommer handläggaren ändå verifiera bokslutet. Detta fält är read-only i användargränssnittet\r\n * @type {number}\r\n * @memberof RevenueType\r\n */\r\n revenueYear: number;\r\n /**\r\n * Företagets bruttoomsättning för året angivet i revenueYear (2 år)\r\n * @type {number}\r\n * @memberof RevenueType\r\n */\r\n revenue: number;\r\n}\r\n\r\nexport function RevenueTypeFromJSON(json: any): RevenueType {\r\n return RevenueTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function RevenueTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): RevenueType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'revenueYear': json['revenueYear'],\r\n 'revenue': json['revenue'],\r\n };\r\n}\r\n\r\nexport function RevenueTypeToJSON(value?: RevenueType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'revenueYear': value.revenueYear,\r\n 'revenue': value.revenue,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n/**\r\n *

StakeholderType


Maps to Loan Process stakeholders
\\'Borgensman\\'
\\'Driftbolag\\'
\\'Maka/Make/regpartner\\'
\\'sambo\\'
\\'ägarandel i pant\\'
\\'ägare juridiskt över 50%\\'
\\'övriga med ekonomisk intressegemenskap\\'
\\'SOKANDE\\'
- betyder att de är en sökande på lånet.
\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum StakeholderType {\r\n SOKANDE = 'SOKANDE',\r\n INTRESSENT = 'INTRESSENT',\r\n BORGENSMAN = 'BORGENSMAN',\r\n DRIFTBOLAG = 'DRIFTBOLAG',\r\n MAKEMAKAREGPART = 'MAKEMAKAREGPART',\r\n AGAREJURIDIKO50 = 'AGAREJURIDIKO50',\r\n AGARANDELIPANT = 'AGARANDELIPANT',\r\n SAMBO = 'SAMBO',\r\n EKONOMISKINTRESSEGEMENSKAP = 'EKONOMISKINTRESSEGEMENSKAP'\r\n}\r\n\r\nexport function StakeholderTypeFromJSON(json: any): StakeholderType {\r\n return StakeholderTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function StakeholderTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): StakeholderType {\r\n return json as StakeholderType;\r\n}\r\n\r\nexport function StakeholderTypeToJSON(value?: StakeholderType | null): any {\r\n return value as any;\r\n}\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * This represent loan in other institute to redeem\r\n * @export\r\n * @interface TakeoverLoanType\r\n */\r\nexport interface TakeoverLoanType {\r\n /**\r\n * application model unique identification\r\n * @type {string}\r\n * @memberof TakeoverLoanType\r\n */\r\n processId?: string;\r\n /**\r\n * takeoverLoanId identity\r\n * @type {string}\r\n * @memberof TakeoverLoanType\r\n */\r\n takeoverLoanId: string;\r\n /**\r\n * Lånet är hos kredit institut\r\n * @type {string}\r\n * @memberof TakeoverLoanType\r\n */\r\n creditInstitute?: string;\r\n /**\r\n * This will only be a temporary loanNumber, when can we reserve a loan number in SAP\r\n * @type {string}\r\n * @memberof TakeoverLoanType\r\n */\r\n loanNumber?: string;\r\n /**\r\n * Dept of loan in other institute to redeem\r\n * @type {number}\r\n * @memberof TakeoverLoanType\r\n */\r\n debtAmount?: number;\r\n /**\r\n * Ändamål och syfte ska sättas på respektive lån som går över till LP. I de fall där det inte specifiseras ska handläggaren göra det innan överföring till SAP. Detta för att de ska bli rätt i uppföljning ned i SAS och den finsiella rapporteringen.\r\n * @type {string}\r\n * @memberof TakeoverLoanType\r\n */\r\n purposeText?: string;\r\n /**\r\n * Delsyfte på respektive lån, läses från mainPurposes.json\r\n * @type {string}\r\n * @memberof TakeoverLoanType\r\n */\r\n aimText?: string;\r\n /**\r\n * Aktuell ränta hos nuvarande institute inför lösen\r\n * @type {number}\r\n * @memberof TakeoverLoanType\r\n */\r\n interest?: number;\r\n /**\r\n * Aktuell bindningstid hos nuvarande institue inför lösen\r\n * @type {string}\r\n * @memberof TakeoverLoanType\r\n */\r\n conditionchangedate?: string;\r\n}\r\n\r\nexport function TakeoverLoanTypeFromJSON(json: any): TakeoverLoanType {\r\n return TakeoverLoanTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function TakeoverLoanTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): TakeoverLoanType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'processId': !exists(json, 'processId') ? undefined : json['processId'],\r\n 'takeoverLoanId': json['takeoverLoanId'],\r\n 'creditInstitute': !exists(json, 'creditInstitute') ? undefined : json['creditInstitute'],\r\n 'loanNumber': !exists(json, 'loanNumber') ? undefined : json['loanNumber'],\r\n 'debtAmount': !exists(json, 'debtAmount') ? undefined : json['debtAmount'],\r\n 'purposeText': !exists(json, 'purposeText') ? undefined : json['purposeText'],\r\n 'aimText': !exists(json, 'aimText') ? undefined : json['aimText'],\r\n 'interest': !exists(json, 'interest') ? undefined : json['interest'],\r\n 'conditionchangedate': !exists(json, 'conditionchangedate') ? undefined : json['conditionchangedate'],\r\n };\r\n}\r\n\r\nexport function TakeoverLoanTypeToJSON(value?: TakeoverLoanType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'processId': value.processId,\r\n 'takeoverLoanId': value.takeoverLoanId,\r\n 'creditInstitute': value.creditInstitute,\r\n 'loanNumber': value.loanNumber,\r\n 'debtAmount': value.debtAmount,\r\n 'purposeText': value.purposeText,\r\n 'aimText': value.aimText,\r\n 'interest': value.interest,\r\n 'conditionchangedate': value.conditionchangedate,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * Taxerad ägare\r\n * @export\r\n * @interface TaxedOwnerType\r\n */\r\nexport interface TaxedOwnerType {\r\n /**\r\n * Unique identifier\r\n * @type {string}\r\n * @memberof TaxedOwnerType\r\n */\r\n taxedOwnerId: string;\r\n /**\r\n * Taxerad ägare till fastigheten\r\n * @type {string}\r\n * @memberof TaxedOwnerType\r\n */\r\n taxedOwner: string;\r\n}\r\n\r\nexport function TaxedOwnerTypeFromJSON(json: any): TaxedOwnerType {\r\n return TaxedOwnerTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function TaxedOwnerTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): TaxedOwnerType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'taxedOwnerId': json['taxedOwnerId'],\r\n 'taxedOwner': json['taxedOwner'],\r\n };\r\n}\r\n\r\nexport function TaxedOwnerTypeToJSON(value?: TaxedOwnerType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'taxedOwnerId': value.taxedOwnerId,\r\n 'taxedOwner': value.taxedOwner,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n/**\r\n * Värdeföråd för säkerhet (Fastighet, EU-stöd, borgensman)\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum TypeOfCollateral {\r\n FASTIGHET = 'FASTIGHET',\r\n EUSTOD = 'EUSTOD',\r\n BORGENSMAN = 'BORGENSMAN'\r\n}\r\n\r\nexport function TypeOfCollateralFromJSON(json: any): TypeOfCollateral {\r\n return TypeOfCollateralFromJSONTyped(json, false);\r\n}\r\n\r\nexport function TypeOfCollateralFromJSONTyped(json: any, ignoreDiscriminator: boolean): TypeOfCollateral {\r\n return json as TypeOfCollateral;\r\n}\r\n\r\nexport function TypeOfCollateralToJSON(value?: TypeOfCollateral | null): any {\r\n return value as any;\r\n}\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n/**\r\n * Employeed or Not Employeed, from SAP on existing customer and from UC? or entered by customer. employment mapping to Loan Process PERMANENT - Anställd, tills-vidare-anställd TEMPORARY - Tidbegränsad anställning PROBATIONARY - Provanställning UNEMPLOYMENT_INSURANCE - Arbetslöshetskassa SELF_EMPLOYED - Eget företag STUDENT_AID - Studiestöd PENSION - Inkomst av pension\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum TypeOfEmployeement {\r\n PERMANENT = 'PERMANENT',\r\n TEMPORARY = 'TEMPORARY',\r\n PROBATIONARY = 'PROBATIONARY',\r\n UNEMPLOYMENTINSURANCE = 'UNEMPLOYMENT_INSURANCE',\r\n SELFEMPLOYED = 'SELF_EMPLOYED',\r\n STUDENTAID = 'STUDENT_AID',\r\n PENSION = 'PENSION'\r\n}\r\n\r\nexport function TypeOfEmployeementFromJSON(json: any): TypeOfEmployeement {\r\n return TypeOfEmployeementFromJSONTyped(json, false);\r\n}\r\n\r\nexport function TypeOfEmployeementFromJSONTyped(json: any, ignoreDiscriminator: boolean): TypeOfEmployeement {\r\n return json as TypeOfEmployeement;\r\n}\r\n\r\nexport function TypeOfEmployeementToJSON(value?: TypeOfEmployeement | null): any {\r\n return value as any;\r\n}\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n/**\r\n * typ av annat boende\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum TypeOfHouse {\r\n Villa = 'Villa',\r\n Hyresrtt = 'Hyresrätt',\r\n VrigtBoende = 'Övrigt Boende',\r\n Landbruksfastighet = 'Landbruksfastighet',\r\n Bostadsrtt = 'Bostadsrätt',\r\n Fritidshus = 'Fritidshus'\r\n}\r\n\r\nexport function TypeOfHouseFromJSON(json: any): TypeOfHouse {\r\n return TypeOfHouseFromJSONTyped(json, false);\r\n}\r\n\r\nexport function TypeOfHouseFromJSONTyped(json: any, ignoreDiscriminator: boolean): TypeOfHouse {\r\n return json as TypeOfHouse;\r\n}\r\n\r\nexport function TypeOfHouseToJSON(value?: TypeOfHouse | null): any {\r\n return value as any;\r\n}\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n/**\r\n * Enumeration of type of loans\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum TypeOfLoan {\r\n Studieln = 'Studielån',\r\n KontoKortkredit = 'Konto/kortkredit',\r\n AvbetalningskreditBillnBtln = 'Avbetalningskredit/Billån/båtlån',\r\n Borgenstagande = 'Borgensåtagande',\r\n Garantier = 'Garantier',\r\n Nringskredit = 'Näringskredit',\r\n BlancokreditVrigaLn = 'Blancokredit/övriga lån'\r\n}\r\n\r\nexport function TypeOfLoanFromJSON(json: any): TypeOfLoan {\r\n return TypeOfLoanFromJSONTyped(json, false);\r\n}\r\n\r\nexport function TypeOfLoanFromJSONTyped(json: any, ignoreDiscriminator: boolean): TypeOfLoan {\r\n return json as TypeOfLoan;\r\n}\r\n\r\nexport function TypeOfLoanToJSON(value?: TypeOfLoan | null): any {\r\n return value as any;\r\n}\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\nimport { exists, mapValues } from '../runtime';\r\n/**\r\n * Array of BudgetType, Budget records, minusposter registreras som minusposter value1; Resultaträkning; Skog value2; Resultaträkning; Växtodling value3; Resultaträkning; EU-stöd value4; Resultaträkning; Övrig djurproduktion value5; Resultaträkning; Förändring av lager produktion value6; Resultaträkning; Mjölk value7; Resultaträkning; Övriga intäkter value8; Omsättning totalt (Totala intäkter) summa value1-7 value9; Inköp (Råvaror och förnödenheter) value10; Arrendekostnader value11; Personalkostnader value12; Övriga rörelsekostnader value13; S:a kostnader (summa value9-12) value14; Resultat före avskrivningar (value8 + (-value13)) value15; Avskrivning inventarier (exkl. byggnadsinventerier) value16; Övriga avskrivningar value17; S:a avskrivningar (-value15) + (-value16) value18; Resultat före avskrivningar value14 + (-value17) value19; Finansiella intäkter value20; Finansiellakonstnader value21; Resultat finansiella poster (value18) + value19 + (-value20) value22; Extraordinärar intäkter och kostnader value23; Bokslutsdispositioner value24; Skatt (ägaruttag prognosår EF) value25; Åretsresultat (value21) sum (value22+value23+value24)\r\n * @export\r\n * @interface ValueType\r\n */\r\nexport interface ValueType {\r\n /**\r\n * Intäkter skog\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value1?: number;\r\n /**\r\n * Intäkter växtodling\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value2?: number;\r\n /**\r\n * Intäkter EU-Stöd\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value3?: number;\r\n /**\r\n * Intäkter Övrig djurproduktion\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value4?: number;\r\n /**\r\n * Intäkter Förändring av lager produktion\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value5?: number;\r\n /**\r\n * Intäkter Mjölk\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value6?: number;\r\n /**\r\n * Övriga intäkter\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value7?: number;\r\n /**\r\n * Bruttoomsättning totalt (totala intäkter)\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value8?: number;\r\n /**\r\n * Kostnader, inköp (Råvaror och förnödenheter)\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value9?: number;\r\n /**\r\n * Kostnader, arrendekostnader\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value10?: number;\r\n /**\r\n * Kostnader, personalkostnader\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value11?: number;\r\n /**\r\n * Kostnader, övriga rörelsekostnader\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value12?: number;\r\n /**\r\n * Kostnader, summa kostnader\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value13?: number;\r\n /**\r\n * Resultat för avskrivningar\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value14?: number;\r\n /**\r\n * Avskrivningar inventarier (exkl byggn.inventarier)\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value15?: number;\r\n /**\r\n * Avskrivningar, övriga avskrivningar och nedskrivningar\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value16?: number;\r\n /**\r\n * Summa Avskrivningar\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value17?: number;\r\n /**\r\n * Resultat efter avskrivningar\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value18?: number;\r\n /**\r\n * Finansiella intäkter\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value19?: number;\r\n /**\r\n * Finansiella kostnader\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value20?: number;\r\n /**\r\n * Resultat efter finansiella poster\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value21?: number;\r\n /**\r\n * Extraordinärar intäkter och kostnader\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value22?: number;\r\n /**\r\n * Bokslutdispositioner\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value23?: number;\r\n /**\r\n * Skatt (Ägaruttag prognosår EF)\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value24?: number;\r\n /**\r\n * Årets resultat\r\n * @type {number}\r\n * @memberof ValueType\r\n */\r\n value25?: number;\r\n}\r\n\r\nexport function ValueTypeFromJSON(json: any): ValueType {\r\n return ValueTypeFromJSONTyped(json, false);\r\n}\r\n\r\nexport function ValueTypeFromJSONTyped(json: any, ignoreDiscriminator: boolean): ValueType {\r\n if ((json === undefined) || (json === null)) {\r\n return json;\r\n }\r\n return {\r\n \r\n 'value1': !exists(json, 'value1') ? undefined : json['value1'],\r\n 'value2': !exists(json, 'value2') ? undefined : json['value2'],\r\n 'value3': !exists(json, 'value3') ? undefined : json['value3'],\r\n 'value4': !exists(json, 'value4') ? undefined : json['value4'],\r\n 'value5': !exists(json, 'value5') ? undefined : json['value5'],\r\n 'value6': !exists(json, 'value6') ? undefined : json['value6'],\r\n 'value7': !exists(json, 'value7') ? undefined : json['value7'],\r\n 'value8': !exists(json, 'value8') ? undefined : json['value8'],\r\n 'value9': !exists(json, 'value9') ? undefined : json['value9'],\r\n 'value10': !exists(json, 'value10') ? undefined : json['value10'],\r\n 'value11': !exists(json, 'value11') ? undefined : json['value11'],\r\n 'value12': !exists(json, 'value12') ? undefined : json['value12'],\r\n 'value13': !exists(json, 'value13') ? undefined : json['value13'],\r\n 'value14': !exists(json, 'value14') ? undefined : json['value14'],\r\n 'value15': !exists(json, 'value15') ? undefined : json['value15'],\r\n 'value16': !exists(json, 'value16') ? undefined : json['value16'],\r\n 'value17': !exists(json, 'value17') ? undefined : json['value17'],\r\n 'value18': !exists(json, 'value18') ? undefined : json['value18'],\r\n 'value19': !exists(json, 'value19') ? undefined : json['value19'],\r\n 'value20': !exists(json, 'value20') ? undefined : json['value20'],\r\n 'value21': !exists(json, 'value21') ? undefined : json['value21'],\r\n 'value22': !exists(json, 'value22') ? undefined : json['value22'],\r\n 'value23': !exists(json, 'value23') ? undefined : json['value23'],\r\n 'value24': !exists(json, 'value24') ? undefined : json['value24'],\r\n 'value25': !exists(json, 'value25') ? undefined : json['value25'],\r\n };\r\n}\r\n\r\nexport function ValueTypeToJSON(value?: ValueType | null): any {\r\n if (value === undefined) {\r\n return undefined;\r\n }\r\n if (value === null) {\r\n return null;\r\n }\r\n return {\r\n \r\n 'value1': value.value1,\r\n 'value2': value.value2,\r\n 'value3': value.value3,\r\n 'value4': value.value4,\r\n 'value5': value.value5,\r\n 'value6': value.value6,\r\n 'value7': value.value7,\r\n 'value8': value.value8,\r\n 'value9': value.value9,\r\n 'value10': value.value10,\r\n 'value11': value.value11,\r\n 'value12': value.value12,\r\n 'value13': value.value13,\r\n 'value14': value.value14,\r\n 'value15': value.value15,\r\n 'value16': value.value16,\r\n 'value17': value.value17,\r\n 'value18': value.value18,\r\n 'value19': value.value19,\r\n 'value20': value.value20,\r\n 'value21': value.value21,\r\n 'value22': value.value22,\r\n 'value23': value.value23,\r\n 'value24': value.value24,\r\n 'value25': value.value25,\r\n };\r\n}\r\n\r\n\r\n","/* tslint:disable */\r\n/* eslint-disable */\r\n/**\r\n * SelmaSME API\r\n * This definition is the API between customer SME-Gui and the persistence layer for the application NOT FOR V1 When customer logg-in to Selma-EN, we will create a processId with applicant CustomerId (from BankID). When a customer added attachment to the application, we don\\'t have a CaseId i LP, should we add a LP-Service to create/reserve a caseId to be able to attach a document to the caseId in DM.\r\n *\r\n * The version of the OpenAPI document: 0.7.4\r\n * Contact: developer@landshypotek.se\r\n *\r\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\r\n * https://openapi-generator.tech\r\n * Do not edit the class manually.\r\n */\r\n\r\n\r\nimport * as runtime from '../runtime';\r\nimport {\r\n ErrorModel,\r\n ErrorModelFromJSON,\r\n ErrorModelToJSON,\r\n LinksAll,\r\n LinksAllFromJSON,\r\n LinksAllToJSON,\r\n ProcessType,\r\n ProcessTypeFromJSON,\r\n ProcessTypeToJSON,\r\n ProcessesType,\r\n ProcessesTypeFromJSON,\r\n ProcessesTypeToJSON,\r\n} from '../models';\r\n\r\nexport interface AddProcessRequest {\r\n process?: ProcessType;\r\n}\r\n\r\nexport interface DeleteProcessRequest {\r\n xProcessID: string;\r\n caseIdStatus: DeleteProcessCaseIdStatusEnum;\r\n}\r\n\r\nexport interface GetProcessAllRequest {\r\n xProcessID: string;\r\n}\r\n\r\nexport interface GetProcessesRequest {\r\n customerId: string;\r\n}\r\n\r\nexport interface ReserveCaseIdRequest {\r\n xProcessID: string;\r\n caseIdStatus: ReserveCaseIdCaseIdStatusEnum;\r\n customerId: string;\r\n}\r\n\r\nexport interface SaveProcessAllRequest {\r\n processSaveAll?: LinksAll;\r\n}\r\n\r\nexport interface UpdateProcessStatusRequest {\r\n xProcessID: string;\r\n caseIdStatus: UpdateProcessStatusCaseIdStatusEnum;\r\n caseId?: string;\r\n}\r\n\r\n/**\r\n * no description\r\n */\r\nexport class ProcessesApi extends runtime.BaseAPI {\r\n\r\n /**\r\n * This operation will return a processid that has to be used i header X-process-ID for all other requests in all APIs. As parameter we will allways be using STARTEDBYAPPLICANT\r\n * Operation will be invoked when a customer want to create a new application\r\n */\r\n async addProcessRaw(requestParameters: AddProcessRequest): Promise> {\r\n const queryParameters: runtime.HTTPQuery = {};\r\n\r\n const headerParameters: runtime.HTTPHeaders = {};\r\n\r\n headerParameters['Content-Type'] = 'application/json';\r\n\r\n if (this.configuration && this.configuration.accessToken) {\r\n // oauth required\r\n if (typeof this.configuration.accessToken === 'function') {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken(\"application\", [\"read\", \"write\"]);\r\n } else {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken;\r\n }\r\n }\r\n\r\n const response = await this.request({\r\n path: `/v1/addprocess`,\r\n method: 'PUT',\r\n headers: headerParameters,\r\n query: queryParameters,\r\n body: ProcessTypeToJSON(requestParameters.process),\r\n });\r\n\r\n return new runtime.JSONApiResponse(response, (jsonValue) => ProcessTypeFromJSON(jsonValue));\r\n }\r\n\r\n /**\r\n * This operation will return a processid that has to be used i header X-process-ID for all other requests in all APIs. As parameter we will allways be using STARTEDBYAPPLICANT\r\n * Operation will be invoked when a customer want to create a new application\r\n */\r\n async addProcess(requestParameters: AddProcessRequest): Promise {\r\n const response = await this.addProcessRaw(requestParameters);\r\n return await response.value();\r\n }\r\n\r\n /**\r\n * The customer has choice to end the application process, the whole X-process-ID will be CLOSEDBYAPPLICANT and will be removed during the batch thinning process in Loan Process. A call to LP is required to set ststus on the reserved caseid.\r\n * Set status CLOSEDBYAPPLICANT at the X-process-ID in the model\r\n */\r\n async deleteProcessRaw(requestParameters: DeleteProcessRequest): Promise> {\r\n if (requestParameters.xProcessID === null || requestParameters.xProcessID === undefined) {\r\n throw new runtime.RequiredError('xProcessID','Required parameter requestParameters.xProcessID was null or undefined when calling deleteProcess.');\r\n }\r\n\r\n if (requestParameters.caseIdStatus === null || requestParameters.caseIdStatus === undefined) {\r\n throw new runtime.RequiredError('caseIdStatus','Required parameter requestParameters.caseIdStatus was null or undefined when calling deleteProcess.');\r\n }\r\n\r\n const queryParameters: runtime.HTTPQuery = {};\r\n\r\n const headerParameters: runtime.HTTPHeaders = {};\r\n\r\n if (requestParameters.xProcessID !== undefined && requestParameters.xProcessID !== null) {\r\n headerParameters['X-process-ID'] = String(requestParameters.xProcessID);\r\n }\r\n\r\n if (requestParameters.caseIdStatus !== undefined && requestParameters.caseIdStatus !== null) {\r\n headerParameters['caseIdStatus'] = String(requestParameters.caseIdStatus);\r\n }\r\n\r\n if (this.configuration && this.configuration.accessToken) {\r\n // oauth required\r\n if (typeof this.configuration.accessToken === 'function') {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken(\"application\", [\"read\", \"write\"]);\r\n } else {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken;\r\n }\r\n }\r\n\r\n const response = await this.request({\r\n path: `/v1/deleteprocess`,\r\n method: 'DELETE',\r\n headers: headerParameters,\r\n query: queryParameters,\r\n });\r\n\r\n return new runtime.JSONApiResponse(response);\r\n }\r\n\r\n /**\r\n * The customer has choice to end the application process, the whole X-process-ID will be CLOSEDBYAPPLICANT and will be removed during the batch thinning process in Loan Process. A call to LP is required to set ststus on the reserved caseid.\r\n * Set status CLOSEDBYAPPLICANT at the X-process-ID in the model\r\n */\r\n async deleteProcess(requestParameters: DeleteProcessRequest): Promise {\r\n const response = await this.deleteProcessRaw(requestParameters);\r\n return await response.value();\r\n }\r\n\r\n /**\r\n * Return all data for all object in the activiti process regardless if the contains any information, empty objects will return null\r\n * Return all information object for a given processid\r\n */\r\n async getProcessAllRaw(requestParameters: GetProcessAllRequest): Promise> {\r\n if (requestParameters.xProcessID === null || requestParameters.xProcessID === undefined) {\r\n throw new runtime.RequiredError('xProcessID','Required parameter requestParameters.xProcessID was null or undefined when calling getProcessAll.');\r\n }\r\n\r\n const queryParameters: runtime.HTTPQuery = {};\r\n\r\n const headerParameters: runtime.HTTPHeaders = {};\r\n\r\n if (requestParameters.xProcessID !== undefined && requestParameters.xProcessID !== null) {\r\n headerParameters['X-process-ID'] = String(requestParameters.xProcessID);\r\n }\r\n\r\n if (this.configuration && this.configuration.accessToken) {\r\n // oauth required\r\n if (typeof this.configuration.accessToken === 'function') {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken(\"application\", [\"read\", \"write\"]);\r\n } else {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken;\r\n }\r\n }\r\n\r\n const response = await this.request({\r\n path: `/v1/getprocess`,\r\n method: 'POST',\r\n headers: headerParameters,\r\n query: queryParameters,\r\n });\r\n\r\n return new runtime.JSONApiResponse(response, (jsonValue) => LinksAllFromJSON(jsonValue));\r\n }\r\n\r\n /**\r\n * Return all data for all object in the activiti process regardless if the contains any information, empty objects will return null\r\n * Return all information object for a given processid\r\n */\r\n async getProcessAll(requestParameters: GetProcessAllRequest): Promise {\r\n const response = await this.getProcessAllRaw(requestParameters);\r\n return await response.value();\r\n }\r\n\r\n /**\r\n * Return a list of active applications for a specific customer.\r\n * get a list of active processes for a in:body parameter customerId\r\n */\r\n async getProcessesRaw(requestParameters: GetProcessesRequest): Promise> {\r\n if (requestParameters.customerId === null || requestParameters.customerId === undefined) {\r\n throw new runtime.RequiredError('customerId','Required parameter requestParameters.customerId was null or undefined when calling getProcesses.');\r\n }\r\n\r\n const queryParameters: runtime.HTTPQuery = {};\r\n\r\n const headerParameters: runtime.HTTPHeaders = {};\r\n\r\n headerParameters['Content-Type'] = 'application/json';\r\n\r\n if (this.configuration && this.configuration.accessToken) {\r\n // oauth required\r\n if (typeof this.configuration.accessToken === 'function') {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken(\"application\", [\"read\", \"write\"]);\r\n } else {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken;\r\n }\r\n }\r\n\r\n const response = await this.request({\r\n path: `/v1/getprocesses`,\r\n method: 'POST',\r\n headers: headerParameters,\r\n query: queryParameters,\r\n body: requestParameters.customerId as any,\r\n });\r\n\r\n return new runtime.JSONApiResponse(response, (jsonValue) => ProcessesTypeFromJSON(jsonValue));\r\n }\r\n\r\n /**\r\n * Return a list of active applications for a specific customer.\r\n * get a list of active processes for a in:body parameter customerId\r\n */\r\n async getProcesses(requestParameters: GetProcessesRequest): Promise {\r\n const response = await this.getProcessesRaw(requestParameters);\r\n return await response.value();\r\n }\r\n\r\n /**\r\n * Reserve a CaseId in Loan Process to be able to use attachment i DM. In this case parameter caseIdStatus should be set to enumeration of STARTEDBYAPPLICANT\r\n * Reserve a CaseId in Loan Process\r\n */\r\n async reserveCaseIdRaw(requestParameters: ReserveCaseIdRequest): Promise> {\r\n if (requestParameters.xProcessID === null || requestParameters.xProcessID === undefined) {\r\n throw new runtime.RequiredError('xProcessID','Required parameter requestParameters.xProcessID was null or undefined when calling reserveCaseId.');\r\n }\r\n\r\n if (requestParameters.caseIdStatus === null || requestParameters.caseIdStatus === undefined) {\r\n throw new runtime.RequiredError('caseIdStatus','Required parameter requestParameters.caseIdStatus was null or undefined when calling reserveCaseId.');\r\n }\r\n\r\n if (requestParameters.customerId === null || requestParameters.customerId === undefined) {\r\n throw new runtime.RequiredError('customerId','Required parameter requestParameters.customerId was null or undefined when calling reserveCaseId.');\r\n }\r\n\r\n const queryParameters: runtime.HTTPQuery = {};\r\n\r\n const headerParameters: runtime.HTTPHeaders = {};\r\n\r\n headerParameters['Content-Type'] = 'application/json';\r\n\r\n if (requestParameters.xProcessID !== undefined && requestParameters.xProcessID !== null) {\r\n headerParameters['X-process-ID'] = String(requestParameters.xProcessID);\r\n }\r\n\r\n if (requestParameters.caseIdStatus !== undefined && requestParameters.caseIdStatus !== null) {\r\n headerParameters['caseIdStatus'] = String(requestParameters.caseIdStatus);\r\n }\r\n\r\n if (this.configuration && this.configuration.accessToken) {\r\n // oauth required\r\n if (typeof this.configuration.accessToken === 'function') {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken(\"application\", [\"read\", \"write\"]);\r\n } else {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken;\r\n }\r\n }\r\n\r\n const response = await this.request({\r\n path: `/v1/reserveeaseid`,\r\n method: 'POST',\r\n headers: headerParameters,\r\n query: queryParameters,\r\n body: requestParameters.customerId as any,\r\n });\r\n\r\n return new runtime.TextApiResponse(response) as any;\r\n }\r\n\r\n /**\r\n * Reserve a CaseId in Loan Process to be able to use attachment i DM. In this case parameter caseIdStatus should be set to enumeration of STARTEDBYAPPLICANT\r\n * Reserve a CaseId in Loan Process\r\n */\r\n async reserveCaseId(requestParameters: ReserveCaseIdRequest): Promise {\r\n const response = await this.reserveCaseIdRaw(requestParameters);\r\n return await response.value();\r\n }\r\n\r\n /**\r\n * To be able to implement a service that save all information object\r\n * Save all information object for a given processid\r\n */\r\n async saveProcessAllRaw(requestParameters: SaveProcessAllRequest): Promise> {\r\n const queryParameters: runtime.HTTPQuery = {};\r\n\r\n const headerParameters: runtime.HTTPHeaders = {};\r\n\r\n headerParameters['Content-Type'] = 'application/json';\r\n\r\n if (this.configuration && this.configuration.accessToken) {\r\n // oauth required\r\n if (typeof this.configuration.accessToken === 'function') {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken(\"application\", [\"read\", \"write\"]);\r\n } else {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken;\r\n }\r\n }\r\n\r\n const response = await this.request({\r\n path: `/v1/saveprocess`,\r\n method: 'POST',\r\n headers: headerParameters,\r\n query: queryParameters,\r\n body: LinksAllToJSON(requestParameters.processSaveAll),\r\n });\r\n\r\n return new runtime.JSONApiResponse(response);\r\n }\r\n\r\n /**\r\n * To be able to implement a service that save all information object\r\n * Save all information object for a given processid\r\n */\r\n async saveProcessAll(requestParameters: SaveProcessAllRequest): Promise {\r\n const response = await this.saveProcessAllRaw(requestParameters);\r\n return await response.value();\r\n }\r\n\r\n /**\r\n * When we create/reserve a caseId in LP we also have to set the status\r\n * set status on the reserved caseId\r\n */\r\n async updateProcessStatusRaw(requestParameters: UpdateProcessStatusRequest): Promise> {\r\n if (requestParameters.xProcessID === null || requestParameters.xProcessID === undefined) {\r\n throw new runtime.RequiredError('xProcessID','Required parameter requestParameters.xProcessID was null or undefined when calling updateProcessStatus.');\r\n }\r\n\r\n if (requestParameters.caseIdStatus === null || requestParameters.caseIdStatus === undefined) {\r\n throw new runtime.RequiredError('caseIdStatus','Required parameter requestParameters.caseIdStatus was null or undefined when calling updateProcessStatus.');\r\n }\r\n\r\n const queryParameters: runtime.HTTPQuery = {};\r\n\r\n const headerParameters: runtime.HTTPHeaders = {};\r\n\r\n headerParameters['Content-Type'] = 'application/json';\r\n\r\n if (requestParameters.xProcessID !== undefined && requestParameters.xProcessID !== null) {\r\n headerParameters['X-process-ID'] = String(requestParameters.xProcessID);\r\n }\r\n\r\n if (requestParameters.caseIdStatus !== undefined && requestParameters.caseIdStatus !== null) {\r\n headerParameters['caseIdStatus'] = String(requestParameters.caseIdStatus);\r\n }\r\n\r\n if (this.configuration && this.configuration.accessToken) {\r\n // oauth required\r\n if (typeof this.configuration.accessToken === 'function') {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken(\"application\", [\"read\", \"write\"]);\r\n } else {\r\n headerParameters[\"Authorization\"] = this.configuration.accessToken;\r\n }\r\n }\r\n\r\n const response = await this.request({\r\n path: `/v1/updateprocessstatus`,\r\n method: 'PATCH',\r\n headers: headerParameters,\r\n query: queryParameters,\r\n body: requestParameters.caseId as any,\r\n });\r\n\r\n return new runtime.JSONApiResponse(response);\r\n }\r\n\r\n /**\r\n * When we create/reserve a caseId in LP we also have to set the status\r\n * set status on the reserved caseId\r\n */\r\n async updateProcessStatus(requestParameters: UpdateProcessStatusRequest): Promise {\r\n const response = await this.updateProcessStatusRaw(requestParameters);\r\n return await response.value();\r\n }\r\n\r\n}\r\n\r\n/**\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum DeleteProcessCaseIdStatusEnum {\r\n CLOSEDBYAPPLICANT = 'CLOSEDBYAPPLICANT',\r\n STARTEDBYAPPLICANT = 'STARTEDBYAPPLICANT',\r\n CLOSEDBYOFFICER = 'CLOSEDBYOFFICER',\r\n CLOSEDBYTHINNING = 'CLOSEDBYTHINNING',\r\n READYFOROFFICER = 'READYFOROFFICER'\r\n}\r\n/**\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum ReserveCaseIdCaseIdStatusEnum {\r\n CLOSEDBYAPPLICANT = 'CLOSEDBYAPPLICANT',\r\n STARTEDBYAPPLICANT = 'STARTEDBYAPPLICANT',\r\n CLOSEDBYOFFICER = 'CLOSEDBYOFFICER',\r\n CLOSEDBYTHINNING = 'CLOSEDBYTHINNING',\r\n READYFOROFFICER = 'READYFOROFFICER'\r\n}\r\n/**\r\n * @export\r\n * @enum {string}\r\n */\r\nexport enum UpdateProcessStatusCaseIdStatusEnum {\r\n CLOSEDBYAPPLICANT = 'CLOSEDBYAPPLICANT',\r\n STARTEDBYAPPLICANT = 'STARTEDBYAPPLICANT',\r\n CLOSEDBYOFFICER = 'CLOSEDBYOFFICER',\r\n CLOSEDBYTHINNING = 'CLOSEDBYTHINNING',\r\n READYFOROFFICER = 'READYFOROFFICER'\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { Configuration, RequestContext, FetchParams } from '../libs/SMELPOClient';\r\nimport { ProcessesApi, UpdateProcessStatusCaseIdStatusEnum} from '../libs/SMELPOClient/apis';\r\nimport { ProcessType, LinksAll, ProcessesType } from '../libs/SMELPOClient/models';\r\nimport { SessionService } from './SessionService';\r\nimport { AddProcessRequest } from '../libs/SMELPOClient/apis/ProcessesApi';\r\nimport { CaseIdStatus } from '../libs/SMELPOClient/models/CaseIdStatus';\r\nimport { AdminCasesSearch, AdminCasesSearchResult } from '../models/extendedlpo/Admin';\r\nimport { FullProcess } from '../models/extendedlpo/FullProcess';\r\nimport { SearchApplicantResult } from '../models/extendedlpo/ApplicantSearch';\r\n\r\nexport interface SMELPOResult {\r\n\tresultTime: Date;\r\n\tdata:T;\r\n}\r\n\r\nexport class SMELPOService extends BaseService {\r\n\r\n\tprivate url: string;\r\n\tprivate apiConfiguration: Configuration;\r\n\r\n\tconstructor(url: string, private sessionService: SessionService) {\r\n\t\tsuper();\r\n\t\tthis.url = url;\r\n\r\n\t\tthis.apiConfiguration = new Configuration({\r\n\t\t\tbasePath: this.url,\r\n\t\t\tmiddleware: [{\r\n\t\t\t\t//pre?(context: RequestContext): Promise;\r\n\t\t\t\tpre: this.preRequest\r\n\t\t\t\t//post?(context: ResponseContext): Promise;\r\n\t\t\t}]\r\n\t\t\t//accessToken: \"token\"\r\n\t\t});\r\n\t}\r\n\r\n\tpreRequest = (context: RequestContext): Promise => {\r\n\t\tlet init = context.init;\r\n\t\tinit.credentials = \"include\";\r\n\t\tlet params:FetchParams = {\r\n\t\t\turl: context.url,\r\n\t\t\tinit: init\r\n\t\t};\r\n\t\treturn Promise.resolve(params);\r\n\t}\r\n\r\n\r\n\t// Gets a an API with interface of type T. func is the factory for the type.\r\n\tprivate api(func): T {\r\n\t\t//console.log(\"SMELPOService api \" + func.name);\r\n\t\tvar apiObj = new func(this.apiConfiguration /*, fetch, basePath*/);\r\n\t\treturn apiObj;\r\n\t}\r\n\r\n\tprivate result(promise: Promise): Promise> {\r\n\t\treturn promise.then(result => {\r\n\t\t\t//console.log(\"SMELPOService 200OK\");\r\n\t\t\treturn {\r\n\t\t\t\tresultTime: new Date(),\r\n\t\t\t\tdata: result\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tokResult() {\r\n\t\treturn Promise.resolve({\r\n\t\t\tresultTime: new Date()\r\n\t\t});\r\n\t}\r\n\r\n\tprivate mySsn(): string {\r\n\t\tlet login = this.sessionService.getLogin();\r\n\t\treturn login.ssn;\r\n\t}\r\n\r\n\tprivate post(op:string, body:any) : Promise {\r\n\t\tlet bodyJson = JSON.stringify(body);\r\n\t\treturn fetch(this.url+'/'+op, {\r\n\t\t\tmethod:\"POST\",\r\n\t\t\tcache: 'no-cache',\r\n\t\t\tcredentials: \"include\",\r\n\t\t\theaders: {\r\n\t\t\t\t'Accept': 'application/json',\r\n\t\t\t\t'Content-Type': 'application/json'\r\n\t\t\t},\r\n\t\t\tbody: bodyJson\r\n\t\t})\r\n\t\t.then(result => {\r\n\t\t\treturn result.json();\r\n\t\t})\r\n\t\t.then((result) => {\r\n\t\t\tlet bidResult = result;\r\n\t\t\treturn bidResult;\r\n\t\t});\r\n\t}\r\n\r\n\t// ==== PROCESS ======================\r\n\r\n\tgetProcess(processId: string): Promise> {\r\n\t\treturn this.result(\r\n\t\t\tthis.api(ProcessesApi).getProcessAll({\r\n\t\t\t\txProcessID: processId\r\n\t\t\t})\r\n\t\t);\r\n\t}\r\n\r\n\tgetProcesses(customerId?: string): Promise> {\r\n\t\tif (!customerId)\r\n\t\t\tcustomerId = this.mySsn();\r\n\t\treturn this.result(\r\n\t\t\tthis.api(ProcessesApi).getProcesses({\r\n\t\t\t\tcustomerId: customerId\r\n\t\t\t})\r\n\t\t);\r\n\t}\r\n\r\n\taddProcess(process: ProcessType, customerId?: string): Promise> {\r\n\t\tif (!customerId)\r\n\t\t\tcustomerId = this.mySsn();\r\n\r\n\t\tlet arg:AddProcessRequest = {\r\n\t\t\tprocess: {\r\n\t\t\t\tprocessId: process.processId,\r\n\t\t\t\tcaseIdStatus: CaseIdStatus.STARTEDBYAPPLICANT, // 'STARTEDBYAPPLICANT', //AddProcessCaseIdStatusEnum.STARTEDBYAPPLICANT,\r\n\t\t\t\tcustomers: [{ customerId: customerId, customerAdded: new Date().toISOString() }]\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn this.result(\r\n\t\t\tthis.api(ProcessesApi).addProcess(arg)\r\n\t\t\t.then(result => { \r\n\t\t\t\treturn result;\r\n\t\t\t})\r\n\t\t);\r\n\t}\r\n\r\n\tsaveProcess(process: FullProcess): Promise> {\r\n\t\treturn this.result(\r\n\t\t\tthis.api(ProcessesApi).saveProcessAll({\r\n\t\t\t\tprocessSaveAll: process\r\n\t\t\t})\r\n\t\t); \r\n\t}\r\n\r\n\t// ==== CASE ======================\r\n\r\n\tdeleteCase(processId: string, caseId: string, status:UpdateProcessStatusCaseIdStatusEnum): Promise> {\r\n\t\treturn this.setCaseStatus(processId, caseId, status);\r\n\t}\r\n\r\n\tsetCaseStatus(processId: string, caseId: string, //caseStatus: 'CLOSEDBYAPPLICANT' | 'STARTEDBYAPPLICANT' | 'CLOSEDBYOFFICER' | 'CLOSEDBYTHINNING' | 'READYFOROFFICER'\r\n\t\tcaseStatus: UpdateProcessStatusCaseIdStatusEnum\r\n\t): Promise> {\r\n\t\treturn this.result(\r\n\t\t\tthis.api(ProcessesApi).updateProcessStatus({ xProcessID: processId, caseIdStatus: caseStatus, caseId: caseId })\r\n\t\t);\r\n\t}\r\n\r\n\t// ==== ADMIN ======================\r\n\r\n\tadminSearchProcesses(search:AdminCasesSearch) : Promise {\r\n\t\treturn this.post('Admin/SearchAdminCases', search); \r\n\t}\r\n\r\n\tdownloadFetchResult(result:Promise) {\r\n\t\tvar httpResponse;\r\n\t\treturn result.then(response => {\r\n\t\t\thttpResponse = response;\r\n\t\t\treturn response.blob()\r\n\t\t})\r\n\t\t.then(blob => {\r\n\t\t\tvar cd = httpResponse.headers[\"Content-Disposition\"];\r\n\t\t\tvar fileName = cd;\r\n\r\n\t\t\tvar url = URL.createObjectURL(blob);\r\n\t\t\tvar a = document.createElement('a');\r\n\t\t\ta.href = url;\r\n\t\t\ta.download = fileName;\r\n\t\t\tdocument.body.appendChild(a); // we need to append the element to the dom -> otherwise it will not work in firefox\r\n\t\t\ta.click(); \r\n\t\t\ta.remove(); //afterwards we remove the element again \r\n\t\t})\r\n\t\t// .then(blob => URL.createObjectURL(blob))\r\n\t\t// .then(url => {\r\n\t\t// \twindow.open(url, '_blank');\r\n\t\t// \tURL.revokeObjectURL(url);\r\n\t\t// });\r\n\t}\r\n\r\n\r\n\t// ==== APPLICANT ======================\r\n\r\n\tsearchApplicant(processId: string, customerId:string): Promise {\r\n\t\t// return fetch(this.url+'/Search/searchapplicant', {\r\n\t\t// \tmethod: 'POST',\r\n\t\t// \tcredentials: \"include\",\r\n\t\t// \theaders: {\r\n\t\t// \t\t'Accept': 'application/json',\r\n\t\t// \t\t'Content-Type': 'application/json'\r\n\t\t// \t},\r\n\t\t// \tbody: JSON.stringify({\r\n\t\t// \t\tProcessId:processId,\r\n\t\t// \t\tCustomerId:customerId\r\n\t\t// \t})\r\n\t\t// })\r\n\t\t// .then(result => {\r\n\t\t// \treturn result.json();\r\n\t\t// });\r\n\t\treturn this.post('Search/searchapplicant', {\r\n\t\t\tProcessId:processId,\r\n\t\t\tCustomerId:customerId\r\n\t\t});\r\n\t}\r\n\r\n\r\n\t// addApplicant(processId: string, applicant: Applicant): Promise {\r\n\t// \treturn this.result(\r\n\t// \t\tthis.api(ApplicantsApi).addApplicant({processId, applicant})\r\n\t// \t);\r\n\t// }\r\n\r\n\t// updateApplicant(processId: string, updateApplicant: UpdateApplicantType): Promise {\r\n\t// \treturn this.result(\r\n\t// \t\tthis.api(ApplicantsApi).updateApplicant(processId, updateApplicant)\r\n\t// \t);\r\n\t// }\r\n\r\n\t// deleteApplicant(processId: string, customerId: string): Promise {\r\n\t// \treturn this.result(\r\n\t// \t\tthis.api(ApplicantsApi).deleteApplicant(processId, customerId)\r\n\t// \t);\r\n\t// }\r\n\r\n\r\n\t// ==== COMPANIES ======================\r\n\r\n\t// addCompany(processId:string, applicant:Applicant) : Promise {\r\n\t// return this.result(\r\n\t// this.api(ApplicantsApi).addApplicant(processId, applicant)\r\n\t// );\r\n\t// }\r\n\r\n\t// updateCompany(processId:string, updateApplicant:UpdateApplicantType) : Promise {\r\n\t// return this.result(\r\n\t// this.api(ApplicantsApi).updateApplicant(processId, updateApplicant)\r\n\t// );\r\n\t// }\r\n\r\n\t// deleteCompany(processId:string, customerId:string) : Promise {\r\n\t// return this.result(\r\n\t// this.api(ApplicantsApi).deleteApplicant(processId, customerId)\r\n\t// );\r\n\t// } \r\n\r\n\r\n}\r\n","import { UiLanguageService, UiLanguage } from './UiLanguageService';\r\nimport { BaseService } from './BaseService';\r\nimport { StateService } from './StateService';\r\n\r\nexport class TextService extends BaseService {\r\n\r\n\tprivate stateService: StateService;\r\n\tprivate uiLanguageService: UiLanguageService;\r\n\r\n\tconstructor(stateService: StateService, uiLanguageService: UiLanguageService) {\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.uiLanguageService = uiLanguageService;\r\n\t}\r\n\r\n\ttext(key: string): string | undefined {\r\n\t\tlet l = this.stateService.state.language;\r\n\t\tif (l)\r\n\t\t\treturn l.texts[key];\r\n\t\treturn undefined;\r\n\t}\r\n\r\n\ttexts(keys: string[]): (string|undefined)[] {\r\n\t\tlet l = this.stateService.state.language;\r\n\t\tif (!l) {\r\n\t\t\treturn [];\r\n\t\t}\r\n\t\tlet ll = l;\r\n\t\treturn keys.map(key => { return ll.texts[key];});\r\n\t}\r\n\r\n\ttextsOrEmpty(keys: string[]): string[] {\r\n\t\treturn this.texts(keys).map(str => { return str?str:''; });\r\n\t}\r\n\r\n\ttextOrKey(key: string): string {\r\n\t\treturn this.textOrDefault(key,key);\r\n\t}\r\n\r\n\ttextOrEmpty(key: string): string {\r\n\t\treturn this.textOrDefault(key,'');\r\n\t}\r\n\r\n\tformattedTextOrEmpty(key: string, data:any): string {\r\n\t\tconst t = this.textOrDefault(key,'');\r\n\t\tconst ft = this.format(t, data);\r\n\t\treturn ft;\r\n\t}\r\n\r\n\t// Takes a string such as \"foo bar {paramA}, {paramB} xxx yyy\"\r\n\t// and formats with data from object such as {paramA:\"Patrik\", paramB:\"Awesome\"}\r\n\t// into a string.\r\n\tformat(text:string, data:any) : string {\r\n\t\tfor (var property in data) {\r\n\t\t\t// eslint-disable-next-line no-prototype-builtins\r\n\t\t\tif (data.hasOwnProperty(property)) {\r\n\t\t\t\tlet r = new RegExp(\"{\"+property+\"}\",\"g\")\r\n\t\t\t\tlet val = data[property];\r\n\t\t\t\ttext = text.replace(r, val);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn text;\r\n\t}\r\n\r\n\ttextOrDefault(key: string, defaultText:string): string {\r\n\t\tvar t = this.text(key);\r\n\t\tif (t)\r\n\t\t\treturn t;\r\n\t\treturn defaultText;\r\n\t}\r\n\r\n\t/**\r\n\t * Nils never return empty values. If empty, the value==key, ex \"lang|sv-SE|SME.Settings_MaintenanceMode\": \"lang|sv-SE|SME.Settings_MaintenanceMode\"\r\n\t * Editors in nils can \"empty\" the value by setting a whitespace \" \" which is returned by Nils Service\r\n\t * this method returns defaultText if key==value or value.lengt <3 chars\r\n\t * @param key Text key\r\n\t * @param defaultText Default value\r\n\t */\r\n\tnilsEmptyOrDefault(key:string, defaultText:string): string {\r\n\t\tlet value = this.text(key);\r\n\r\n\t\tif (value === undefined)\r\n\t\t\treturn defaultText;\r\n\r\n\t\t// keys in SME api are stripped from 'lang|sv-SE|SME.' so just compare last part of value against 'key'\r\n\t\tif (value.toLowerCase().endsWith(key.toLocaleLowerCase()))\r\n\t\t\treturn defaultText;\r\n\r\n\t\tif (value.length < 3)\r\n\t\t\treturn defaultText;\r\n\r\n\t\treturn value;\r\n\t}\r\n\r\n\tuseLanguage(languageCode: string): Promise {\r\n\t\treturn this.uiLanguageService\r\n\t\t\t.load(languageCode)\r\n\t\t\t.then((result) => {\r\n\t\t\t\tlet oldLang = this.stateService.state.language;\r\n\t\t\t\tthis.stateService.state.language = result;\r\n\t\t\t\tthis.stateService.replace(oldLang, result);\r\n\t\t\t\treturn result;\r\n\t\t\t})\r\n\t}\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { StateService } from './StateService';\r\n\r\nexport interface Oidc {\r\n\tauthority: string,\r\n\tclientId: string,\r\n\tredirectUri: string,\r\n\tautomaticSilentRenew: string,\r\n\tscope: string,\r\n\tpostLogoutRedirectUri: string,\r\n\tfetchRequestCredentials: string\r\n}\r\n\r\nexport interface Configuration {\r\n\tmaintenanceMode: boolean;\r\n\tuseLocalLogin: boolean;\r\n\tsmeBaseUrl: string;\r\n\tbidBaseUrl: string;\r\n\toidcBaseUrl: string,\r\n\tlpBaseUrl: string;\r\n\tebbotChatEnabled: boolean;\r\n\tebbotChatBotId: string;\r\n\takkaUrl: string,\r\n\toidc: Oidc\r\n}\r\n\r\n\r\nexport class ConfigurationService extends BaseService {\r\n\r\n\tprivate configuration?: Configuration; // current config.\r\n\tprivate stateService: StateService;\r\n\tprivate protectAgainstPageLeaveEnabled: boolean = true;\r\n\r\n\tconstructor(stateService: StateService) {\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t}\r\n\r\n\tload(url: string): Promise {\r\n\t\tlet promise = fetch(`${url}?cache=${Date.now()}`)\r\n\t\t\t.then((result) => {\r\n\t\t\t\treturn result.json();\r\n\t\t\t}).then((result: Configuration) => {\r\n\t\t\t\tlet prevConfig = this.configuration;\r\n\t\t\t\tthis.configuration = result;\r\n\t\t\t\tthis.stateService.state.configuration = this.configuration;\r\n\t\t\t\tthis.stateService.replace(prevConfig, this.configuration);\r\n\t\t\t\treturn this.configuration;\r\n\t\t\t});\r\n\t\treturn promise;\r\n\t}\r\n\r\n\tgetConfiguration(): Configuration {\r\n\t\tif (!this.configuration)\r\n\t\t\tthrow 'No config';\r\n\t\treturn this.configuration;\r\n\t}\r\n\r\n\tmaintenanceMode(): boolean {\r\n\t\treturn this.configuration && this.configuration.maintenanceMode === true ? true : false;\r\n\t}\r\n\r\n\tebbotChatEnabled(): boolean {\r\n\t\treturn this.configuration && this.configuration.ebbotChatEnabled === true ? true : false;\r\n\t}\r\n\r\n\tebbotChatBotId(): string {\r\n\t\treturn this.configuration?.ebbotChatBotId ?? '';\r\n\t}\r\n\r\n\toidcSettings(): Oidc {\r\n\t\treturn this.configuration?.oidc ?? {} as Oidc;\r\n\t}\r\n\r\n\tprotectAgainstPageLeave(): boolean {\r\n\t\treturn this.protectAgainstPageLeaveEnabled;\r\n\t}\r\n\r\n\tsetProtectAgainstPageLeave(enabled: boolean): void {\r\n\t\tthis.protectAgainstPageLeaveEnabled = enabled;\r\n\t}\r\n\r\n\tuseLocalLogin(): boolean {\r\n\t\tif(this.configuration)\r\n\t\t\treturn process.env.NODE_ENV === 'development' && this.configuration.useLocalLogin\r\n\t\treturn false;\r\n\t}\r\n}\r\n","/* eslint-disable no-control-regex */\r\nimport { BaseService } from './BaseService';\r\nimport { ConvertService } from './ConvertService';\r\n\r\nexport class GuardService extends BaseService {\r\n\r\n\tconvertService?:ConvertService;\r\n\r\n\t// http://emailregex.com/ General Email Regex (RFC 5322 Official Standard)\r\n\temailPattern = /^(?:[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*|\"(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21\\x23-\\x5b\\x5d-\\x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])*\")@(?:(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?|\\[(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?|[a-z0-9-]*[a-z0-9]:(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21-\\x5a\\x53-\\x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])+)\\])$/i;\r\n\r\n\t// https://sv.wikipedia.org/wiki/Diakritiskt_tecken\r\n\tlatinUnicodeDiacritics = \"ÀÁÂÃÄÅÇÈÉÊËÌÍÎÏÑÒÓÔÕÖØÙÚÛÜÝàáâãäåçèéêëìíîïñòóôõöøùúûüýÿĀāĂ㥹ĆćĈĉĊċČčĎďĐđĒēĔĕĖėĘęĚěĜĝĞğĠġĢģĤĥĦħĨĩĪīĬĭĮįİĴĵĶķĹĺĻļĽľĿŀŁłŃńŅņŇňʼnŌōŎŏŐőŔŕŖŗŘřŚśŜŝŞşŠšŢţŤťŦŧŨũŪūŬŭŮůŰűŲųŴŵŶŷŸŹźŻżŽŽƂƃƇƈƋƌƑƒƓƘƙƝƠơƣƤƥƨƫƬƭƮƯưƳƴƵƶǍǎǏǐǑǒǓǔǕǖǗǘǙǚǛǜǝǞǟǠǡǤǥǦǧǨǩǪǫǬǭǰǴǵǸǹǺǻǾǿȀȁȂȃȄȅȆȇȈȉȊȋȌȍȎȏȐȑȒȓȔȕȖȗȘșȚțȞȟȤȥȦȧȨȩȪȫȬȭȮȯȰȱȲȳḀḁḂḃḄḅḆḇḈḉḊḋḌḍḎḏḐḑḒḓḔḕḖḗḘḙḚḛḜḝḞḟḠḡḢḣḤḥḦḧḨḩḪḫḬḭḮḯḰḱḲḳḴḵḶḷḸḹḺḻḼḽḾḿṀṁṂṃṄṅṆṇṈṉṊṋṌṍṎṏṐṑṒṓṔṕṖṗṘṙṚṛṜṝṞṟṠṡṢṣṤṥṦṧṨṩṪṫṬṭṮṯṰṱṲṳṴṵṶṷṸṹṺṻṼṽṾṿẀẁẂẃẄẅẆẇẈẉẊẋẌẍẎẏẐẑẒẓẔẕẖẗẘẙẚẠạẢảẤấẦầẨẩẪẫẬậẮắẰằẲẳẴẵẶặẸẹẺẻẼẽẾếỀềỂểỄễỆệỈỉỊịỌọỎỏỐốỒồỔổỖỗỘộỚớỜờỞởỠỡỢợỤụỦủỨứỪừỬửỮữỰựỲỳỴỵỶỷỸỹ\";\r\n\temailNegPattern = new RegExp('[' + this.latinUnicodeDiacritics + ']');\r\n\r\n\t// === Type checks =========\r\n\tisString(val: any): boolean {\r\n\t\treturn typeof(val)===\"string\" || val instanceof String;\r\n\t}\r\n\tisNumber(val: any): boolean {\r\n\t\treturn typeof(val)===\"number\";\r\n\t}\r\n\tisObject(val: any): boolean {\r\n\t\treturn typeof(val)===\"object\";\r\n\t}\r\n\r\n\t// === Undefined (=undef) =========\r\n\tisUndefined(val: any): boolean {\r\n\t\treturn typeof (val) === \"undefined\";\r\n\t}\r\n\tisUndefinedOrEmpty(val: string | Array | undefined): boolean {\r\n\t\treturn this.isUndefined(val) || !val || val.length === 0;\r\n\t}\r\n\tisUndefinedOrLessThanZero(val: number): boolean {\r\n\t\treturn this.isUndefined(val) || val < 0;\r\n\t}\r\n\tisDefined(val: any): boolean {\r\n\t\treturn typeof (val) !== \"undefined\";\r\n\t}\r\n\r\n\t// === Unvalued (=undef or =null) =========\r\n\tisUnvalued(val: any): boolean {\r\n\t\treturn this.isUndefined(val) || val === null;\r\n\t}\r\n\tisUnvaluedOrFalse(val: boolean | undefined): boolean {\r\n\t\treturn this.isUndefined(val) || val === null || val === false;\r\n\t}\r\n\tisUnvaluedOrTrue(val: boolean | undefined): boolean {\r\n\t\treturn this.isUndefined(val) || val === null || val === true;\r\n\t}\r\n\tisUnvaluedOrEmpty(val: string | Array | undefined): boolean {\r\n\t\treturn this.isUndefined(val) || val === null || val===undefined || val.length === 0;\r\n\t}\r\n\tisUnvaluedOrLessThanZero(val: number | undefined): boolean {\r\n\t\treturn this.isUndefined(val) || val === null || val===undefined || val < 0;\r\n\t}\r\n\tisUnvaluedOrLessThan(val: number | undefined, limit: number): boolean {\r\n\t\treturn this.isUndefined(val) || val === null || val===undefined || val < limit;\r\n\t}\r\n\tisUnvaluedOrZero(val: any): boolean {\r\n\t\treturn this.isUndefined(val) || val === null || val === 0;\r\n\t}\r\n\r\n\thasLengthGreaterThan(list: string | Array | undefined, limit: number): boolean {\r\n\t\tif( !list ) return false;\r\n\t\tif( this.isString(list) )\r\n\t\t\treturn list.length>limit;\r\n\t\telse \r\n\t\t\treturn list.length>limit;\r\n\t}\r\n\thasLengthGreaterThanZero(list: string | Array | undefined): boolean {\r\n\t\treturn this.hasLengthGreaterThan(list,0);\r\n\t}\r\n\thasLengthLessThan(list: string | Array | undefined, limit: number): boolean {\r\n\t\tif( !list ) return false;\r\n\t\tif( this.isString(list) )\r\n\t\t\treturn list.length limit;\r\n\t}\r\n\tisGreaterThanOrEqual(val: number|undefined, limit: number): boolean {\r\n\t\treturn this.isDefined(val) && val!==undefined && val !== null && val >= limit;\r\n\t}\r\n\tisInRange(val: number|undefined, min: number, max: number): boolean {\r\n\t\treturn this.isDefined(val) && val!==undefined&& val !== null && val >= min && val <= max;\r\n\t}\r\n\tisGreaterThanZero(val: number|undefined): boolean {\r\n\t\treturn this.isDefined(val) && val!==undefined&& val !== null && val > 0;\r\n\t}\r\n\tisZeroOrGreater(val: number|undefined): boolean {\r\n\t\treturn this.isDefined(val) && val!==undefined && val !== null && val >= 0;\r\n\t}\r\n\r\n\t// === Validations =====\r\n\tisValidEmail(str: string): boolean {\r\n\t\tif (this.isUnvaluedOrEmpty(str))\r\n\t\t\treturn false;\r\n\t\tif (this.emailNegPattern.test(str))\r\n\t\t\treturn false;\r\n\t\treturn this.emailPattern.test(str);\r\n\t}\r\n\tisValidSsn(str: string): boolean {\r\n\t\tif (this.isUnvaluedOrEmpty(str))\r\n\t\t\treturn false;\r\n\r\n\t\t// Remove non normalized chars.\r\n\t\tstr = str.replace(\"-\", \"\");\r\n\r\n\t\t// Check for invalid chars.\r\n\t\t// const badChars = (/\\D/g).test(str);\r\n\t\t// if(badChars) {\r\n\t\t// \treturn false;\r\n\t\t// }\r\n\r\n\t\t// Remove century and check number\r\n\t\tif (str.length === 12) {\r\n\t\t\tstr = str.substr(2, 10);\r\n\t\t} else if (str.length === 10) {\r\n\t\t\tstr = str.substr(0, 10);\r\n\t\t} else {\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\tvar year = parseInt(str.substr(0, 2), 10);\r\n\t\tvar month = parseInt(str.substr(2, 2), 10) - 1;\r\n\t\tvar day = parseInt(str.substr(4, 2), 10);\r\n\r\n\t\tvar date = new Date(year, month, day);\r\n\t\tvar dateYear = parseInt(date.getFullYear().toString().substr(2, 2));\r\n\t\tif (dateYear !== year || date.getMonth() !== month || date.getDate() !== day) {\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\t// Remove check number\r\n\t\tvar check = parseInt(str.substr(9, 1), 10);\r\n\t\tstr = str.substr(0, 9);\r\n\r\n\t\t// Calculate check number\r\n\t\tvar result = 0;\r\n\t\tfor (var i = 0, len = str.length; i < len; i++) {\r\n\r\n\t\t\tvar number = parseInt(str.substr(i, 1), 10);\r\n\r\n\t\t\t// Multiply every other number with two\r\n\t\t\tif ((i % 2) === 0) {\r\n\t\t\t\tnumber = (number * 2);\r\n\t\t\t}\r\n\r\n\t\t\t// If result is greater than 10, 'sum the digits' which is the same as 1 + (number mod 10)\r\n\t\t\tif (number > 9) {\r\n\t\t\t\tresult += (1 + (number % 10));\r\n\t\t\t} else {\r\n\t\t\t\tresult += number;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn (((check + result) % 10) === 0);\r\n\r\n\t}\r\n\tisValidOrgNr(str: string): boolean {\r\n\t\tif (this.isUnvaluedOrEmpty(str))\r\n\t\t\treturn false;\r\n\r\n\t\t// Remove non numeric\r\n\t\tstr = str.replace(/\\D/g, \"\");\r\n\r\n\t\t// Remove century and check number\r\n\t\tif (str.length !== 10) {\r\n\t\t\treturn false;\r\n\t\t} \r\n\r\n\t\t// Remove check number\r\n\t\tvar check = parseInt(str.substr(9, 1), 10);\r\n\t\tstr = str.substr(0, 9);\r\n\r\n\t\t// Calculate check number\r\n\t\tvar result = 0;\r\n\t\tfor (var i = 0, len = str.length; i < len; i++) {\r\n\r\n\t\t\tvar number = parseInt(str.substr(i, 1), 10);\r\n\r\n\t\t\t// Multiply every other number with two\r\n\t\t\tif ((i % 2) === 0) {\r\n\t\t\t\tnumber = (number * 2);\r\n\t\t\t}\r\n\r\n\t\t\t// If result is greater than 10, 'sum the digits' which is the same as 1 + (number mod 10)\r\n\t\t\tif (number > 9) {\r\n\t\t\t\tresult += (1 + (number % 10));\r\n\t\t\t} else {\r\n\t\t\t\tresult += number;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn (((check + result) % 10) === 0);\r\n\r\n\t}\r\n\tisValidMobileNumber(str: string): boolean {\r\n\t\t/*\r\n\t\t0701234567\r\n\t\t070-1234567\r\n\t\t*/\r\n\t\tif (this.isUnvaluedOrEmpty(str))\r\n\t\t\treturn false;\r\n\r\n\t\tconst pattern = /^(07\\d{1}-\\d{7})$|^(07\\d{8})$/;\r\n\r\n\t\treturn pattern.test(str);\r\n\t}\r\n\r\n\tisDate(value: any): boolean {\r\n\t\tif (value && value.getDate)\r\n\t\t\treturn true;\r\n\t\treturn false;\r\n\t}\r\n\r\n\tisValidDate(value: any): boolean {\r\n\t\tif (!this.isDate(value))\r\n\t\t\treturn false;\r\n\t\tif (isNaN(value.getTime()))\r\n\t\t\treturn false;\r\n\t\treturn true;\r\n\t}\r\n\r\n\tisBeforeDate(date: Date, dateLimit: Date): boolean {\r\n\t\tif (!this.isDate(date))\r\n\t\t\treturn false;\r\n\t\tif (!dateLimit)\r\n\t\t\treturn true;\r\n\t\treturn date < dateLimit;\r\n\t}\r\n\r\n\tisAfterDate(date: Date, dateLimit: Date): boolean {\r\n\t\tif (!this.isDate(date))\r\n\t\t\treturn false;\r\n\t\tif (!dateLimit)\r\n\t\t\treturn true;\r\n\t\treturn date > dateLimit;\r\n\t}\r\n\r\n\tisBeforeNow(date: Date): boolean {\r\n\t\treturn this.isBeforeDate(date, new Date());\r\n\t}\r\n\r\n\tisAfterNow(date: Date): boolean {\r\n\t\treturn this.isAfterDate(date, new Date());\r\n\t}\r\n\r\n\tcompareSsn(ssn1: string, ssn2: string): boolean {\r\n\t\tif (!ssn1 || !ssn2)\r\n\t\t\treturn false;\r\n\t\tif (ssn1.replace(\"-\", \"\") === ssn2.replace(\"-\", \"\"))\r\n\t\t\treturn true;\r\n\t\treturn false;\r\n\t}\r\n\r\n\tnormalizeAndCompareSsn(ssn1: string, ssn2: string): boolean {\r\n\t\tif (!ssn1 || !ssn2)\r\n\t\t\treturn false;\r\n\t\tif( this.convertService ) {\r\n\t\t\tssn1 = this.convertService.toNormalizedSsn(ssn1);\r\n\t\t\tssn2 = this.convertService.toNormalizedSsn(ssn2);\r\n\t\t}\r\n\r\n\t\tif (ssn1===ssn2)\r\n\t\t\treturn true;\r\n\t\treturn false;\r\n\t}\r\n\r\n\tcompareCustomerId(customerId1: string , customerId2: string): boolean {\r\n\t\treturn this.normalizeAndCompareSsn(customerId1, customerId2);\r\n\t}\r\n}","import { object } from \"prop-types\";\r\n\r\nexport type ObsMatch = (obj:any) => boolean;\r\nexport type ObsCallback = (event: IObsEvent) => void;\r\nexport type UnobserveHandle = () => void;\r\n\r\n// A registered observation.\r\nexport interface IObs {\r\n\tmatch: ObsMatch;\r\n\tcallback: ObsCallback;\r\n\t//obj: any;\r\n}\r\n\r\n// Event emitted on observation of change.\r\nexport interface IObsEvent {\r\n\tobserver: IObs;\r\n\tobj: any;\r\n\tchange: ObsChange;\r\n}\r\n\r\n// Type of change that can occur.\r\nexport enum ObsChange {\r\n\tadd,\r\n\tupdate,\r\n\tremove,\r\n}\r\n\r\nfunction objectContains (object:object, find:any):boolean {\r\n\tfor (var property in object) {\r\n\t\tconst val = object[property];\r\n\t\tif( val===find )\r\n\t\t\treturn true;\r\n\t\t\r\n\t\tif( val instanceof Object ) {\r\n\t\t\tconst r = objectContains(val, find);\r\n\t\t\tif( r )\r\n\t\t\t\treturn true;\r\n\t\t}\r\n\t\telse if( val instanceof Array ) {\r\n\t\t\tfor( var i=0; i;\r\n\r\n\tconstructor() {\r\n\t\tthis.observers = [];\r\n\t}\r\n\r\n\tupdate(obj: any): void {\r\n\t\tthis.emitChange(obj, ObsChange.update);\r\n\t}\r\n\r\n\tadd(obj: any): void {\r\n\t\tthis.emitChange(obj, ObsChange.add);\r\n\t}\r\n\r\n\tremove(obj: any): void {\r\n\t\tthis.emitChange(obj, ObsChange.remove);\r\n\t}\r\n\r\n\treplace(oldObj: any, newObj: any): void {\r\n\t\tthis.emitChange(oldObj, ObsChange.remove);\r\n\t\tthis.emitChange(newObj, ObsChange.add);\r\n\t}\r\n\r\n\tprivate emitChange(obj: any, change: ObsChange): void {\r\n\r\n\t\tconst observers = this.observers;\r\n\t\tfor( let i=observers.length-1; i>=0; i--) {\r\n\t\t\tconst observer = observers[i];\r\n\t\t\tif (!observer.match(obj))\r\n\t\t\t\tcontinue;\r\n\r\n\t\t\tlet callback = observer.callback;\r\n\t\t\tlet event = {\r\n\t\t\t\tchange: change,\r\n\t\t\t\tobserver: observer,\r\n\t\t\t\tobj: obj,\r\n\t\t\t}\r\n\t\t\ttry {\r\n\t\t\t\tcallback(event);\r\n\t\t\t}\r\n\t\t\tcatch (ex) {\r\n\t\t\t\t//console.log(\"ObjServer emit change error. \"+observer.match.name, ex);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tobserve(obj:any, callback:ObsCallback): UnobserveHandle {\r\n\t\treturn this.observeInternal({\r\n\t\t\tmatch: (x:any) => x===obj,\r\n\t\t\tcallback:callback\r\n\t\t});\r\n\t}\r\n\r\n\tobserveDeep(obj:any, callback:ObsCallback): UnobserveHandle {\r\n\t\treturn this.observeInternal({\r\n\t\t\tmatch: (x) => objectSelfOrContains(obj,x),\r\n\t\t\tcallback:callback\r\n\t\t});\r\n\t}\r\n\r\n\tobserveInternal(observer: IObs): UnobserveHandle {\r\n\t\tif (!observer.match)\r\n\t\t\tthrow new Error(\"No matcher in observer.\");\r\n\t\tif (!observer.callback)\r\n\t\t\tthrow new Error(\"No callback in observer.\");\r\n\r\n\t\tthis.observers.push(observer);\r\n\r\n\t\tlet u = this.unobserve.bind(this);\r\n\t\treturn function () {\r\n\t\t\tu(observer);\r\n\t\t};\r\n\t}\r\n\r\n\tunobserve(observer: IObs): void {\r\n\t\tthis.observers = this.observers.filter(x => x !== observer);\r\n\t}\r\n\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { UiLanguage } from './UiLanguageService';\r\nimport { Objserver } from '../utils/Objserver';\r\nimport { Case as SelmaCase } from '../models/SelmaModels';\r\nimport { Session } from './SessionService';\r\nimport { Configuration } from './ConfigurationService';\r\n\r\nexport interface ApplicationState {\r\n\tloaded: boolean;\r\n\tconfiguration?: Configuration;\r\n\tlanguage?: UiLanguage;\r\n\tsession: Session;\r\n\tcases?: SelmaCase[];\r\n\tcase?: SelmaCase;\r\n}\r\n\r\nexport class StateService extends BaseService {\r\n\tpublic state: ApplicationState; // TODO: dont expose this.\r\n\tpublic stateObjserver: Objserver; // should be private.\r\n\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis.state = {\r\n\t\t\tloaded: false,\r\n\t\t\tsession: {},\r\n\t\t};\r\n\t\tthis.stateObjserver = new Objserver();\r\n\t}\r\n\r\n\tupdate(obj: any) {\r\n\t\tthis.stateObjserver.update(obj);\r\n\t\tthis.writeStateToStorage();\r\n\t}\r\n\r\n\tupdateState() {\r\n\t\tthis.update(this.state);\r\n\t}\r\n\r\n\treplace(oldObj: any, newObj: any) {\r\n\t\tthis.stateObjserver.replace(oldObj, newObj);\r\n\t}\r\n\r\n\t// Mutates list so that (first) item is removed.\r\n\tlistRemove(list: Array, item: T): void {\r\n\t\tconst ix = list.indexOf(item);\r\n\t\tif (ix < 0) return;\r\n\t\telse {\r\n\t\t\tlist.splice(ix, 1);\r\n\t\t\tthis.update(list);\r\n\t\t}\r\n\t}\r\n\r\n\t// Mutates list so that (first) item is removed.\r\n\tlistRemoveWhere(list: Array, match: (x: T) => boolean): number {\r\n\t\tvar toRemove = list.filter(match);\r\n\t\tif (toRemove.length === 0) {\r\n\t\t\treturn 0;\r\n\t\t}\r\n\r\n\t\tvar cnt = 0;\r\n\t\ttoRemove.forEach((item) => {\r\n\t\t\tconst ix = list.indexOf(item);\r\n\t\t\tif (ix >= 0) {\r\n\t\t\t\tlist.splice(ix, 1);\r\n\t\t\t\tcnt++;\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tthis.update(list);\r\n\t\treturn cnt;\r\n\t}\r\n\r\n\tlistRemoveAll(list: Array): void {\r\n\t\tconst len = list.length;\r\n\t\tif (len <= 0) return;\r\n\t\telse {\r\n\t\t\tconst deleted = list.splice(0);\r\n\t\t\tdeleted.forEach((x) => {\r\n\t\t\t\tthis.update(x);\r\n\t\t\t});\r\n\t\t\tthis.update(list);\r\n\t\t}\r\n\t}\r\n\r\n\tlistAdd(list: Array, item: T) {\r\n\t\tlist.push(item);\r\n\t\tthis.update(list);\r\n\t}\r\n\r\n\tloadState(\r\n\t\tstate: string,\r\n\t\treplace: boolean = false\r\n\t): Promise {\r\n\t\tif (state.startsWith('{')) return this.setState(JSON.parse(state), replace);\r\n\t\t// Assume 'state' is json.\r\n\t\telse if (state.startsWith('http'))\r\n\t\t\treturn this.loadStateByUrl(state, replace); // Assume 'state' is URL.\r\n\t\telse return this.loadStateByName(state, replace); // Assume 'state' is name of state file.\r\n\t}\r\n\r\n\tprivate fixStateAfterLoad(state: ApplicationState) {\r\n\t\tif (state && state.case && state.case.id && state.cases) {\r\n\t\t\tconst caseId = state.case.id;\r\n\t\t\tconst r = state.cases.filter((x) => x.id === caseId);\r\n\t\t\tif (r.length === 1) state.case = r[0];\r\n\t\t}\r\n\t}\r\n\r\n\tsetState(\r\n\t\tstate: ApplicationState,\r\n\t\treplace: boolean = false\r\n\t): Promise {\r\n\t\tif (replace) {\r\n\t\t\tlet prevState = this.state;\r\n\t\t\tthis.state = state;\r\n\t\t\tthis.stateObjserver.replace(prevState, this.state);\r\n\t\t} else {\r\n\t\t\tObject.assign(this.state, state);\r\n\t\t\tthis.stateObjserver.update(this.state);\r\n\t\t}\r\n\t\treturn Promise.resolve(this.state);\r\n\t}\r\n\r\n\tloadStateByName(\r\n\t\tname: string,\r\n\t\treplace: boolean = false\r\n\t): Promise {\r\n\t\tlet url = '/state/' + name + '.appstate.json';\r\n\t\tlet promise = this.loadStateByUrl(url, replace);\r\n\t\treturn promise;\r\n\t}\r\n\r\n\tloadStateByUrl(\r\n\t\turl: string,\r\n\t\treplace: boolean = false\r\n\t): Promise {\r\n\t\tlet promise = fetch(url)\r\n\t\t\t.then((result) => {\r\n\t\t\t\treturn result.json();\r\n\t\t\t})\r\n\t\t\t.then((state: ApplicationState) => {\r\n\t\t\t\tthis.fixStateAfterLoad(state);\r\n\t\t\t\treturn this.setState(state, replace);\r\n\t\t\t});\r\n\t\treturn promise;\r\n\t}\r\n\r\n\tprivate writeStateToStorage() {\r\n\t\twindow.sessionStorage.setItem('smeState', JSON.stringify(this.state));\r\n\t}\r\n\r\n\tloadStateFromStorage(replace: boolean = false): ApplicationState | undefined {\r\n\t\tlet stateString = window.sessionStorage.getItem('smeState');\r\n\t\tif (!stateString) return undefined;\r\n\t\tlet state = JSON.parse(stateString);\r\n\t\tthis.setState(state, replace);\r\n\t\treturn state;\r\n\t}\r\n}\r\n","\r\nexport interface ValidationResultItem {\r\n\tvalidator: Function;\r\n\tobject?: any;\r\n\targs?: any[];\r\n\tok: boolean;\r\n}\r\n\r\nexport class ValidationResult {\r\n\r\n\tprivate items: ValidationResultItem[];\r\n\r\n\tconstructor(validator?: Function) {\r\n\t\tthis.items = [];\r\n\t}\r\n\r\n\tadd(item: ValidationResultItem): void {\r\n\t\tthis.items.push(item);\r\n\t}\r\n\r\n\taddItem(item: ValidationResultItem): void {\r\n\t\tthis.items.push(item);\r\n\t}\r\n\r\n\taddMultiple(items: ValidationResultItem[]): void {\r\n\t\titems.forEach(x => {\r\n\t\t\tthis.items.push(x)\r\n\t\t});\r\n\t}\r\n\r\n\taddResult(result: ValidationResult): void {\r\n\t\tthis.addMultiple(result.items);\r\n\t}\r\n\r\n\tgetItems() {\r\n\t\treturn this.items;\r\n\t}\r\n\r\n\tgetCount(): number {\r\n\t\treturn this.items.length;\r\n\t}\r\n\r\n\tanyItems(): boolean {\r\n\t\treturn this.items && this.items.length>0;\r\n\t}\r\n\r\n\tgetOkCount(): number {\r\n\t\treturn this.items.filter(x => x.ok).length;\r\n\t}\r\n\r\n\tgetFailCount(): number {\r\n\t\treturn this.items.filter(x => !x.ok).length;\r\n\t}\r\n\r\n\t// Checks if one specifik validator is ok.\r\n\tvalidatorOk(validator: Function): boolean {\r\n\t\tlet vri = this.getValidatorResult(validator);\r\n\t\treturn vri && vri.ok ? true : false;\r\n\t}\r\n\r\n\tgetValidatorResult(validator: Function): ValidationResultItem|undefined {\r\n\t\tfor( let item of this.items ) {\r\n\t\t\tif( item.validator===validator )\r\n\t\t\t\treturn item;\r\n\t\t}\r\n\t}\r\n\r\n\t// Returns a value between 0 and 1, ok/total.\r\n\tgetOkRate(): number {\r\n\t\tlet total = this.getCount();\r\n\t\tif (total === 0)\r\n\t\t\treturn 1;\r\n\t\tlet ok = this.getOkCount();\r\n\t\treturn ok / total;\r\n\t}\r\n\r\n\tok(): boolean {\r\n\t\tfor( let item of this.items ) {\r\n\t\t\tif( !item.ok )\r\n\t\t\t\treturn false;\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n\r\n\tfailed(): boolean {\r\n\t\tfor( let item of this.items ) {\r\n\t\t\tif( !item.ok )\r\n\t\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n}\r\n","\r\nexport interface Loan {\r\n\t// processId?: ProcessId;\r\n\tid: string; // GUID, loanId\r\n\tnumber?: string; // loanNumber\r\n\t// purposeOfLoan?: MainPurposes;\r\n\tamount?: number; // loanAmount // obsolete.\r\n\taims?: Aim[];\r\n\ttakeoverLoans?: TakeoverLoan[];\r\n\ttakeOver?: boolean;\r\n\tdownpaymentOther?: string;\r\n\tdownpaymentType?: DownpaymentSource;\r\n\tdownPaymentAmount?: number;\r\n\tpurposeDescription?: string;\r\n}\r\n\r\n/*\r\nexport enum MainPurposes {\r\n\tBUY, // Kp = 'Köp',\r\n\tTAKEOVER, // Vertag = 'Övertag',\r\n\tEXTENSION, // UtkningLn = 'Utökning lån',\r\n\tUNPLEDGED // UtlningMotObelnat = 'Utlåning mot obelånat'\r\n}\r\n*/\r\n\r\nexport enum DownpaymentSource {\r\n\tSALE_OF_PROPERTY,\r\n\tSAVINGS,\r\n\tBLANCO_LOAN,\r\n\tOTHER\r\n}\r\n\r\nexport interface Aim {\r\n\tid: string; // guid //aimId: AimId;\r\n\taimCategory?: string; // purposeText\r\n\taimDetail?: string; // aimText\r\n\tloanAmountPart?: number; // money, part of loan.amount\r\n}\r\n\r\n// export enum AimType {\r\n// \tFastighetskpPrivatbostad = 'Fastighetsköp - privatbostad',\r\n// \tFastighetskpAnnanFastighet = 'Fastighetsköp - annan fastighet',\r\n// \tFastighetskpJordbruk = 'Fastighetsköp - jordbruk',\r\n// \tFinansieringBefintligBostad = 'Finansiering befintlig bostad',\r\n// \tFinansieringBefintligBostadOmlggningInternt = 'Finansiering befintlig bostad (omläggning internt)',\r\n// \tNytillbyggnadrenoveringMjlkstall = 'Ny/tillbyggnad/renovering mjölkstall'\r\n// }\r\n\r\nexport interface TakeoverLoan {\r\n\tid: string; // guid //takeoverLoanId;\r\n\tcreditInstitute?: string; // Bank\r\n\tloanNumber?: string; // Lånenummer hos nuvarande bank\r\n\tdebtAmount?: number; // Skuld I annan bank\r\n\taimCategory?: string; // # Laddas från mainpurposes.json\r\n\taimDetail?: string; //' # Laddas från mainpurposes.json\r\n\t//interest?: number; //' # Dessa används inte idag men är räntan kunden betalar på nuvarande lån i annan bank som ska lösas\r\n\t//period?: number; //' # Används inte idag med avser den räntebindningstid kunden har på nuvarande lån i annan bank som ska lösas\r\n}\r\n","import { StakeholderType } from \"../../libs/SMELPOClient\";\r\n\r\nexport interface KYC {\r\n\tid:string; // guid.\r\n\r\n\thighRiskCategoryCode?: string;\r\n\tisAmericanCitizen?: boolean;\r\n\tisCrsTaxObligated?: boolean;\r\n\r\n\tapprovedInfoSharing?: boolean; // ucAware\r\n\tapprovedCreditCheck?: boolean; // ucAccepted\r\n\tapprovedInfoHandling?: boolean; // gdprAccepted\r\n\r\n\tapprovedInfoSharingDB?: boolean; // ucAware saved in database\r\n\tapprovedCreditCheckDB?: boolean; // ucAccepted saved in database\r\n\tapprovedInfoHandlingDB?: boolean; // gdprAccepted saved in database\r\n\r\n\tisPep?: boolean;\r\n\t//isPepFunction?: string;\r\n\tisPepRelated?: boolean;\r\n\t//isPepRelatedFunction?: string;\r\n}\r\n\r\nexport interface Applicant {\r\n\tid:string;\r\n\t//processId:string; // used by \r\n\tcustomerId: string; // customerId is swedish ssn or corporate organisation number\r\n\tfirstName?: string;\r\n\tlastName?: string;\r\n\tstreetAddress?: string;\r\n\tpostalAddress?: string;\r\n\tpostalCode?: string;\r\n\temail?: string;\r\n\temailConfirm?: string;\r\n\tmobilePhone?: string;\r\n\tnotifyByEmail?: boolean;\r\n\tnotifyByMobilePhone?: boolean;\r\n\tstakeholderType?: StakeholderType // StakeholderEnum;\r\n\tkyc?: KYC;\r\n\twillBuyAgriForestryProperty?: boolean;\r\n}\r\n\r\nexport interface KycApplicant {\r\n customerId:string,\r\n role: string,\r\n questionnaireStatus: string\r\n}\r\n\r\n// export enum StakeholderEnum {\r\n// \tBONDSMAN, // 'Borgensman'\r\n// \tOPERATING_COMPANY, // 'Driftbolag'\r\n// \tSPOUSE, // 'Maka/Make/regpartner'\r\n// \tDOMESTIC_PARTNER, // 'sambo'\r\n// \tBOND_OWNER, // 'ägarandel i pant'\r\n// \tMAJORITY_OWNER, // 'ägare juridiskt över 50%'\r\n// \tCOMMUNITY_OF_INTERESTS, // 'övriga med ekonomisk intressegemenskap'\r\n// \tAPPLICANT // 'SOKANDE'\r\n// }\r\n\r\nexport enum LPEmploymentEnum {\r\n\t// employment mapping to Loan Process \r\n\tPERMANENT, // - Anställd, tills-vidare-anställd \r\n\tTEMPORARY, // - Tidbegränsad anställning \r\n\tPROBATIONARY, // - Provanställning \r\n\tUNEMPLOYMENT_INSURANCE, // - Arbetslöshetskassa \r\n\tSELF_EMPLOYED, //- Eget företag \r\n\tSTUDENT_AID, // - Studiestöd \r\n\tPENSION // - Inkomst av pension\r\n}\r\n\r\n/*\r\nexport enum SAPEmploymentEnum {\r\n\t// employment mapping to Loan Process \r\n\tPERMANENT, // - Anställd, tills-vidare-anställd \r\n\tTEMPORARY, // - Tidbegränsad anställning \r\n\tPROBATIONARY, // - Provanställning \r\n\tUNEMPLOYMENT_INSURANCE, // - Arbetslöshetskassa \r\n\tSELF_EMPLOYED, //- Eget företag \r\n\tSTUDENT_AID, // - Studiestöd \r\n\tPENSION // - Inkomst av pension\r\n}*/\r\n\r\n\r\n/**\r\n * personal economy for KALP us\r\n * @export\r\n * @interface PersonalEconomy \r\n */\r\nexport interface PersonalEconomy {\r\n\tid: string; // personalEconomyId\r\n\t//processId: string;\r\n\tcustomerId: string; // guid\r\n\t//sapEmployment?: SAPEmploymentEnum; // originally defined in Applicant\r\n\t//lpEmployment?: LPEmploymentEnum; // originally defined in Applicant\r\n\tincome?: number; // // SEK / month //Inkomst av tjänst.\r\n\tyearlyIncome?: number; // SEK / year //Årlig inkomst från näringsverksamhet\r\n\ttypeOfEmployment?: LPEmploymentEnum // EmployeementType;\r\n\temployer?: string; // name of company\r\n\tyearOfEmployment?: number;\r\n\tmonthOfEmployment?: number;\r\n}\r\n","\r\n\r\nexport interface TaxedOwner {\r\n\tid: string; // guid\r\n\tcustomerId: string; // customerId of taxedOwner\r\n}\r\n\r\n/**\r\n * Säkerheter för lånet, om köp, även andra fastigheter kan användas som säkerhet för lånet\r\n * @export\r\n * @interface CollateralType\r\n */\r\nexport interface Collateral {\r\n\t//processId: ProcessId;\r\n\tid?: string; // collateralId, guid\r\n\tcustomerId?: string; // guid\r\n\tcode?: string; // collateralCode\r\n\tname?: string; // collateralName\r\n\ttaxedOwners?: TaxedOwner[];\r\n\tmunicipality?: string;\r\n\tstreet?: string;\r\n\tareal?: number;\r\n\tage?: number;\r\n\tuseAsCollateral?: boolean;\r\n\tbuyCollateral?: boolean;\r\n\tpostponeCollateralCode?: boolean;\r\n}\r\n\r\n\r\n\r\nexport interface Guarantor {\r\n\t//processId: string;\r\n\t/**\r\n\t * TBD\r\n\t * @type {string}\r\n\t * @memberof GuarantorType\r\n\t */\r\n\tid: string; //gaurantorId?: string;\r\n\t/**\r\n\t * TBD\r\n\t * @type {string}\r\n\t * @memberof GuarantorType\r\n\t */\r\n\tname?: string;\r\n\t/**\r\n\t * TBD\r\n\t * @type {string}\r\n\t * @memberof GuarantorType\r\n\t */\r\n\tphone?: string;\r\n\t/**\r\n\t * TBD\r\n\t * @type {string}\r\n\t * @memberof GuarantorType\r\n\t */\r\n\tguarantorCustomerId?: string;\r\n}\r\n\r\nexport enum EUSupportEnum {\r\n\tEU = 1, // ', name:'EU-stöd'},\r\n\tEUNAT = 2, // ', name:'EU-stöd och nationellt stöd'},\r\n\tEUNAT_NOMILK = 3, //', name:'EU-stöd och nationellt stöd, utan mjölk'},\r\n\tNAT_NOMILK = 4, //', name:'Nationellt stöd, utan mjölk'},\r\n};\r\n\r\nexport interface EUSupport {\r\n\t//processId: string;\r\n\t/**\r\n\t * Unique identifier for EU-Support\r\n\t * @type {string}\r\n\t * @memberof EUSupportType\r\n\t */\r\n\tid: string;//euId: string; \r\n\t/**\r\n\t * \r\n\t * @type {EUType}\r\n\t * @memberof EUSupportType\r\n\t */\r\n\teuType?: EUSupportEnum;\r\n\t/**\r\n\t * summerat EU-stöd\r\n\t * @type {number}\r\n\t * @memberof EUSupportType\r\n\t */\r\n\tsupportAmount?: number;\r\n\t/**\r\n\t * EU-stödet gäller år\r\n\t * @type {string}\r\n\t * @memberof EUSupportType\r\n\t */\r\n\tsupportYear?: string;\r\n}\r\n\r\n\r\n\r\n","import { Case, Company, Loan, Aim, Applicant, ExtLoan, ExtLoanOwner, Household, EUSupport,\r\n\tEUSupportEnum as SmeEUSupportType, \r\n\tBudgetYear as SmeBudgetYear,\r\n\tLPEmploymentEnum, HouseholdMember,\r\n\tCompanyEconomy,\r\n\tBudget,\r\n\tKYC,\r\n\tMaintenanceCost,\r\n\tMaintenanceHouse,\r\n\tGuarantor,\r\n\tChild,\r\n\tRevenue,\r\n\tCollateral,\r\n\tTaxedOwner,\r\n\tLoanOwner,\r\n\tDownpaymentSource,\r\n\tBusinessCategory,\r\n\tAttachmentRequest,\r\n\tAttachment,\r\n\tPrincipal} from \"./SelmaModels\";\r\nimport { CompanyType, LoanType, AimType, KycInformationType, ApplicantType, \r\n\tExtLoanType, HouseholdMemberType, EUSupportType, EUType, PersonalEconomyType, \r\n\tTypeOfEmployeement, CompanyEconomyType, RevenueType, BudgetType, \r\n\tMaintenanceCostType, MaintenanceHouseType, ChildType, \r\n\tTaxedOwnerType, ProcessType, DownPaymentType, BusinessCategoryType, BudgetYearType, PrincipalType, TakeoverLoanType, TakeoverLoansType } from \"../libs/SMELPOClient\";\r\nimport { HouseholdType } from '../libs/SMELPOClient/models/HouseholdType';\r\nimport { CollateralType } from '../libs/SMELPOClient/models/CollateralType';\r\nimport { PersonalEconomy } from './selmamodels/Applicant';\r\nimport { GuarantorType } from '../libs/SMELPOClient/models/GuarantorType';\r\nimport { LoanOwnerType } from \"../libs/SMELPOClient/models/LoanOwnerType\";\r\nimport { FullProcess } from \"./extendedlpo/FullProcess\";\r\nimport { LpoAttachmentRequest, LpoAttachment } from \"./extendedlpo/Attachment\";\r\nimport { TakeoverLoan } from \"./selmamodels/Loan\";\r\n\r\n// Takes Selma SME client models and converts to other models such as Lpo server API models.\r\nexport class SmeModelConverter {\r\n\r\n\tstatic toFullProcess(c:Case) : FullProcess {\r\n\t\tlet fp:FullProcess = {\r\n\t\t\tprocesses: [this.toLpoProcess(c)],\r\n\t\t\tcompanies: this.toLpoCompanies(c, c.companies),\r\n\t\t\tloans: this.toLpoLoans(c, c.loan),\r\n\t\t\tapplicants: this.toLpoApplicants(c, c.applicants),\r\n\t\t\textloans: this.toLpoExtLoans(c, c.extLoans),\r\n\t\t\thouseholds: this.toLpoHouseholds(c, c.households),\r\n\t\t\tcollaterals: this.toLpoCollaterals(c, c.collaterals),\r\n\t\t\teusupports: this.toLpoEuSupports(c, c.euSupports),\r\n\t\t\tpersonaleconomies: this.toLpoPersonalEconomies(c, c.personalEconomies),\r\n\t\t\tcompanyeconomies: this.toLpoCompanyEconomies(c, c.companyEconomies),\r\n\t\t\tbudgets: this.toLpoBudgets(c, c.budgets),\r\n\t\t\tkycinformations: this.toLpoKycInfos(c, c.applicants),\r\n\t\t\tguarantors: this.toLpoGuarantors(c, c.guarantors),\r\n\t\t\tmaintenancecosts: this.toLpoMaintenanceCosts(c, c.maintenanceCosts),\r\n\t\t};\r\n\r\n\t\t(fp as any).attachments = this.toLpoAttachments(c, c.attachments);\r\n\t\t(fp as any).attachmentRequests = this.toLpoAttachmentRequests(c, c.attachmentRequests);\r\n\r\n\t\treturn fp;\r\n\t}\r\n\tstatic toLpoAttachmentRequests(c:Case, attachmentRequests: AttachmentRequest[]|undefined): LpoAttachmentRequest[] | undefined {\r\n\t\tif( !attachmentRequests) return;\r\n\t\treturn attachmentRequests.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tid: x.id,\r\n\t\t\t\tprocessId: c.id,\r\n\t\t\t\tcustomerId: x.customerId,\r\n\t\t\t\trequestType: x.requestType,\r\n\t\t\t\trequestVariation: x.requestVariation,\r\n\t\t\t\trequired: x.required\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\tstatic toLpoAttachments(c:Case, attachments: Attachment[]| undefined): LpoAttachment[] | undefined {\r\n\t\tif( !attachments) return;\r\n\t\treturn attachments.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tid: x.id,\r\n\t\t\t\tprocessId: c.id,\r\n\t\t\t\tcustomerId: x.customerId,\r\n\t\t\t\trequestType: x.requestType,\r\n\t\t\t\trequestVariation: x.requestVariation,\r\n\t\t\t\tmimeType: x.mimeType,\r\n\t\t\t\tfileName: x.fileName,\r\n\t\t\t\tfileSize: x.fileSize\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\tstatic toLpoMaintenanceCosts(c: Case, maintenanceCosts: MaintenanceCost[] | undefined): MaintenanceCostType[] | undefined {\r\n\t\tif( !maintenanceCosts ) return;\r\n\t\treturn maintenanceCosts.map(x => {\r\n\t\t\treturn this.toLpoMaintenanceCost(c, x);\r\n\t\t})\r\n\t}\r\n\tstatic toLpoMaintenanceCost(c: Case, x: MaintenanceCost): MaintenanceCostType {\r\n\t\treturn {\r\n\t\t\tprocessId: c.id,\r\n\t\t\tmaintenanceCostId: x.id,\r\n\t\t\tcustomerId: x.customerId,\r\n\t\t\ttypeofhouses: this.toLpoMaintenanceHouses(c, x.typeofhouses)\r\n\t\t}\r\n\t}\r\n\tstatic toLpoMaintenanceHouses(c:Case, maintenanceHouses: MaintenanceHouse[] | undefined):MaintenanceHouseType[] | undefined {\r\n\t\tif( !maintenanceHouses ) return;\r\n\t\treturn maintenanceHouses.map(x => {\r\n\t\t\treturn this.toLpoMaintenanceHouse(c, x);\r\n\t\t})\r\n\t}\r\n\tstatic toLpoMaintenanceHouse(c: Case, x: MaintenanceHouse): MaintenanceHouseType {\r\n\t\treturn {\r\n\t\t\ttypeOfHouse: x.houseType, // this.toLpoTypeOfHouse(x.houseType),\r\n\t\t\tkeepHouse: x.keepHouse,\r\n\t\t\tloanInOtherInstitute: x.loanInOtherInstitute,\r\n\t\t\tredeemLoan: x.redeemLoan,\r\n\t\t\t// creditInstitut: x. // NOT IN USE\r\n\t\t\t// loanClearing: x // NOT IN USE\r\n\t\t\t//institutLoanNumber?: string; // NOT IN USE\r\n\t\t\tloanOwners: this.toLpoLoanOwners(x.loanOwners),\r\n\t\t\thouseLoanAmount: x.houseLoanAmount,\r\n\t\t\tmaintenanceCost: x.maintenanceCost\r\n\t\t}\r\n\t}\r\n\tstatic toLpoLoanOwners(loanOwners: LoanOwner[] | undefined): LoanOwnerType[] | undefined {\r\n\t\tif( !loanOwners ) return;\r\n\t\treturn loanOwners.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tcustomerId: x.customerId,\r\n\t\t\t\townershipPart: x.ownershipPart\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\t// static toLpoTypeOfHouse(houseType: string | undefined): TypeOfHouse | undefined {\r\n\t// \tif( !houseType|| houseType=='') return;\r\n\t// \tif( houseType=='HOUSE') return TypeOfHouse.Villa;\r\n\t// \tif( houseType=='OTHER') return TypeOfHouse.VrigtBoende;\r\n\t// \tif( houseType=='TENANCY') return TypeOfHouse.Hyresrtt;\r\n\t// \tif( houseType=='FARM') return TypeOfHouse.Landbruksfastighet;\r\n\t// \tif( houseType=='APARTMENT') return TypeOfHouse.Bostadsrtt;\r\n\t// \tif( houseType=='VACATIONHOUSE') return TypeOfHouse.Fritidshus;\r\n\t// }\r\n\tstatic toLpoGuarantors(c: Case, guarantors: Guarantor[] | undefined): GuarantorType[] | undefined {\r\n\t\tif( !guarantors ) return;\r\n\t\treturn guarantors.map(x => {\r\n\t\t\treturn this.toLpoGuarantor(c, x);\r\n\t\t})\r\n\t}\r\n\tstatic toLpoGuarantor(c: Case, x: Guarantor): GuarantorType {\r\n\t\treturn {\r\n\t\t\tprocessId: c.id,\r\n\t\t\tguarantorId: x.id,\r\n\t\t\tguarantorName: x.name,\r\n\t\t\tguarantorPhone: x.phone,\r\n\t\t\tguarantorCustomerId: x.guarantorCustomerId\r\n\t\t}\r\n\t}\r\n\tstatic toLpoKycInfos(c: Case, applicants: Applicant[] | undefined): KycInformationType[] | undefined {\r\n\t\tif( !applicants ) return;\r\n\t\treturn applicants\r\n\t\t.filter(x => x.kyc?true:false)\r\n\t\t.map(x => {\r\n\t\t\tconst kyc: KYC = x.kyc as KYC;\r\n\t\t\treturn this.toLpoKycInfo(c, x, kyc);\r\n\t\t});\r\n\t}\r\n\tstatic toLpoKycInfo(c: Case, x: Applicant, kyc: KYC): KycInformationType {\r\n\t\treturn {\r\n\t\t\tprocessId: c.id,\r\n\t\t\tcustomerId: x.customerId,\r\n\t\t\tkycId: kyc.id,\r\n\t\t\tkycAcceptUC: kyc.approvedCreditCheck,\r\n\t\t\tkycAcceptGDPR: kyc.approvedInfoHandling,\r\n\t\t\tkycUCAware: kyc.approvedInfoSharing,\r\n\t\t\tkycPublicFunction: kyc.isPep,\r\n\t\t\tkycRelatedPublicFunction: kyc.isPepRelated,\r\n\t\t\tkycAmericanCitizen: kyc.isAmericanCitizen,\r\n\t\t\tkycCrsTaxObligation: kyc.isCrsTaxObligated,\r\n\t\t\tkycHighRiskIndustry: (!kyc.highRiskCategoryCode || kyc.highRiskCategoryCode==='' || kyc.highRiskCategoryCode==='0')?false:true,\r\n\t\t\tkycHighRiskIndustryText: kyc.highRiskCategoryCode\r\n\t\t}\r\n\t}\r\n\r\n\tstatic toLpoBudgets(c: Case, budgets: Budget[] | undefined): BudgetType[] | undefined {\r\n\t\tif( !budgets) return;\r\n\t\treturn budgets\r\n\t\t.map(x => {\r\n\t\t\treturn this.toLpoBudget(c, x)\r\n\t\t})\r\n\t}\r\n\tstatic toLpoBudget(c: Case, budget: Budget): BudgetType {\r\n\t\treturn {\r\n\t\t\tprocessId: c.id,\r\n\t\t\tcompanyEconomyId: budget.companyEconomyId,\r\n\t\t\tbudgetYears: this.toLpoBudgetYears(c, budget.budgetYears)\r\n\t\t}\r\n\t}\r\n\tstatic toLpoBudgetYears(c: Case, budgetYears: SmeBudgetYear[] | undefined): BudgetYearType[] | undefined {\r\n\t\tif( !budgetYears ) return;\r\n\t\treturn budgetYears.map(x => {\r\n\t\t\treturn this.toLpoBudgetYear(c, x);\r\n\t\t})\r\n\t}\r\n\tstatic toLpoBudgetYear(c: Case, x: SmeBudgetYear): BudgetYearType {\r\n\t\treturn {\r\n\t\t\tbudgetId: x.budgetId,\r\n\t\t\tbudgetyear: x.year,\r\n\t\t\tbudget: {\r\n\t\t\t\tvalue1: x.value1,\r\n\t\t\t\tvalue2: x.value2,\r\n\t\t\t\tvalue3: x.value3,\r\n\t\t\t\tvalue4: x.value4,\r\n\t\t\t\tvalue5: x.value5,\r\n\t\t\t\tvalue6: x.value6,\r\n\t\t\t\tvalue7: x.value7,\r\n\t\t\t\tvalue8: x.value8,\r\n\t\t\t\tvalue9: x.value9,\r\n\t\t\t\tvalue10: x.value10,\r\n\t\t\t\tvalue11: x.value11,\r\n\t\t\t\tvalue12: x.value12,\r\n\t\t\t\tvalue13: x.value13,\r\n\t\t\t\tvalue14: x.value14,\r\n\t\t\t\tvalue15: x.value15,\r\n\t\t\t\tvalue16: x.value16,\r\n\t\t\t\tvalue17: x.value17,\r\n\t\t\t\tvalue18: x.value18,\r\n\t\t\t\tvalue19: x.value19,\r\n\t\t\t\tvalue20: x.value20,\r\n\t\t\t\tvalue21: x.value21,\r\n\t\t\t\tvalue22: x.value22,\r\n\t\t\t\tvalue23: x.value23,\r\n\t\t\t\tvalue24: x.value24,\r\n\t\t\t\tvalue25: x.value25\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\tstatic toLpoCompanyEconomies(c: Case, companyEconomies: CompanyEconomy[] | undefined):\r\n\t\tCompanyEconomyType[] | undefined {\r\n\t\tif( !companyEconomies )\r\n\t\t\treturn;\r\n\t\treturn companyEconomies.map(x => {\r\n\t\t\treturn this.toLpoCompanyEconomy(c, x);\r\n\t\t})\r\n\t}\r\n\tstatic toLpoCompanyEconomy(c: Case, x: CompanyEconomy): CompanyEconomyType {\r\n\t\treturn {\r\n\t\t\tprocessId: c.id,\r\n\t\t\tcompanyId: x.companyId,\r\n\t\t\tcompanyEconomyId: x.id,\r\n\t\t\trevenues: this.toLpoRevenues(x.revenues), // TODO must be fixed by Kjell. NOT IN USE.\r\n\t\t\tcustomerCategory: x.customerCategory\r\n\t\t}\r\n\t}\r\n\tstatic toLpoRevenues(revenues: Revenue[] | undefined) : RevenueType[]|undefined {\r\n\t\tif( !revenues ) return;\r\n\t\treturn revenues.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\trevenueYear: x.year,\r\n\t\t\t\trevenue: x.revenue||0\r\n\t\t\t};\r\n\t\t})\r\n\t}\r\n\tstatic toLpoPersonalEconomies(c: Case, personalEconomies: PersonalEconomy[] | undefined): PersonalEconomyType[] | undefined {\r\n\t\tif( !personalEconomies )\r\n\t\t\treturn;\r\n\t\treturn personalEconomies.map(x => {\r\n\t\t\treturn this.toLpoPersonalEconomy(c, x);\r\n\t\t})\r\n\t}\r\n\tstatic toLpoPersonalEconomy(c: Case, x: PersonalEconomy): PersonalEconomyType {\r\n\t\treturn {\r\n\t\t\tprocessId: c.id,\r\n\t\t\tcustomerId: x.customerId,\r\n\t\t\tpersonalEconomyId: x.id,\r\n\t\t\tyearlyIncome: x.yearlyIncome,\r\n\t\t\tincome: x.income,\r\n\t\t\ttypeOfEmployeement: this.toLpoLPEmploymentEnum(x.typeOfEmployment),\r\n\t\t\temployeer: x.employer,\r\n\t\t\tyearOfEmployment: x.yearOfEmployment,\r\n\t\t\tmonthOfEmployment: x.monthOfEmployment\r\n\t\t}\r\n\t}\r\n\r\n\tstatic toLpoLPEmploymentEnum(typeOfEmployeement: LPEmploymentEnum | undefined): TypeOfEmployeement | undefined {\r\n\t\tconst t = typeOfEmployeement;\r\n\t\tif( t===undefined )\r\n\t\t\treturn;\r\n\r\n\t\tif( t===LPEmploymentEnum.PERMANENT ) return TypeOfEmployeement.PERMANENT; // - Anställd, tills-vidare-anställd \r\n\t\tif( t===LPEmploymentEnum.TEMPORARY ) return TypeOfEmployeement.TEMPORARY; // - Tidbegränsad anställning \r\n\t\tif( t===LPEmploymentEnum.PROBATIONARY ) return TypeOfEmployeement.PROBATIONARY; // - Provanställning \r\n\t\tif( t===LPEmploymentEnum.UNEMPLOYMENT_INSURANCE ) return TypeOfEmployeement.UNEMPLOYMENTINSURANCE; // - Arbetslöshetskassa \r\n\t\tif( t===LPEmploymentEnum.SELF_EMPLOYED ) return TypeOfEmployeement.SELFEMPLOYED; //- Eget företag \r\n\t\tif( t===LPEmploymentEnum.STUDENT_AID ) return TypeOfEmployeement.STUDENTAID; // - Studiestöd \r\n\t\tif( t===LPEmploymentEnum.PENSION) return TypeOfEmployeement.PENSION; // - Inkomst av pension\r\n\t}\r\n\tstatic toLpoEuSupports(c:Case, euSupports: EUSupport[] | undefined): EUSupportType[] | undefined {\r\n\t\tif( !euSupports )\r\n\t\t\treturn;\r\n\t\treturn euSupports.map(x => {\r\n\t\t\treturn this.toLpoEuSupport(c, x);\r\n\t\t})\r\n\t}\r\n\tstatic toLpoEuSupport(c:Case, euSupport: EUSupport): EUSupportType {\r\n\t\tconst e = euSupport;\r\n\t\treturn {\r\n\t\t\teuId: e.id,\r\n\t\t\tprocessId: c.id,\r\n\t\t\teuType: this.toEUSupportType(e.euType),\r\n\t\t\tsupportAmount: e.supportAmount,\r\n\t\t\tsupportYear: e.supportYear,\r\n\t\t}\r\n\t}\r\n\tstatic toEUSupportType(euType: SmeEUSupportType | undefined): EUType | undefined {\r\n\t\tconst t = euType;\r\n\t\tif( t===undefined)\r\n\t\t\treturn;\r\n\t\tif( t===SmeEUSupportType.EU)\r\n\t\t\treturn EUType.EUStd;\r\n\t\tif( t===SmeEUSupportType.EUNAT)\r\n\t\t\treturn EUType.EUStdOchNationelltStd;\r\n\t\tif( t===SmeEUSupportType.EUNAT_NOMILK)\r\n\t\t\treturn EUType.EUStdOchNationelltStdUtanMjlk;\r\n\t\tif( t===SmeEUSupportType.NAT_NOMILK)\r\n\t\t\treturn EUType.NationellStdUtanMjlk;\r\n\t}\r\n\tstatic toLpoCollaterals(c: Case, collaterals: Collateral[] | undefined): CollateralType[] | undefined {\r\n\t\tif( !collaterals) return;\r\n\t\treturn collaterals.map(x => {\r\n\t\t\treturn this.toLpoCollateral(c, x);\r\n\t\t})\r\n\t}\r\n\tstatic toLpoCollateral(c: Case, x: Collateral): CollateralType {\r\n\t\treturn {\r\n\t\t\tprocessId: c.id,\r\n\t\t\tcustomerId: x.customerId,\r\n\t\t\t//typeOfCollateral: x.t;\r\n\t\t\tcollateralId: x.id,\r\n\t\t\tcollateralCode: x.code,\r\n\t\t\tcollateralName: x.name,\r\n\t\t\ttaxedOwners: this.toLpoTaxedOwners(x.taxedOwners),\r\n\t\t\tcollateralMunicipality: x.municipality,\r\n\t\t\tcollateralStreet: x.street,\r\n\t\t\tcollateralAreal: x.areal,\r\n\t\t\t//collateralAge: x.age, // NOT IN USE.\r\n\t\t\tuseAsCollateral: x.useAsCollateral,\r\n\t\t\tbuyCollateral: x.buyCollateral\r\n\t\t}\r\n\t}\r\n\tstatic toLpoTaxedOwners(taxedOwners: TaxedOwner[] | undefined): TaxedOwnerType[] | undefined {\r\n\t\tif( !taxedOwners) return;\r\n\t\treturn taxedOwners.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\ttaxedOwnerId: x.id,\r\n\t\t\t\ttaxedOwner: x.customerId\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\tstatic toLpoHouseholds(c: Case, households: Household[] | undefined): HouseholdType[] | undefined {\r\n\t\tif( !households ) return;\r\n\t\treturn households.map(x=>{\r\n\t\t\treturn this.toLpoHousehold(c, x);\r\n\t\t})\r\n\t}\r\n\tstatic toLpoHousehold(c: Case, x: Household):HouseholdType {\r\n\t\treturn {\r\n\t\t\tprocessId: c.id,\r\n\t\t\thouseholdId: c.id,\r\n\t\t\thouseholdMembers: this.toLpoHouseholdMembers(c, x.members),\r\n\t\t\tnumberOfChildsAtHome: x.numberOfChildrenAtHome,\r\n\t\t\tchilds: this.toLpoChildren(x.children),\r\n\t\t\tnumberOfCars: x.numberOfCars,\r\n\t\t\tchildMaintenaceCost: x.childMaintenanceCost,\r\n\t\t\treceiveChildMaintenanceCost: x.childMaintenanceIncome,\r\n\t\t\tchildCareAmount: x.childCareAmount\r\n\t\t}\r\n\t}\r\n\tstatic toLpoHouseholdMembers(c:Case, members: HouseholdMember[]|undefined): HouseholdMemberType[] | undefined {\r\n\t\tif( !members ) return;\r\n\t\treturn members.map(x => {\r\n\t\t\treturn this.toLpoHouseholdMember(x);\r\n\t\t})\r\n\t}\r\n\tstatic toLpoHouseholdMember(x: HouseholdMember): HouseholdMemberType {\r\n\t\treturn {\r\n\t\t\thouseholdMember: x.householdMember\r\n\t\t}\r\n\t}\r\n\tstatic toLpoChildren(children: Child[] | undefined): ChildType[] | undefined {\r\n\t\tif( !children ) return;\r\n\t\treturn children.map(x => {\r\n\t\t\treturn this.toLpoChild(x);\r\n\t\t})\r\n\t}\r\n\tstatic toLpoChild(x: Child): ChildType {\r\n\t\treturn {\r\n\t\t\tchildId: x.id,\r\n\t\t\tchildsAge: x.childsAge,\r\n\t\t\tpartInHousehold: x.partInHousehold\r\n\t\t}\r\n\t}\r\n\tstatic toLpoExtLoans(c:Case, extLoans:ExtLoan[] | undefined): ExtLoanType[] | undefined {\r\n\t\tif( !extLoans) return;\r\n\t\treturn extLoans.map(x => {\r\n\t\t\treturn this.toLpoExtLoan(c, x);\r\n\t\t});\r\n\t}\r\n\tstatic toLpoExtLoan(c:Case, x:ExtLoan) : ExtLoanType {\r\n\t\treturn {\r\n\t\t\tprocessId: c.id,\r\n\t\t\textloanId: x.id,\r\n\t\t\ttypeOfLoan: x.type,\r\n\t\t\textLoanOwners: this.toExtLoanOwnersCustomerIds(x.loanOwners),\r\n\t\t\textCreditInstitute: x.creditInstitute,\r\n\t\t\textloanClearing: x.loanClearing,\r\n\t\t\textloanNumber: x.loanNumber,\r\n\t\t\textloanAmount: x.amount,\r\n\t\t\textRedeemLoan: x.redeemLoan,\r\n\t\t\textMonthlyCost: x.monthlyCost\r\n\t\t}\r\n\t}\r\n\tstatic toExtLoanOwnersCustomerIds(loanOwners: ExtLoanOwner[] | undefined): string[] | undefined {\r\n\t\tif( !loanOwners) return;\r\n\t\treturn loanOwners.map(x=>{ return x.customerId});\r\n\t}\r\n\tstatic toLpoProcess(c: Case): ProcessType {\r\n\t\treturn {\r\n\t\t\tprocessId: c.id,\r\n\t\t\tcustomers: c.customers, // DIRECT COPY.\r\n\t\t\treferenceId: c.number,\r\n\t\t\tprocessVersion: c.version,\r\n\t\t\tcaseId: c.lpCaseId,\r\n\t\t\tcaseIdStatus: c.status,\r\n\t\t\tprocessCreatedDate: this.toDateString(c.createdDate),\r\n\t\t\tlastAccessed: this.toDateString(c.lastAccessedDate)\r\n\t\t}\r\n\t}\r\n\tstatic toDateString(date: Date): string {\r\n\t\tif( !date || (date as any)==='' ) return '';\r\n\t\treturn date.toISOString();\r\n\t}\r\n\tstatic toLpoCompanies(c: Case, companies: Company[] | undefined): CompanyType[] | undefined {\r\n\t\tif( !companies )\r\n\t\t\treturn;\r\n\t\tlet result = companies.map(co => {\r\n\t\t\tlet company:CompanyType = {\r\n\t\t\t\tprocessId: c.id,\r\n\t\t\t\tcompanyId: co.id,\r\n\t\t\t\torgNumber: co.orgNumber,\r\n\t\t\t\tcompanyName: co.name,\r\n\t\t\t\tstatusCode: co.statusCode,\r\n\t\t\t\t//statusTextHigh: co.statusTextHigh,\r\n\t\t\t\tcreated: this.toYYYY_MM_DD(co.created),\r\n\t\t\t\tbusinessFocuses: this.toLpoBusinessCategories(co.businessFocuses), // DIRECT COPY.\r\n\t\t\t\tindustriCode: co.industriCode,\r\n\t\t\t\tindustriText: co.industriText,\r\n\t\t\t\tleagalGroupCode: co.legalGroupCode,\r\n\t\t\t\tlegalGroupText: co.legalGroupText,\r\n\t\t\t\tbrokenFiscalYear: co.brokenFiscalYear,\r\n\t\t\t\tfiscalYearEndDate: co.fiscalYearEndDate,\r\n\t\t\t\tprincipals: this.toLpoPrincipals(co.principals)\r\n\r\n\t\t\t\t//streetAddress: co.streetAddress,\r\n\t\t\t\t//postalAddress: co.postalAddress,\r\n\t\t\t\t//postalCode: co.postalCode,\r\n\t\t\t\t//selectedCompany: co.selectedCompany,\r\n\t\t\t}\r\n\t\t\treturn company;\r\n\t\t})\r\n\t\treturn result;\r\n\t}\r\n\tstatic toYYYY_MM_DD(d:Date|undefined):string|undefined {\r\n\t\tif( !d )\r\n\t\t\treturn;\r\n\r\n\t\treturn new Date(d.getTime() - (d.getTimezoneOffset() * 60000 ))\r\n\t\t\t.toISOString()\r\n\t\t\t.split(\"T\")[0];\r\n\t}\r\n\t\r\n\tstatic toLpoPrincipals(principals: Principal[] | undefined): PrincipalType[] | undefined {\r\n\t\tif( !principals ) return;\r\n\t\treturn principals.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tprincipalName: x.name,\r\n\t\t\t\tcustomerId: x.customerId\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\tstatic toLpoBusinessCategories(businessFocuses: BusinessCategory[] | undefined): BusinessCategoryType[] | undefined {\r\n\t\tif( !businessFocuses) return;\r\n\t\treturn businessFocuses.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tbusinessId: x.id,\r\n\t\t\t\tbusinessCategory:x.businessCategoryCode,\r\n\t\t\t\tbusinessPart: x.businessPart,\r\n\t\t\t\tmainBusiness: x.mainDirection \r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\tstatic toLpoLoans(c:Case, loan: Loan | undefined):LoanType[]|undefined {\r\n\t\tif( !loan )\r\n\t\t\treturn;\r\n\t\tlet result:LoanType = {\r\n\t\t\tprocessId: c.id,\r\n\t\t\tloanId: loan.id,\r\n\t\t\tloanNumber: loan.number,\r\n\t\t\tloanTakeOver: loan.takeOver, // obsolete.\r\n\t\t\t//purposeOfLoan: loan.purposeOfLoan, // not in use.\r\n\t\t\tloanAmount: loan.amount, // obsolete.\r\n\t\t\tdownPaymentAmount: loan.downPaymentAmount,\r\n\t\t\tdownPaymentOther: loan.downpaymentOther,\r\n\t\t\taims: this.toLpoAims(loan.aims),\r\n\t\t\ttakeoverloans: this.toLpoTakeoverLoans(loan.takeoverLoans), // TODO.\r\n\t\t\tdownPaymentType: this.toLpoDownpaymentType(loan.downpaymentType),\r\n\t\t\tpurposeDescription: loan.purposeDescription,\r\n\t\t}\r\n\t\treturn [result];\r\n\t}\r\n\tstatic toLpoDownpaymentType(downpaymentType: DownpaymentSource | undefined): DownPaymentType | undefined {\r\n\t\tconst d = downpaymentType;\r\n\t\tif( d===DownpaymentSource.BLANCO_LOAN )\r\n\t\t\treturn DownPaymentType.Blanco;\r\n\t\telse if( d===DownpaymentSource.OTHER )\r\n\t\t\treturn DownPaymentType.Vrigt;\r\n\t\telse if( d===DownpaymentSource.SALE_OF_PROPERTY )\r\n\t\t\treturn DownPaymentType.FrsljningBostad;\r\n\t\telse if( d===DownpaymentSource.SAVINGS )\r\n\t\t\treturn DownPaymentType.Sparande;\r\n\t\telse \r\n\t\t\treturn;\r\n\t}\r\n\tstatic toLpoAims(aims: Aim[] | undefined): AimType[] | undefined {\r\n\t\tif( !aims )\r\n\t\t\treturn;\r\n\t\tconst result:AimType[] = aims.map(aim => {\r\n\t\t\tconst purposeText = aim.aimCategory;\r\n\t\t\tconst aimText = aim.aimDetail;\r\n\r\n\t\t\tconst a:AimType = {\r\n\t\t\t\taimId: aim.id, \r\n\t\t\t\tpurposeText: purposeText,\r\n\t\t\t\taimText: aimText, \r\n\t\t\t\tloanAmountPart: aim.loanAmountPart\r\n\t\t\t}\r\n\t\t\treturn a;\r\n\t\t})\r\n\t\treturn result;\r\n\t}\r\n\t\r\n\tstatic toLpoTakeoverLoansType(takeoverLoans: TakeoverLoan[] | undefined): TakeoverLoansType | undefined {\r\n\t\tif( !takeoverLoans )\r\n\t\t\treturn undefined;\r\n\t\telse {\r\n\t\t\tconst tolst:TakeoverLoansType = {\r\n\t\t\t\ttakeoverloans: this.toLpoTakeoverLoans(takeoverLoans)\r\n\t\t\t};\r\n\t\t\treturn tolst;\r\n\t\t}\r\n\t}\r\n\tstatic toLpoTakeoverLoans(takeoverLoans: TakeoverLoan[] | undefined): TakeoverLoanType[] | undefined {\r\n\t\tif( !takeoverLoans )\r\n\t\t\treturn;\r\n\t\tconst result:TakeoverLoanType[] = takeoverLoans.map(x => {\r\n\t\t\tconst purposeText = x.aimCategory;\r\n\t\t\tconst aimText = x.aimDetail;\r\n\r\n\t\t\tconst a:TakeoverLoanType = {\r\n\t\t\t\ttakeoverLoanId: x.id, \r\n\t\t\t\tpurposeText: purposeText,\r\n\t\t\t\taimText: aimText, \r\n\t\t\t\tdebtAmount: x.debtAmount,\r\n\t\t\t\tcreditInstitute: x.creditInstitute,\r\n\t\t\t\tloanNumber: x.loanNumber,\r\n\t\t\t\t//interest: x.interest,\r\n\t\t\t\t//period: x.period\r\n\t\t\t}\r\n\t\t\treturn a;\r\n\t\t})\r\n\t\treturn result;\r\n\t}\r\n\tstatic toLpoApplicants(c:Case, applicants: Applicant[] | undefined) : ApplicantType[]|undefined {\r\n\t\tif( !applicants )\r\n\t\t\treturn;\r\n\t\treturn applicants.map(a => {\r\n\t\t\tlet name = (a.firstName||'') + ' ' + (a.lastName||'');\r\n\t\t\tname = name.trim();\r\n\r\n\t\t\tconst at:ApplicantType = {\r\n\t\t\t\tapplicantId: a.id,\r\n\t\t\t\tprocessId: c.id,\r\n\t\t\t\tcustomerId: a.customerId,\r\n\t\t\t\tapplicantName: name,\r\n\t\t\t\tapplicantAddress: a.streetAddress,\r\n\t\t\t\tapplicantPostAddress: a.postalAddress,\r\n\t\t\t\tstakeholderType: a.stakeholderType,\r\n\t\t\t\tcontactInformation: {\r\n\t\t\t\t\tapplicanteMail: a.email,\r\n\t\t\t\t\tapplicantMobileNumber: a.mobilePhone,\r\n\t\t\t\t},\r\n\t\t\t\tapplicantBySms: a.notifyByMobilePhone,\r\n\t\t\t\tapplicantByeMail: a.notifyByEmail,\r\n\t\t\t\tapplicantCollateralToBuy: a.willBuyAgriForestryProperty\r\n\t\t\t}\r\n\t\t\treturn at;\r\n\t\t})\r\n\t}\r\n}","import { BaseService } from './BaseService';\r\n\r\nexport class IdService extends BaseService {\r\n\r\n\tprivate id: number;\r\n\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t\tthis.id = 1;\r\n\t}\r\n\r\n\tnewId(): number {\r\n\t\treturn ++this.id;\r\n\t}\r\n\r\n\tnewIdString(): string {\r\n\t\treturn this.newId().toString();\r\n\t}\r\n\r\n\tnewGuid() : string {\r\n\t\treturn this.generateUUID();\r\n\t}\r\n\r\n\t//// Public Domain/MIT\r\n\t// From https://stackoverflow.com/questions/105034/create-guid-uuid-in-javascript\r\n\tprivate generateUUID() { \r\n\t\tvar d = new Date().getTime();\r\n\t\tif (typeof performance !== 'undefined' && typeof performance.now === 'function'){\r\n\t\t\td += performance.now(); //use high-precision timer if available\r\n\t\t}\r\n\t\treturn 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {\r\n\t\t\tvar r = (d + Math.random() * 16) % 16 | 0;\r\n\t\t\td = Math.floor(d / 16);\r\n\t\t\treturn (c === 'x' ? r : ((r & 0x3) | 0x8)).toString(16);\r\n\t\t});\r\n\t}\r\n}\r\n","import { IdService } from \"../services/IdService\";\r\n\r\nimport { Case, Company, Loan, Aim, Applicant, CompanyEconomy, \r\n\tBudget, Revenue, EUSupport, KYC, PersonalEconomy, LPEmploymentEnum, Guarantor,\r\n\tEUSupportEnum as SmeEUSupportType, BudgetYear as SmeBudgetYear,\r\n\tExtLoan, Household, MaintenanceCost, MaintenanceHouse, \r\n\tChild, HouseholdMember, ExtLoanOwner, LoanOwner, DownpaymentSource, BusinessCategory, Collateral, TaxedOwner, Principal } from \"./SelmaModels\";\r\n\r\nimport { CompanyType, LoanType, AimType, KycInformationType, ApplicantType, ProcessType, \r\n\tCaseIdStatus, LinksAll, CompanyEconomyType, BudgetType, EUType,\r\n\tRevenueType, EUSupportType, PersonalEconomyType, HouseholdType, ChildType, HouseholdMemberType, \r\n\tGuarantorType, ExtLoanType, TypeOfEmployeement, MaintenanceCostType, MaintenanceHouseType, \r\n\tTypeOfHouse, DownPaymentType, BusinessCategoryType, BudgetYearType, CollateralType, TaxedOwnerType, PrincipalType, TakeoverLoanType} from \"../libs/SMELPOClient\";\r\n\r\nimport { LoanOwnerType } from \"../libs/SMELPOClient/models/LoanOwnerType\";\r\nimport { AttachmentRequest, Attachment } from \"./selmamodels/Attachment\";\r\nimport { LpoAttachmentRequest, LpoAttachment } from \"./extendedlpo/Attachment\";\r\nimport { TakeoverLoan } from \"./selmamodels/Loan\";\r\n\r\n\r\nexport class LpoModelConverter {\r\n\tstatic idService = new IdService();\r\n\r\n\tstatic toCase(process:ProcessType) : Case {\r\n\t\tlet createdDate = this.fromDateString(process.processCreatedDate);\r\n\t\tlet lastAccessedDate = this.fromDateString(process.lastAccessed);\r\n\t\tlet c: Case = {\r\n\t\t\tid: process.processId,\r\n\t\t\tnumber: process.referenceId||0,\r\n\t\t\tversion: process.processVersion||'v1',\r\n\t\t\tlpCaseId: process.caseId,\r\n\t\t\tstatus: process.caseIdStatus?process.caseIdStatus:CaseIdStatus.STARTEDBYAPPLICANT,\r\n\t\t\tcustomers: process.customers||[],\r\n\t\t\tcreatedDate: createdDate?createdDate:new Date(),\r\n\t\t\tkycApplicantsStatus: [],\r\n\t\t\tlastAccessedDate: lastAccessedDate?lastAccessedDate:new Date(),\r\n\t\t}\r\n\t\treturn c;\r\n\t}\r\n\r\n\tstatic fromDateString(str: string | undefined): Date|undefined {\r\n\t\tif( !str )\r\n\t\t\treturn;\r\n\r\n\t\tlet date = new Date(str);\r\n\t\treturn date;\r\n\t}\r\n\r\n\tstatic linksAllToCase(linksAll:LinksAll) : Case {\r\n\t\tif( !linksAll.processes ||linksAll.processes.length!==1 )\r\n\t\t\tthrow 'Not single links all'\r\n\t\tlet process = linksAll.processes[0];\r\n\r\n\t\tlet c: Case = this.toCase(process);\r\n\t\tc.applicants = this.toApplicants(linksAll.applicants, linksAll.kycinformations);\r\n\t\tc.loan = linksAll.loans?this.toLoan(linksAll.loans[0]):undefined;\r\n\t\tc.companies = this.toCompanies(linksAll.companies);\r\n\t\tc.companyEconomies = this.toCompanyEconomies(linksAll.companyeconomies);\r\n\t\tc.collaterals = this.toCollaterals(linksAll.collaterals);\r\n\t\tc.euSupports = this.toEuSupports(linksAll.eusupports);\r\n\t\tc.extLoans = this.toExtLoans(linksAll.extloans);\r\n\t\tc.budgets = this.toBudgets(linksAll.budgets);\r\n\t\tc.guarantors = this.toGuarantors(linksAll.guarantors);\r\n\t\tc.households = this.toHouseholds(linksAll.households);\r\n\t\tc.personalEconomies = this.toPersonalEconomies(linksAll.personaleconomies);\r\n\t\tc.maintenanceCosts = this.toMaintenanceCosts(linksAll.maintenancecosts);\r\n\t\tc.attachments = this.toAttachments((linksAll).attachments);\r\n\t\tc.attachmentRequests = this.toAttachmentRequests((linksAll).attachmentRequests);\r\n\t\treturn c;\r\n\t}\r\n\tstatic toCollaterals(collaterals: CollateralType[] | undefined): Collateral[] | undefined {\r\n\t\tif( !collaterals) return;\r\n\t\treturn collaterals.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tid: x.collateralId,\r\n\t\t\t\tcustomerId: x.customerId,\r\n\t\t\t\tcode: x.collateralCode, \r\n\t\t\t\tname: x.collateralName, \r\n\t\t\t\tmunicipality: x.collateralMunicipality,\r\n\t\t\t\tstreet: x.collateralStreet,\r\n\t\t\t\t//age: x.collateralAge,\r\n\t\t\t\tareal: x.collateralAreal,\r\n\t\t\t\tuseAsCollateral: x.useAsCollateral,\r\n\t\t\t\tbuyCollateral: x.buyCollateral,\r\n\t\t\t\ttaxedOwners: this.toTaxedOwners(x.taxedOwners)\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\tstatic toTaxedOwners(taxedOwners: TaxedOwnerType[] | undefined): TaxedOwner[]|undefined {\r\n\t\tif( !taxedOwners) return;\r\n\t\treturn taxedOwners.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tid: x.taxedOwnerId,\r\n\t\t\t\tcustomerId: x.taxedOwner\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\tstatic toBudgets(budgets: BudgetType[] | undefined): Budget[] | undefined {\r\n\t\tif( !budgets ) return;\r\n\t\treturn budgets.map(x => {\r\n\t\t\treturn this.toBudget(x);\r\n\t\t})\r\n\t}\r\n\tstatic toAttachmentRequests(attachmentRequests: LpoAttachmentRequest[]|undefined): AttachmentRequest[] | undefined {\r\n\t\tif( !attachmentRequests) return;\r\n\t\treturn attachmentRequests.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tid: x.id,\r\n\t\t\t\tcustomerId: x.customerId,\r\n\t\t\t\trequestType: x.requestType,\r\n\t\t\t\trequestVariation: x.requestVariation,\r\n\t\t\t\trequired: x.required\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\tstatic toAttachments(attachments: LpoAttachment[]| undefined): Attachment[] | undefined {\r\n\t\tif( !attachments) return;\r\n\t\treturn attachments.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tid: x.id,\r\n\t\t\t\tcustomerId: x.customerId,\r\n\t\t\t\trequestType: x.requestType,\r\n\t\t\t\trequestVariation: x.requestVariation,\r\n\t\t\t\tmimeType: x.mimeType,\r\n\t\t\t\tfileName: x.fileName,\r\n\t\t\t\tfileSize: x.fileSize\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\tstatic toMaintenanceCosts(maintenancecosts: MaintenanceCostType[] | undefined): MaintenanceCost[] | undefined {\r\n\t\tif( !maintenancecosts)\r\n\t\t\treturn;\r\n\t\treturn maintenancecosts.map(x=> {\r\n\t\t\treturn this.toMaintenanceCost(x);\r\n\t\t})\r\n\t}\r\n\tstatic toMaintenanceCost(x: MaintenanceCostType): MaintenanceCost {\r\n\t\treturn {\r\n\t\t\tid: x.maintenanceCostId,\r\n\t\t\tcustomerId: x.customerId,\r\n\t\t\ttypeofhouses: this.toMaintenanceHouses(x.typeofhouses)\r\n\t\t}\r\n\t}\r\n\tstatic toMaintenanceHouses(typeofhouses: MaintenanceHouseType[] | undefined): MaintenanceHouse[] | undefined {\r\n\t\tif( !typeofhouses )\r\n\t\t\treturn;\r\n\t\treturn typeofhouses.map(x=> {\r\n\t\t\treturn this.toMaintenanceHouse(x);\r\n\t\t})\r\n\t}\r\n\tstatic toMaintenanceHouse(x: MaintenanceHouseType): MaintenanceHouse {\r\n\t\treturn {\r\n\t\t\thouseType: x.typeOfHouse, //this.toHouseTypeCode(x.typeOfHouse),\r\n\t\t\tkeepHouse: x.keepHouse,\r\n\t\t\tloanInOtherInstitute: x.loanInOtherInstitute,\r\n\t\t\tredeemLoan: x.redeemLoan,\r\n\t\t\tloanOwners: this.toLoanOwners(x.loanOwners),\r\n\t\t\thouseLoanAmount: x.houseLoanAmount,\r\n\t\t\tmaintenanceCost: x.maintenanceCost \r\n\t\t}\r\n\t}\r\n\tstatic toLoanOwners(extLoanOwners: LoanOwnerType[] | undefined): LoanOwner[] | undefined {\r\n\t\tif( !extLoanOwners)\r\n\t\t\treturn;\r\n\t\treturn extLoanOwners.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tcustomerId : x.customerId||'',\r\n\t\t\t\townershipPart: x.ownershipPart\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\t// static toHouseTypeCode(houseType: TypeOfHouse | undefined): string | undefined {\r\n\t// \tif( !houseType ) return;\r\n\t// \tif( houseType==TypeOfHouse.Villa) return 'HOUSE';\r\n\t// \tif( houseType==TypeOfHouse.VrigtBoende) return 'OTHER';\r\n\t// \tif( houseType==TypeOfHouse.Hyresrtt) return 'TENANCY';\r\n\t// \tif( houseType==TypeOfHouse.Landbruksfastighet) return 'FARM';\r\n\t// \tif( houseType==TypeOfHouse.Bostadsrtt) return 'APARTMENT';\r\n\t// \tif( houseType==TypeOfHouse.Fritidshus) return 'VACATIONHOUSE';\r\n\t// }\r\n\tstatic toPersonalEconomies(personaleconomies: PersonalEconomyType[] | undefined): PersonalEconomy[] | undefined {\r\n\t\tif( !personaleconomies)\r\n\t\t\treturn;\r\n\t\treturn personaleconomies.map(x=> {\r\n\t\t\treturn this.toPersonalEconomy(x);\r\n\t\t})\r\n\t}\r\n\tstatic toPersonalEconomy(x: PersonalEconomyType): PersonalEconomy {\r\n\t\treturn {\r\n\t\t\tid: x.personalEconomyId,\r\n\t\t\tcustomerId: x.customerId, // guid\r\n\t\t\t//sapEmployment?: SAPEmploymentEnum; // originally defined in Applicant\r\n\t\t\t//lpEmployment?: LPEmploymentEnum; // originally defined in Applicant\r\n\t\t\tincome: x.income, // // SEK / month\r\n\t\t\tyearlyIncome: x.yearlyIncome, // SEK / year\r\n\t\t\ttypeOfEmployment: this.toTypeOfEmployment(x.typeOfEmployeement), // EmployeementType;\r\n\t\t\temployer: x.employeer, // name of company\r\n\t\t\tyearOfEmployment: x.yearOfEmployment,\r\n\t\t\tmonthOfEmployment: x.monthOfEmployment\r\n\t\t}\r\n\t}\r\n\tstatic toTypeOfEmployment(typeOfEmployeement: TypeOfEmployeement | undefined): LPEmploymentEnum | undefined {\r\n\t\tconst t = typeOfEmployeement;\r\n\t\tif( !t )\r\n\t\t\treturn;\r\n\r\n\t\tif( t===TypeOfEmployeement.PERMANENT) return LPEmploymentEnum.PERMANENT; // - Anställd, tills-vidare-anställd \r\n\t\tif( t===TypeOfEmployeement.TEMPORARY) return LPEmploymentEnum.TEMPORARY; // - Tidbegränsad anställning \r\n\t\tif( t===TypeOfEmployeement.PROBATIONARY) return LPEmploymentEnum.PROBATIONARY; // - Provanställning \r\n\t\tif( t===TypeOfEmployeement.UNEMPLOYMENTINSURANCE) return LPEmploymentEnum.UNEMPLOYMENT_INSURANCE; // - Arbetslöshetskassa \r\n\t\tif( t===TypeOfEmployeement.SELFEMPLOYED) return LPEmploymentEnum.SELF_EMPLOYED; //- Eget företag \r\n\t\tif( t===TypeOfEmployeement.STUDENTAID) return LPEmploymentEnum.STUDENT_AID; // - Studiestöd \r\n\t\tif( t===TypeOfEmployeement.PENSION) return LPEmploymentEnum.PENSION; // - Inkomst av pension\r\n\t}\r\n\tstatic toHouseholds(households: HouseholdType[] | undefined): Household[] | undefined {\r\n\t\tif( !households)\r\n\t\t\treturn;\r\n\t\treturn households.map(x=> {\r\n\t\t\treturn this.toHousehold(x);\r\n\t\t})\r\n\t}\r\n\tstatic toHousehold(x: HouseholdType): Household {\r\n\t\treturn {\r\n\t\t\tid: x.householdId,\r\n\t\t\tmembers: this.toHouseholdMembers(x.householdMembers),\r\n\t\t\tnumberOfChildrenAtHome: x.numberOfChildsAtHome, // integer\r\n\t\t\tchildren: this.toChildren(x.childs),\r\n\t\t\tnumberOfCars: x.numberOfCars, // integer\r\n\t\t\tchildMaintenanceCost: x.childMaintenaceCost, // Money, SEK/year\r\n\t\t\tchildMaintenanceIncome: x.receiveChildMaintenanceCost, // Money, SEK/year\r\n\t\t\tchildCareAmount: x.childCareAmount\r\n\t\t}\r\n\t}\r\n\tstatic toChildren(childs: ChildType[] | undefined): Child[] | undefined {\r\n\t\tif( !childs )\r\n\t\t\treturn;\r\n\t\treturn childs.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tid: x.childId,\r\n\t\t\t\tchildsAge:x.childsAge,\r\n\t\t\t\tpartInHousehold:x.partInHousehold\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\tstatic toHouseholdMembers(householdMembers: HouseholdMemberType[] | undefined): HouseholdMember[] | undefined {\r\n\t\tif( !householdMembers )\r\n\t\t\treturn;\r\n\t\t\r\n\t\treturn householdMembers.map(x => {\r\n\t\t\treturn this.toHouseholdMember(x);\r\n\r\n\t\t})\r\n\t\t\r\n\t}\r\n\tstatic toHouseholdMember(x: HouseholdMemberType): HouseholdMember {\r\n\t\treturn {\r\n\t\t\t//id: x.householdMemberId||'', // TODO: should not be undefined-able.\r\n\t\t\thouseholdMember: x.householdMember\r\n\t\t}\r\n\t}\r\n\tstatic toGuarantors(guarantors: GuarantorType[] | undefined): Guarantor[] | undefined {\r\n\t\tif( !guarantors)\r\n\t\t\treturn;\r\n\t\treturn guarantors.map(x=> {\r\n\t\t\treturn this.toGuarantor(x);\r\n\t\t})\r\n\t}\r\n\tstatic toGuarantor(x: GuarantorType): Guarantor {\r\n\t\treturn {\r\n\t\t\tid: x.guarantorId||'',\r\n\t\t\tname: x.guarantorName,\r\n\t\t\tphone: x.guarantorPhone,\r\n\t\t\tguarantorCustomerId: x.guarantorCustomerId\t\r\n\t\t}\r\n\t}\r\n\tstatic toExtLoans(extloans: ExtLoanType[] | undefined): ExtLoan[] | undefined {\r\n\t\tif( !extloans)\r\n\t\t\treturn;\r\n\t\treturn extloans.map(x => {\r\n\t\t\treturn this.toExtLoan(x);\r\n\t\t})\r\n\t}\r\n\tstatic toExtLoan(x: ExtLoanType): ExtLoan {\r\n\t\treturn {\r\n\t\t\tid: x.extloanId,\r\n\t\t\ttype: x.typeOfLoan,\r\n\t\t\tloanOwners: this.toExtLoanOwners(x.extLoanOwners),\r\n\t\t\tcreditInstitute: x.extCreditInstitute,\r\n\t\t\tloanClearing: x.extloanClearing, // extloanClearing\r\n\t\t\tloanNumber: x.extloanNumber, // extloanNumber\r\n\t\t\tamount: x.extloanAmount, // SEK, extloanAmount\r\n\t\t\tmonthlyCost: x.extMonthlyCost,\r\n\t\t\tredeemLoan: x.extRedeemLoan // extRedeemLoan, skall lånet lösas?\r\n\t\t}\r\n\t}\r\n\tstatic toExtLoanOwners(extLoanOwners: string[] | undefined): ExtLoanOwner[] | undefined {\r\n\t\tif( !extLoanOwners)\r\n\t\t\treturn;\r\n\t\treturn extLoanOwners.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tcustomerId : x\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\tstatic toEuSupports(euSupports: EUSupportType[] | undefined): EUSupport[] | undefined {\r\n\t\tif( !euSupports )\r\n\t\t\treturn;\r\n\t\treturn euSupports.map(x => {\r\n\t\t\treturn this.toEuSupport(x);\r\n\t\t})\r\n\t}\r\n\tstatic toEuSupport(euSupport: EUSupportType): EUSupport {\r\n\t\tconst e = euSupport;\r\n\t\treturn {\r\n\t\t\t\tid: e.euId,\r\n\t\t\t\teuType: this.toEUSupportType( e.euType),\r\n\t\t\t\tsupportAmount: e.supportAmount,\r\n\t\t\t\tsupportYear: e.supportYear,\r\n\t\t}\r\n\t}\r\n\tstatic toEUSupportType(euType: EUType | undefined): SmeEUSupportType | undefined {\r\n\t\tif( !euType)\r\n\t\t\treturn;\r\n\t\tif( euType==EUType.EUStd)\r\n\t\t\treturn SmeEUSupportType.EU;\r\n\t\tif( euType==EUType.EUStdOchNationelltStd)\r\n\t\t\treturn SmeEUSupportType.EUNAT;\r\n\t\tif( euType==EUType.EUStdOchNationelltStdUtanMjlk)\r\n\t\t\treturn SmeEUSupportType.EUNAT_NOMILK;\r\n\t\tif( euType==EUType.NationellStdUtanMjlk)\r\n\t\t\treturn SmeEUSupportType.NAT_NOMILK;\r\n\t}\r\n\tstatic toCompanyEconomies(companyeconomies: CompanyEconomyType[] | undefined): CompanyEconomy[] | undefined {\r\n\t\tif( !companyeconomies )\r\n\t\t\treturn;\r\n\t\treturn companyeconomies.map(x=> {\r\n\t\t\t//let budget:BudgetType|undefined = this.getBudgetTypeByCompanyEconomyType(budgets, x);\r\n\t\t\treturn this.toCompanyEconomy(x);\r\n\t\t})\r\n\t}\r\n\tstatic toCompanyEconomy(companyEconomy: CompanyEconomyType): CompanyEconomy {\r\n\t\tconst cet = companyEconomy;\r\n\t\tconst ce:CompanyEconomy = {\r\n\t\t\tid: cet.companyEconomyId,\r\n\t\t\tcompanyId: cet.companyId,\r\n\t\t\tcustomerCategory: cet.customerCategory,\r\n\t\t\trevenues: this.toRevenues(cet.revenues), // NOT IN USE.\r\n\t\t}\r\n\t\treturn ce;\r\n\t}\r\n\tstatic toBudget(budget: BudgetType):Budget {\r\n\t\treturn {\r\n\t\t\tcompanyEconomyId: budget.companyEconomyId||'',\r\n\t\t\tbudgetYears: this.toBudgetYears(budget.budgetYears) // TODO: LHB must fix.\r\n\t\t}\r\n\t}\r\n\tstatic toBudgetYears(budgetYears: BudgetYearType[] | undefined): SmeBudgetYear[] | undefined {\r\n\t\tif( !budgetYears ) return;\r\n\t\treturn budgetYears.map(x => {\r\n\t\t\treturn this.toBudgetYear(x);\r\n\t\t})\r\n\t}\r\n\tstatic toBudgetYear(x: BudgetYearType): SmeBudgetYear {\r\n\t\tlet v = x.budget||{};\r\n\t\treturn {\r\n\t\t\tbudgetId: x.budgetId,\r\n\t\t\tyear: x.budgetyear,\r\n\t\t\tvalue1: v.value1,\r\n\t\t\tvalue2: v.value2,\r\n\t\t\tvalue3: v.value3,\r\n\t\t\tvalue4: v.value4,\r\n\t\t\tvalue5: v.value5,\r\n\t\t\tvalue6: v.value6,\r\n\t\t\tvalue7: v.value7,\r\n\t\t\tvalue8: v.value8,\r\n\t\t\tvalue9: v.value9,\r\n\t\t\tvalue10: v.value10,\r\n\t\t\tvalue11: v.value11,\r\n\t\t\tvalue12: v.value12,\r\n\t\t\tvalue13: v.value13,\r\n\t\t\tvalue14: v.value14,\r\n\t\t\tvalue15: v.value15,\r\n\t\t\tvalue16: v.value16,\r\n\t\t\tvalue17: v.value17,\r\n\t\t\tvalue18: v.value18,\r\n\t\t\tvalue19: v.value19,\r\n\t\t\tvalue20: v.value20,\r\n\t\t\tvalue21: v.value21,\r\n\t\t\tvalue22: v.value22,\r\n\t\t\tvalue23: v.value23,\r\n\t\t\tvalue24: v.value24,\r\n\t\t\tvalue25: v.value25\r\n\t\t}\r\n\t}\r\n\tstatic toRevenues(revenues: RevenueType[] | undefined): Revenue[] | undefined {\r\n\t\tif( !revenues) return;\r\n\t\treturn revenues.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tyear: x.revenueYear,\r\n\t\t\t\trevenue: x.revenue\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\r\n\tstatic toLoan(loan: LoanType): Loan {\r\n\r\n\t\tlet tol:TakeoverLoanType[]|undefined = loan.takeoverloans;\r\n\t\t// if( loan.takeoverloans && loan.takeoverloans.takeoverloans) {\r\n\t\t// \ttol = loan.takeoverloans.takeoverloans;\r\n\t\t// }\r\n\t\t\r\n\t\treturn {\r\n\t\t\tid: loan.loanId,\r\n\t\t\tnumber: loan.loanNumber,\r\n\t\t\tamount: loan.loanAmount, // obsolete\r\n\t\t\taims: this.toAims(loan.aims),\r\n\t\t\ttakeoverLoans: this.toTakeoverLoans(tol), // TODO.\r\n\t\t\ttakeOver: loan.loanTakeOver, // obsolete\r\n\t\t\tdownpaymentOther: loan.downPaymentOther,\r\n\t\t\tdownpaymentType: this.toDownpaymentSource(loan.downPaymentType),\r\n\t\t\tdownPaymentAmount: loan.downPaymentAmount,\r\n\t\t\tpurposeDescription: loan.purposeDescription\r\n\t\t}\r\n\t}\r\n\tstatic toDownpaymentSource(downPaymentType: DownPaymentType | undefined): DownpaymentSource | undefined {\r\n\t\tconst d = downPaymentType;\r\n\t\tif( d==DownPaymentType.Blanco)\r\n\t\t\treturn DownpaymentSource.BLANCO_LOAN;\r\n\t\telse if( d==DownPaymentType.FrsljningBostad)\r\n\t\t\treturn DownpaymentSource.SALE_OF_PROPERTY;\r\n\t\telse if( d==DownPaymentType.Sparande)\r\n\t\t\treturn DownpaymentSource.SAVINGS;\r\n\t\telse if( d==DownPaymentType.Vrigt)\r\n\t\t\treturn DownpaymentSource.OTHER;\r\n\t\telse\r\n\t\t\treturn;\r\n\t}\r\n\tstatic toAims(aims: AimType[] | undefined): Aim[] | undefined {\r\n\t\tif( !aims ) return;\r\n\t\treturn aims.map(x => {\r\n\t\t\tconst aimCategory:string|undefined = x.purposeText;\r\n\t\t\tconst aimDetail:string|undefined = x.aimText;\r\n\t\t\treturn {\r\n\t\t\t\tid: x.aimId,\r\n\t\t\t\tloanAmountPart: x.loanAmountPart,\r\n\t\t\t\taimCategory: aimCategory,\r\n\t\t\t\taimDetail: aimDetail\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\tstatic toTakeoverLoans(takeoverLoans: TakeoverLoanType[] | undefined): TakeoverLoan[] | undefined {\r\n\t\tif( !takeoverLoans ) return;\r\n\t\treturn takeoverLoans.map(x => {\r\n\t\t\tconst aimCategory:string|undefined = x.purposeText;\r\n\t\t\tconst aimDetail:string|undefined = x.aimText;\r\n\t\t\treturn {\r\n\t\t\t\tid: x.takeoverLoanId,\r\n\t\t\t\taimCategory: aimCategory,\r\n\t\t\t\taimDetail: aimDetail,\r\n\t\t\t\tdebtAmount: x.debtAmount,\r\n\t\t\t\tcreditInstitute: x.creditInstitute,\r\n\t\t\t\tloanNumber: x.loanNumber\r\n\t\t\t\t//interest: x.interest,\r\n\t\t\t\t//period: x.period\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\t// static toMainPurpose(purposeOfLoan: MainPurposes | undefined): SmeMainPurposes | undefined {\r\n\t// \tif( !purposeOfLoan )\r\n\t// \t\treturn;\r\n\t// \tif( purposeOfLoan==MainPurposes.Kp)\r\n\t// \t\treturn SmeMainPurposes.BUY;\r\n\t// \tif( purposeOfLoan==MainPurposes.UtkningLn)\r\n\t// \t\treturn SmeMainPurposes.EXTENSION;\r\n\t// \tif( purposeOfLoan==MainPurposes.UtlningMotObelnat)\r\n\t// \t\treturn SmeMainPurposes.UNPLEDGED;\r\n\t// \tif( purposeOfLoan==MainPurposes.Vertag)\r\n\t// \t\treturn SmeMainPurposes.TAKEOVER;\r\n\t// }\r\n\tstatic toApplicants(applicants: ApplicantType[] | undefined, kycs:KycInformationType[]|undefined): Applicant[] | undefined {\r\n\t\tif( !applicants )\r\n\t\t\treturn;\r\n\r\n\t\treturn applicants.map(x => {\r\n\t\t\tlet kycResult = kycs?kycs.filter(k => k.customerId==x.customerId):[];\r\n\t\t\tlet kyc = kycResult.length==1?kycResult[0]:undefined;\r\n\t\t\treturn this.toApplicant(x, kyc);\r\n\t\t});\r\n\t}\r\n\r\n\tstatic toApplicant(applicant:ApplicantType, kyc?:KycInformationType|undefined) : Applicant {\r\n\t\tconst x = applicant;\r\n\r\n\t\tlet firstName = x.applicantName||'';\r\n\t\tlet lastName;\r\n\t\tlet spPos = firstName.lastIndexOf(' ');\r\n\t\tif( spPos>0 ) {\r\n\t\t\tlastName = firstName.slice(spPos).trim();\r\n\t\t\tfirstName = firstName.slice(0,spPos).trim();\r\n\t\t}\r\n\r\n\t\tlet email = x.contactInformation?x.contactInformation.applicanteMail:undefined;\r\n\r\n\t\tlet a:Applicant = {\r\n\t\t\tid: x.applicantId,\r\n\t\t\tfirstName: firstName,\r\n\t\t\tlastName: lastName,\r\n\t\t\tcustomerId: x.customerId,\r\n\t\t\tstreetAddress: x.applicantAddress,\r\n\t\t\tpostalAddress: x.applicantPostAddress,\r\n\t\t\tpostalCode: x.applicantPostalCode,\r\n\t\t\temail: email,\r\n\t\t\temailConfirm: email,\r\n\t\t\tmobilePhone: x.contactInformation?x.contactInformation.applicantMobileNumber:undefined,\r\n\t\t\tstakeholderType: x.stakeholderType,\r\n\t\t\tkyc: this.toKyc(kyc),\r\n\t\t\tnotifyByEmail: x.applicantByeMail,\r\n\t\t\tnotifyByMobilePhone: x.applicantBySms,\r\n\t\t\twillBuyAgriForestryProperty: x.applicantCollateralToBuy\r\n\t\t}\r\n\t\treturn a;\r\n\t}\r\n\tstatic toApplicantOrUndefined(applicant:ApplicantType|undefined, kyc?:KycInformationType|undefined) : Applicant|undefined {\r\n\t\tif( !applicant )\r\n\t\t\treturn; \r\n\t\treturn this.toApplicant(applicant, kyc);\r\n\t}\r\n\tstatic toKyc(kyc: KycInformationType | undefined): KYC | undefined {\r\n\t\tif( !kyc )\r\n\t\t\treturn undefined;\r\n\t\treturn {\r\n\t\t\tid:kyc.kycId||'',\r\n\t\t\thighRiskCategoryCode: kyc.kycHighRiskIndustryText,\r\n\t\t\tapprovedInfoSharing: kyc.kycUCAware, // ucAware\r\n\t\t\tapprovedCreditCheck: kyc.kycAcceptUC, // ucAccepted\r\n\t\t\tapprovedInfoHandling: kyc.kycAcceptGDPR, // gdprAccepted\r\n\t\t\tapprovedInfoSharingDB: kyc.kycUCAware, // ucAware\r\n\t\t\tapprovedCreditCheckDB: kyc.kycAcceptUC, // ucAccepted\r\n\t\t\tapprovedInfoHandlingDB: kyc.kycAcceptGDPR, // gdprAccepted\t\t\t\r\n\t\t\tisPep: kyc.kycPublicFunction,\r\n\t\t\t//isPepFunction: kyc.kycRelatedPublicFunction,\r\n\t\t\tisPepRelated: kyc.kycRelatedPublicFunction,\r\n\t\t\t//isPepRelatedFunction: kyc.kycRelatedPublicFunction,\r\n\t\t\tisAmericanCitizen: kyc.kycAmericanCitizen,\r\n\t\t\tisCrsTaxObligated: kyc.kycCrsTaxObligation\r\n\t\t}\r\n\t}\r\n\r\n\tstatic toCompany(company:CompanyType|undefined) : Company|undefined {\r\n\t\tif( !company )\r\n\t\t\treturn;\r\n\t\tconst x = company;\r\n\t\tlet c:Company = {\r\n\t\t\tid: x.companyId,\r\n\t\t\torgNumber: x.orgNumber,\r\n\t\t\tname: x.companyName,\r\n\t\t\tstatusCode: x.statusCode,\r\n\t\t\thighRiskCode: x.statusTextHigh,\r\n\t\t\tcreated:x.created?new Date(x.created):undefined,\r\n\t\t\tbusinessFocuses: this.toBusinessCategories(x.businessFocuses),\r\n\t\t\tindustriCode: x.industriCode,\r\n\t\t\tindustriText: x.industriText,\r\n\t\t\t//selectedCompany: x.selectedCompany,\r\n\t\t\tlegalGroupCode: x.leagalGroupCode,\r\n\t\t\tlegalGroupText: x.legalGroupText,\r\n\t\t\tbrokenFiscalYear: x.brokenFiscalYear,\r\n\t\t\tfiscalYearEndDate: x.fiscalYearEndDate,\r\n\t\t\tprincipals: this.toPrincipals(x.principals)\r\n\t\t}\r\n\t\treturn c;\r\n\t}\r\n\r\n\tstatic toPrincipals(principals: PrincipalType[] | undefined): Principal[] | undefined {\r\n\t\tif( !principals) return;\r\n\t\treturn principals.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tcustomerId: x.customerId,\r\n\t\t\t\tname: x.principalName\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\r\n\tstatic toBusinessCategories(businessCategories: BusinessCategoryType[] | undefined): BusinessCategory[] | undefined {\r\n\t\tif( !businessCategories) return;\r\n\t\treturn businessCategories.map(x => {\r\n\t\t\treturn {\r\n\t\t\t\tid: x.businessId||this.idService.newGuid(),\r\n\t\t\t\tbusinessCategoryCode: x.businessCategory,\r\n\t\t\t\tbusinessCategoryText: x.businessCategory,\r\n\t\t\t\tbusinessPart: x.businessPart,\r\n\t\t\t\tmainDirection: x.mainBusiness\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\r\n\tstatic toCompanies(companies:CompanyType[]|undefined) : Company[]|undefined {\r\n\t\tif( !companies)\r\n\t\t\treturn;\r\n\t\tlet r = companies.filter(x=>x!==undefined).map(x => this.toCompany(x));\r\n\t\treturn r as Company[];\r\n\t}\r\n\r\n\r\n\r\n}","import { BaseService } from './BaseService';\r\nimport { Case, Applicant, } from '../models/SelmaModels';\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { GuardService } from './GuardService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { ApplicantService } from './ApplicantService';\r\nimport { IdService } from './IdService';\r\nimport { UpdateProcessStatusCaseIdStatusEnum, CaseIdStatus, LinksAllFromJSON, StakeholderType, CustomerIdType } from '../libs/SMELPOClient';\r\nimport { Login, SessionService } from './SessionService';\r\nimport { SmeModelConverter } from '../models/SmeModelConverter';\r\nimport { LpoModelConverter } from '../models/LpoModelConverter';\r\nimport { ConfigurationService } from './ConfigurationService';\r\nimport { AdminCasesSearch } from '../models/extendedlpo/Admin';\r\nimport { AttachmentService } from './AttachmentService';\r\nimport KycService from './KycService';\r\n\r\nexport class CaseService extends BaseService {\r\n\r\n\tprivate stateService: StateService;\r\n\tprivate smelpoService: SMELPOService;\r\n\tprivate guardService: GuardService;\r\n\tprivate applicantService: ApplicantService;\r\n\tpublic attachmentService?: AttachmentService;\r\n\tprivate kycService: KycService;\r\n\r\n\tconstructor(stateService: StateService, smelpoService: SMELPOService, guardService: GuardService,\r\n\t\tapplicantService: ApplicantService, kycService: KycService, private idService: IdService,\r\n\t\tprivate sessionService: SessionService,\r\n\t\tprivate configurationService: ConfigurationService) {\r\n\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.smelpoService = smelpoService;\r\n\t\tthis.guardService = guardService;\r\n\t\tthis.applicantService = applicantService;\r\n\t\tthis.kycService = kycService;\r\n\t}\r\n\r\n\tupdate(c: Case) {\r\n\t\tthis.stateService.update(c);\r\n\t}\r\n\r\n\tsetCurrentCase(c: Case): Case {\r\n\t\tif (this.stateService.state.case !== c) {\r\n\t\t\tthis.stateService.state.case = c;\r\n\t\t\tthis.stateService.update(this.stateService.state);\r\n\t\t}\r\n\t\treturn this.stateService.state.case;\r\n\t}\r\n\r\n\tgetCurrentCase(): Case | undefined {\r\n\t\treturn this.stateService.state.case;\r\n\t}\r\n\r\n\thasOngoingCase(cases: Case[]): boolean {\r\n\t\tlet r = cases.filter(x => x.status === CaseIdStatus.STARTEDBYAPPLICANT);\r\n\t\treturn r.length > 0;\r\n\t}\r\n\r\n\taddNewCase(): Promise {\r\n\t\tif (!this.stateService.state.cases)\r\n\t\t\tthis.stateService.state.cases = [];\r\n\t\tlet cases = this.stateService.state.cases;\r\n\t\tlet login = this.sessionService.getLogin();\r\n\t\treturn this.addCaseOnClient(login, cases);\r\n\t}\r\n\r\n\t// ensureCustomerIdOnCase = (c:Case, customerId:string):void => {\r\n\t// \tlet customer = this.getCustomerByCustomerId(c, customerId);\r\n\t// \tif( !customer ) {\r\n\t// \t\tthis.addNewCustomerToCase(c, customerId);\r\n\t// \t}\r\n\t// }\r\n\r\n\tprivate addNewCustomerToCase(c: Case, customerId: string): CustomerIdType {\r\n\t\tif (!c.customers)\r\n\t\t\tc.customers = [];\r\n\r\n\t\tlet customer = {\r\n\t\t\tcustomerId: customerId,\r\n\t\t\tcustomerAdded: new Date().toISOString()\r\n\t\t};\r\n\t\tc.customers.push(customer);\r\n\t\treturn customer;\r\n\t}\r\n\r\n\t// getCustomerByCustomerId = (c:Case, customerId:string):CustomerIdType|undefined => {\r\n\t// \tif( !c.customers )\r\n\t// \t\treturn;\r\n\t// \tconst g = this.guardService;\r\n\t// \tconst compareCustomerId = g.compareCustomerId;\r\n\t// \tlet customer = c.customers.find(x => compareCustomerId(x.customerId||'', customerId));\r\n\t// \treturn customer;\r\n\t// }\r\n\r\n\tprivate addCaseOnClient(login: Login, cases: Case[]): Promise {\r\n\t\tlet c: Case = {\r\n\t\t\tid: this.idService.newGuid(),\r\n\t\t\tnumber: 0,\r\n\t\t\tcustomers: [],\r\n\t\t\tcreatedDate: new Date(),\r\n\t\t\tlastAccessedDate: new Date(),\r\n\t\t\tlpCaseId: \"\",\r\n\t\t\tstatus: CaseIdStatus.STARTEDBYAPPLICANT,\r\n\t\t\tkycApplicantsStatus: [], \r\n\t\t\tapplicants: [{\r\n\t\t\t\tid: this.idService.newGuid(),\r\n\t\t\t\tstakeholderType: StakeholderType.SOKANDE,\r\n\t\t\t\tcustomerId: login.ssn,\r\n\t\t\t\tfirstName: login.firstName,\r\n\t\t\t\tlastName: login.lastName\r\n\t\t\t}]\r\n\t\t}\r\n\t\tthis.addNewCustomerToCase(c, login.ssn);\r\n\t\tthis.addCaseToStateCases(c);\r\n\t\treturn Promise.resolve(c);\r\n\t}\r\n\r\n\t// Checks if case originates from database.\r\n\tisServerCase(c: Case): boolean {\r\n\t\treturn c.number ? true : false;\r\n\t}\r\n\r\n\tprivate addCaseOnServer(cases: Case[]): Promise {\r\n\t\tif (!this.stateService.state.session || !this.stateService.state.session.login)\r\n\t\t\tthrow new Error(\"No session and login.\");\r\n\r\n\t\tlet login = this.stateService.state.session.login;\r\n\t\tconst customerId = login.ssn;\r\n\r\n\t\t// Create process on server.\r\n\t\tlet processId = this.idService.newGuid();\r\n\t\tlet promise = this.smelpoService.addProcess({\r\n\t\t\tprocessId: processId,\r\n\t\t}, customerId).then(result => {\r\n\t\t\t// Attach process from server as case on client. \r\n\t\t\tconst process = result.data;\r\n\t\t\tconst processId = process.processId;\r\n\t\t\treturn this.loadCase(processId);\r\n\t\t});\r\n\r\n\t\treturn promise;\r\n\t}\r\n\r\n\tcanDeleteCase(c: Case): boolean {\r\n\t\treturn c.status && c.status === CaseIdStatus.STARTEDBYAPPLICANT ? true : false;\r\n\t}\r\n\r\n\tdeleteCase(cases: Case[], c: Case): Promise {\r\n\t\tif (this.isServerCase(c)) {\r\n\t\t\treturn this.smelpoService\r\n\t\t\t\t.deleteCase(c.id, c.lpCaseId || '', UpdateProcessStatusCaseIdStatusEnum.CLOSEDBYAPPLICANT)\r\n\t\t\t\t.then(result => {\r\n\t\t\t\t\tthis.removeCaseFromCases(cases, c);\r\n\t\t\t\t\treturn c;\r\n\t\t\t\t});\r\n\t\t} else {\r\n\t\t\tthis.removeCaseFromCases(cases, c);\r\n\t\t\treturn Promise.resolve(c);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate removeCaseFromCases(cases: Case[], c: Case): void {\r\n\t\tthis.stateService.listRemove(cases, c);\r\n\t\tthis.stateService.updateState();\r\n\t}\r\n\r\n\tvalidateCase(c: Case): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tif (c.applicants) {\r\n\t\t\tc.applicants.forEach(applicant => {\r\n\t\t\t\tvr.addResult(this.applicantService.validateApplicant(applicant));\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tsendInApplication(c: Case): Promise {\r\n\t\treturn this.smelpoService\r\n\t\t\t.setCaseStatus(c.id, c.lpCaseId || '', UpdateProcessStatusCaseIdStatusEnum.READYFOROFFICER)\r\n\t\t\t.then(x => {\r\n\t\t\t\tc.status = CaseIdStatus.READYFOROFFICER;\r\n\t\t\t\tthis.stateService.update(c);\r\n\t\t\t\treturn c;\r\n\t\t\t});\r\n\t}\r\n\r\n\tprivate saveCaseToServer(c: Case): Promise {\r\n\t\tlet process = SmeModelConverter.toFullProcess(c);\r\n\t\treturn this.smelpoService\r\n\t\t\t.saveProcess(process)\r\n\t\t\t.then(result => {\r\n\t\t\t\treturn c;\r\n\t\t\t});\r\n\t}\r\n\r\n\tprivate moveDataFromCreatedServerCaseToClientCase(clientCase: Case, serverCase: Case) {\r\n\t\tconst cc = clientCase;\r\n\t\tconst sc = serverCase;\r\n\r\n\t\tcc.id = sc.id;\r\n\t\tcc.number = sc.number;\r\n\t\tcc.status = sc.status;\r\n\t\tcc.createdDate = sc.createdDate;\r\n\t\tcc.lastAccessedDate = sc.lastAccessedDate;\r\n\t\tcc.customers = sc.customers;\r\n\t\tif (cc.applicants && sc.applicants) {\r\n\t\t\tconst cca = cc.applicants[0];\r\n\t\t\tconst csa = sc.applicants[0];\r\n\t\t\tcca.id = csa.id;\r\n\t\t\tif (csa.firstName)\r\n\t\t\t\tcca.firstName = csa.firstName;\r\n\t\t\tif (csa.lastName)\r\n\t\t\t\tcca.lastName = csa.lastName;\r\n\t\t\tcca.postalAddress = csa.postalAddress;\r\n\t\t\tcca.postalCode = csa.postalCode;\r\n\t\t\tcca.streetAddress = csa.streetAddress;\r\n\t\t}\r\n\r\n\t\tthis.update(cc);\r\n\t}\r\n\r\n\tsaveCase(c: Case): Promise {\r\n\t\tlet promise: Promise;\r\n\t\tif (!this.isServerCase(c)) {\r\n\t\t\t// Create case on server and then save.\r\n\t\t\tif (!this.stateService.state.cases)\r\n\t\t\t\tthis.stateService.state.cases = [];\r\n\t\t\tpromise = this.addCaseOnServer(this.stateService.state.cases)\r\n\t\t\t\t.then(result => {\r\n\t\t\t\t\t// Merge data from created case to client case.\r\n\t\t\t\t\tthis.moveDataFromCreatedServerCaseToClientCase(c, result);\r\n\t\t\t\t\t// Perform proper save.\r\n\t\t\t\t\treturn this.saveCaseToServer(c);\r\n\t\t\t\t}).then(result => {\r\n\t\t\t\t\t// Return original client case but with updated data.\r\n\t\t\t\t\treturn c;\r\n\t\t\t\t})\r\n\t\t} else {\r\n\t\t\t// Case already exists on server. Just save. \r\n\t\t\tpromise = this.saveCaseToServer(c);\r\n\t\t}\r\n\r\n\t\t// After saving, always do this.\r\n\t\treturn promise.then((result: Case) => {\r\n\t\t\tthis.setApplicantsApprovalAsSavedToDB(c.applicants)\r\n\t\t\treturn result;\r\n\t\t});\r\n\t}\r\n\r\n\tsetApplicantsApprovalAsSavedToDB(applicants: Applicant[] | undefined) {\r\n\t\tif (!applicants)\r\n\t\t\treturn;\r\n\t\tapplicants.forEach(x => {\r\n\t\t\tif (x.kyc) {\r\n\t\t\t\tconst kyc = x.kyc;\r\n\t\t\t\tkyc.approvedCreditCheckDB = kyc.approvedCreditCheck;\r\n\t\t\t\tkyc.approvedInfoHandlingDB = kyc.approvedInfoHandling;\r\n\t\t\t\tkyc.approvedInfoSharingDB = kyc.approvedInfoSharing;\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\r\n\tcanSaveCase(c: Case): boolean {\r\n\t\tconst hasApproval = this.applicantService.allApplicantsHaveGivenFullApproval(c);\r\n\t\treturn hasApproval;\r\n\t}\r\n\r\n\tprivate later(delay: number, value: T): Promise {\r\n\t\treturn new Promise(function (resolve) {\r\n\t\t\tsetTimeout(function () {\r\n\t\t\t\tresolve(value);\r\n\t\t\t}, delay);\r\n\t\t});\r\n\t}\r\n\r\n\tprivate loadCase = async (processId: string): Promise => {\r\n\t\tconst x = await this.smelpoService.getProcess(processId);\r\n let linksAll = x.data;\r\n let c = LpoModelConverter.linksAllToCase(linksAll);\r\n\r\n if (this.attachmentService)\r\n this.attachmentService.ensureCorrectAttachmentRequests(c);\r\n\r\n return c;\r\n\t}\r\n\r\n\tprivate addCaseToStateCases = (c: Case) => {\r\n\t\tconst state = this.stateService.state;\r\n\t\tif (!state.cases) {\r\n\t\t\tstate.cases = [c];\r\n\t\t} else {\r\n\t\t\tstate.cases.push(c);\r\n\t\t}\r\n\t\tthis.stateService.update(state.cases);\r\n\t\tthis.stateService.updateState();\r\n\t}\r\n\r\n\tprivate addCasesToStateCases = (cases: Case[]) => {\r\n\t\tconst state = this.stateService.state;\r\n\t\tif (cases && cases.length > 0) {\r\n\t\t\tcases.sort((a, b) => {\r\n\t\t\t\tif (a.number < b.number)\r\n\t\t\t\t\treturn -1;\r\n\t\t\t\telse\r\n\t\t\t\t\treturn 1;\r\n\t\t\t})\r\n\t\t\tif (!state.cases) {\r\n\t\t\t\tstate.cases = cases;\r\n\t\t\t} else {\r\n\t\t\t\tstate.cases.length = 0;\r\n\t\t\t\tstate.cases.splice(0, 0, ...cases);\r\n\t\t\t}\r\n\t\t\tthis.stateService.update(state.cases);\r\n\t\t\tthis.stateService.updateState();\r\n\t\t}\r\n\t}\r\n\r\n\tloadCases = (): Promise => {\r\n\t\treturn this.getMyCases().then(cases => {\r\n\t\t\tthis.addCasesToStateCases(cases);\r\n\t\t\treturn cases;\r\n\t\t})\r\n\t}\r\n\r\n\tappendKycStatusToCases = async (cases: Case[]): Promise => {\r\n\t\tawait Promise.all(cases.map(async (c) => {\r\n\t\t\tif (this.kycService) {\r\n\t\t\t\tconst x = await this.kycService.getKycForCase(c);\r\n\t\t\t\tc.kycApplicantsStatus = x.applicants;\r\n\t\t\t}\r\n\t\t}));\r\n\t\t\r\n\t\tthis.stateService.update(cases);\r\n\t\tthis.stateService.updateState();\r\n\t\t\r\n\t\treturn cases;\r\n\t};\r\n\r\n\tprivate getMyCases = (): Promise => {\r\n\t\tif (this.stateService.state.session && this.stateService.state.session.login) {\r\n\t\t\tlet mySSN = this.stateService.state.session.login.ssn;\r\n\r\n\t\t\tvar promise = new Promise((resolve, reject) => {\r\n\r\n\t\t\t\tthis.smelpoService.getProcesses(mySSN)\r\n\t\t\t\t\t.then(x => {\r\n\t\t\t\t\t\tif (x.data.processes) {\r\n\t\t\t\t\t\t\tlet cases: Case[] = [];\r\n\t\t\t\t\t\t\tlet fails = 0;\r\n\t\t\t\t\t\t\tlet processes = x.data.processes || [];\r\n\t\t\t\t\t\t\tprocesses.forEach(process => {\r\n\t\t\t\t\t\t\t\tthis.loadCase(process.processId)\r\n\t\t\t\t\t\t\t\t\t.then(c => {\r\n\t\t\t\t\t\t\t\t\t\tif(c.status === \"STARTEDBYAPPLICANT\" || c.status === \"READYFOROFFICER\" && !c.lpCaseId) {\r\n\t\t\t\t\t\t\t\t\t\t\tif(c.applicants) {\r\n\t\t\t\t\t\t\t\t\t\t\t\tfor(let i = 0; i < c.applicants.length; i++) {\r\n\t\t\t\t\t\t\t\t\t\t\t\t\tif(c.applicants[i].kyc)\t{\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tc.applicants[i].kyc!.isAmericanCitizen = undefined;\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tc.applicants[i].kyc!.isCrsTaxObligated = undefined;\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tc.applicants[i].kyc!.isPep = undefined;\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tc.applicants[i].kyc!.isPepRelated = undefined;\r\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\t\t\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\t\tcases.push(c);\r\n\t\t\t\t\t\t\t\t\t\tif (fails + cases.length === processes.length)\r\n\t\t\t\t\t\t\t\t\t\t\tresolve(cases);\r\n\t\t\t\t\t\t\t\t\t}, () => {\r\n\t\t\t\t\t\t\t\t\t\tfails++;\r\n\t\t\t\t\t\t\t\t\t\tif (fails + cases.length === processes.length) {\r\n\t\t\t\t\t\t\t\t\t\t\tif (cases.length > 0)\r\n\t\t\t\t\t\t\t\t\t\t\t\tresolve(cases);\r\n\t\t\t\t\t\t\t\t\t\t\telse\r\n\t\t\t\t\t\t\t\t\t\t\t\treject(cases);\r\n\t\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t\treturn cases;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\treturn [];\r\n\t\t\t\t\t});\r\n\r\n\t\t\t});\r\n\r\n\t\t\treturn (promise as Promise);\r\n\t\t}\r\n\t\telse {\r\n\t\t\treturn Promise.resolve([]);\r\n\t\t}\r\n\t}\r\n\r\n\t// === ADMIN =======\r\n\r\n\r\n\tadminDeleteCase(cases: Case[], c: Case): Promise {\r\n\t\treturn this.smelpoService\r\n\t\t\t.deleteCase(c.id, c.lpCaseId || '', UpdateProcessStatusCaseIdStatusEnum.CLOSEDBYTHINNING)\r\n\t\t\t.then(result => {\r\n\t\t\t\tthis.stateService.listRemove(cases, c);\r\n\t\t\t\tthis.stateService.updateState();\r\n\t\t\t\treturn c;\r\n\t\t\t});\r\n\t}\r\n\r\n\tadminMarkCaseAsHandled(c: Case): Promise {\r\n\t\treturn this.smelpoService\r\n\t\t\t.setCaseStatus(c.id, c.lpCaseId || '', UpdateProcessStatusCaseIdStatusEnum.CLOSEDBYOFFICER)\r\n\t\t\t.then(result => {\r\n\t\t\t\tthis.stateService.updateState();\r\n\t\t\t\treturn c;\r\n\t\t\t});\r\n\t}\r\n\r\n\tadminSearchCases(search: AdminCasesSearch): Promise {\r\n\t\treturn this.smelpoService.adminSearchProcesses(search)\r\n\t\t\t.then(result => {\r\n\t\t\t\tconst cases = result.cases.map(x => {\r\n\t\t\t\t\t// UGLY REMAPPING b/c of casing differences.\r\n\t\t\t\t\t//let json = JSON.stringify(x);\r\n\t\t\t\t\tlet goodLinksAll = LinksAllFromJSON(x);\r\n\t\t\t\t\tlet c = LpoModelConverter.linksAllToCase(goodLinksAll);\r\n\t\t\t\t\treturn c;\r\n\t\t\t\t});\r\n\t\t\t\treturn cases;\r\n\t\t\t})\r\n\t}\r\n\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { Case, KYC, Household, AttachmentRequest, Attachment, Collateral } from '../models/SelmaModels';\r\nimport { Applicant } from \"../models/selmamodels/Applicant\";\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { GuardService } from './GuardService';\r\nimport { IdService } from './IdService';\r\nimport { Company } from '../models/selmamodels/Company';\r\nimport { LpoModelConverter } from '../models/LpoModelConverter';\r\nimport { ConfigurationService } from './ConfigurationService';\r\nimport { StakeholderType, CustomerIdType } from '../libs/SMELPOClient';\r\nimport { CompanyService } from './CompanyService';\r\nimport { SearchApplicantResult } from '../models/extendedlpo/ApplicantSearch';\r\nimport { HouseholdService } from './HouseholdService';\r\nexport interface SearchForApplicantResult {\r\n\tapplicant?: Applicant;\r\n\tcompanies?: Company[];\r\n\ttooManyRequests: boolean\r\n}\r\n\r\nexport class ApplicantService extends BaseService {\r\n\r\n\tcompanyService?: CompanyService;\r\n\thouseholdService?: HouseholdService;\r\n\r\n\tconstructor(private stateService: StateService, private smelpoService: SMELPOService,\r\n\t\tprivate guardService: GuardService, private idService: IdService,\r\n\t\tprivate configurationService: ConfigurationService) {\r\n\t\tsuper();\r\n\t}\r\n\r\n\tupdate(obj: Applicant | KYC | Case): void {\r\n\t\tthis.stateService.update(obj);\r\n\t}\r\n\r\n\r\n\tnewApplicant(c: Case, ssn: string): Applicant {\r\n\t\tlet applicant: Applicant = {\r\n\t\t\tid: this.idService.newGuid(),\r\n\t\t\tcustomerId: ssn,\r\n\t\t};\r\n\t\treturn applicant;\r\n\t}\r\n\r\n\tnewKyc(): KYC {\r\n\t\treturn {\r\n\t\t\tid: this.idService.newGuid(),\r\n\t\t\tapprovedCreditCheck: false,\r\n\t\t\tapprovedInfoHandling: false,\r\n\t\t\tapprovedInfoSharing: false\r\n\t\t}\r\n\t}\r\n\r\n\tensureKyc(applicant: Applicant): KYC {\r\n\t\tif (applicant.kyc) {\r\n\t\t\treturn applicant.kyc;\r\n\t\t} else {\r\n\t\t\tconst kyc = this.newKyc();\r\n\t\t\tapplicant.kyc = kyc;\r\n\t\t\tthis.update(applicant);\r\n\t\t\treturn kyc;\r\n\t\t}\r\n\r\n\t}\r\n\r\n\taddApplicant(c: Case, applicant: Applicant): Applicant {\r\n\t\tif (!c.applicants) {\r\n\t\t\tc.applicants = [applicant];\r\n\t\t\tthis.ensureCustomer(c, applicant.customerId);\r\n\t\t\tthis.afterApplicantChange(c);\r\n\t\t\tthis.update(c);\r\n\t\t\treturn applicant;\r\n\t\t} else {\r\n\t\t\tthis.ensureCustomer(c, applicant.customerId);\r\n\t\t\tlet existingApplicant = this.getApplicantBySsn(c, applicant.customerId);\r\n\t\t\tif (existingApplicant) {\r\n\t\t\t\treturn existingApplicant;\r\n\t\t\t} else {\r\n\t\t\t\tc.applicants.push(applicant);\r\n\t\t\t\tthis.afterApplicantChange(c);\r\n\t\t\t\tthis.update(c);\r\n\t\t\t\treturn applicant;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tgetCustomer(c: Case, customerId: string): CustomerIdType | undefined {\r\n\t\tif (!c.customers)\r\n\t\t\treturn;\r\n\t\tlet r = c.customers.find(x => { return this.guardService.compareCustomerId(x.customerId || '', customerId) });\r\n\t\treturn r;\r\n\t}\r\n\r\n\tensureCustomer(c: Case, customerId: string): void {\r\n\t\tif (!c.customers)\r\n\t\t\tc.customers = [];\r\n\t\tlet customer = this.getCustomer(c, customerId);\r\n\t\tif (!customer) {\r\n\t\t\tc.customers.push({\r\n\t\t\t\tcustomerId: customerId,\r\n\t\t\t\tcustomerAdded: new Date().toUTCString()\r\n\t\t\t});\r\n\t\t\tthis.update(c);\r\n\t\t}\r\n\t}\r\n\r\n\tremoveCustomer(c: Case, customerId: string): void {\r\n\t\tlet customer = this.getCustomer(c, customerId);\r\n\t\tif (customer) {\r\n\t\t\tthis.stateService.listRemove(c.customers, customer);\r\n\t\t}\r\n\t}\r\n\r\n\thasApplicants(c: Case): boolean {\r\n\t\tif (c.applicants && c.applicants.length > 0)\r\n\t\t\treturn true;\r\n\t\treturn false;\r\n\t}\r\n\r\n\tgetApplicants(c: Case): Applicant[] {\r\n\t\tif (!c.applicants)\r\n\t\t\treturn [];\r\n\t\treturn c.applicants;\r\n\t}\r\n\r\n\tgetPhysicumApplicants(c: Case): Applicant[] {\r\n\t\tlet applicants = this.getApplicants(c);\r\n\t\tif (applicants.length === 0)\r\n\t\t\treturn applicants;\r\n\r\n\t\tlet r = applicants.filter(x => {\r\n\t\t\tlet isPP = this.isPhysicum(c, x);\r\n\t\t\treturn isPP;\r\n\t\t});\r\n\t\treturn r;\r\n\t}\r\n\r\n\tsetWillBuyAgriForestryProperty(c: Case, applicant: Applicant, checked: boolean) {\r\n\t\tif (applicant.willBuyAgriForestryProperty === checked)\r\n\t\t\treturn;\r\n\r\n\t\tapplicant.willBuyAgriForestryProperty = checked;\r\n\r\n\t\tif (checked) {\r\n\t\t\t// Remove current selected company, if any.\r\n\t\t\tconst companyService = this.companyService;\r\n\t\t\tif (companyService) {\r\n\t\t\t\tconst company = companyService.getApplicantCompany(c, applicant);\r\n\t\t\t\tif (company) {\r\n\t\t\t\t\tcompanyService.removeCompany(c, company);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\tthis.afterApplicantChange(c);\r\n\t\tthis.update(applicant);\r\n\t}\r\n\r\n\tvalidateMyApplicantKycApproval(c: Case): ValidationResult {\r\n\t\tlet myApplicant = this.getMyApplicant(c);\r\n\t\treturn this.validateApplicantKycApproval(myApplicant);\r\n\t}\r\n\tvalidateApplicantKycApproval(applicant: Applicant): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tvr.add({ validator: this.hasKycApprovedCreditCheck, object: applicant, ok: this.hasKycApprovedCreditCheck(applicant) });\r\n\t\tvr.add({ validator: this.hasKycApprovedInfoHandling, object: applicant, ok: this.hasKycApprovedInfoHandling(applicant) });\r\n\t\tvr.add({ validator: this.hasKycApprovedInfoSharing, object: applicant, ok: this.hasKycApprovedInfoSharing(applicant) });\r\n\t\treturn vr;\r\n\t}\r\n\r\n\thasKycApprovedCreditCheck(applicant: Applicant): boolean {\r\n\t\treturn applicant && applicant.kyc && applicant.kyc.approvedCreditCheck ? true : false;\r\n\t}\r\n\thasKycApprovedInfoHandling(applicant: Applicant): boolean {\r\n\t\treturn applicant && applicant.kyc && applicant.kyc.approvedInfoHandling ? true : false;\r\n\t}\r\n\thasKycApprovedInfoSharing(applicant: Applicant): boolean {\r\n\t\treturn applicant && applicant.kyc && applicant.kyc.approvedInfoSharing ? true : false;\r\n\t}\r\n\r\n\tmyApplicantHasGivenFullApproval(c: Case): boolean {\r\n\t\tlet applicant = this.getMyApplicant(c);\r\n\t\tif (!applicant || !applicant.kyc)\r\n\t\t\treturn false;\r\n\r\n\t\treturn this.applicantHasGivenFullApproval(applicant);\r\n\t}\r\n\r\n\tapplicantHasGivenFullApproval(applicant: Applicant): boolean {\r\n\t\tlet kyc = applicant.kyc;\r\n\t\tif (!kyc)\r\n\t\t\treturn false;\r\n\t\treturn kyc.approvedCreditCheck === true\r\n\t\t\t&& kyc.approvedInfoHandling === true\r\n\t\t\t&& kyc.approvedInfoSharing === true;\r\n\t}\r\n\r\n\tallApplicantsHaveGivenFullApproval(c: Case): boolean {\r\n\t\tif (!c.applicants) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\tfor (let applicant of c.applicants) {\r\n\t\t\tif (applicant && !this.applicantHasGivenFullApproval(applicant)) {\r\n\t\t\t\treturn false;\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n\r\n\tgetApplicantByCustomerId(c: Case, customerId: string): Applicant | undefined {\r\n\t\tif (!c.applicants)\r\n\t\t\treturn;\r\n\r\n\t\tlet applicants = c.applicants.filter(x => x.customerId === customerId);\r\n\t\tif (applicants && applicants.length === 1)\r\n\t\t\treturn applicants[0];\r\n\t\telse\r\n\t\t\treturn;\r\n\t}\r\n\r\n\tgetApplicantBySsn(c: Case, ssn: string): Applicant | undefined {\r\n\t\tif (!c.applicants)\r\n\t\t\treturn;\r\n\t\tconst g = this.guardService;\r\n\t\tlet applicants = c.applicants.filter(x => x.customerId && g.compareSsn(x.customerId, ssn))\r\n\t\tif (applicants && applicants.length === 1)\r\n\t\t\treturn applicants[0];\r\n\t\telse\r\n\t\t\treturn;\r\n\t}\r\n\r\n\tgetMyApplicant(c: Case): Applicant {\r\n\t\tif (!c.applicants)\r\n\t\t\tthrow new Error(\"No applicants on case.\");\r\n\r\n\t\tif (!this.stateService.state.session || !this.stateService.state.session.login)\r\n\t\t\tthrow new Error(\"No session and login.\");\r\n\r\n\t\tlet login = this.stateService.state.session.login;\r\n\t\tlet applicant = this.getApplicantBySsn(c, login.ssn);\r\n\t\tif (!applicant)\r\n\t\t\tthrow new Error(\"No my applicant.\");\r\n\t\treturn applicant;\r\n\t}\r\n\r\n\tgetMainApplicant(c: Case): Applicant {\r\n\t\tif (!c.applicants)\r\n\t\t\tthrow new Error(\"No main applicant on case (no applicants).\");\r\n\r\n\t\tif (c.applicants.length === 1)\r\n\t\t\treturn c.applicants[0];\r\n\r\n\t\tlet customer: CustomerIdType | undefined;\r\n\r\n\t\tc.customers.forEach(x => {\r\n\t\t\tif (!customer)\r\n\t\t\t\tcustomer = x;\r\n\t\t\telse if (x.customerAdded && customer.customerAdded\r\n\t\t\t\t&& x.customerAdded < customer.customerAdded) {\r\n\t\t\t\tcustomer = x;\r\n\t\t\t}\r\n\t\t})\r\n\r\n\t\tlet applicant = customer && customer.customerId\r\n\t\t\t? this.getApplicantBySsn(c, customer.customerId) : undefined;\r\n\r\n\t\tif (!applicant)\r\n\t\t\tthrow new Error(\"No main applicant on case.\");\r\n\r\n\t\treturn applicant;\r\n\t}\r\n\r\n\r\n\tremoveApplicant = (c: Case, applicant: Applicant): void => {\r\n\t\tif (!c.applicants)\r\n\t\t\treturn;\r\n\r\n\t\tconst g = this.guardService;\r\n\t\tthis.stateService.listRemove(c.applicants, applicant);\r\n\r\n\t\tthis.removeCustomer(c, applicant.customerId);\r\n\r\n\t\t// Remove applicant from households.\r\n\t\tif (c.households) {\r\n\t\t\tlet householdsToRemove: Household[] = [];\r\n\t\t\tc.households.forEach(hh => {\r\n\t\t\t\tif (hh.members) {\r\n\t\t\t\t\tlet member = hh.members.find(x => { return g.compareCustomerId(x.householdMember || '', applicant.customerId); });\r\n\t\t\t\t\tif (member) {\r\n\t\t\t\t\t\tthis.stateService.listRemove(hh.members, member);\r\n\t\t\t\t\t\tif (hh.members.length === 0) {\r\n\t\t\t\t\t\t\thouseholdsToRemove.push(hh); // household lost its only member.\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t})\r\n\r\n\t\t\t// Remove households that lost their last member.\r\n\t\t\thouseholdsToRemove.forEach(x => {\r\n\t\t\t\tif (this.householdService)\r\n\t\t\t\t\tthis.householdService.removeHousehold(c, x);\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\t// Remove applicant from extloans.\r\n\t\tif (c.extLoans) {\r\n\t\t\tc.extLoans.forEach(x => {\r\n\t\t\t\tif (x.loanOwners) {\r\n\t\t\t\t\tlet loanOwner = x.loanOwners.find(o => { return g.compareCustomerId(o.customerId, applicant.customerId); });\r\n\t\t\t\t\tif (loanOwner) {\r\n\t\t\t\t\t\tthis.stateService.listRemove(x.loanOwners, loanOwner);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t}\r\n\r\n\t\t// Remove applicant from maintenance cost/house.\r\n\t\tif (c.maintenanceCosts) {\r\n\t\t\tc.maintenanceCosts.forEach(x => {\r\n\t\t\t\tif (x.typeofhouses) {\r\n\t\t\t\t\tx.typeofhouses.forEach(h => {\r\n\t\t\t\t\t\tif (h.loanOwners) {\r\n\t\t\t\t\t\t\tlet loanOwner = h.loanOwners.find(o => { return g.compareCustomerId(o.customerId, applicant.customerId); });\r\n\t\t\t\t\t\t\tif (loanOwner) {\r\n\t\t\t\t\t\t\t\tthis.stateService.listRemove(h.loanOwners, loanOwner);\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t})\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t}\r\n\r\n\t\t// Remove attachments.\r\n\t\tif (c.attachments) {\r\n\t\t\tlet remove: Attachment[] = [];\r\n\t\t\tc.attachments.forEach(x => {\r\n\t\t\t\tif (x.customerId && g.compareCustomerId(x.customerId, applicant.customerId)) {\r\n\t\t\t\t\tremove.push(x);\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t\tremove.forEach(x => {\r\n\t\t\t\tif (c.attachments)\r\n\t\t\t\t\tthis.stateService.listRemove(c.attachments, x);\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\t// Remove attachment requests.\r\n\t\tif (c.attachmentRequests) {\r\n\t\t\tlet remove: AttachmentRequest[] = [];\r\n\t\t\tc.attachmentRequests.forEach(x => {\r\n\t\t\t\tif (x.customerId && g.compareCustomerId(x.customerId, applicant.customerId)) {\r\n\t\t\t\t\tremove.push(x);\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t\tremove.forEach(x => {\r\n\t\t\t\tif (c.attachmentRequests)\r\n\t\t\t\t\tthis.stateService.listRemove(c.attachmentRequests, x);\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\t// Remove collateral estate of applicant.\r\n\t\tif (c.collaterals) {\r\n\t\t\tlet remove: Collateral[] = [];\r\n\t\t\tc.collaterals.forEach(x => {\r\n\t\t\t\tif (x.customerId && g.compareCustomerId(x.customerId, applicant.customerId)) {\r\n\t\t\t\t\tremove.push(x);\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t\tremove.forEach(x => {\r\n\t\t\t\tif (c.collaterals)\r\n\t\t\t\t\tthis.stateService.listRemove(c.collaterals, x);\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\t// Remove company connected to applicant, and all its related data.\r\n\t\tif (this.companyService) {\r\n\t\t\tlet company = this.companyService.getApplicantCompany(c, applicant);\r\n\t\t\tif (company) {\r\n\t\t\t\tthis.companyService.removeCompany(c, company);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tthis.afterApplicantChange(c);\r\n\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\t// Perform changes after set of applicants changed.\r\n\tprivate afterApplicantChange(c: Case): void {\r\n\t\tconst householdService = this.householdService;\r\n\t\tif (householdService) {\r\n\t\t\tconst shouldHaveHouseholds = householdService.shouldHaveHouseholds(c);\r\n\t\t\tif (shouldHaveHouseholds)\r\n\t\t\t\thouseholdService.ensureHouseholds(c);\r\n\t\t\telse {\r\n\t\t\t\thouseholdService.removeAllHouseholds(c);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tcanRemoveApplicant(c: Case, applicant: Applicant) {\r\n\t\tconst myApplicant = this.getMyApplicant(c);\r\n\t\tconst mainApplicant = this.getMainApplicant(c);\r\n\t\tconst isMe = applicant === myApplicant;\r\n\t\tconst isMain = applicant === mainApplicant;\r\n\t\tconst canNotDelete = isMe || isMain || !c.applicants || c.applicants.length <= 1;\r\n\t\tconst canDelete = !canNotDelete;\r\n\t\treturn canDelete;\r\n\t}\r\n\r\n\r\n\tgetFullName(c: Case, applicant: Applicant): string {\r\n\t\tif (this.companyService) {\r\n\t\t\tconst company = this.companyService.getApplicantCompany(c, applicant);\r\n\t\t\tif (company) {\r\n\t\t\t\treturn this.companyService.getDisplayName(company)\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn this.getPersonFullName(applicant);\r\n\t}\r\n\r\n\tgetPersonFullName(applicant: Applicant): string {\r\n\t\tlet name = applicant.firstName;\r\n\t\tif (!name || name.length === 0)\r\n\t\t\tname = applicant.lastName;\r\n\t\telse if (applicant.lastName && applicant.lastName.length > 0)\r\n\t\t\tname = name + \" \" + applicant.lastName;\r\n\t\tif (!name)\r\n\t\t\tname = \"\";\r\n\t\treturn name;\r\n\t}\r\n\r\n\tvalidateApplicant(applicant: Applicant): ValidationResult {\r\n\t\tconst g = this.guardService;\r\n\t\tlet vf = this.validateApplicant;\r\n\t\tlet vr = new ValidationResult();\r\n\t\tvr.add({ validator: vf, ok: g.hasValue(applicant.customerId) });\r\n\t\tvr.add({ validator: vf, ok: g.hasValue(applicant.firstName) });\r\n\t\tvr.add({ validator: vf, ok: g.hasValue(applicant.lastName) });\r\n\t\treturn vr;\r\n\t}\r\n\r\n\r\n\r\n\tvalidateApplicantContact(applicant: Applicant): ValidationResult {\r\n\r\n\t\t// TODO: Only if applicant is P or EF, not AB.\r\n\r\n\t\tlet vr = new ValidationResult();\r\n\t\tvr.add({ validator: this.hasValidEmail, object: applicant, ok: this.hasValidEmail(applicant) });\r\n\t\tvr.add({ validator: this.hasMatchingConfirmEmail, object: applicant, ok: this.hasMatchingConfirmEmail(applicant) });\r\n\t\tvr.add({ validator: this.hasValidMobilePhone, object: applicant, ok: this.hasValidMobilePhone(applicant) });\r\n\t\treturn vr;\r\n\t}\r\n\r\n\thasValidEmail(applicant: Applicant): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn applicant.email && g.isValidEmail(applicant.email) ? true : false;\r\n\t}\r\n\r\n\thasMatchingConfirmEmail(applicant: Applicant): boolean {\r\n\t\tif (!applicant.email && !applicant.emailConfirm)\r\n\t\t\treturn true;\r\n\r\n\t\tlet a = applicant.email || '';\r\n\t\tlet b = applicant.emailConfirm || '';\r\n\r\n\t\treturn a.toLowerCase() === b.toLowerCase();\r\n\t}\r\n\r\n\thasValidMobilePhone(applicant: Applicant): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn applicant.mobilePhone && g.isValidMobileNumber(applicant.mobilePhone) ? true : false;\r\n\t}\r\n\r\n\treformatMobilePhone(applicant: Applicant):void {\r\n\t\tconst numericMobilePhone = applicant.mobilePhone?.replace(/\\D/g, '') ?? '';\r\n\r\n\t\tif (numericMobilePhone.length === 10) {\r\n\t\t\tapplicant.mobilePhone = numericMobilePhone.slice(0, 3) + '-' + numericMobilePhone.slice(3);\r\n\t\t\tthis.update(applicant);\r\n\t\t}\r\n\t}\r\n\r\n\tvalidateApplicantPep(applicant: Applicant): ValidationResult {\r\n\t\t// TODO: Only if applicant is P or EF, not AB.\r\n\t\tlet vr = new ValidationResult();\r\n\t\tvr.add({ validator: this.hasKycPep, object: applicant, ok: this.hasKycPep(applicant) });\r\n\t\tvr.add({ validator: this.hasKycPepRelated, object: applicant, ok: this.hasKycPepRelated(applicant) });\r\n\t\tvr.add({ validator: this.hasKycAmericanCitizen, object: applicant, ok: this.hasKycAmericanCitizen(applicant) });\r\n\t\tvr.add({ validator: this.hasKycCrsTaxObligation, object: applicant, ok: this.hasKycCrsTaxObligation(applicant) });\r\n\t\treturn vr;\r\n\t}\r\n\r\n\thasKycPep(applicant: Applicant): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn applicant.kyc && g.hasValue(applicant.kyc.isPep) ? true : false\r\n\t}\r\n\r\n\thasKycPepRelated(applicant: Applicant): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn applicant.kyc && g.hasValue(applicant.kyc.isPepRelated) ? true : false\r\n\t}\r\n\r\n\thasKycAmericanCitizen(applicant: Applicant): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn applicant.kyc && g.hasValue(applicant.kyc.isAmericanCitizen) ? true : false\r\n\t}\r\n\r\n\thasKycCrsTaxObligation(applicant: Applicant): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn applicant.kyc && g.hasValue(applicant.kyc.isCrsTaxObligated) ? true : false\r\n\t}\r\n\r\n\thasSelectedHighRiskCategory(applicant: Applicant): boolean {\r\n\t\treturn applicant &&\r\n\t\t\tapplicant.kyc !== undefined &&\r\n\t\t\tthis.guardService.hasValue(applicant.kyc.highRiskCategoryCode);\r\n\t}\r\n\r\n\thasSelectedHighRiskCategoryAndItIsRisky(applicant: Applicant): boolean {\r\n\t\tlet highRiskCategoryCode = this.getHighRiskCategory(applicant);\r\n\t\treturn highRiskCategoryCode && highRiskCategoryCode !== '0' ? true : false;\r\n\t}\r\n\r\n\tgetHighRiskCategory(applicant: Applicant): string | undefined {\r\n\t\treturn applicant && applicant.kyc && applicant.kyc.highRiskCategoryCode;\r\n\t}\r\n\r\n\tvalidateHasSelectedHighRiskCategory(applicant: Applicant): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tvr.add({ validator: this.hasSelectedHighRiskCategory, object: applicant, ok: this.hasSelectedHighRiskCategory(applicant) });\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tclearHighRiskCategory(applicant: Applicant): void {\r\n\t\tif (applicant &&\r\n\t\t\tapplicant.kyc !== undefined &&\r\n\t\t\tthis.guardService.hasValue(applicant.kyc.highRiskCategoryCode)) {\r\n\t\t\tapplicant.kyc.highRiskCategoryCode = undefined;\r\n\t\t\tthis.update(applicant);\r\n\t\t\tthis.update(applicant.kyc);\r\n\t\t}\r\n\t}\r\n\r\n\tselectHighRiskCategory(applicant: Applicant, value: string) {\r\n\t\tif (!applicant.kyc)\r\n\t\t\tapplicant.kyc = this.newKyc();\r\n\t\tif (applicant.kyc) {\r\n\t\t\tapplicant.kyc.highRiskCategoryCode = value;\r\n\t\t\tthis.update(applicant);\r\n\t\t\tthis.update(applicant.kyc);\r\n\t\t}\r\n\t}\r\n\r\n\ttoSearchForApplicantResult(result: SearchApplicantResult): SearchForApplicantResult {\r\n\t\tlet r: SearchForApplicantResult = {\r\n\t\t\tapplicant: LpoModelConverter.toApplicantOrUndefined(result.applicant),\r\n\t\t\tcompanies: LpoModelConverter.toCompanies(result.companies),\r\n\t\t\ttooManyRequests: false\r\n\t\t}\r\n\t\treturn r;\r\n\t}\r\n\r\n\tsearchForApplicant(c: Case, ssnOrOrgNumber: string): Promise {\r\n\t\treturn this.smelpoService\r\n\t\t\t.searchApplicant(c.id, ssnOrOrgNumber)\r\n\t\t\t.then(result => {\r\n\t\t\t\tlet r = this.toSearchForApplicantResult(result);\r\n\t\t\t\treturn r;\r\n\t\t\t});\r\n\t}\r\n\r\n\tisPhysicum(c: Case, applicant: Applicant): boolean {\r\n\t\tlet start = applicant.customerId.substr(0, 2);\r\n\t\tlet isPhysicum = start === \"18\" || start === \"19\" || start === \"20\" || start === \"21\" || start === \"10\";\r\n\t\tif (this.companyService) {\r\n\t\t\tlet company = this.companyService.getApplicantCompany(c, applicant);\r\n\t\t\tif (company && this.companyService.isJuridicum(company)) {\r\n\t\t\t\tisPhysicum = false;\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn isPhysicum;\r\n\t}\r\n\r\n\tisJuridicum(c: Case, applicant: Applicant): boolean {\r\n\t\treturn !this.isPhysicum(c, applicant);\r\n\t}\r\n\r\n\tisPrivatePerson(c: Case, applicant: Applicant): boolean {\r\n\t\treturn this.isPhysicum(c, applicant)\r\n\t\t\t&& !this.isPersonalCompany(c, applicant);\r\n\t}\r\n\r\n\tisPersonalCompany(c: Case, applicant: Applicant): boolean {\r\n\t\tif (this.isPhysicum(c, applicant)) {\r\n\t\t\tif (this.companyService) {\r\n\t\t\t\tlet company = this.companyService.getApplicantCompany(c, applicant);\r\n\t\t\t\tif (company && this.companyService.isPhysicum(company)) {\r\n\t\t\t\t\treturn true;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\t// isCompany(c:Case, applicant: Applicant) : boolean {\r\n\t// \tlet company = this.companyService && \r\n\t// \t\tthis.companyService.getApplicantCompany(c, applicant);\r\n\t// \tif( company ) {\r\n\t// \t\treturn true;\r\n\t// \t}\r\n\t// \treturn false;\r\n\t// }\r\n\r\n\tisJuridicumCompany(c: Case, applicant: Applicant): boolean {\r\n\t\tif (!this.companyService)\r\n\t\t\treturn false;\r\n\r\n\t\tconst companyService = this.companyService;\r\n\r\n\t\tif (this.isJuridicum(c, applicant)) {\r\n\t\t\tlet company = companyService.getApplicantCompany(c, applicant);\r\n\t\t\tif (company && companyService.isJuridicum(company)) {\r\n\t\t\t\treturn true;\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\t// BUGFIX:\r\n\t\t\tif (c.companies) {\r\n\t\t\t\tlet selectedCompanies = companyService.getSelectedCompaniesInArray(c.companies, applicant);\r\n\t\t\t\tif (selectedCompanies && selectedCompanies.length > 0) {\r\n\t\t\t\t\tlet ret = selectedCompanies.filter(x => { return companyService.isJuridicum(x); });\r\n\t\t\t\t\tif (ret.length > 0)\r\n\t\t\t\t\t\treturn true;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\tshowPepForApplicant(a:Applicant): boolean {\r\n\t\tconst { isAmericanCitizen, isCrsTaxObligated, isPep, isPepRelated } = a.kyc ?? {}\r\n\t\tif(a.kyc == undefined || (isAmericanCitizen == undefined && isCrsTaxObligated == undefined && isPep == undefined && isPepRelated == undefined)) {\r\n\t\t\treturn false;\r\n\t\t}\r\n\t\treturn true;\r\n\t}\r\n\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { Case, CompanyEconomy } from '../models/SelmaModels';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { Application } from '../models/AppModels';\r\nimport { CaseIdStatus } from '../libs/SMELPOClient/models/CaseIdStatus';\r\nimport { TextService } from './TextService';\r\nimport { ApplicantService } from './ApplicantService';\r\n\r\nexport enum CaseStep {\r\n\tCompany, // Lista företag som berörs av lånet.\r\n\tLoan, // Information om lånet som önskas.\r\n\tApplicant, // Information om sökande personer\r\n\tCollateral, // Val av säkerhet för lånet\r\n\tHousehold, // Beskriv hushållet för medsökande.\r\n\tBudget, // Beskrivning av företagets budget.\r\n\tSummary, // Sammanställning av ärendet innan det skickas in.\r\n\tDone // Ansökan inskickad.\r\n}\r\n\r\nexport interface StepDefinition {\r\n\ttype: CaseStep;\r\n\t//ordinal: number;\r\n\tnameTextKey: string;\r\n\tcanGoHome: boolean;\r\n}\r\n\r\nexport interface SaveStepResult {\r\n\tstep: StepDefinition;\r\n}\r\n\r\nconst stepDefinitions: StepDefinition[] = [\r\n\t{\r\n\t\ttype: CaseStep.Company,\r\n\t\t//ordinal: 1,\r\n\t\tnameTextKey: 'Company_Title',\r\n\t\tcanGoHome: true,\r\n\t},\r\n\t{\r\n\t\ttype: CaseStep.Loan,\r\n\t\t//ordinal: 2,\r\n\t\tnameTextKey: 'Loan_Title',\r\n\t\tcanGoHome: true,\r\n\t},\r\n\t{\r\n\t\ttype: CaseStep.Applicant,\r\n\t\t//ordinal: 3,\r\n\t\tnameTextKey: 'Applicant_Title',\r\n\t\tcanGoHome: true,\r\n\t},\r\n\t{\r\n\t\ttype: CaseStep.Collateral,\r\n\t\t//ordinal: 4,\r\n\t\tnameTextKey: 'Collateral_Title',\r\n\t\tcanGoHome: true,\r\n\t},\r\n\t{\r\n\t\ttype: CaseStep.Household,\r\n\t\t//ordinal: 5,\r\n\t\tnameTextKey: 'Household_Title',\r\n\t\tcanGoHome: true,\r\n\t},\r\n\t{\r\n\t\ttype: CaseStep.Budget,\r\n\t\t//ordinal: 6,\r\n\t\tnameTextKey: 'Budget_Title',\r\n\t\tcanGoHome: true,\r\n\t},\r\n\t{\r\n\t\ttype: CaseStep.Summary,\r\n\t\t//ordinal: 7,\r\n\t\tnameTextKey: 'Summary_Title',\r\n\t\tcanGoHome: true,\r\n\t},\r\n\t{\r\n\t\ttype: CaseStep.Done,\r\n\t\t//ordinal: 8,\r\n\t\tnameTextKey: 'Done_StepTitle',\r\n\t\tcanGoHome: false,\r\n\t}\r\n];\r\n\r\n\r\nexport class StepService extends BaseService {\r\n\tconstructor(private application: Application, private textService:TextService, applicantService:ApplicantService) {\r\n\t\tsuper(); \r\n\t}\r\n\r\n\tgetStepDefinitions(c: Case): StepDefinition[] {\r\n\t\tlet steps = stepDefinitions;\r\n\t\tif( !c.companies || c.companies.length===0 ) {\r\n\t\t\tsteps = steps.filter(x => x.type!==CaseStep.Budget);\r\n\t\t}\r\n\t\tif( !c.households || c.households.length===0 ) {\r\n\t\t\tsteps = steps.filter(x => x.type!==CaseStep.Household);\r\n\t\t}\r\n\r\n\t\tif(!this.shouldShowBudgetStep(c)) {\r\n\t\t\tsteps = steps.filter(x => x.type!==CaseStep.Budget);\r\n\t\t}\r\n\r\n\t\treturn steps;\r\n\t}\r\n\r\n\tshouldShowBudgetStep(c: Case): boolean {\r\n\t\tconst companyEconomyService = this.application.services.companyEconomyService;\r\n\t\tconst selectedCompany = this.application.services.companyService.getMySelectedCompany(c);\r\n\t\tconst selectedCompanyEconomy = companyEconomyService.getCompanyEconomy(c, selectedCompany);\r\n\r\n\t\treturn !!companyEconomyService.hasRevenue(selectedCompanyEconomy || {} as CompanyEconomy);\r\n\t}\r\n\r\n\tgetStepIndex(step: StepDefinition, c: Case): number {\r\n\t\tlet steps = this.getStepDefinitions(c);\r\n\t\tlet index = steps.indexOf(step);\r\n\t\treturn index;\r\n\t}\r\n\r\n\tgetStepOrdinal(step: StepDefinition, c: Case): number {\r\n\t\tlet index = this.getStepIndex(step, c);\r\n\t\treturn index+1;\r\n\t}\r\n\r\n\tgetStepDefinitionByType(steps: StepDefinition[], type: CaseStep): StepDefinition | undefined {\r\n\t\tvar r = steps.filter(x => { return x.type===type});\r\n\t\tif( r && r.length===1 ) return r[0]\r\n\t\telse return;\r\n\t}\r\n\r\n\tvalidateStepCompany(c: Case): ValidationResult {\r\n\t\tvar vr = new ValidationResult();\r\n\t\tconst companyService = this.application.services.companyService;\r\n\t\tconst companyEconomyService = this.application.services.companyEconomyService;\r\n\t\t//const applicantService = this.application.services.applicantService;\r\n\t\t//const caseService = this.application.services.caseService;\r\n\r\n\t\t// Must have selected company, or promise that they will buy a company.\r\n\t\tvr.add({ validator:companyService.hasSelectedCompany, ok: companyService.hasSelectedCompany(c) });\r\n\r\n\t\t// Must have selected company economy.\r\n\r\n\t\t// Must have selected HasRevenue yes/no\r\n\t\t// If hasRevenue=true\r\n\t\t// Must have selected high risk businiess\r\n\t\t// Must have all required Revenues.\r\n\t\t// All Revenues must have value zero or higher.\r\n\t\t// Must have at least one business focus.\r\n\t\t// Sum of one business focus parts (percent) must be 100.\r\n\t\t// If the maxmimum business focus part exists two or more times, mainFocus must be set on one of them.\r\n\t\t// If hasRevenue=false\r\n\t\t// Nothing.\r\n\t\tvr.addResult(companyEconomyService.validateMySelectedCompanies(c));\r\n\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tvalidateStepLoan(c: Case): ValidationResult {\r\n\t\tvar vr = new ValidationResult();\r\n\r\n\t\tconst applicantService = this.application.services.applicantService;\r\n\t\tconst loanService = this.application.services.loanService;\r\n\r\n\t\t// Validate loan and data under loan.\r\n\t\tvr.addResult(loanService.validateCaseLoan(c));\r\n\r\n\t\t// My applicant must have checked all KYC approvals.\r\n\t\tvr.addResult(applicantService.validateMyApplicantKycApproval(c));\r\n\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tvalidateStepApplicant(c: Case): ValidationResult {\r\n\t\tvar vr = new ValidationResult();\r\n\r\n\t\tconst applicantService = this.application.services.applicantService;\r\n\t\tconst myApplicantHasGivenFullApproval = applicantService.myApplicantHasGivenFullApproval(c);\r\n\t\tif( !myApplicantHasGivenFullApproval )\r\n\t\t\treturn vr;\r\n\r\n\t\tconst personalEconomyService = this.application.services.personalEconomyService;\r\n\t\tconst companyService = this.application.services.companyService;\r\n\t\tconst companyEconomyService = this.application.services.companyEconomyService;\r\n\r\n\t\tlet hasApplicants = applicantService.hasApplicants(c);\r\n\t\tvr.add({ validator: applicantService.hasApplicants, object:c, ok: hasApplicants});\r\n\t\tif( hasApplicants && c.applicants ) {\r\n\t\t\tconst myApplicant = applicantService.getMyApplicant(c);\r\n\r\n\t\t\t// For every Person applicant...\r\n\t\t\t// Must have mobile phone.\r\n\t\t\t// Must have mobile email.\r\n\t\t\t// Must have one notification type selected.\r\n\t\t\tc.applicants.forEach(applicant => {\r\n\t\t\t\tconst isMe = applicant===myApplicant;\r\n\t\t\t\tvr.addResult(applicantService.validateApplicantContact(applicant));\r\n\t\t\t\tvr.addResult(applicantService.validateApplicantKycApproval(applicant));\r\n\r\n\t\t\t\tconst isJuridicumCompany = applicantService.isJuridicumCompany(c, applicant);\r\n\r\n\t\t\t\tconst isPhysicum = !isJuridicumCompany && applicantService.isPhysicum(c, applicant);\r\n\t\t\t\tif( isPhysicum ) {\r\n\t\t\t\t\tvr.addResult(personalEconomyService.validateApplicantPersonalEconomy(c, applicant));\r\n\t\t\t\t\tif(applicantService.showPepForApplicant(applicant)) {\r\n\t\t\t\t\t\tvr.addResult(applicantService.validateApplicantPep(applicant));\r\n\t\t\t\t\t}\r\n\t\t\t\t\tconst isPersonalCompany = applicantService.isPersonalCompany(c, applicant);\r\n\t\t\t\t\tif( isPersonalCompany ) {\r\n\t\t\t\t\t\tif( !isMe ) {\r\n\t\t\t\t\t\t\tconst company = companyService.getApplicantCompany(c, applicant);\r\n\t\t\t\t\t\t\tif( company ) {\r\n\t\t\t\t\t\t\t\tvr.addResult(companyEconomyService.validateCompany(c, company, applicant));\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t} else { // Private Person.\r\n\t\t\t\t\t\t// Nothing.\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t} else {\r\n\t\t\t\t\tif( isJuridicumCompany ) {\r\n\t\t\t\t\t\tconst company = companyService.getApplicantCompany(c, applicant);\r\n\t\t\t\t\t\tif( company ) {\r\n\t\t\t\t\t\t\tvr.addResult(companyEconomyService.validateCompany(c, company, applicant));\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tvalidateStepCollateral(c: Case): ValidationResult {\r\n\t\tvar vr = new ValidationResult();\r\n\r\n\t\tconst applicantService = this.application.services.applicantService;\r\n\t\tconst myApplicantHasGivenFullApproval = applicantService.myApplicantHasGivenFullApproval(c);\r\n\t\tif( !myApplicantHasGivenFullApproval )\r\n\t\t\treturn vr;\r\n\r\n\t\tconst collateralService = this.application.services.collateralService;\r\n\r\n\t\t// Must have at least one collateral.\r\n\t\tvr.add({validator:this.validateStepCollateral, object:c, \r\n\t\t\tok: ((c.collaterals && c.collaterals.length > 0) ? true:false) \r\n\t\t\t|| ((c.euSupports && c.euSupports.length > 0) ? true:false)\r\n\t\t\t|| ((c.guarantors && c.guarantors.length > 0) ? true:false) \r\n\t\t});\r\n\r\n\t\t// For every Estate (type Collateral)...\r\n\t\t// Must have municipality\r\n\t\t// Must have house code.\r\n\t\tif( c.collaterals ) {\r\n\t\t\tc.collaterals.forEach(x => {\r\n\t\t\t\tvr.addResult(collateralService.validateCollateral(c, x));\r\n\t\t\t})\r\n\t\t}\r\n\r\n\t\t// For every EU-support ...\r\n\t\t// Must have type\r\n\t\t// Must have amount.\r\n\t\tif( c.euSupports ) {\r\n\t\t\tconst euSupportService = this.application.services.euSupportService;\r\n\t\t\tc.euSupports.forEach(x => {\r\n\t\t\t\tvr.addResult(euSupportService.validateEuSupport(c, x));\r\n\t\t\t})\r\n\t\t}\r\n\r\n\t\t// For every Guarantor ...\r\n\t\t// Must have name\r\n\t\t// Must have phone.\r\n\t\t// Must have ssn.\r\n\t\tif( c.guarantors ) {\r\n\t\t\tconst guarantorService = this.application.services.guarantorService;\r\n\t\t\tvr.addResult(guarantorService.validateGuarantors(c));\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tvalidateStepHousehold(c: Case): ValidationResult {\r\n\t\tvar vr = new ValidationResult();\r\n\r\n\t\tconst applicantService = this.application.services.applicantService;\r\n\t\tconst myApplicantHasGivenFullApproval = applicantService.myApplicantHasGivenFullApproval(c);\r\n\t\tif( !myApplicantHasGivenFullApproval )\r\n\t\t\treturn vr;\r\n\r\n\t\tconst householdService = this.application.services.householdService;\r\n\r\n\t\t// Must have at least one household.\r\n\t\tconst mustHaveHousehold = householdService.shouldHaveHouseholds(c);\r\n\t\tif( !mustHaveHousehold ) {\r\n\t\t\tvr.add({validator:this.validateStepHousehold, object:c, ok: true });\r\n\t\t}\r\n\t\telse //if( mustHaveHousehold )\r\n\t\t{\r\n\t\t\tvr.add({validator:this.validateStepHousehold, object:c, \r\n\t\t\t\tok: (c.households && c.households.length>0?true:mustHaveHousehold) \r\n\t\t\t});\r\n\r\n\t\t\t// For every Person or EF applicant...\r\n\t\t\t// Must be part of household.\r\n\r\n\t\t\t// For every Household...\r\n\t\t\t// Must have at least one member.\r\n\t\t\tif( c.households ) {\r\n\t\t\t\tc.households.forEach(x => {\r\n\t\t\t\t\tvr.addResult(householdService.validateHousehold(c, x));\r\n\t\t\t\t})\r\n\t\t\t}\r\n\r\n\t\t\t// For every Household...\r\n\t\t\t// Must have at least one member.\r\n\t\t\t// Must have selected child count.\r\n\t\t\t// Must have selected car count.\r\n\t\t\t// If child count > 0 ...\r\n\t\t\t// Age must be 0 or higher.\r\n\t\t\t// Partial must be selected.\r\n\r\n\t\t\t// For every Maintenance cost\r\n\t\t\t// TODO: Must be valid.\r\n\t\t\tif( c.maintenanceCosts ) {\r\n\t\t\t\tconst maintenanceCostService = this.application.services.maintenanceCostService;\r\n\t\t\t\tc.maintenanceCosts.forEach(x => {\r\n\t\t\t\t\tvr.addResult(maintenanceCostService.validateMaintenanceCost(c, x));\r\n\t\t\t\t})\r\n\t\t\t}\r\n\r\n\t\t\t// For every ExtLoan \r\n\t\t\t// TODO: Must be valid.\r\n\t\t\tif( c.extLoans ) {\r\n\t\t\t\tconst extLoanService = this.application.services.extLoanService;\r\n\t\t\t\tc.extLoans.forEach(x => {\r\n\t\t\t\t\tvr.addResult(extLoanService.validateExtLoan(c, x));\r\n\t\t\t\t})\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tvalidateStepBudget(c: Case): ValidationResult {\r\n\t\tvar vr = new ValidationResult();\r\n\r\n\t\tconst applicantService = this.application.services.applicantService;\r\n\t\tconst myApplicantHasGivenFullApproval = applicantService.myApplicantHasGivenFullApproval(c);\r\n\t\tif( !myApplicantHasGivenFullApproval )\r\n\t\t\treturn vr;\r\n\r\n\t\t// For every required attachement request...\r\n\t\t// Must have matching attachment.\r\n\t\tconst attachmentService = this.application.services.attachmentService;\r\n\t\tvr.addResult(attachmentService.validateAttachmentRequestsByRequestType(c, \"COMPANYBUDGET\"));\r\n\r\n\t\tconst budgetService = this.application.services.budgetService;\r\n\t\tvr.addResult(budgetService.validateBudgets(c));\r\n\r\n\t\tif( vr.getItems().length===0 ) {\r\n\t\t\t// Add a single ok item if no items to signal that step is finished.\r\n\t\t\tlet v = this.validateStepBudget;\r\n\t\t\tvr.add({validator: v, object:c, ok: true});\r\n\t\t}\r\n\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tvalidateStepSummary(c: Case): ValidationResult {\r\n\t\tvar vr = new ValidationResult();\r\n\r\n\t\tconst applicantService = this.application.services.applicantService;\r\n\t\tconst myApplicantHasGivenFullApproval = applicantService.myApplicantHasGivenFullApproval(c);\r\n\t\tif( !myApplicantHasGivenFullApproval )\r\n\t\t\treturn vr;\r\n\r\n\t\tconst summaryService = this.application.services.summaryService;\r\n\t\tvr.addResult(summaryService.validateSummary(c));\r\n\r\n\t\t// Validate all previous steps.\r\n\t\tlet v = this.validateStepSummary;\r\n\t\tvr.add({validator: v, object:c, ok: this.validateStepCompany(c).ok()});\r\n\t\tvr.add({validator: v, object:c, ok: this.validateStepLoan(c).ok()});\r\n\t\tvr.add({validator: v, object:c, ok: this.validateStepApplicant(c).ok()});\r\n\t\tvr.add({validator: v, object:c, ok: this.validateStepCollateral(c).ok()});\r\n\t\tvr.add({validator: v, object:c, ok: this.validateStepHousehold(c).ok()});\r\n\r\n\t\tif (this.shouldShowBudgetStep(c)) {\r\n\t\t\tvr.add({validator: v, object:c, ok: this.validateStepBudget(c).ok()});\r\n\t\t}\r\n\r\n\t\treturn vr;\r\n\t}\r\n\t\r\n\tvalidateStepDone(c: Case): ValidationResult {\r\n\t\tvar vr = new ValidationResult();\r\n\r\n\t\tif( c.status===CaseIdStatus.READYFOROFFICER || c.status===CaseIdStatus.CLOSEDBYOFFICER ) {\r\n\t\t\t// Add one ok for the fact that we have reached this step.\r\n\t\t\tvr.add({ validator: this.validateStepDone, object:c, ok:true});\r\n\r\n\t\t\t// For every required attachement request...\r\n\t\t\t// Must have matching attachment.\r\n\t\t\tconst attachmentService = this.application.services.attachmentService;\r\n\t\t\tvr.addResult(attachmentService.validateAttachmentRequests(c));\r\n\r\n\t\t\t// For every active kyc in case, must have status done\r\n\t\t\tconst kycService = this.application.services.kycService;\r\n\t\t\tif(kycService.showKycForCase(c)) {\r\n\t\t\t\tvr.addResult(kycService.validateCaseKyc(c));\r\n\t\t\t}\t\t\t\r\n\t\t}\r\n\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tvalidateStep(step: StepDefinition, c: Case) : ValidationResult {\r\n\r\n\t\tif( c.status===CaseIdStatus.STARTEDBYAPPLICANT ) {\r\n\t\t\tif( step.type===CaseStep.Company) {\r\n\t\t\t\treturn this.validateStepCompany(c);\r\n\t\t\t} else if( step.type===CaseStep.Loan ) {\r\n\t\t\t\treturn this.validateStepLoan(c);\r\n\t\t\t} else if( step.type===CaseStep.Applicant ) {\r\n\t\t\t\treturn this.validateStepApplicant(c);\r\n\t\t\t} else if( step.type===CaseStep.Collateral ) {\r\n\t\t\t\treturn this.validateStepCollateral(c);\r\n\t\t\t} else if( step.type===CaseStep.Household ) {\r\n\t\t\t\treturn this.validateStepHousehold(c);\r\n\t\t\t} else if( step.type===CaseStep.Budget ) {\r\n\t\t\t\treturn this.validateStepBudget(c);\r\n\t\t\t} else if( step.type===CaseStep.Summary ) {\r\n\t\t\t\treturn this.validateStepSummary(c);\r\n\t\t\t} \r\n\t\t}\r\n\r\n\t\t// Application sent in and not last step.\r\n\t\telse if( c.status===CaseIdStatus.READYFOROFFICER || c.status===CaseIdStatus.CLOSEDBYOFFICER ) {\r\n\t\t\t\r\n\t\t\tif(step.type===CaseStep.Done) {\r\n\t\t\t\treturn this.validateStepDone(c);\r\n\t\t\t} else {\r\n\t\t\t\tvar vr = new ValidationResult();\r\n\t\t\t\tvr.add({ validator: this.validateStep, object: c, ok: true})\r\n\t\t\t\treturn vr;\r\n\t\t\t}\r\n\t\t}\r\n\t\t// else if( c.status==CaseIdStatus.CLOSEDBYOFFICER ) {\r\n\t\t// \tvar vr = new ValidationResult();\r\n\t\t// \tvr.add({ validator: this.validateStep, object: c, ok: true})\r\n\t\t// \treturn vr;\r\n\t\t// }\r\n\t\telse if( c.status===CaseIdStatus.CLOSEDBYAPPLICANT || c.status===CaseIdStatus.CLOSEDBYTHINNING ) {\r\n\t\t\tvar vr2 = new ValidationResult();\r\n\t\t\tvr2.add({ validator: this.validateStep, object: c, ok: false})\r\n\t\t\treturn vr2;\r\n\t\t}\r\n\r\n\t\treturn new ValidationResult(); // Should never happen.\r\n\t}\r\n\r\n\tsaveStep(step: StepDefinition, c: Case) : Promise {\r\n\r\n\t\tif( step.type===CaseStep.Summary || step.type===CaseStep.Done )\r\n\t\t\treturn Promise.resolve({step: step}); // dont save these steps.\r\n\r\n\t\tconst canSaveCase = this.application.services.caseService.canSaveCase(c);\r\n\t\tif( !canSaveCase ) {\r\n\t\t\treturn Promise.resolve({step: step});\r\n\t\t}\r\n\t\t\r\n\t\treturn this.application.services.caseService\r\n\t\t.saveCase(c)\r\n\t\t.then(result => {\r\n\t\t\treturn {\r\n\t\t\t\tstep: step\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\t// The first step that needs more info.\r\n\tgetStartStep(c: Case): StepDefinition|undefined {\r\n\t\tconst steps = this.getStepDefinitions(c);\r\n\t\tif( c.status===CaseIdStatus.READYFOROFFICER ) {\r\n\t\t\treturn this.getStepDefinitionByType(steps, CaseStep.Done);\r\n\t\t}\r\n\t\tlet currentStep:StepDefinition|undefined;\r\n\t\tfor(let i=0; i x.companyId === companyId);\r\n\t\t\tif (ces.length === 1) companyEconomy = ces[0];\r\n\t\t}\r\n\t\treturn companyEconomy;\r\n\t}\r\n\r\n\tensureCompanyEconomy(c: Case, company: Company): CompanyEconomy {\r\n\t\tlet companyEconomy = this.getCompanyEconomyByCompanyId(c, company.id);\r\n\t\tif (!companyEconomy) {\r\n\t\t\tcompanyEconomy = this.newCompanyEconomy(c, company);\r\n\t\t\tthis.addCompanyEconomy(c, companyEconomy);\r\n\t\t}\r\n\t\treturn companyEconomy;\r\n\t}\r\n\r\n\tensureRequiredRevenueYears(companyEconomy: CompanyEconomy) {\r\n\t\tthis.getRequiredYearsOfRevenue().forEach((year) => {\r\n\t\t\tthis.ensureRevenueYear(companyEconomy, year);\r\n\t\t});\r\n\t}\r\n\r\n\tsetNoRevenueYears(companyEconomy: CompanyEconomy) {\r\n\t\tif( !companyEconomy.revenues || companyEconomy.revenues.length>0 ) {\r\n\t\t\tcompanyEconomy.revenues = [];\r\n\t\t\tthis.update(companyEconomy);\r\n\t\t}\r\n\t}\r\n\r\n\thasRevenue(companyEconomy: CompanyEconomy) : boolean|undefined {\r\n\t\tif( !companyEconomy.revenues ) {\r\n\t\t\treturn; // no array.\r\n\t\t} else if( companyEconomy.revenues.length>0 ) { // array with item(s)\r\n\t\t\treturn true;\r\n\t\t} else {\r\n\t\t\treturn false; // Empty array.\r\n\t\t}\r\n\t}\r\n\r\n\thasRevenueSelected(companyEconomy: CompanyEconomy) : boolean {\r\n\t\tlet hasRevenue = this.hasRevenue(companyEconomy);\r\n\t\treturn this.guardService.hasValue(hasRevenue);\r\n\t}\r\n\r\n\t\r\n\tprivate ensureRevenueYear(\r\n\t\tcompanyEconomy: CompanyEconomy,\r\n\t\tyear: number\r\n\t): BudgetYear {\r\n\t\tlet revenue: Revenue | undefined;\r\n\t\tif (!companyEconomy.revenues) companyEconomy.revenues = [];\r\n\t\telse revenue = this.getRevenueByYear(companyEconomy, year);\r\n\t\tif (!revenue) {\r\n\t\t\trevenue = {\r\n\t\t\t\tyear: year,\r\n\t\t\t\trevenue: undefined\r\n\t\t\t};\r\n\t\t\tcompanyEconomy.revenues.push(revenue);\r\n\t\t\tthis.update(companyEconomy);\r\n\t\t}\r\n\t\treturn revenue;\r\n\t}\r\n\r\n\tgetRevenueByYear(companyEconomy: CompanyEconomy, year: number): Revenue | undefined {\r\n\t\tif (!companyEconomy.revenues) return;\r\n\t\tlet r = companyEconomy.revenues.filter((x) => x.year === year);\r\n\t\tif (r.length === 1) {\r\n\t\t\treturn r[0];\r\n\t\t} else {\r\n\t\t\treturn;\r\n\t\t}\r\n\t}\r\n\r\n\tgetRequiredYearsOfRevenue(): number[] {\r\n\t\tconst thisYear = new Date().getFullYear();\r\n\t\tconst minYearsOfBudget = 2;\r\n\t\tconst firstYear = thisYear - minYearsOfBudget + 1;\r\n\t\tconst lastYear = thisYear;\r\n\r\n\t\tlet years: number[] = [];\r\n\t\tfor (let year = firstYear; year <= lastYear; year++) {\r\n\t\t\tyears.push(year);\r\n\t\t}\r\n\t\treturn years;\r\n\t}\r\n\r\n\tsetRevenueValue(\r\n\t\tcompanyEconomy: CompanyEconomy,\r\n\t\trevenue: Revenue,\r\n\t\treveneuValue: number | undefined\r\n\t) {\r\n\t\trevenue.revenue = reveneuValue;\r\n\t\tthis.update(revenue);\r\n\t\tthis.update(companyEconomy);\r\n\t}\r\n\r\n\tvalidateMySelectedCompanies(c: Case): ValidationResult {\r\n\t\tconst myApplicant = this.applicantService.getMyApplicant(c);\r\n\t\tlet companies = this.companyService.getMySelectedCompanies(c);\r\n\t\tlet vr = new ValidationResult();\r\n\t\tif( companies && companies.length ) {\r\n\t\t\tcompanies.forEach(company => {\r\n\t\t\t\tvr.addResult(this.validateCompany(c, company, myApplicant));\r\n\t\t\t})\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tvalidateCompany(c: Case, company:Company, applicant: Applicant): ValidationResult {\r\n\t\tlet companyEconomy:CompanyEconomy|undefined;\r\n\t\tif( company ) {\r\n\t\t\tcompanyEconomy = this.getCompanyEconomy(c, company);\r\n\t\t}\r\n\t\tlet vr = new ValidationResult();\r\n\t\tif( company && companyEconomy ) {\r\n\t\t\tvr.add({validator: this.hasRevenueSelected, object: companyEconomy, ok: this.hasRevenueSelected(companyEconomy) })\r\n\r\n\t\t\tlet hasRevenue = companyEconomy && this.hasRevenue(companyEconomy);\r\n\t\t\tif( hasRevenue===true ) {\r\n\t\t\t\tvr.addResult(this.applicantService.validateHasSelectedHighRiskCategory(applicant));\r\n\t\t\t\tvr.addResult(this.validateRequiredRevenues(companyEconomy));\r\n\t\t\t\tvr.addResult(this.companyService.validateHasMinimumBussinessFocuses(company));\r\n\t\t\t\tvr.addResult(this.companyService.validateBussinessFocuses(company));\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tprivate getRequiredRevenues(companyEconomy: CompanyEconomy): \r\n\t\t{ year: number; revenue: Revenue | undefined }[] {\r\n\t\tlet years = this.getRequiredYearsOfRevenue();\r\n\t\tlet r = years.map((year) => {\r\n\t\t\treturn {\r\n\t\t\t\tyear: year,\r\n\t\t\t\trevenue: this.getRevenueByYear(companyEconomy, year),\r\n\t\t\t};\r\n\t\t});\r\n\t\treturn r;\r\n\t}\r\n\r\n\tprivate validateRequiredRevenues(companyEconomy: CompanyEconomy): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tif (\r\n\t\t\t!companyEconomy ||\r\n\t\t\t!companyEconomy.revenues ||\r\n\t\t\t!companyEconomy.revenues\r\n\t\t)\r\n\t\t\treturn vr;\r\n\r\n\t\tthis.getRequiredRevenues(companyEconomy).forEach((x) => {\r\n\t\t\tif( x.revenue ) {\r\n\t\t\t\tvr.add({\r\n\t\t\t\t\tvalidator: this.revenueHasZeroOrHigherRevenue,\r\n\t\t\t\t\tobject: x.revenue,\r\n\t\t\t\t\tok: this.revenueHasZeroOrHigherRevenue(x.revenue),\r\n\t\t\t\t});\r\n\t\t\t} else {\r\n\t\t\t\tvr.add({\r\n\t\t\t\t\tvalidator: this.getRevenueByYear,\r\n\t\t\t\t\tobject: companyEconomy,\r\n\t\t\t\t\targs: [x.year],\r\n\t\t\t\t\tok: false,\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t});\r\n\t\treturn vr;\r\n\t}\r\n\r\n\trevenueHasZeroOrHigherRevenue(revenue: Revenue): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isZeroOrGreater(revenue.revenue);\r\n\t}\r\n\t\r\n}\r\n","export class UiModelConverter {\r\n\r\n\tstatic prettySsn(ssn: string): string {\r\n\t\tif( ssn.length===12 )\r\n\t\t\treturn ssn.substr(0,8)+'-'+ssn.substr(8,4);\r\n\t\telse\r\n\t\t\treturn ssn;\r\n\t}\r\n\r\n\tstatic prettyOrgNr(orgNr: string|undefined): string {\r\n\t\tif( !orgNr )\r\n\t\t\treturn '';\r\n\t\telse if( orgNr.length===10 )\r\n\t\t\treturn orgNr.substr(0,6)+'-'+orgNr.substr(6,4);\r\n\t\telse\r\n\t\t\treturn orgNr;\r\n\t}\r\n\r\n\tstatic prettyCustomerId(customerId: string|undefined): string {\r\n\t\tif( !customerId )\r\n\t\t\treturn '';\r\n\t\telse if( customerId.length===12 )\r\n\t\t\treturn this.prettySsn(customerId);\r\n\t\telse if( customerId.length===10 )\r\n\t\t\treturn this.prettyOrgNr(customerId);\r\n\t\treturn customerId;\r\n\t}\r\n\r\n\tstatic prettyDateString(date: string|Date|undefined): string {\r\n\t\tif( !date || date===null )\r\n\t\t\treturn '';\r\n\t\telse if( typeof(date) == 'string' ) {\r\n\t\t\tlet d = Date.parse(date as string);\r\n\t\t\tdate = new Date(d);\r\n\t\t}\r\n\t\r\n\t\tif( date instanceof Date ) {\r\n\t\t\treturn date.toLocaleDateString();\r\n\t\t} else {\r\n\t\t\treturn '?';\r\n\t\t}\r\n\t}\r\n\r\n\tstatic numberToIntegerThousandSeparatedString (value: number, separator: string = \"\\u0020\"): string {\r\n\t\tif (value===undefined || value === null)\r\n\t\t\treturn \"\";\r\n\r\n\t\tvar v = Math.round(value);\r\n\r\n\t\tif (v > -1000 && v < 1000)\r\n\t\t\treturn value.toString();\r\n\r\n\t\tvar str = value.toString();\r\n\r\n\t\t// Add thousands separator. \r\n\t\t// Originally it was the unicode character \"\\u2009\" == THIN SPACE\r\n\t\t// but it was replaced with a regular space \"\\u0200\" since Safari on iOS\r\n\t\t// couldn't render thin space.\r\n\t\tfor (var i = str.length - 3; i > 0; i -= 3) {\r\n\t\t\tstr = str.substring(0, i) + separator + str.substring(i);\r\n\t\t}\r\n\r\n\t\treturn str;\r\n\t};\r\n\t\r\n\t// static integerThousandSeparatedStringToNumber(value: string): number {\r\n\t// \tif (angular.isUndefined(value) || value === null)\r\n\t// \t\treturn null;\r\n\r\n\t// \tvalue = value.replace(/\\D/g, \"\");\r\n\r\n\t// \tvar num = parseFloat(value);\r\n\t// \tif (isNaN(num))\r\n\t// \t\treturn null;\r\n\r\n\t// \treturn num;\r\n\t// }\r\n\t\r\n\t\t\t// Takes an ssn on any form. returns it in normalized form: YYYYMMDDNNNN.\r\n\tstatic toNormalizedSsn(ssn: string): string {\r\n\t\tif (!ssn || !ssn.toLowerCase)\r\n\t\t\treturn ssn;\r\n\t\tif (ssn.length === 12) // YYYYMMDDNNNN\r\n\t\t\treturn ssn;\r\n\t\tif (ssn.length === 13) // YYYYMMDD-NNNN\r\n\t\t\treturn ssn.replace(/-/, \"\");\r\n\t\tif (ssn.length === 10)// YYMMDDNNNN\r\n\t\t\treturn \"19\" + ssn;\r\n\t\tif (ssn.length === 11)// YYMMDD-NNNN\r\n\t\t\treturn \"19\" + ssn.replace(/-/, \"\");\r\n\t\treturn ssn;\r\n\t}\r\n\t\r\n\t\t// Takes an ssn on any form. returns it in normalized form: YYYYMMDD-NNNN.\r\n\t\t// toPrettyNormalizedSsn: function (ssn: string): string {\r\n\t\t// \tif (!angular.isString(ssn))\r\n\t\t// \t\treturn ssn;\r\n\t\t// \tssn = svc.toNormalizedSsn(ssn);\r\n\t\t// \tif (ssn.length === 12) // YYYYMMDDNNNN\r\n\t\t// \t\tssn = ssn.substr(0, 8) + \"-\" + ssn.substr(8, 4); // YYYYMMDD-NNNN\r\n\t\t// \treturn ssn;\r\n\t\t// },\r\n\r\n\tstatic getSsnDate(ssn: string): Date|undefined {\r\n\t\tif (!ssn || ssn.length === 0)\r\n\t\t\treturn;\r\n\r\n\t\tssn = UiModelConverter.toNormalizedSsn(ssn.replace('-', ''));\r\n\t\tif (ssn.length !== 12)\r\n\t\t\treturn;\r\n\r\n\t\tlet year = parseInt(ssn.substr(0, 4));\r\n\t\tlet month = parseInt(ssn.substr(4, 2));\r\n\t\tlet day = parseInt(ssn.substr(6, 2));\r\n\r\n\t\treturn new Date(year, month, day);\r\n\t};\r\n\r\n\tstatic getAgeByDate(date: Date, now?: Date) : number {\r\n\t\tif (!now)\r\n\t\t\tnow = new Date();\r\n\r\n\t\tvar ageDifMs = now.getTime() - date.getTime();\r\n\t\tvar ageDate = new Date(ageDifMs); // miliseconds from epoch\r\n\t\treturn Math.abs(ageDate.getUTCFullYear() - 1970);\r\n\t};\r\n\r\n\tstatic getAgeBySsn(ssn: string): number {\r\n\t\tlet ssnDate = UiModelConverter.getSsnDate(ssn);\r\n\t\tif (!ssnDate)\r\n\t\t\treturn -9999;\r\n\r\n\t\treturn UiModelConverter.getAgeByDate(ssnDate);\r\n\t};\r\n\r\n\t// toIsoDateString: function(value: Date): string {\r\n\t// \tlet yyyy = value.getFullYear().toString();\r\n\t// \tlet mm = (value.getMonth() + 1).toString(); // getMonth() is zero-based \r\n\t// \tlet dd = value.getDate().toString();\r\n\t// \treturn yyyy + \"-\" + (mm[1] ? mm : \"0\" + mm[0]) + \"-\" + (dd[1] ? dd : \"0\" + dd[0]) + \"T00:00:00.000Z\";\r\n\t// }\r\n\t\r\n}","import { BaseService } from './BaseService';\r\nimport { BusinessCategory, Case, Applicant } from '../models/SelmaModels';\r\nimport { Company, Principal } from \"../models/selmamodels/Company\";\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { GuardService } from './GuardService';\r\nimport { CompanyEconomyService } from './CompanyEconomyService';\r\nimport { IdService } from './IdService';\r\nimport { ApplicantService } from './ApplicantService';\r\nimport { ConvertService } from './ConvertService';\r\nimport { UiModelConverter } from '../models/UiModelConverter';\r\n\r\n/*\r\nHandles all logic for Company.\r\n*/\r\nexport class CompanyService extends BaseService {\r\n\r\n\tcompanyEconomyService?:CompanyEconomyService;\r\n\r\n\tconstructor(private stateService: StateService, \r\n\t\tprivate smelpoService: SMELPOService,\r\n\t\tprivate guardService: GuardService, \r\n\t\tprivate idService:IdService,\r\n\t\tprivate applicantService: ApplicantService,\r\n\t\tprivate convertService:ConvertService) {\r\n\t\tsuper();\r\n\t}\r\n\r\n\tupdate(company: Company|BusinessCategory|Case): void {\r\n\t\tthis.stateService.update(company);\r\n\t}\r\n\r\n\tnormalizeOrgnr(orgNr:string):string {\r\n\t\tlet normalizedOrgNr = orgNr.trim().replace(/-/g,'');\r\n\t\treturn normalizedOrgNr;\r\n\t}\r\n\r\n\tcompareOrgnr(a:string, b:string):boolean {\r\n\t\treturn this.normalizeOrgnr(a)===this.normalizeOrgnr(b);\r\n\t}\r\n\r\n\tgetDisplayName(company: Company): string {\r\n\t\tlet name:string = \"\";\r\n\t\tif( company.name ) {\r\n\t\t\tname = company.name;\r\n\t\t} else if( company.orgNumber ) {\r\n\t\t\tname = UiModelConverter.prettyOrgNr(company.orgNumber);\r\n\t\t} else {\r\n\t\t\tname = \"ID \" + company.id;\r\n\t\t}\r\n\t\treturn name;\r\n\t}\r\n\r\n\taddCompany(c:Case, company:Company) : Company {\r\n\r\n\t\tthis.ensureMinimumBusinessFocuses(company);\r\n\r\n\t\tlet existingCompany = this.getCompanyByOrgnr(c, company.orgNumber);\r\n\t\tif( !existingCompany ) {\r\n\t\t\tif( !c.companies )\r\n\t\t\t\tc.companies = [company];\r\n\t\t\telse \r\n\t\t\t\tc.companies.push(company);\r\n\t\t\t\r\n\t\t\tthis.update(company);\r\n\t\t\tthis.update(c);\r\n\t\t\treturn company;\r\n\t\t}\r\n\t\telse \r\n\t\t\treturn existingCompany;\r\n\t}\r\n\r\n\tremoveCompany(c:Case, company:Company) {\r\n\t\tif( c.companies ) {\r\n\t\t\tthis.stateService.listRemove(c.companies, company);\r\n\t\t\tif( this.companyEconomyService ) {\r\n\t\t\t\tlet ce = this.companyEconomyService.getCompanyEconomyByCompanyId(c, company.id);\r\n\t\t\t\tif( ce ) {\r\n\t\t\t\t\tthis.companyEconomyService.removeCompanyEconomy(c, ce);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tif( c.attachmentRequests ) {\r\n\t\t\t\tvar attachmentRequestsToRemove = c.attachmentRequests.filter(ar => {\r\n\t\t\t\t\tif( !ar.customerId || !company.orgNumber )\r\n\t\t\t\t\t\treturn false;\r\n\t\t\t\t\treturn this.guardService.compareCustomerId(ar.customerId, company.orgNumber);\r\n\t\t\t\t});\r\n\r\n\t\t\t\tif( attachmentRequestsToRemove && attachmentRequestsToRemove.length>0 ) {\r\n\t\t\t\t\tattachmentRequestsToRemove.forEach(ar => {\r\n\t\t\t\t\t\tif( c.attachmentRequests )\r\n\t\t\t\t\t\t\tthis.stateService.listRemove(c.attachmentRequests, ar);\r\n\t\t\t\t\t})\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\tthis.update(c);\r\n\t\t}\r\n\t}\r\n\r\n\tgetCompanyByOrgnr(c:Case, orgNr:string|undefined): Company|undefined {\r\n\t\tif( !c.companies || c.companies.length===0 || !orgNr)\r\n\t\t\treturn undefined;\r\n\t\treturn this.getCompanyByOrgnrInArray(c.companies, orgNr);\r\n\t}\r\n\r\n\tgetCompanyByOrgnrInArray(companies:Company[], orgNr:string): Company|undefined {\r\n\t\tif( !companies || companies.length===0)\r\n\t\t\treturn undefined;\r\n\t\tconst g = this.guardService;\r\n\t\tconst orgNrIsAlsoSsn = g.isValidSsn(orgNr);\r\n\t\torgNr = this.normalizeOrgnr(orgNr);\r\n\r\n\t\tlet r = companies.filter(x => {\r\n\t\t\tif( !x.orgNumber )\r\n\t\t\t\treturn false;\r\n\t\t\tconst n = this.normalizeOrgnr(x.orgNumber);\r\n\t\t\tif( !n )\r\n\t\t\t\treturn false;\r\n\t\t\tif( n===orgNr )\r\n\t\t\t\treturn true;\r\n\t\t\t\r\n\t\t\t// Special case when matching \r\n\t\t\tif( orgNrIsAlsoSsn && g.isValidSsn(x.orgNumber)) {\r\n\t\t\t\tconst nOrgNr = this.convertService.toNormalizedSsn(orgNr);\r\n\t\t\t\tconst nOrgNumber = this.convertService.toNormalizedSsn(x.orgNumber);\r\n\t\t\t\tconst eq = g.compareSsn(nOrgNr, nOrgNumber);\r\n\t\t\t\tif( eq )\r\n\t\t\t\t\treturn true;\r\n\t\t\t}\r\n\r\n\t\t\treturn false;\r\n\t\t});\r\n\t\tif( r.length===1 )\r\n\t\t\treturn r[0];\r\n\t\telse\r\n\t\t\treturn undefined;\r\n\t}\r\n\r\n\tgetCompanyById(c: Case, companyId: string): Company|undefined {\r\n\t\tif( !c.companies || c.companies.length===0 || !companyId)\r\n\t\t\treturn undefined;\r\n\t\treturn this.getCompanyByIdInArray(c.companies, companyId);\r\n\t}\r\n\r\n\tgetCompanyByIdInArray(companies:Company[], companyId:string): Company|undefined {\r\n\t\tif( !companies || companies.length===0)\r\n\t\t\treturn undefined;\r\n\t\tlet r = companies.filter(x => {\r\n\t\t\t\treturn x.id===companyId;\r\n\t\t});\r\n\t\tif( r.length===1 )\r\n\t\t\treturn r[0];\r\n\t\telse\r\n\t\t\treturn undefined;\r\n\t}\r\n\r\n\taddCompaniesToArrayByOrgnr(companies: Company[], availableCompanies: Company[]) : void {\r\n\t\tif( !availableCompanies || availableCompanies.length===0)\r\n\t\t\treturn;\r\n\t\tavailableCompanies.forEach(x => {\r\n\t\t\tif( !x.orgNumber )\r\n\t\t\t\treturn;\r\n\t\t\tlet existingCompany = this.getCompanyByOrgnrInArray(companies, x.orgNumber);\r\n\t\t\tif( !existingCompany )\r\n\t\t\t\tcompanies.push(x);\r\n\t\t});\r\n\t}\r\n\r\n\tgetApplicantCompany(c:Case, applicant: Applicant) : Company | undefined {\r\n\t\tlet applicantCompany = this.getCompanyByOrgnr(c, applicant.customerId);\r\n\t\tif( !applicantCompany ) {\r\n\t\t\tlet companies = this.getSelectedCompanies(c, applicant);\r\n\t\t\tif( companies && companies.length>0 ) {\r\n\t\t\t\treturn companies[0];\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn applicantCompany;\r\n\t}\r\n\r\n\tgetMySelectedCompanies(c: Case): Company[] | undefined {\r\n\t\tconst applicant = this.applicantService.getMyApplicant(c);\r\n\t\treturn this.getSelectedCompanies(c, applicant);\r\n\t}\r\n\r\n\t\r\n\tgetSelectedCompanies(c: Case, applicant:Applicant): Company[] | undefined {\r\n\t\tif( !c.companies )\r\n\t\t\treturn undefined;\r\n\t\telse {\r\n\t\t\tlet r = this.getSelectedCompaniesInArray(c.companies, applicant);\r\n\t\t\treturn r;\r\n\t\t}\r\n\t}\r\n\r\n\tgetMySelectedCompany(c: Case): Company | undefined {\r\n\t\tconst mySelectedCompanies = this.getMySelectedCompanies(c);\r\n\t\tif( mySelectedCompanies && mySelectedCompanies.length>0 ) {\r\n\t\t\treturn mySelectedCompanies[0];\r\n\t\t}\r\n\t\treturn;\r\n\t}\r\n\r\n\tgetSelectedCompaniesInArray(companies: Company[], applicant:Applicant): Company[] | undefined {\r\n\t\tif( !companies || companies.length===0)\r\n\t\t\treturn undefined;\r\n\r\n\t\tlet r = companies.filter(x => {\r\n\t\t\treturn this.isSelectedByApplicant(x, applicant);\r\n\t\t});\r\n\t\tif( r.length>0 )\r\n\t\t\treturn r;\r\n\t\telse\r\n\t\t\treturn undefined;\r\n\t}\r\n\r\n\tisSelectedByApplicant(company:Company, applicant:Applicant):boolean {\r\n\t\tlet r = this.getPrincipalByCustomerId(company,applicant.customerId);\r\n\t\treturn r?true:false;\r\n\t}\r\n\r\n\tgetPrincipalByCustomerId(company:Company,customerId:string):Principal|undefined {\r\n\t\tif( !company.principals )\r\n\t\t\treturn;\r\n\t\tconst g = this.guardService;\r\n\t\tlet r = company.principals.find(x => g.compareSsn(x.customerId||'',customerId));\r\n\t\treturn r;\r\n\t}\r\n\r\n\taddPrincipalFromApplicant(company:Company, applicant:Applicant):Principal {\r\n\t\tif( !company.principals )\r\n\t\t\tcompany.principals = [];\r\n\t\telse {\r\n\t\t\tlet p = this.getPrincipalByCustomerId(company, applicant.customerId);\r\n\t\t\tif( p )\r\n\t\t\t\treturn p;\r\n\t\t}\r\n\t\tlet principal = {\r\n\t\t\tcustomerId:applicant.customerId,\r\n\t\t\tname: this.applicantService.getPersonFullName(applicant)\r\n\t\t}\r\n\t\tcompany.principals.push(principal);\r\n\t\treturn principal;\r\n\t}\r\n\r\n\tvalidateHasSelectedCompany(c: Case) : ValidationResult {\r\n\r\n\t\tlet vr = this.validateHasCompanies(c);\r\n\t\tif( vr.failed() )\r\n\t\t\treturn vr;\r\n\r\n\t\tvr.add({validator:this.hasSelectedCompany, object:c, ok: this.hasSelectedCompany(c)});\r\n\t\treturn vr;\r\n\t}\r\n\r\n\r\n\tisPhysicum(company: Company):boolean {\r\n\t\treturn company.legalGroupCode!==undefined && company.legalGroupCode!==null && company.legalGroupCode===\"EF\";\r\n\t}\r\n\r\n\tisJuridicum(company: Company):boolean {\r\n\t\treturn company.legalGroupCode!==undefined && company.legalGroupCode!==null && company.legalGroupCode!==\"EF\";\r\n\t}\r\n\r\n\tanyPhysicumCompanies(companies: Company[]):boolean {\r\n\t\treturn companies.filter(x => {\r\n\t\t\treturn this.isPhysicum(x);\r\n\t\t}).length>0;\r\n\t}\r\n\r\n\thasCompanies(c: Case): boolean {\r\n\t\treturn c.companies?true:false;\r\n\t}\r\n\tvalidateHasCompanies(c: Case): ValidationResult {\r\n\t\tvar vr = new ValidationResult();\r\n\t\tvr.add({ validator:this.hasCompanies, object: c, ok: this.hasCompanies(c) });\r\n\t\treturn vr;\r\n\t}\r\n\r\n\thasMinimumBusinessFocuses(company: Company):boolean {\r\n\t\tif( company.businessFocuses && company.businessFocuses.length>0 )\r\n\t\t\treturn true;\r\n\t\treturn false;\r\n\t}\r\n\r\n\tensureMinimumBusinessFocuses(company: Company) {\r\n\t\tif( !this.hasMinimumBusinessFocuses(company)) {\r\n\t\t\tthis.addNewBusinessFocus(company);\r\n\t\t}\r\n\t}\r\n\r\n\tsetBusiniessFocusesPart(company: Company, businessCategory: BusinessCategory, value: number|undefined) {\r\n\r\n\t\tif( value!==undefined && company.businessFocuses && company.businessFocuses.length===2) {\r\n\t\t\tlet otherBusinessFocus = company.businessFocuses[0]===businessCategory?company.businessFocuses[1]:company.businessFocuses[0];\r\n\t\t\totherBusinessFocus.businessPart = 100-value;\r\n\t\t\tthis.updateBusinessFocus(company, otherBusinessFocus);\r\n\t\t}\r\n\r\n\t\tbusinessCategory.businessPart = value;\r\n\t\tthis.updateBusinessFocus(company, businessCategory);\r\n\t}\r\n\r\n\tgetPossibleMainDirectionBusinessFocuses(company:Company) : BusinessCategory[] {\r\n\t\tif( !company.businessFocuses )\r\n\t\t\treturn [];\r\n\t\tif( company.businessFocuses.length<2 )\r\n\t\t\treturn [];\r\n\r\n\t\tconst maxBusinessPart = company.businessFocuses.map(x => x.businessPart||0).reduce((agg,x) => Math.max(agg,x), 0);\r\n\t\tconst countMaxBusinessPart = company.businessFocuses.filter(x => x.businessPart===maxBusinessPart);\r\n\t\tif( countMaxBusinessPart.length>=2 )\r\n\t\t\treturn countMaxBusinessPart;\r\n\t\t\r\n\t\treturn [];\r\n\t}\r\n\r\n\tneedsToSpecifyMainDirectionForBusiniessFocuses(company:Company) : boolean {\r\n\t\treturn this.getPossibleMainDirectionBusinessFocuses(company).length>1;\r\n\t}\r\n\r\n\thasSpecifiedMainDirectionForBusiniessFocuses(company:Company) : boolean {\r\n\t\tlet r = this.getPossibleMainDirectionBusinessFocuses(company).filter(x => x.mainDirection===true);\r\n\t\tif( r.length===1 )\r\n\t\t\treturn true;\r\n\t\treturn false;\r\n\t}\r\n\r\n\tsetBusinessFocusMainDirection(company:Company, businessFocus:BusinessCategory):void {\r\n\t\tif( !company.businessFocuses )\r\n\t\t\treturn;\r\n\r\n\t\tlet changed = false;\r\n\t\tcompany.businessFocuses.forEach(x => {\r\n\t\t\tconst currentMainDirection = x.mainDirection===true;\r\n\t\t\tconst newMainDirection = x===businessFocus;\r\n\t\t\tif( currentMainDirection!==newMainDirection ) {\r\n\t\t\t\tx.mainDirection = newMainDirection;\r\n\t\t\t\tthis.update(x);\r\n\t\t\t\tchanged = true;\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tif( changed ) {\r\n\t\t\tthis.update(company);\r\n\t\t}\r\n\t}\r\n\r\n\tvalidateHasMinimumBussinessFocuses(company: Company): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tvr.add({validator: this.hasMinimumBusinessFocuses, object: company, ok: this.hasMinimumBusinessFocuses(company) })\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tbusinessFocusHasCategory(businessFocus: BusinessCategory) :boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(businessFocus.businessCategoryCode);\r\n\t}\r\n\r\n\tbusinessFocusHasBusinessPart(businessFocus: BusinessCategory) :boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isGreaterThan(businessFocus.businessPart, 0);\r\n\t}\r\n\r\n\tcompanyBusinessFocusBusinessPartSumIsCorrect(company:Company, sum:number) : boolean {\r\n\t\treturn sum===100;\r\n\t}\r\n\r\n\tvalidateBussinessFocuses(company: Company): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tif( company.businessFocuses ) {\r\n\t\t\tcompany.businessFocuses.forEach(x => {\r\n\t\t\t\tvr.add({validator: this.businessFocusHasCategory, object: x, ok: this.businessFocusHasCategory(x) })\r\n\t\t\t})\r\n\r\n\t\t\tlet businessPartSum = 0;\r\n\t\t\tcompany.businessFocuses.forEach(x => {\r\n\t\t\t\tvr.add({validator: this.businessFocusHasBusinessPart, object: x, ok: this.businessFocusHasBusinessPart(x) })\r\n\t\t\t\tconst businessPart = x.businessPart?x.businessPart:0;\r\n\t\t\t\tbusinessPartSum += businessPart;\r\n\t\t\t});\r\n\t\t\tvr.add({validator: this.companyBusinessFocusBusinessPartSumIsCorrect, object: company, args:[businessPartSum], \r\n\t\t\t\tok: this.companyBusinessFocusBusinessPartSumIsCorrect(company, businessPartSum) });\r\n\r\n\t\t\tif( this.needsToSpecifyMainDirectionForBusiniessFocuses(company) ) {\r\n\t\t\t\tlet hasSpecifiedMainDirectionForBusiniessFocuses = this.hasSpecifiedMainDirectionForBusiniessFocuses(company);\r\n\t\t\t\tlet r = this.getPossibleMainDirectionBusinessFocuses(company);\r\n\t\t\t\tr.forEach(x => {\r\n\t\t\t\t\tvr.add({validator: this.hasSpecifiedMainDirectionForBusiniessFocuses, object: x, ok: hasSpecifiedMainDirectionForBusiniessFocuses })\r\n\t\t\t\t})\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn vr;\r\n\t}\r\n\r\n\thasSelectedCompany(c: Case) :boolean {\r\n\t\tconst r = this.getMySelectedCompanies(c);\r\n\t\tconst hasSelectedCompany = r && r.length>0 ? true : false;\r\n\t\tif( hasSelectedCompany )\r\n\t\t\treturn true;\r\n\t\telse {\r\n\t\t\tif( c.applicants && c.applicants.filter(x => x.willBuyAgriForestryProperty===true).length>0 ) {\r\n\t\t\t\treturn true;\r\n\t\t\t}\r\n\t\t\telse \r\n\t\t\t\treturn false;\r\n\t\t}\r\n\t}\r\n\r\n\tgetBusinessFocusesPartSum(company:Company) : number {\r\n\t\tif( !company.businessFocuses )\r\n\t\t\treturn 0;\r\n\t\tlet sum = company.businessFocuses.reduce((agg,x) => agg+(x.businessPart||0), 0);\r\n\t\treturn sum;\r\n\t}\r\n\r\n\taddNewBusinessFocus(company:Company) {\r\n\t\tif( !company.businessFocuses ) {\r\n\t\t\tcompany.businessFocuses = [];\r\n\t\t}\r\n\t\tlet businessFocus:BusinessCategory = {\r\n\t\t\tid: this.idService.newGuid(),\r\n\t\t};\r\n\t\tif( company.businessFocuses.length===0) {\r\n\t\t\tbusinessFocus.businessPart = 100;\r\n\t\t} else {\r\n\t\t\tlet sum = this.getBusinessFocusesPartSum(company);\r\n\t\t\tif( sum<100 ) {\r\n\t\t\t\tbusinessFocus.businessPart = 100-sum;\r\n\t\t\t}\r\n\t\t}\r\n\t\tthis.stateService.listAdd(company.businessFocuses, businessFocus);\r\n\t\tthis.update(company);\r\n\t}\r\n\r\n\tremoveBusinessFocus(company: Company, businessCategory: BusinessCategory) {\r\n\t\tif( !company.businessFocuses ) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tthis.stateService.listRemove(company.businessFocuses, businessCategory);\r\n\t\tthis.update(company);\r\n\r\n\t\tif( company.businessFocuses.length===1 ) {\r\n\t\t\tcompany.businessFocuses[0].businessPart = 100;\r\n\t\t\tthis.update(company.businessFocuses[0]);\r\n\t\t}\r\n\t}\r\n\r\n\tupdateBusinessFocus(company: Company, businessFocus: BusinessCategory) {\r\n\t\tthis.update(company);\r\n\t\tthis.update(businessFocus); \r\n\t}\r\n\r\n\r\n}\r\n","\r\nexport interface UIBusinessCategory {\r\n\tBusinessCategoryID: string;\r\n\tBusinessCategory: string;\r\n}\r\n\r\nexport interface UIBusinessDirection {\r\n\tBusinessDirectionID: string;\r\n\tBusinessDirection: string;\r\n}\r\n\r\n// This array is provided as-is from LHB.\r\nexport let uiBusinessCategories: UIBusinessCategory[] = [\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"1\",\r\n\t\t\"BusinessCategory\": \"Jordbruksväxter\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"2\",\r\n\t\t\"BusinessCategory\": \"Trädgårdsväxter\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"3\",\r\n\t\t\"BusinessCategory\": \"Nötkreatur\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"4\",\r\n\t\t\"BusinessCategory\": \"Får och getter\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"5\",\r\n\t\t\"BusinessCategory\": \"Svinproduktion\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"6\",\r\n\t\t\"BusinessCategory\": \"Fjäderfäskötsel\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"7\",\r\n\t\t\"BusinessCategory\": \"Hästverksamhet\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"8\",\r\n\t\t\"BusinessCategory\": \"Annan djurskötsel\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"9\",\r\n\t\t\"BusinessCategory\": \"Prod av skog\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"10\",\r\n\t\t\"BusinessCategory\": \"Förädling av skog\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"11\",\r\n\t\t\"BusinessCategory\": \"Övrik skogsverksam.\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"12\",\r\n\t\t\"BusinessCategory\": \"Maskinenteprenad\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"13\",\r\n\t\t\"BusinessCategory\": \"Lokaler\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"14\",\r\n\t\t\"BusinessCategory\": \"Turism\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"15\",\r\n\t\t\"BusinessCategory\": \"Tillverkning\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"16\",\r\n\t\t\"BusinessCategory\": \"Tjäns. - konsultv\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"17\",\r\n\t\t\"BusinessCategory\": \"Övrigt\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"101\",\r\n\t\t\"BusinessCategory\": \"Jordbruksväxter\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"102\",\r\n\t\t\"BusinessCategory\": \"Trädgård, grönsaker, frukt & bär\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"103\",\r\n\t\t\"BusinessCategory\": \"Mjölkproduktion\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"104\",\r\n\t\t\"BusinessCategory\": \"Nötkreatur (kött etc.)\"\r\n\t},\t\t\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"105\",\r\n\t\t\"BusinessCategory\": \"Svinproduktion\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"106\",\r\n\t\t\"BusinessCategory\": \"Fjäderfäproduktion\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"107\",\r\n\t\t\"BusinessCategory\": \"Hästverksamhet\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"108\",\r\n\t\t\"BusinessCategory\": \"Annan djurskötsel\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"109\",\r\n\t\t\"BusinessCategory\": \"Skog - Produktion/Förädling/övrigt\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"110\",\r\n\t\t\"BusinessCategory\": \"Maskinentreprenad\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"111\",\r\n\t\t\"BusinessCategory\": \"Elproduktion\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"112\",\r\n\t\t\"BusinessCategory\": \"Förädling av egna produkter/Konferens & Upplevelseverksamhet\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"113\",\r\n\t\t\"BusinessCategory\": \"Inkomst av tjänst och kapital/övrigt\"\r\n\t},\r\n\t{\r\n\t\t\"BusinessCategoryID\": \"114\",\r\n\t\t\"BusinessCategory\": \"Arrende- och hyresintäkter\"\r\n\t}\t\t\t\r\n];\r\n","import { UIKeyed } from \"./UIKeyed\";\r\nimport { UINamed } from \"./UINamed\";\r\nimport { EUSupportEnum } from \"../SelmaModels\";\r\n\r\nexport interface UIEUSupport extends UIKeyed, UINamed {\r\n\ttype: EUSupportEnum;\r\n}\r\n\r\nexport const uiEUSupports:UIEUSupport[] = [\r\n\t{ key:'EU', name:'EU-stöd', nameTextkey:\"UIEUSupport_EU\", type:EUSupportEnum.EU },\r\n\t{ key:'EUNAT', name:'EU-stöd och nationellt stöd', nameTextkey:\"UIEUSupport_EUNAT\", type:EUSupportEnum.EUNAT },\r\n\t{ key:'EUNAT_NOMILK', name:'EU-stöd och nationellt stöd, utan mjölk', nameTextkey:\"UIEUSupport_EUNAT_NOMILK\", type:EUSupportEnum.EUNAT_NOMILK },\r\n\t{ key:'NAT_NOMILK', name:'Nationellt stöd, utan mjölk', nameTextkey:\"UIEUSupport_NAT_NOMILK\", type:EUSupportEnum.NAT_NOMILK }\r\n];\r\n\r\n","import { UIKeyed } from \"./UIKeyed\";\r\nimport { UINamed } from \"./UINamed\";\r\nimport { TypeOfHouse } from \"../../libs/SMELPOClient\";\r\n\r\nexport interface UIEstateType extends UIKeyed, UINamed {\r\n\tid:number;\r\n\ttype: TypeOfHouse;\r\n}\r\n\r\nexport const uiEstateTypes:UIEstateType[] = [\r\n\t{ id: 1, key: 'HOUSE', name: \"Villa\", nameTextkey: \"EstateType_HOUSE\", type:TypeOfHouse.Villa }, \r\n\t{ id: 2, key: 'VACATIONHOUSE', name: \"Fritidshus\", nameTextkey: \"EstateType_VACATIONHOUSE\", type:TypeOfHouse.Fritidshus },\r\n\t{ id: 3, key: 'TENANCY', name: \"Hyresrätt\", nameTextkey: \"EstateType_TENANCY\", type:TypeOfHouse.Hyresrtt },\r\n\t{ id: 4, key: 'APARTMENT', name: \"Bostadsrätt\", nameTextkey: \"EstateType_APARTMENT\", type:TypeOfHouse.Bostadsrtt },\r\n\t{ id: 6, key: 'FARM', name: \"Lantbruksfastighet\", nameTextkey: \"EstateType_FARM\", type:TypeOfHouse.Landbruksfastighet },\r\n\t{ id: 5, key: 'OTHER', name: \"Övrigt boende\", nameTextkey: \"EstateType_OTHER\", type:TypeOfHouse.VrigtBoende }\r\n];","import { UINamed } from \"./UINamed\";\r\n\r\nexport interface UIHighRiskCategory extends UINamed {\r\n\tid: number;\r\n}\r\n\r\nexport const uiHighRiskCategories: UIHighRiskCategory[] = [\r\n\t{ id: 0, name: 'Nej, inget av nedanstående', nameTextkey: 'HighRiskCategory_EMPTY' },\r\n\t{\r\n\t\tid: 1,\r\n\t\tname: 'Utvinning av uran- och/eller toriummalm/Vapenhandlare',\r\n\t\tnameTextkey: 'HighRiskCategory_07210',\r\n\t},\r\n\t{\r\n\t\tid: 2,\r\n\t\tname: 'Sprängämnestillverkning/Vapenhandlare',\r\n\t\tnameTextkey: 'HighRiskCategory_20510',\r\n\t},\r\n\t{\r\n\t\tid: 3,\r\n\t\tname: 'Tillverkning av kärnbränsle/Vapenhandlare',\r\n\t\tnameTextkey: 'HighRiskCategory_24460',\r\n\t},\r\n\t{\r\n\t\tid: 4,\r\n\t\tname: 'Tillverkning av vapen och ammunition/Vapenhandlare',\r\n\t\tnameTextkey: 'HighRiskCategory_25400',\r\n\t},\r\n\t{\r\n\t\tid: 5,\r\n\t\tname: 'Tillverkning av militära stridsfordon/Vapenhandlare',\r\n\t\tnameTextkey: 'HighRiskCategory_30400',\r\n\t},\r\n\t{\r\n\t\tid: 6,\r\n\t\tname: 'Specialiserad butikshandel med ur',\r\n\t\tnameTextkey: 'HighRiskCategory_47771',\r\n\t},\r\n\t{\r\n\t\tid: 7,\r\n\t\tname:\r\n\t\t\t'Specialiserad butikshandel med guldsmedsvaror och smycken (av ädel metall)',\r\n\t\tnameTextkey: 'HighRiskCategory_47772',\r\n\t},\r\n\t{\r\n\t\tid: 8,\r\n\t\tname: 'Specialiserad butikshandel med konst samt galleriverksamhet',\r\n\t\tnameTextkey: 'HighRiskCategory_47783',\r\n\t},\r\n\t{\r\n\t\tid: 9,\r\n\t\tname: 'Specialiserad butikshandel med mynt och frimärken',\r\n\t\tnameTextkey: 'HighRiskCategory_47784',\r\n\t},\r\n\t{\r\n\t\tid: 10,\r\n\t\tname: 'Specialiserad butikshandel med antikviteter',\r\n\t\tnameTextkey: 'HighRiskCategory_47791',\r\n\t},\r\n\t{ id: 11, name: 'Auktioner i butik', nameTextkey: 'HighRiskCategory_47793' },\r\n\t{ id: 12, name: 'Auktioner på Internet', nameTextkey: 'HighRiskCategory_47917' },\r\n\t{\r\n\t\tid: 13,\r\n\t\tname:\r\n\t\t\t'Postorderhandel och detaljhandel på Internet med övriga varor (apoteksartiklar)',\r\n\t\tnameTextkey: 'HighRiskCategory_47919',\r\n\t},\r\n\t{\r\n\t\tid: 14,\r\n\t\tname: 'Auktioner ej i butiker eller på Internet',\r\n\t\tnameTextkey: 'HighRiskCategory_47994',\r\n\t},\r\n\t{\r\n\t\tid: 15,\r\n\t\tname: 'Valutaväxling, växlingskontor',\r\n\t\tnameTextkey: 'HighRiskCategory_66120',\r\n\t},\r\n\t{ id: 16, name: 'Betalningsförmedling', nameTextkey: 'HighRiskCategory_66190' },\r\n\t{ id: 17, name: 'Fastighetsförmedling', nameTextkey: 'HighRiskCategory_68310' },\r\n\t{ id: 18, name: 'Humanitära insatser', nameTextkey: 'HighRiskCategory_88994' },\r\n\t{\r\n\t\tid: 19,\r\n\t\tname: 'Spel- och vadhållningsverksamhet',\r\n\t\tnameTextkey: 'HighRiskCategory_92000',\r\n\t},\r\n\t{\r\n\t\tid: 101,\r\n\t\tname: 'Handel, service och reparation av motorfordon, motorcyklar, båt mm',\r\n\t\tnameTextkey: 'HighRiskCategory_45'\r\n\t},\r\n\t{\r\n\t\tid: 102,\r\n\t\tname: 'Taxiverksamhet',\r\n\t\tnameTextkey: 'HighRiskCategory_49'\r\n\t},\r\n\t{\r\n\t\tid: 103,\r\n\t\tname: 'Butikshandel med klockor, smycken, konst, antikviteter, auktioner mm',\r\n\t\tnameTextkey: 'HighRiskCategory_4777'\r\n\t},\r\n\t{\r\n\t\tid: 104,\r\n\t\tname: 'Gruvdrift, stenkol',\r\n\t\tnameTextkey: 'HighRiskCategory_5100'\r\n\t},\r\n\t{\r\n\t\tid: 105,\r\n\t\tname: 'Gruvdrift, brytning brunkol',\r\n\t\tnameTextkey: 'HighRiskCategory_5200'\r\n\t},\r\n\t{\r\n\t\tid: 106,\r\n\t\tname: 'Förvaltning och uthyrning av egna eller arrenderade fastigheter',\r\n\t\tnameTextkey: 'HighRiskCategory_6820'\r\n\t},\r\n\t{\r\n\t\tid: 107,\r\n\t\tname: 'Juridisk verksamhet',\r\n\t\tnameTextkey: 'HighRiskCategory_6910'\r\n\t},\r\n\t{\r\n\t\tid: 108,\r\n\t\tname: 'Revision, bokföring, skatterådgivning',\r\n\t\tnameTextkey: 'HighRiskCategory_6920'\r\n\t},\r\n\t{\r\n\t\tid: 109,\r\n\t\tname: 'Gruvdrift, järnmalm',\r\n\t\tnameTextkey: 'HighRiskCategory_7100'\r\n\t},\r\n\t{\r\n\t\tid: 110,\r\n\t\tname: 'Utvinning av uran- och toriummalm',\r\n\t\tnameTextkey: 'HighRiskCategory_7210'\r\n\t},\r\n\t{\r\n\t\tid: 111,\r\n\t\tname: 'Gruvdrift, icke-järnmalm (utom uranmalm och toriummalm)',\r\n\t\tnameTextkey: 'HighRiskCategory_7290'\r\n\t},\r\n\t{\r\n\t\tid: 113,\r\n\t\tname: 'Petroleumraffinering',\r\n\t\tnameTextkey: 'HighRiskCategory_19200'\r\n\t},\r\n\t{\r\n\t\tid: 114,\r\n\t\tname: 'Industrigasframställning',\r\n\t\tnameTextkey: 'HighRiskCategory_20110'\r\n\t},\r\n\t{\r\n\t\tid: 115,\r\n\t\tname: 'Sprängämnestillverkning',\r\n\t\tnameTextkey: 'HighRiskCategory_20510'\r\n\t},\r\n\t{\r\n\t\tid: 116,\r\n\t\tname: 'Tillverkning av kärnbränsle',\r\n\t\tnameTextkey: 'HighRiskCategory_24460'\r\n\t},\r\n\t{\r\n\t\tid: 117,\r\n\t\tname: 'Tillverkning av vapen och ammunition/Vapenhandlare',\r\n\t\tnameTextkey: 'HighRiskCategory_25400'\r\n\t},\r\n\t{\r\n\t\tid: 118,\r\n\t\tname: 'Tillverkning av militära stridsfordon',\r\n\t\tnameTextkey: 'HighRiskCategory_30400'\r\n\t},\r\n\t{\r\n\t\tid: 119,\r\n\t\tname: 'Övriga anläggningsarbeten',\r\n\t\tnameTextkey: 'HighRiskCategory_42990'\r\n\t},\r\n\t{\r\n\t\tid: 120,\r\n\t\tname: 'Uthyrning av bygg- och anläggningsmaskiner',\r\n\t\tnameTextkey: 'HighRiskCategory_43991'\r\n\t},\r\n\t{\r\n\t\tid: 121,\r\n\t\tname: 'Övrig specialiserad bygg- och anläggningsverksamhet',\r\n\t\tnameTextkey: 'HighRiskCategory_43999'\r\n\t},\r\n\t{\r\n\t\tid: 122,\r\n\t\tname: 'Provisionshandel med bränsle, malm, metaller och industrikemikalier',\r\n\t\tnameTextkey: 'HighRiskCategory_46120'\r\n\t},\r\n\t{\r\n\t\tid: 123,\r\n\t\tname: 'Partihandel med diverse andra maskiner och diverse annan utrustning',\r\n\t\tnameTextkey: 'HighRiskCategory_46699'\r\n\t},\r\n\t{\r\n\t\tid: 124,\r\n\t\tname: 'Partihandel med bränsle',\r\n\t\tnameTextkey: 'HighRiskCategory_46710'\r\n\t},\r\n\t{\r\n\t\tid: 125,\r\n\t\tname: 'Specialiserad detaljhandel med drivmedel',\r\n\t\tnameTextkey: 'HighRiskCategory_47300'\r\n\t},\r\n\t{\r\n\t\tid: 126,\r\n\t\tname: 'Butikshandel med konst samt galleriverksamhet',\r\n\t\tnameTextkey: 'HighRiskCategory_47783'\r\n\t},\r\n\t{\r\n\t\tid: 127,\r\n\t\tname: 'Butikshandel med mynt och frimärken',\r\n\t\tnameTextkey: 'HighRiskCategory_47784'\r\n\t},\r\n\t{\r\n\t\tid: 128,\r\n\t\tname: 'Vapen för krigsändamål-partihandel vapen och ammunition',\r\n\t\tnameTextkey: 'HighRiskCategory_47789'\r\n\t},\r\n\t{\r\n\t\tid: 129,\r\n\t\tname: 'Butikshandel med antikviteter',\r\n\t\tnameTextkey: 'HighRiskCategory_47791'\r\n\t},\r\n\t{\r\n\t\tid: 130,\r\n\t\tname: 'Auktioner i butik',\r\n\t\tnameTextkey: 'HighRiskCategory_47793'\r\n\t},\r\n\t{\r\n\t\tid: 131,\r\n\t\tname: 'Auktioner på Internet',\r\n\t\tnameTextkey: 'HighRiskCategory_47917'\r\n\t},\r\n\t{\r\n\t\tid: 132,\r\n\t\tname: 'Postorderhandel och detaljhandel på Internet med övriga varor',\r\n\t\tnameTextkey: 'HighRiskCategory_47919'\r\n\t},\r\n\t{\r\n\t\tid: 133,\r\n\t\tname: 'Auktioner ej i butiker eller på Internet',\r\n\t\tnameTextkey: 'HighRiskCategory_47994'\r\n\t},\r\n\t{\r\n\t\tid: 134,\r\n\t\tname: 'Restaurang, fik, gårdförsäljning mm',\r\n\t\tnameTextkey: 'HighRiskCategory_56100'\r\n\t},\r\n\t{\r\n\t\tid: 135,\r\n\t\tname: 'Värdepappersfonder',\r\n\t\tnameTextkey: 'HighRiskCategory_64301'\r\n\t},\r\n\t{\r\n\t\tid: 136,\r\n\t\tname: 'Annan kreditgivning',\r\n\t\tnameTextkey: 'HighRiskCategory_64920'\r\n\t},\r\n\t{\r\n\t\tid: 137,\r\n\t\tname: 'Handel med och förvaltning av värdepapper, för egen räkning (med tillstånd från Finansinspektionen)',\r\n\t\tnameTextkey: 'HighRiskCategory_64992'\r\n\t},\r\n\t{\r\n\t\tid: 138,\r\n\t\tname: 'Förvaltning och handel med värdepapper för annans räkning i mindre krets',\r\n\t\tnameTextkey: 'HighRiskCategory_64993'\r\n\t},\r\n\t{\r\n\t\tid: 139,\r\n\t\tname: 'Drift av auktoriserade marknadsplatser för värdepapper och råvaror',\r\n\t\tnameTextkey: 'HighRiskCategory_66110'\r\n\t},\r\n\t{\r\n\t\tid: 140,\r\n\t\tname: 'Valutaväxling, växlingskontor',\r\n\t\tnameTextkey: 'HighRiskCategory_66120'\r\n\t},\r\n\t{\r\n\t\tid: 141,\r\n\t\tname: 'Andra stödtjänster till finansiella tjänster utom försäkring och pensionsfondsverksamhet',\r\n\t\tnameTextkey: 'HighRiskCategory_66190'\r\n\t},\r\n\t{\r\n\t\tid: 142,\r\n\t\tname: 'Fondförvaltning av värdepappersfonder, för annans räkning (tillstånd krävs från Finansinspektionen)',\r\n\t\tnameTextkey: 'HighRiskCategory_66301'\r\n\t},\r\n\t{\r\n\t\tid: 143,\r\n\t\tname: 'Fastighetsförmedling',\r\n\t\tnameTextkey: 'HighRiskCategory_68310'\r\n\t},\r\n\t{\r\n\t\tid: 144,\r\n\t\tname: 'Övriga företagstjänster',\r\n\t\tnameTextkey: 'HighRiskCategory_82990'\r\n\t},\r\n\t{\r\n\t\tid: 145,\r\n\t\tname: 'Utrikesförvaltning',\r\n\t\tnameTextkey: 'HighRiskCategory_84210'\r\n\t},\r\n\t{\r\n\t\tid: 146,\r\n\t\tname: 'Heldygnsvård med boende för barn och ungdomar',\r\n\t\tnameTextkey: 'HighRiskCategory_87901'\r\n\t},\r\n\t{\r\n\t\tid: 147,\r\n\t\tname: 'Öppna sociala insatser för äldre personer',\r\n\t\tnameTextkey: 'HighRiskCategory_88101'\r\n\t},\r\n\t{\r\n\t\tid: 148,\r\n\t\tname: 'Öppna sociala insatser för personer med funktionshinder',\r\n\t\tnameTextkey: 'HighRiskCategory_88102'\r\n\t},\r\n\t{\r\n\t\tid: 149,\r\n\t\tname: 'Humanitära insatser',\r\n\t\tnameTextkey: 'HighRiskCategory_88994'\r\n\t},\r\n\t{\r\n\t\tid: 150,\r\n\t\tname: 'Drift av flyktingförläggning',\r\n\t\tnameTextkey: 'HighRiskCategory_88995'\r\n\t},\r\n\t{\r\n\t\tid: 151,\r\n\t\tname: 'Spel- och vadhållningsverksamhet',\r\n\t\tnameTextkey: 'HighRiskCategory_92000'\r\n\t},\r\n\t{\r\n\t\tid: 152,\r\n\t\tname: 'Skönhetsbehandling, manikyr, mm',\r\n\t\tnameTextkey: 'HighRiskCategory_96022'\r\n\t},\r\n\t{\r\n\t\tid: 153,\r\n\t\tname: 'Massage, kroppsvård mm',\r\n\t\tnameTextkey: 'HighRiskCategory_96040'\r\n\t},\r\n\t{\r\n\t\tid: 154,\r\n\t\tname: 'Verksamhet vid internationella organisationer, utländska ambassader o.d.',\r\n\t\tnameTextkey: 'HighRiskCategory_99000'\r\n\t}\r\n];\r\n\r\n\r\n/*\r\n[\r\n\t\"Andra stödtjänster till finansiella tjänster utom försäkring och pensionsfondsverksamhet\",\r\n\t\"Annan kreditgivning\",\r\n\t\"Auktioner ej i butiker eller på Internet\",\r\n\t\"Auktioner i butik\",\r\n\t\"Auktioner på Internet\",\r\n\t\"Butikshandel med antikviteter\",\r\n\t\"Butikshandel med klockor, smycken, konst, antikviteter, auktioner mm\",\r\n\t\"Butikshandel med konst samt galleriverksamhet\",\r\n\t\"Butikshandel med mynt och frimärken\",\r\n\t\"Drift av auktoriserade marknadsplatser för vardepapper och råvaror\",\r\n\t\"Drift av flyktingförläggning\",\r\n\t\"Fastighetsförmedling\",\r\n\t\"Fondförvaltning av värdepappersfonder, för annans räkning (tillstånd krävs från Finansinspektionen)\",\r\n\t\"Förvaltning och handel med värdepapper för annans räkning i mindre krets\",\r\n\t\"Förvaltning och uthyrning av egna eller arrenderade fastigheter\",\r\n\t\"Gruvdrift, brytning brunkol\",\r\n\t\"Gruvdrift, icke-järnmalm (utom uranmalm och toriummalm)\",\r\n\t\"Gruvdrift, järnmalm\",\r\n\t\"Gruvdrift, stenkol\",\r\n\t\"Handel med och förvaltning av värdepapper för egen räkning (med tillstånd från Finansinspektionen)\",\r\n\t\"Handel, service och reparation av motorfordon, motorcyklar, båt mm\",\r\n\t\"Heldygnsvård med boende för barn och ungdomar\",\r\n\t\"Humanitära insatser\",\r\n\t\"Industrigasframställning\",\r\n\t\"Juridisk verksamhet\",\r\n\t\"Massage, kroppsvård mm\",\r\n\t\"Oppna sociala insatser för personer med funktionshinder\",\r\n\t\"Oppna sociala insatser för äldre personer\",\r\n\t\"Ovriga företagstjänster\",\r\n\t\"Partihandel med bränslen\",\r\n\t\"Partihandel med diverse andra maskiner och diverse annan utrustning\",\r\n\t\"Petroleumraffinering\",\r\n\t\"Postorderhandel och detaljhandel på Internet med övriga varor\",\r\n\t\"Provisionshandel med bränsle, malm, metaller och industrikemikalier\",\r\n\t\"Restaurang, fik, gårdsförsäljning mm\",\r\n\t\"Revision, bokföring, skatterådgivning\",\r\n\t\"Skönhetsbehandling, manikyr, mm\",\r\n\t\"Specialiserad detaljhandel med drivmedel\",\r\n\t\"Spel- och vadhållningsverksamhet\",\r\n\t\"Sprängämnestillverkning\",\r\n\t\"Taxiverksamhet\",\r\n\t\"Tillverkning av kärnbränsle\",\r\n\t\"Tillverkning av militära stridsfordon\",\r\n\t\"Tillverkning av vapen och ammunitionNapenhandlare\",\r\n\t\"Uthyrning av bygg- och anläggningsmaskiner\",\r\n\t\"Utrikesförvaltning\",\r\n\t\"Utvinning av uran- och toriummalm\",\r\n\t\"Valutaväxling, växlingskontor\",\r\n\t\"Vapen för krigsändamål-partihandel vapen och ammunition\",\r\n\t\"Verksamhet vid internationella organisationer, utländska ambassader o d\",\r\n\t\"Värdepappersfonder\",\r\n\t\"Övrig specialiserad bygg- och anläggningsverksamhet\",\r\n\t\"Övriga anläggningsarbeten\"\r\n];\r\n*/","\r\nexport interface UIMunicipality {\r\n\tid: string;\r\n\tname: string;\r\n}\r\n\r\nexport const uiMunicipalities:UIMunicipality[] = [\r\n\t{ id: \"0114\", name: \"Upplands Väsby\"},\r\n\t{ id: \"0115\", name: \"Vallentuna\"},\r\n\t{ id: \"0117\", name: \"Österåker\"},\r\n\t{ id: \"0120\", name: \"Värmdö\"},\r\n\t{ id: \"0123\", name: \"Järfälla\"},\r\n\t{ id: \"0125\", name: \"Ekerö\"},\r\n\t{ id: \"0126\", name: \"Huddinge\"},\r\n\t{ id: \"0127\", name: \"Botkyrka\"},\r\n\t{ id: \"0128\", name: \"Salem\"},\r\n\t{ id: \"0136\", name: \"Haninge\"},\r\n\t{ id: \"0138\", name: \"Tyresö\"},\r\n\t{ id: \"0139\", name: \"Upplands-Bro\"},\r\n\t{ id: \"0140\", name: \"Nykvarn\"},\r\n\t{ id: \"0160\", name: \"Täby\"},\r\n\t{ id: \"0162\", name: \"Danderyd\"},\r\n\t{ id: \"0163\", name: \"Sollentuna\"},\r\n\t{ id: \"0180\", name: \"Stockholm\"},\r\n\t{ id: \"0181\", name: \"Södertälje\"},\r\n\t{ id: \"0182\", name: \"Nacka\"},\r\n\t{ id: \"0183\", name: \"Sundbyberg\"},\r\n\t{ id: \"0184\", name: \"Solna\"},\r\n\t{ id: \"0186\", name: \"Lidingö\"},\r\n\t{ id: \"0187\", name: \"Vaxholm\"},\r\n\t{ id: \"0188\", name: \"Norrtälje\"},\r\n\t{ id: \"0191\", name: \"Sigtuna\"},\r\n\t{ id: \"0192\", name: \"Nynäshamn\"},\r\n\r\n\t{ id: \"0305\", name: \"Håbo\"},\r\n\t{ id: \"0319\", name: \"Älvkarleby\"},\r\n\t{ id: \"0330\", name: \"Knivsta\"},\r\n\t{ id: \"0331\", name: \"Heby\"},\r\n\t{ id: \"0360\", name: \"Tierp\"},\r\n\t{ id: \"0380\", name: \"Uppsala\"},\r\n\t{ id: \"0381\", name: \"Enköping\"},\r\n\t{ id: \"0382\", name: \"Östhammar\"},\r\n\r\n\t{ id: \"0428\", name: \"Vingåker\"},\r\n\t{ id: \"0461\", name: \"Gnesta\"},\r\n\t{ id: \"0480\", name: \"Nyköping\"},\r\n\t{ id: \"0481\", name: \"Oxelösund\"},\r\n\t{ id: \"0482\", name: \"Flen\"},\r\n\t{ id: \"0483\", name: \"Katrineholm\"},\r\n\t{ id: \"0484\", name: \"Eskilstuna\"},\r\n\t{ id: \"0486\", name: \"Strängnäs\"},\r\n\t{ id: \"0488\", name: \"Trosa\"},\r\n\r\n\t{ id: \"0509\", name: \"Ödeshög\"},\r\n\t{ id: \"0512\", name: \"Ydre\"},\r\n\t{ id: \"0513\", name: \"Kinda\"},\r\n\t{ id: \"0560\", name: \"Boxholm\"},\r\n\t{ id: \"0561\", name: \"Åtvidaberg\"},\r\n\t{ id: \"0562\", name: \"Finspång\"},\r\n\t{ id: \"0563\", name: \"Valdemarsvik\"},\r\n\t{ id: \"0580\", name: \"Linköping\"},\r\n\t{ id: \"0581\", name: \"Norrköping\"},\r\n\t{ id: \"0582\", name: \"Söderköping\"},\r\n\t{ id: \"0583\", name: \"Motala\"},\r\n\t{ id: \"0584\", name: \"Vadstena\"},\r\n\t{ id: \"0586\", name: \"Mjölby\"},\r\n\r\n\t{ id: \"0604\", name: \"Aneby\"},\r\n\t{ id: \"0617\", name: \"Gnosjö\"},\r\n\t{ id: \"0642\", name: \"Mullsjö\"},\r\n\t{ id: \"0643\", name: \"Habo\"},\r\n\t{ id: \"0662\", name: \"Gislaved\"},\r\n\t{ id: \"0665\", name: \"Vaggeryd\"},\r\n\t{ id: \"0680\", name: \"Jönköping\"},\r\n\t{ id: \"0682\", name: \"Nässjö\"},\r\n\t{ id: \"0683\", name: \"Värnamo\"},\r\n\t{ id: \"0684\", name: \"Sävsjö\"},\r\n\t{ id: \"0685\", name: \"Vetlanda\"},\r\n\t{ id: \"0686\", name: \"Eksjö\"},\r\n\t{ id: \"0687\", name: \"Tranås\"},\r\n\r\n\t{ id: \"0760\", name: \"Uppvidinge\"},\r\n\t{ id: \"0761\", name: \"Lessebo\"},\r\n\t{ id: \"0763\", name: \"Tingsryd\"},\r\n\t{ id: \"0764\", name: \"Alvesta\"},\r\n\t{ id: \"0765\", name: \"Älmhult\"},\r\n\t{ id: \"0767\", name: \"Markaryd\"},\r\n\t{ id: \"0780\", name: \"Växjö\"},\r\n\t{ id: \"0781\", name: \"Ljungby\"},\r\n\r\n\t{ id: \"0821\", name: \"Högsby\"},\r\n\t{ id: \"0834\", name: \"Torsås\"},\r\n\t{ id: \"0840\", name: \"Mörbylånga\"},\r\n\t{ id: \"0860\", name: \"Hultsfred\"},\r\n\t{ id: \"0861\", name: \"Mönsterås\"},\r\n\t{ id: \"0862\", name: \"Emmaboda\"},\r\n\t{ id: \"0880\", name: \"Kalmar\"},\r\n\t{ id: \"0881\", name: \"Nybro\"},\r\n\t{ id: \"0882\", name: \"Oskarshamn\"},\r\n\t{ id: \"0883\", name: \"Västervik\"},\r\n\t{ id: \"0884\", name: \"Vimmerby\"},\r\n\t{ id: \"0885\", name: \"Borgholm\"},\r\n\r\n\t{ id: \"0980\", name: \"Gotland\"},\r\n\r\n\t{ id: \"1060\", name: \"Olofström\"},\r\n\t{ id: \"1080\", name: \"Karlskrona\"},\r\n\t{ id: \"1081\", name: \"Ronneby\"},\r\n\t{ id: \"1082\", name: \"Karlshamn\"},\r\n\t{ id: \"1083\", name: \"Sölvesborg\"},\r\n\r\n\t{ id: \"1214\", name: \"Svalöv\"},\r\n\t{ id: \"1230\", name: \"Staffanstorp\"},\r\n\t{ id: \"1231\", name: \"Burlöv\"},\r\n\t{ id: \"1233\", name: \"Vellinge\"},\r\n\t{ id: \"1256\", name: \"Östra Göinge\"},\r\n\t{ id: \"1257\", name: \"Örkelljunga\"},\r\n\t{ id: \"1260\", name: \"Bjuv\"},\r\n\t{ id: \"1261\", name: \"Kävlinge\"},\r\n\t{ id: \"1262\", name: \"Lomma\"},\r\n\t{ id: \"1263\", name: \"Svedala\"},\r\n\t{ id: \"1264\", name: \"Skurup\"},\r\n\t{ id: \"1265\", name: \"Sjöbo\"},\r\n\t{ id: \"1266\", name: \"Hörby\"},\r\n\t{ id: \"1267\", name: \"Höör\"},\r\n\t{ id: \"1270\", name: \"Tomelilla\"},\r\n\t{ id: \"1272\", name: \"Bromölla\"},\r\n\t{ id: \"1273\", name: \"Osby\"},\r\n\t{ id: \"1275\", name: \"Perstorp\"},\r\n\t{ id: \"1276\", name: \"Klippan\"},\r\n\t{ id: \"1277\", name: \"Åstorp\"},\r\n\t{ id: \"1278\", name: \"Båstad\"},\r\n\t{ id: \"1280\", name: \"Malmö\"},\r\n\t{ id: \"1281\", name: \"Lund\"},\r\n\t{ id: \"1282\", name: \"Landskrona\"},\r\n\t{ id: \"1283\", name: \"Helsingborg\"},\r\n\t{ id: \"1284\", name: \"Höganäs\"},\r\n\t{ id: \"1285\", name: \"Eslöv\"},\r\n\t{ id: \"1286\", name: \"Ystad\"},\r\n\t{ id: \"1287\", name: \"Trelleborg\"},\r\n\t{ id: \"1290\", name: \"Kristianstad\"},\r\n\t{ id: \"1291\", name: \"Simrishamn\"},\r\n\t{ id: \"1292\", name: \"Ängelholm\"},\r\n\t{ id: \"1293\", name: \"Hässleholm\"},\r\n\r\n\t{ id: \"1315\", name: \"Hylte\"},\r\n\t{ id: \"1380\", name: \"Halmstad\"},\r\n\t{ id: \"1381\", name: \"Laholm\"},\r\n\t{ id: \"1382\", name: \"Falkenberg\"},\r\n\t{ id: \"1383\", name: \"Varberg\"},\r\n\t{ id: \"1384\", name: \"Kungsbacka\"},\r\n\r\n\t{ id: \"1401\", name: \"Härryda\"},\r\n\t{ id: \"1402\", name: \"Partille\"},\r\n\t{ id: \"1407\", name: \"Öckerö\"},\r\n\t{ id: \"1415\", name: \"Stenungsund\"},\r\n\t{ id: \"1419\", name: \"Tjörn\"},\r\n\t{ id: \"1421\", name: \"Orust\"},\r\n\t{ id: \"1427\", name: \"Sotenäs\"},\r\n\t{ id: \"1430\", name: \"Munkedal\"},\r\n\t{ id: \"1435\", name: \"Tanum\"},\r\n\t{ id: \"1438\", name: \"Dals-Ed\"},\r\n\t{ id: \"1439\", name: \"Färgelanda\"},\r\n\t{ id: \"1440\", name: \"Ale\"},\r\n\t{ id: \"1441\", name: \"Lerum\"},\r\n\t{ id: \"1442\", name: \"Vårgårda\"},\r\n\t{ id: \"1443\", name: \"Bollebygd\"},\r\n\t{ id: \"1444\", name: \"Grästorp\"},\r\n\t{ id: \"1445\", name: \"Essunga\"},\r\n\t{ id: \"1446\", name: \"Karlsborg\"},\r\n\t{ id: \"1447\", name: \"Gullspång\"},\r\n\t{ id: \"1452\", name: \"Tranemo\"},\r\n\t{ id: \"1460\", name: \"Bengtsfors\"},\r\n\t{ id: \"1461\", name: \"Mellerud\"},\r\n\t{ id: \"1462\", name: \"Lilla Edet\"},\r\n\t{ id: \"1463\", name: \"Mark\"},\r\n\t{ id: \"1465\", name: \"Svenljunga\"},\r\n\t{ id: \"1466\", name: \"Herrljunga\"},\r\n\t{ id: \"1470\", name: \"Vara\"},\r\n\t{ id: \"1471\", name: \"Götene\"},\r\n\t{ id: \"1472\", name: \"Tibro\"},\r\n\t{ id: \"1473\", name: \"Töreboda\"},\r\n\t{ id: \"1480\", name: \"Göteborg\"},\r\n\t{ id: \"1481\", name: \"Mölndal\"},\r\n\t{ id: \"1482\", name: \"Kungälv\"},\r\n\t{ id: \"1484\", name: \"Lysekil\"},\r\n\t{ id: \"1485\", name: \"Uddevalla\"},\r\n\t{ id: \"1486\", name: \"Strömstad\"},\r\n\t{ id: \"1487\", name: \"Vänersborg\"},\r\n\t{ id: \"1488\", name: \"Trollhättan\"},\r\n\t{ id: \"1489\", name: \"Alingsås\"},\r\n\t{ id: \"1490\", name: \"Borås\"},\r\n\t{ id: \"1491\", name: \"Ulricehamn\"},\r\n\t{ id: \"1492\", name: \"Åmål\"},\r\n\t{ id: \"1493\", name: \"Mariestad\"},\r\n\t{ id: \"1494\", name: \"Lidköping\"},\r\n\t{ id: \"1495\", name: \"Skara\"},\r\n\t{ id: \"1496\", name: \"Skövde\"},\r\n\t{ id: \"1497\", name: \"Hjo\"},\r\n\t{ id: \"1498\", name: \"Tidaholm\"},\r\n\t{ id: \"1499\", name: \"Falköping\"},\r\n\r\n\t{ id: \"1715\", name: \"Kil\"},\r\n\t{ id: \"1730\", name: \"Eda\"},\r\n\t{ id: \"1737\", name: \"Torsby\"},\r\n\t{ id: \"1760\", name: \"Storfors\"},\r\n\t{ id: \"1761\", name: \"Hammarö\"},\r\n\t{ id: \"1762\", name: \"Munkfors\"},\r\n\t{ id: \"1763\", name: \"Forshaga\"},\r\n\t{ id: \"1764\", name: \"Grums\"},\r\n\t{ id: \"1765\", name: \"Årjäng\"},\r\n\t{ id: \"1766\", name: \"Sunne\"},\r\n\t{ id: \"1780\", name: \"Karlstad\"},\r\n\t{ id: \"1781\", name: \"Kristinehamn\"},\r\n\t{ id: \"1782\", name: \"Filipstad\"},\r\n\t{ id: \"1783\", name: \"Hagfors\"},\r\n\t{ id: \"1784\", name: \"Arvika\"},\r\n\t{ id: \"1785\", name: \"Säffle\"},\r\n\r\n\t{ id: \"1814\", name: \"Lekeberg\"},\r\n\t{ id: \"1860\", name: \"Laxå\"},\r\n\t{ id: \"1861\", name: \"Hallsberg\"},\r\n\t{ id: \"1862\", name: \"Degerfors\"},\r\n\t{ id: \"1863\", name: \"Hällefors\"},\r\n\t{ id: \"1864\", name: \"Ljusnarsberg\"},\r\n\t{ id: \"1880\", name: \"Örebro\"},\r\n\t{ id: \"1881\", name: \"Kumla\"},\r\n\t{ id: \"1882\", name: \"Askersund\"},\r\n\t{ id: \"1883\", name: \"Karlskoga\"},\r\n\t{ id: \"1884\", name: \"Nora\"},\r\n\t{ id: \"1885\", name: \"Lindesberg\"},\r\n\r\n\t{ id: \"1904\", name: \"Skinnskatteberg\"},\r\n\t{ id: \"1907\", name: \"Surahammar\"},\r\n\t{ id: \"1960\", name: \"Kungsör\"},\r\n\t{ id: \"1961\", name: \"Hallstahammar\"},\r\n\t{ id: \"1962\", name: \"Norberg\"},\r\n\t{ id: \"1980\", name: \"Västerås\"},\r\n\t{ id: \"1981\", name: \"Sala\"},\r\n\t{ id: \"1982\", name: \"Fagersta\"},\r\n\t{ id: \"1983\", name: \"Köping\"},\r\n\t{ id: \"1984\", name: \"Arboga\"},\r\n\r\n\t{ id: \"2021\", name: \"Vansbro\"},\r\n\t{ id: \"2023\", name: \"Malung-Sälen\"},\r\n\t{ id: \"2026\", name: \"Gagnef\"},\r\n\t{ id: \"2029\", name: \"Leksand\"},\r\n\t{ id: \"2031\", name: \"Rättvik\"},\r\n\t{ id: \"2034\", name: \"Orsa\"},\r\n\t{ id: \"2039\", name: \"Älvdalen\"},\r\n\t{ id: \"2061\", name: \"Smedjebacken\"},\r\n\t{ id: \"2062\", name: \"Mora\"},\r\n\t{ id: \"2080\", name: \"Falun\"},\r\n\t{ id: \"2081\", name: \"Borlänge\"},\r\n\t{ id: \"2082\", name: \"Säter\"},\r\n\t{ id: \"2083\", name: \"Hedemora\"},\r\n\t{ id: \"2084\", name: \"Avesta\"},\r\n\t{ id: \"2085\", name: \"Ludvika\"},\r\n\r\n\t{ id: \"2101\", name: \"Ockelbo\"},\r\n\t{ id: \"2104\", name: \"Hofors\"},\r\n\t{ id: \"2121\", name: \"Ovanåker\"},\r\n\t{ id: \"2132\", name: \"Nordanstig\"},\r\n\t{ id: \"2161\", name: \"Ljusdal\"},\r\n\t{ id: \"2180\", name: \"Gävle\"},\r\n\t{ id: \"2181\", name: \"Sandviken\"},\r\n\t{ id: \"2182\", name: \"Söderhamn\"},\r\n\t{ id: \"2183\", name: \"Bollnäs\"},\r\n\t{ id: \"2184\", name: \"Hudiksvall\"},\r\n\r\n\t{ id: \"2260\", name: \"Ånge\"},\r\n\t{ id: \"2262\", name: \"Timrå\"},\r\n\t{ id: \"2280\", name: \"Härnösand\"},\r\n\t{ id: \"2281\", name: \"Sundsvall\"},\r\n\t{ id: \"2282\", name: \"Kramfors\"},\r\n\t{ id: \"2283\", name: \"Sollefteå\"},\r\n\t{ id: \"2284\", name: \"Örnsköldsvik\"},\r\n\r\n\t{ id: \"2303\", name: \"Ragunda\"},\r\n\t{ id: \"2305\", name: \"Bräcke\"},\r\n\t{ id: \"2309\", name: \"Krokom\"},\r\n\t{ id: \"2313\", name: \"Strömsund\"},\r\n\t{ id: \"2321\", name: \"Åre\"},\r\n\t{ id: \"2326\", name: \"Berg\"},\r\n\t{ id: \"2361\", name: \"Härjedalen\"},\r\n\t{ id: \"2380\", name: \"Östersund\"},\r\n\r\n\t{ id: \"2401\", name: \"Nordmaling\"},\r\n\t{ id: \"2403\", name: \"Bjurholm\"},\r\n\t{ id: \"2404\", name: \"Vindeln\"},\r\n\t{ id: \"2409\", name: \"Robertsfors\"},\r\n\t{ id: \"2417\", name: \"Norsjö\"},\r\n\t{ id: \"2418\", name: \"Malå\"},\r\n\t{ id: \"2421\", name: \"Storuman\"},\r\n\t{ id: \"2422\", name: \"Sorsele\"},\r\n\t{ id: \"2425\", name: \"Dorotea\"},\r\n\t{ id: \"2460\", name: \"Vännäs\"},\r\n\t{ id: \"2462\", name: \"Vilhelmina\"},\r\n\t{ id: \"2463\", name: \"Åsele\"},\r\n\t{ id: \"2480\", name: \"Umeå\"},\r\n\t{ id: \"2481\", name: \"Lycksele\"},\r\n\t{ id: \"2482\", name: \"Skellefteå\"},\r\n\r\n\t{ id: \"2505\", name: \"Arvidsjaur\"},\r\n\t{ id: \"2506\", name: \"Arjeplog\"},\r\n\t{ id: \"2510\", name: \"Jokkmokk\"},\r\n\t{ id: \"2513\", name: \"Överkalix\"},\r\n\t{ id: \"2514\", name: \"Kalix\"},\r\n\t{ id: \"2518\", name: \"Övertorneå\"},\r\n\t{ id: \"2521\", name: \"Pajala\"},\r\n\t{ id: \"2523\", name: \"Gällivare\"},\r\n\t{ id: \"2560\", name: \"Älvsbyn\"},\r\n\t{ id: \"2580\", name: \"Luleå\"},\r\n\t{ id: \"2581\", name: \"Piteå\"},\r\n\t{ id: \"2582\", name: \"Boden\"},\r\n\t{ id: \"2583\", name: \"Haparanda\"},\r\n\t{ id: \"2584\", name: \"Kiruna\"}\r\n];\r\n","\r\nexport interface UILoanAimCategory {\r\n\tid: string;\r\n\tname: string;\r\n\tdetails: UILoanAimDetail[];\r\n}\r\n\r\nexport interface UILoanAimDetail {\r\n\tid: string;\r\n\tname: string;\r\n}\r\n\r\n\r\n// This array is provided as-is from LHB. See mapper function at the end.\r\nexport const uiLoanAimCategories: UILoanAimCategory[] =\r\n[\r\n\t{\r\n\t\tid: \"01\",\r\n\t\tmainText: \"Nybyggnad\",\r\n\t\tmainDisplayText: \"Nybyggnad\",\r\n\t\taims: [\r\n\t\t\t{\r\n\t\t\t\taimText: \"Bostad\",\r\n\t\t\t\taimDisplayText: \"Bostad\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Fjäderfä\",\r\n\t\t\t\taimDisplayText: \"Stall fjäderfä\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Maskinhall\",\r\n\t\t\t\taimDisplayText: \"Maskinhall\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Mjölkstall\",\r\n\t\t\t\taimDisplayText: \"Mjölkstall\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Nötstall\",\r\n\t\t\t\taimDisplayText: \"Nötstall\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Svinstall\",\r\n\t\t\t\taimDisplayText: \"Svinstall\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Övr. djurslag\",\r\n\t\t\t\taimDisplayText: \"Övriga djurslag\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Övr. ekonomibyggnad\",\r\n\t\t\t\taimDisplayText: \"Övrig ekonomibyggnad\"\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\tid: \"02\",\r\n\t\tmainText: \"Renovering\",\r\n\t\tmainDisplayText: \"Renovering\",\r\n\t\taims: [\r\n\t\t\t{\r\n\t\t\t\taimText: \"Bostad\",\r\n\t\t\t\taimDisplayText: \"Bostad\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Fjäderfä\",\r\n\t\t\t\taimDisplayText: \"Stall fjäderfä\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Maskinhall\",\r\n\t\t\t\taimDisplayText: \"Maskinhall\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Mjölkstall\",\r\n\t\t\t\taimDisplayText: \"Mjölkstall\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Nötstall\",\r\n\t\t\t\taimDisplayText: \"Nötstall\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Svinstall\",\r\n\t\t\t\taimDisplayText: \"Svinstall\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Övr. djurslag\",\r\n\t\t\t\taimDisplayText: \"Övriga djurslag\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Övr. ekonomibyggnad\",\r\n\t\t\t\taimDisplayText: \"Övrig ekonomibyggnad\"\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\tid: \"03\",\r\n\t\tmainText: \"Tillbyggnad\",\r\n\t\tmainDisplayText: \"Tillbyggnad\",\r\n\t\taims: [\r\n\t\t\t{\r\n\t\t\t\taimText: \"Bostad\",\r\n\t\t\t\taimDisplayText: \"Bostad\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Fjäderfä\",\r\n\t\t\t\taimDisplayText: \"Stall fjäderfä\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Maskinhall\",\r\n\t\t\t\taimDisplayText: \"Maskinhall\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Mjölkstall\",\r\n\t\t\t\taimDisplayText: \"Mjölkstall\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Nötstall\",\r\n\t\t\t\taimDisplayText: \"Nötstall\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Svinstall\",\r\n\t\t\t\taimDisplayText: \"Svinstall\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Övr. djurslag\",\r\n\t\t\t\taimDisplayText: \"Övriga djurslag\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Övr. ekonomibyggnad\",\r\n\t\t\t\taimDisplayText: \"Övrig ekonomibyggnad\"\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\tid: \"04\",\r\n\t\tmainText: \"Maskininvestering\",\r\n\t\tmainDisplayText: \"Maskininvestering\",\r\n\t\taims: [\r\n\t\t\t{\r\n\t\t\t\taimText: \"Maskiner\",\r\n\t\t\t\taimDisplayText: \"Maskiner\"\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\tid: \"05\",\r\n\t\tmainText: \"Fastighetsköp\",\r\n\t\tmainDisplayText: \"Fastighetsköp\",\r\n\t\taims: [\r\n\t\t\t{\r\n\t\t\t\taimText: \"Jordbruk\",\r\n\t\t\t\taimDisplayText: \"Jordbruk\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Annan fastighet\",\r\n\t\t\t\taimDisplayText: \"Annan fastighet\"\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\tid: \"06\",\r\n\t\tmainText: \"Rörelsekapital\",\r\n\t\tmainDisplayText: \"Rörelsekapital\",\r\n\t\taims: [\r\n\t\t\t{\r\n\t\t\t\taimText: \"Djur\",\r\n\t\t\t\taimDisplayText: \"Djur\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Lager\",\r\n\t\t\t\taimDisplayText: \"Lager\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Likvid förstärkning\",\r\n\t\t\t\taimDisplayText: \"Likvid förstärkning\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Rekonstruktion\",\r\n\t\t\t\taimDisplayText: \"Rekonstrukt\"\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\tid: \"07\",\r\n\t\tmainText: \"Energiproduktion\",\r\n\t\tmainDisplayText: \"Energiproduktion\",\r\n\t\taims: [\r\n\t\t\t{\r\n\t\t\t\taimText: \"Biogas\",\r\n\t\t\t\taimDisplayText: \"Biogas\"\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\taimText: \"Vindkraft\",\r\n\t\t\t\taimDisplayText: \"Vindkraft\"\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n].map(x => {\r\n\tlet cat: UILoanAimCategory = {\r\n\t\tid: x.mainText,\r\n\t\tname: x.mainDisplayText,\r\n\t\tdetails: x.aims.map(y => {\r\n\t\t\tlet aim: UILoanAimDetail = {\r\n\t\t\t\tid: y.aimText,\r\n\t\t\t\tname: y.aimDisplayText\r\n\t\t\t};\r\n\t\t\treturn aim;\r\n\t\t})\r\n\t}\r\n\treturn cat;\r\n});\r\n","import { UIKeyed } from \"./UIKeyed\";\r\nimport { UINamed } from \"./UINamed\";\r\nimport { TypeOfLoan } from \"../../libs/SMELPOClient\";\r\n\r\nexport interface UIExtLoanType extends UIKeyed, UINamed {\r\n\tid: number;\r\n\ttype: TypeOfLoan;\r\n}\r\n\r\nexport const uiExtLoanTypes:UIExtLoanType[] = [\r\n\t{ key: \"STUDENT\", id: 0, name: \"Studielån\", nameTextkey: \"LoanType_STUDENT\", type:TypeOfLoan.Studieln }, // STUDENT // (Studielån)\r\n\t{ key: \"ACCOUNTCREDIT\", id: 2, name: \"Kontokredit/Kortkredit\", nameTextkey: \"LoanType_ACCOUNTCREDIT\", type:TypeOfLoan.KontoKortkredit }, // ACCOUNTCREDIT // (Kort/Kontokredit)\r\n\t{ key: \"INSTALLMENT\", id: 3, name: \"Avbetalningskredit/Billån/Båtlån\", nameTextkey: \"LoanType_INSTALLMENT\", type:TypeOfLoan.AvbetalningskreditBillnBtln }, // INSTALLMENT // (Avbetalning/Leasing)\r\n\t//{ key: 4, name: \"Bolån\", nameTextkey: \"LoanType_MORTGAGE\", type:TypeOfLoan.Studieln }, //MORTGAGE // (Bolån)\r\n\t{ key: \"SECURITY\", id: 5, name: \"Borgen\", nameTextkey: \"LoanType_SECURITY\", type:TypeOfLoan.Borgenstagande }, //SECURITY // (Borgen)\r\n\t{ key: \"GUARANTEES\", id: 6, name: \"Garantier\", nameTextkey: \"LoanType_GUARANTEES\", type:TypeOfLoan.Garantier }, //GUARANTEES // (Garanti)\r\n\t{ key: \"BUSINESS\", id: 8, name: \"Näringskredit\", nameTextkey: \"LoanType_BUSINESS\", type:TypeOfLoan.Nringskredit }, //BUSINESS // (Näringskredit)\r\n\t{ key: \"BLANCO\", id: 1, name: \"Blancolån/Övriga lån\", nameTextkey: \"LoanType_BLANCO\", type:TypeOfLoan.BlancokreditVrigaLn } //UNSECURED // (Blancolån)\r\n];\r\n","import { DownpaymentSource } from \"../SelmaModels\";\r\nimport { UIKeyed } from \"./UIKeyed\";\r\nimport { UINamed } from \"./UINamed\";\r\n\r\nexport interface UILoanDownpaymentType extends UIKeyed, UINamed {\r\n\ttype: DownpaymentSource;\r\n}\r\n\r\nexport const uiLoanDownpaymentTypes: UILoanDownpaymentType[] = [\r\n\t{ key: 'SALE_OF_PROPERTY', name: 'Försäljning bostad', nameTextkey:\"UILoanDownpaymentType_SALE_OF_PROPERTY\", type: DownpaymentSource.SALE_OF_PROPERTY },\r\n\t{ key: 'SAVINGS', name: 'Sparande', nameTextkey:\"UILoanDownpaymentType_SAVINGS\",type: DownpaymentSource.SAVINGS },\r\n\t{ key: 'BLANCO', name: 'Blancolån', nameTextkey:\"UILoanDownpaymentType_BLANCO\",type: DownpaymentSource.BLANCO_LOAN },\r\n\t{ key: 'OTHER', name: 'Övrigt', nameTextkey:\"UILoanDownpaymentType_OTHER\",type: DownpaymentSource.OTHER },\r\n];","import { LPEmploymentEnum } from \"../selmamodels/Applicant\";\r\nimport { UIKeyed } from \"./UIKeyed\";\r\nimport { UINamed } from \"./UINamed\";\r\n\r\nexport interface UIEmploymentType extends UIKeyed, UINamed {\r\n\ttype: LPEmploymentEnum;\r\n}\r\n\r\nexport const uiEmploymentType: UIEmploymentType[] = [\r\n\t{ key: 'PERMANENT', name: 'Anställning, tillsvidareanställning', nameTextkey:\"UIEmploymentType_PERMANENT\", type: LPEmploymentEnum.PERMANENT },\r\n\t{ key: 'TEMPORARY', name: 'Tidbegränsad anställning', nameTextkey:\"UIEmploymentType_TEMPORARY\", type: LPEmploymentEnum.TEMPORARY},\r\n\t{ key: 'PROBATIONARY', name: ' Provanställning', nameTextkey:\"UIEmploymentType_PROBATIONARY\", type: LPEmploymentEnum.PROBATIONARY },\r\n\t{ key: 'SELF_EMPLOYED', name: 'Eget företag', nameTextkey:\"UIEmploymentType_SELF_EMPLOYED\", type: LPEmploymentEnum.SELF_EMPLOYED },\r\n\t{ key: 'PENSION', name: 'Inkomst av pension', nameTextkey:\"UIEmploymentType_PENSION\", type: LPEmploymentEnum.PENSION },\r\n\t{ key: 'UNEMPLOYMENT_INSURANCE', name: 'Arbetslöshetskassa', nameTextkey:\"UIEmploymentType_UNEMPLOYMENT_INSURANCE\", type: LPEmploymentEnum.UNEMPLOYMENT_INSURANCE },\r\n\t{ key: 'STUDENT_AID', name: 'Studiestöd', nameTextkey:\"UIEmploymentType_STUDENT_AID\", type: LPEmploymentEnum.STUDENT_AID },\r\n];\r\n","import { UIKeyed } from \"./UIKeyed\";\r\nimport { UINamed } from \"./UINamed\";\r\n\r\nexport interface UIBank extends UIKeyed, UINamed {\r\n}\r\n\r\nexport const uiBanks: UIBank[] = [\r\n// Lista enligt Daniel Stenman 2016-09-16\r\n{ key: \"Landshypotek Bank\", name: \"Landshypotek Bank\", nameTextkey: \"UIBank_LandshypotekBank\" },\r\n{ key: \"Danske Bank\" , name: \"Danske Bank\", nameTextkey: \"UIBank_DanskeBank\" },\r\n{ key: \"Handelsbanken\"\t, name: \"Handelsbanken\", nameTextkey: \"UIBank_Handelsbanken\" },\r\n{ key: \"Länsförsäkringar\", name: \"Länsförsäkringar\", nameTextkey: \"UIBank_Länsförsäkringar\" },\r\n{ key: \"Nordea\", name: \"Nordea\", nameTextkey: \"UIBank_Nordea\" },\r\n{ key: \"SEB\", name: \"SEB\", nameTextkey: \"UIBank_SEB\" },\r\n{ key: \"Skandiabanken\", name: \"Skandiabanken\", nameTextkey: \"UIBank_Skandiabanken\" },\r\n{ key: \"Stadshypotek\", name: \"Stadshypotek\", nameTextkey: \"UIBank_Stadshypotek\" },\r\n{ key: \"Swedbank\", name: \"Swedbank\", nameTextkey: \"UIBank_Swedbank\" },\r\n{ key: \"Annan bank\", name: \"Annan bank\", nameTextkey: \"UIBank_Other\" }\r\n];\r\n\r\n","import { BaseService } from './BaseService';\r\nimport { Case, Aim, DownpaymentSource } from '../models/SelmaModels';\r\nimport { Loan, TakeoverLoan } from \"../models/selmamodels/Loan\";\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { GuardService } from './GuardService';\r\nimport { Application } from '../models/AppModels';\r\nimport { uiLoanAimCategories, UILoanAimCategory } from '../models/UiModels';\r\n\r\nexport class LoanService extends BaseService {\r\n\tprivate stateService: StateService;\r\n\tprivate smelpoService: SMELPOService;\r\n\tprivate guardService: GuardService;\r\n\r\n\tconstructor(private application: Application, stateService: StateService, smelpoService: SMELPOService, guardService: GuardService) {\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.smelpoService = smelpoService;\r\n\t\tthis.guardService = guardService;\r\n\t}\r\n\r\n\tupdate(loan: Loan|TakeoverLoan): void {\r\n\t\tthis.stateService.update(loan);\r\n\t}\r\n\r\n\tvalidateLoan(loan: Loan): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\treturn vr;\r\n\t}\r\n\r\n\thasAmount(loan: Loan): boolean {\r\n\t\treturn loan &&\r\n\t\t\tthis.guardService.isGreaterThanZero(this.getLoanAmount(loan));\r\n\t}\r\n\r\n\thasLoan(c: Case): boolean {\r\n\t\treturn c.loan?true:false;\r\n\t}\r\n\r\n\tensureLoan(c: Case): Loan {\r\n\t\tif( !c.loan ) {\r\n\t\t\tc.loan = { id: this.application.services.idService.newGuid()};\r\n\t\t}\r\n\t\treturn c.loan;\r\n\t}\r\n\r\n\tgetMinimumLoanAmount(c: Case) {\r\n\t\treturn 50000; // the minimum amount in total to borrow per process.\r\n\t}\r\n\r\n\tgetMinimumSubLoanAmount() {\r\n\t\treturn 10000; // the minimum amount to borrow per aim or takeoverLoan.\r\n\t}\r\n\r\n\tgetMaximumLoanAmount(c: Case) {\r\n\t\treturn 1000*1000*1000;\r\n\t}\r\n\r\n\thasTakeoverLoans(loan: Loan): boolean {\r\n\t\treturn this.guardService.hasLengthGreaterThanZero(loan.takeoverLoans);\r\n\t}\r\n\r\n\thasAims(loan: Loan): boolean {\r\n\t\treturn this.guardService.hasLengthGreaterThanZero(loan.aims);\r\n\t}\r\n\r\n\thasSubLoans(loan: Loan): boolean {\r\n\t\treturn this.hasTakeoverLoans(loan) || this.hasAims(loan);\r\n\t}\r\n\r\n\t// setLoanAmount(c: Case, loan: Loan, amount: number): void {\r\n\t// \tif( amount>=0) {\r\n\t// \t\tconst prevAmount = loan.amount||0;\r\n\t// \t\tif( prevAmount!=amount ) {\r\n\t// \t\t\tloan.amount = amount;\r\n\t// \t\t\tthis.update(loan);\r\n\t// \t\t}\r\n\r\n\t// \t\tif( loan.aims && loan.aims.length===1 ) {\r\n\t// \t\t\tconst aim = loan.aims[0];\r\n\t// \t\t\tif( this.guardService.isUnvaluedOrZero(aim.loanAmountPart) || aim.loanAmountPart===prevAmount ) {\r\n\t// \t\t\t\tif( aim.loanAmountPart != amount) {\r\n\t// \t\t\t\t\taim.loanAmountPart = amount;\r\n\t// \t\t\t\t\tthis.stateService.update(aim);\r\n\t// \t\t\t\t}\r\n\t// \t\t\t}\r\n\t// \t\t}\r\n\r\n\t// \t}\r\n\t// }\r\n\r\n\tgetLoanAmount(loan:Loan): number {\r\n\t\tlet amountSum = this.getAimsAmountSum(loan) + this.getTakeoverLoansDebtSum(loan);\r\n\t\treturn amountSum;\r\n\t}\r\n\r\n\tgetAimsAmountSum(loan:Loan): number {\r\n\t\tlet amountSum = 0;\r\n\t\tif( loan && loan.aims ) {\r\n\t\t\tloan.aims.forEach(x => {\r\n\t\t\t\tamountSum += x.loanAmountPart||0;\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn amountSum;\r\n\t}\r\n\r\n\tgetTakeoverLoansDebtSum(loan:Loan): number {\r\n\t\tlet amountSum = 0;\r\n\t\tif( loan && loan.takeoverLoans ) {\r\n\t\t\tloan.takeoverLoans.forEach(x => {\r\n\t\t\t\tamountSum += x.debtAmount||0;\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn amountSum;\r\n\t}\r\n\r\n\r\n\thasValidLoanAmount(c: Case): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\tif( !c || !c.loan )\r\n\t\t\treturn false;\r\n\r\n\t\tconst loan = c.loan;\r\n\t\tconst loanAmount = this.getLoanAmount(loan);\r\n\t\treturn loanAmount && \r\n\t\t\tg.isGreaterThanOrEqual(loanAmount, this.getMinimumLoanAmount(c)) \r\n\t\t\t? true : false;\r\n\t}\r\n\r\n\t// getAimSum(loan: Loan): number {\r\n\t// \tif( !loan.aims ) return 0;\r\n\t// \tconst sum = loan.aims.reduce((acc,val)=> {\r\n\t// \t\treturn acc + (val.loanAmountPart||0);\r\n\t// \t}, 0);\r\n\t// \treturn sum;\r\n\t// }\r\n\r\n/****************************************** */\r\n/* LOAN AIMS */\r\n/****************************************** */\r\n\taddNewAim(loan: Loan): Aim {\r\n\t\tif( !loan.aims ) {\r\n\t\t\tloan.aims = [];\r\n\t\t}\r\n\t\t// const loanAmount = loan.amount||0;\r\n\t\t// const aimSum = this.getAimsAmountSum(loan);\r\n\t\tconst aim = {\r\n\t\t\tid: this.application.services.idService.newGuid(),\r\n\t\t\tloanAmountPart: undefined\r\n\t\t};\r\n\t\tthis.stateService.listAdd(loan.aims, aim);\r\n\t\tthis.update(loan);\r\n\t\treturn aim;\r\n\t}\r\n\r\n\tupdateAim(loan: Loan, aim: Aim) {\r\n\t\tthis.update(loan);\r\n\t\tthis.stateService.update(aim);\r\n\t}\r\n\r\n\tremoveAim(loan: Loan, aim: Aim) {\r\n\t\tif( !loan || !loan.aims ) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tthis.stateService.listRemove(loan.aims, aim);\r\n\t\tthis.update(loan);\r\n\t}\r\n\r\n\tremoveAllAims(loan: Loan):void {\r\n\t\tif( !loan || !loan.aims ) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tloan.aims = undefined;\r\n\t\tthis.update(loan);\r\n\t}\r\n\r\n\tsetAimLoanAmountPart(loan: Loan, aim: Aim, amountPart: number|undefined) {\r\n\t\taim.loanAmountPart = amountPart;\r\n\t\tthis.updateAim(loan, aim);\r\n\t}\r\n\r\n\tgetMaximumAimAmount() {\r\n\t\treturn 1000*1000*1000;\r\n\t}\r\n\r\n\t\r\n\t// hasMinimumLoanParts(loan: Loan) : boolean {\r\n\t// \treturn loan.aims && loan.aims.length>0?true:false;\r\n\t// }\r\n\r\n\tensureMinimumLoanAims(loan: Loan) {\r\n\t\tif( this.guardService.isUnvaluedOrEmpty(loan.aims) ) {\r\n\t\t\tthis.addNewAim(loan);\r\n\t\t}\r\n\t}\r\n\r\n\r\n/****************************************** */\r\n/* LOAN TAKEOVERS */\r\n/****************************************** */\r\n\taddNewLoanTakeOver(loan: Loan): TakeoverLoan {\r\n\t\tif( !loan.takeoverLoans ) {\r\n\t\t\tloan.takeoverLoans = [];\r\n\t\t}\r\n\r\n\t\tconst takeoverLoan = {\r\n\t\t\tid: this.application.services.idService.newGuid()\r\n\t\t};\r\n\r\n\t\tthis.stateService.listAdd(loan.takeoverLoans, takeoverLoan);\r\n\t\tthis.update(loan);\r\n\t\treturn takeoverLoan;\r\n\t}\r\n\r\n\tensureMinimumTakeoverLoans(loan: Loan) {\r\n\t\tif( this.guardService.isUnvaluedOrEmpty(loan.takeoverLoans) ) {\r\n\t\t\tthis.addNewLoanTakeOver(loan);\r\n\t\t}\r\n\t}\r\n\r\n\tupdateLoanTakeOver(loan: Loan, takeoverLoan: TakeoverLoan) {\r\n\t\tthis.update(loan);\r\n\t\tthis.stateService.update(takeoverLoan);\r\n\t}\r\n\r\n\tremoveLoanTakeOver(loan: Loan, takeoverLoan: TakeoverLoan) {\r\n\t\tif( !loan || !loan.takeoverLoans ) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tthis.stateService.listRemove(loan.takeoverLoans, takeoverLoan);\r\n\t\tthis.update(loan);\r\n\t}\r\n\r\n\tremoveAllTakeOverLoans(loan: Loan):void {\r\n\t\tif( !loan || !loan.takeoverLoans ) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tloan.takeoverLoans = undefined;\r\n\t\tthis.update(loan);\r\n\t}\r\n\r\n\tsetLoanTakeOverDebtAmount(loan: Loan, takeoverLoan: TakeoverLoan, debtAmount: number|undefined) {\r\n\t\ttakeoverLoan.debtAmount = debtAmount;\r\n\t\tthis.updateLoanTakeOver(loan, takeoverLoan);\r\n\t}\r\n\r\n\tsetLoanTakeOverBank(loan: Loan, takeoverLoan: TakeoverLoan, creditInstitute: string) {\r\n\t\ttakeoverLoan.creditInstitute = creditInstitute;\r\n\t\tthis.updateLoanTakeOver(loan, takeoverLoan);\r\n\t}\r\n\r\n\tsetLoanTakeOverLoanNumber(loan: Loan, takeoverLoan: TakeoverLoan, loanNumber: string) {\r\n\t\ttakeoverLoan.loanNumber = loanNumber;\r\n\t\tthis.updateLoanTakeOver(loan, takeoverLoan);\r\n\t}\r\n\r\n\r\n\taskAboutDownpayment(loan: Loan) : boolean {\r\n\t\tif( !loan.aims || loan.aims.length===0 ) return false;\r\n\r\n\t\tconst r = loan.aims.filter(x => x.aimCategory===\"Fastighetsköp\");\r\n\t\treturn r.length>0;\r\n\t}\r\n\r\n\taskAboutDownpaymentOther(loan: Loan) : boolean {\r\n\t\tif( !this.askAboutDownpayment(loan) ) return false;\r\n\t\tif( loan.downpaymentType === DownpaymentSource.OTHER ) return true;\r\n\t\treturn false;\r\n\t}\r\n\r\n\r\n\tgetMaximumTakeoverLoanDebtAmount() {\r\n\t\treturn 1000*1000*1000;\r\n\t}\r\n\r\n\tclearTakeoverLoanDetails(takeoverLoan: TakeoverLoan) {\r\n\t\ttakeoverLoan.loanNumber = undefined;\r\n\t\ttakeoverLoan.creditInstitute = undefined;\r\n\t\tthis.update(takeoverLoan);\r\n\t}\r\n\r\n\thasTakeoverLoanDetails(takeoverLoan: TakeoverLoan): boolean | undefined {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(takeoverLoan.loanNumber) || g.hasValue(takeoverLoan.creditInstitute);\r\n\t}\r\n\r\n\thasValidPurposeDescription(l:Loan):boolean {\r\n\t\tconst g = this.guardService;\r\n\r\n\t\tif (g.isUnvaluedOrEmpty(l.purposeDescription))\r\n\t\t\treturn true;\r\n\r\n\t\treturn g.hasLengthLessThan(l.purposeDescription, 3500);\r\n\t}\r\n\r\n\r\n\t// === Validation ===\r\n\r\n\tvalidateCaseLoan(c: Case): ValidationResult {\r\n\t\tconst vr = new ValidationResult();\r\n\t\tconst loanService = this;\r\n\r\n\t\t// Must have loan sum.\r\n\t\tconst loan = c.loan;\r\n\t\tconst hasLoan = loanService.hasLoan(c);\r\n\t\tvr.add({ validator: loanService.hasLoan, object:c, ok: hasLoan});\r\n\t\tif( loan && hasLoan ) {\r\n\t\t\t// Must have at least one sub-loan (takeover or aim).\r\n\t\t\tvr.add({ validator: loanService.hasSubLoans, object:c.loan, ok:loanService.hasSubLoans(loan) });\r\n\r\n\t\t\t// Loan sum must be greater than 1000 SEK and even to 1000 SEK\r\n\t\t\tvr.add({ validator: loanService.hasValidLoanAmount, object:c.loan, ok:loanService.hasValidLoanAmount(c) });\r\n\t\t\t\r\n\t\t\t// Purpose description must not be longer than 3500 chars\r\n\t\t\tvr.add({ validator: loanService.hasValidPurposeDescription, object:c.loan, ok:loanService.hasValidPurposeDescription(loan) });\r\n\r\n\t\t\t// Must have at least one aim.\r\n\t\t\t// vr.add({ validator: loanService.hasMinimumLoanAims, object:c.loan, \r\n\t\t\t// \tok: (c.loan && loanService.hasMinimumLoanAims(c.loan))?true:false });\r\n\r\n\t\t\tvr.addResult(loanService.validateAimsAndDownpayment(loan));\r\n\t\t\tvr.addResult(loanService.validateTakeoverLoans(loan));\r\n\t\t}\r\n\r\n\t\treturn vr;\r\n\t}\r\n\r\n\taimHasCategory(x: Aim): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasLengthGreaterThan(x.aimCategory,0);\r\n\t}\r\n\r\n\taimHasDetail(x: Aim): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasLengthGreaterThan(x.aimDetail,0);\r\n\t}\r\n\r\n\taimHasAmount(x: Aim): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isGreaterThanZero(x.loanAmountPart);\r\n\t}\r\n\r\n\taimHasValidAmount(x: Aim): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isGreaterThanOrEqual(x.loanAmountPart, this.getMinimumSubLoanAmount());\r\n\t}\r\n\r\n\ttakeoverLoanHasCategory(x: TakeoverLoan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasLengthGreaterThan(x.aimCategory,0);\r\n\t}\r\n\r\n\ttakeoverLoanHasDetail(x: TakeoverLoan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasLengthGreaterThan(x.aimDetail,0);\r\n\t}\r\n\r\n\ttakeoverLoanHasAmount(x: TakeoverLoan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isGreaterThanZero(x.debtAmount);\r\n\t}\r\n\r\n\ttakeoverLoanHasValidAmount(x: TakeoverLoan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isGreaterThanOrEqual(x.debtAmount, this.getMinimumSubLoanAmount());\r\n\t}\r\n\r\n\taimsHaveValidAmountSum(loan: Loan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\tconst sum = this.getAimsAmountSum(loan);\r\n\t\treturn g.isGreaterThanZero(sum);\r\n\t}\r\n\r\n\ttakeoverLoansHaveValidAmountSum(loan: Loan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\tconst sum = this.getTakeoverLoansDebtSum(loan);\r\n\t\treturn g.isGreaterThanZero(sum);\r\n\t}\r\n\r\n\tvalidateTakeoverLoans(loan: Loan): ValidationResult {\r\n\t\tconst vr = new ValidationResult();\r\n\r\n\t\tif( loan.takeoverLoans && this.hasTakeoverLoans(loan) ) {\r\n\t\t\tloan.takeoverLoans.forEach(x => {\r\n\t\t\t\tvr.addResult(this.validateTakeoverLoan(x));\r\n\t\t\t});\r\n\t\t\tvr.add({ validator: this.takeoverLoansHaveValidAmountSum, object:loan, ok: this.takeoverLoansHaveValidAmountSum(loan)}); \r\n\t\t}\r\n\r\n\t\treturn vr;\r\n\t}\r\n\tvalidateTakeoverLoan(x: TakeoverLoan): ValidationResult {\r\n\t\tconst vr = new ValidationResult();\r\n\t\tvr.add({ validator: this.takeoverLoanHasCategory, object:x, ok: this.takeoverLoanHasCategory(x)});\r\n\t\tvr.add({ validator: this.takeoverLoanHasDetail, object:x, ok: this.takeoverLoanHasDetail(x)});\r\n\t\tvr.add({ validator: this.takeoverLoanHasAmount, object:x, ok: this.takeoverLoanHasAmount(x)});\r\n\t\tvr.add({ validator: this.takeoverLoanHasValidAmount, object:x, ok: this.takeoverLoanHasValidAmount(x)});\r\n\t\treturn vr; \r\n\t}\r\n\r\n\tvalidateAimsAndDownpayment(loan: Loan): ValidationResult {\r\n\t\tconst vr = new ValidationResult();\r\n\r\n\t\t// Every aim must have detail code.\r\n\t\t// Every aim must have amount.\r\n\t\t// Sum of all aim amount must be equal to loan amount.\r\n\t\tif( loan.aims && this.hasAims(loan) ) {\r\n\t\t\tloan.aims.forEach(x => {\r\n\t\t\t\tvr.addResult(this.validateAim(x));\r\n\t\t\t});\r\n\t\t\tvr.add({ validator: this.aimsHaveValidAmountSum, object:loan, ok: this.aimsHaveValidAmountSum(loan)}); \r\n\t\t}\r\n\r\n\r\n\t\t// If at least one aim category is Fastighetsköp ...\r\n\t\tif( this.askAboutDownpayment(loan) ) {\r\n\t\t\t// DownpaymentSource must be selected.\r\n\r\n\t\t\tvr.add({ validator: this.hasDownpaymentType, object:loan, ok: this.hasDownpaymentType(loan)});\r\n\r\n\t\t\tif( this.askAboutDownpaymentOther(loan) ) {\r\n\t\t\t\t// If DownpaymentSource is OTHER ...\r\n\t\t\t\t// DownpaymentSourceText must have length > 0.\r\n\t\t\t\tvr.add({ validator: this.hasDownpaymentOther, object:loan, ok: this.hasDownpaymentOther(loan)});\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn vr;\r\n\t}\r\n\tvalidateAim(x: Aim): ValidationResult {\r\n\t\tconst vr = new ValidationResult();\r\n\t\tvr.add({ validator: this.aimHasCategory, object:x, ok: this.aimHasCategory(x)});\r\n\t\tvr.add({ validator: this.aimHasDetail, object:x, ok: this.aimHasDetail(x)});\r\n\t\tvr.add({ validator: this.aimHasAmount, object:x, ok: this.aimHasAmount(x)});\r\n\t\tvr.add({ validator: this.aimHasValidAmount, object:x, ok: this.aimHasValidAmount(x)});\r\n\t\treturn vr;\r\n\t}\r\n\r\n\thasDownpaymentType(loan: Loan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(loan.downpaymentType);\r\n\t}\r\n\thasDownpaymentOther(loan: Loan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn !g.isUnvaluedOrEmpty(loan.downpaymentOther);\r\n\t}\r\n\r\n\r\n\t// === Value look up tools ===\r\n\r\n\tgetUiAimCategory(aimCategory: string | undefined): UILoanAimCategory|undefined {\r\n\t\tif( !aimCategory || aimCategory === \"\") return;\r\n\r\n\t\tconst uiAimCategory = uiLoanAimCategories.find((x) => x.id === aimCategory);\r\n\t\treturn uiAimCategory;\r\n\t}\r\n\r\n\tgetAimCategoryName(aimCategory: string | undefined): string {\r\n\t\tconst uiAimCategory = this.getUiAimCategory(aimCategory);\r\n\t\tif( !uiAimCategory ) return \"\";\r\n\t\treturn uiAimCategory.name;\r\n\t}\r\n\r\n\tgetAimDetailName(aimCategory: string | undefined, aimDetail: string | undefined): string {\r\n\t\tconst uiAimCategory = this.getUiAimCategory(aimCategory);\r\n\t\tif( !uiAimCategory ) return \"\";\r\n\r\n\t\tconst uiAimDetail = uiAimCategory.details.find((x) => x.id === aimDetail);\r\n\t\tif( !uiAimDetail ) return \"\";\r\n\r\n\t\treturn uiAimDetail.name;\r\n\t}\r\n\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { Case, HouseholdMember } from '../models/SelmaModels';\r\nimport { Household, Child } from '../models/selmamodels/Household';\r\nimport { Applicant } from \"../models/selmamodels/Applicant\";\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { GuardService } from './GuardService';\r\nimport { ApplicantService } from './ApplicantService';\r\nimport { IdService } from './IdService';\r\nimport { CompanyService } from './CompanyService';\r\nimport { ExtLoanService } from './ExtLoanService';\r\nimport { MaintenanceCostService } from './MaintenanceCostService';\r\n\r\n/*\r\nHandles all logic for Household.\r\n*/\r\nexport class HouseholdService extends BaseService {\r\n\r\n\tprivate stateService: StateService;\r\n\tprivate smelpoService: SMELPOService;\r\n\tprivate guardService: GuardService;\r\n\r\n\tpublic companyService?:CompanyService; \r\n\tpublic extLoanService?:ExtLoanService;\r\n\tpublic maintenanceCostService?:MaintenanceCostService;\r\n\r\n\tconstructor(stateService: StateService, smelpoService: SMELPOService, \r\n\t\tguardService: GuardService, private applicantService:ApplicantService,\r\n\t\tprivate idService:IdService\r\n\t\t) {\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.smelpoService = smelpoService;\r\n\t\tthis.guardService = guardService;\r\n\t} \r\n\r\n\tupdate(household: Household|Case|Child): void {\r\n\t\tthis.stateService.update(household);\r\n\t}\r\n\r\n\tgetHouseholdDescription(c: Case, household: Household) {\r\n\t\tif( !household.members || household.members.length===0 )\r\n\t\t\treturn \"Tomt hushåll\";\r\n\r\n\t\tlet desc:string = \"\";\r\n\r\n\t\thousehold.members.forEach(x => {\r\n\t\t\tif( x.householdMember ) {\r\n\t\t\t\tlet applicant = this.applicantService.getApplicantByCustomerId(c, x.householdMember);\r\n\t\t\t\tif( applicant ) {\r\n\t\t\t\t\tlet name = this.applicantService.getPersonFullName(applicant);\r\n\t\t\t\t\tif( name ) {\r\n\t\t\t\t\t\tif( desc.length>0 )\r\n\t\t\t\t\t\t\tdesc += \" och \"\r\n\t\t\t\t\t\tdesc += name;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\t// Creates all missing sure there is at least one household for this applicant\r\n\tensureHouseholds(c:Case):void {\r\n\t\tvar applicansThatShouldHaveHouseholds = this.getApplicantsForHouseholds(c);\r\n\t\tapplicansThatShouldHaveHouseholds.forEach(x => {\r\n\t\t\tthis.ensureHouseholdForApplicant(c, x);\r\n\t\t})\r\n\t}\r\n\r\n\tprivate ensureHouseholdForApplicant(c:Case, applicant:Applicant):void {\r\n\t\tif( !applicant.customerId )\r\n\t\t\treturn;\r\n\t\tif( !this.applicantService.isPhysicum(c,applicant))\r\n\t\t\treturn;\r\n\r\n\t\tif( this.hasHouseholds(c))\r\n\t\t\treturn; // TODO: Fix this in the future by convincing LHB that they should have multiple households.\r\n\r\n\t\tlet households = this.getHouseholdsByCustomerId(c, applicant.customerId);\r\n\t\tif( households.length===0 ) {\r\n\t\t\tlet household = this.newHousehold(applicant);\r\n\t\t\tthis.addHousehold(c, household);\r\n\t\t}\r\n\t}\r\n\r\n\tnewHousehold(applicant: Applicant) : Household {\r\n\t\tif( !applicant.customerId )\r\n\t\t\tthrow Error('No applicant customer id');\r\n\r\n\t\tlet hhMember:HouseholdMember = {\r\n\t\t\t//id: this.idService.newGuid(),\r\n\t\t\thouseholdMember: applicant.customerId||''\r\n\t\t}\r\n\t\tlet hh:Household = {\r\n\t\t\tid: this.idService.newGuid(),\r\n\t\t\tmembers: [\r\n\t\t\t\thhMember\r\n\t\t\t]\r\n\t\t}\r\n\t\treturn hh;\r\n\t}\r\n\r\n\tremoveHousehold(c:Case, household:Household):void {\r\n\t\tif( !c.households ) \r\n\t\t\treturn;\r\n\r\n\t\tthis.removeHouseholdExtLoans(c, household);\r\n\t\tthis.removeHouseholdMaintenanceCosts(c, household);\r\n\t\t\t\t\r\n\t\tthis.stateService.listRemove(c.households, household);\r\n\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tremoveHouseholdExtLoans(c: Case, household: Household):void {\r\n\t\tif( this.extLoanService ) {\r\n\t\t\tthis.extLoanService.removeExtLoansForHousehold(c, household);\r\n\t\t}\r\n\t}\r\n\r\n\tremoveHouseholdMaintenanceCosts(c: Case, household: Household):void {\r\n\t\tif( this.maintenanceCostService ) {\r\n\t\t\tthis.maintenanceCostService.removeMaintenanceCostsForHousehold(c, household);\r\n\t\t}\r\n\t}\r\n\r\n\r\n\r\n\tremoveAllHouseholds(c: Case) {\r\n\t\tif( !c.households ) \r\n\t\t\treturn;\r\n\r\n\t\tif( this.extLoanService)\r\n\t\t\tthis.extLoanService.removeAllExtLoans(c);\r\n\t\tif( this.maintenanceCostService )\r\n\t\t\tthis.maintenanceCostService.removeAllMaintenanceCosts(c);\r\n\t\t\t\r\n\t\tthis.stateService.listRemoveAll(c.households);\r\n\t\tc.households = undefined;\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tshouldHaveHouseholds(c: Case):boolean {\r\n\t\tconst r = this.getApplicantsForHouseholds(c);\r\n\t\treturn r.length>0;\r\n\t}\r\n\r\n\tgetApplicantsForHouseholds(c: Case):Applicant[] {\r\n\t\tconst r = this.applicantService.getPhysicumApplicants(c);\r\n\t\treturn r;\r\n\t}\r\n\r\n\tgetFirstHousehold(c:Case) : Household|undefined {\r\n\t\tif( c.households && c.households.length>0 ) {\r\n\t\t\treturn c.households[0];\r\n\t\t} else {\r\n\t\t\treturn;\r\n\t\t}\r\n\t}\r\n\r\n\tgetHouseholdMembersApplicants(c: Case, household:Household|undefined):Applicant[]|undefined {\r\n\t\tif( !household || !household.members )\r\n\t\t\treturn;\r\n\t\t\r\n\t\tvar applicants = household.members\r\n\t\t\t.map(x => x.householdMember?this.applicantService.getApplicantByCustomerId(c, x.householdMember) : undefined)\r\n\t\t\t.filter(x => x!==undefined) as Applicant[];\r\n\t\treturn applicants;\r\n\t}\r\n\r\n\thasHouseholds(c: Case):boolean {\r\n\t\treturn c.households && c.households.length>0 ? true:false;\r\n\t}\r\n\t\r\n\taddHousehold(c: Case, household: Household) {\r\n\t\tif( !c.households )\r\n\t\t\tc.households = [];\r\n\t\tc.households.push(household);\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tgetHouseholdsByCustomerId(c:Case, customerId: string) : Household[] {\r\n\t\tif( !c.households )\r\n\t\t\treturn [];\r\n\r\n\t\tconst r = c.households.filter(x=>{\r\n\t\t\treturn this.isHouseholdMember(x, customerId)\r\n\t\t});\r\n\t\treturn r;\r\n\t}\r\n\r\n\tisHouseholdMember(household:Household, customerId:string) : boolean {\r\n\t\tif( !household.members )\r\n\t\t\treturn false;\r\n\t\t\r\n\t\tfor( let householdMember of household.members ) {\r\n\t\t\tif( householdMember.householdMember && this.guardService.compareCustomerId(householdMember.householdMember, customerId) )\r\n\t\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\tsetHouseholdMembersByCustomerIds(c:Case, household:Household, customerIds:string[]) : void {\r\n\r\n\t\tvar customerIdsToAdd = customerIds.filter(customerId => !this.getMember(household, customerId));\r\n\t\t\r\n\t\tvar householdMembersToRemove:HouseholdMember[] = [];\r\n\t\tif( household.members ) {\r\n\t\t\thouseholdMembersToRemove = household.members.filter(member => customerIds.findIndex(x=>this.guardService.compareCustomerId(x,member.householdMember||''))<0 )\r\n\t\t}\r\n\r\n\t\tif( customerIdsToAdd.length ) {\r\n\t\t\tcustomerIdsToAdd.forEach(x => {\r\n\t\t\t\tthis.addHouseholdMember(household, x);\r\n\t\t\t})\r\n\t\t}\r\n\r\n\t\tif( householdMembersToRemove.length ) {\r\n\t\t\thouseholdMembersToRemove.forEach(x => {\r\n\t\t\t\tif( x.householdMember )\r\n\t\t\t\t\tthis.removeHouseholdMember(c, household, x.householdMember);\r\n\t\t\t})\r\n\t\t}\r\n\t}\r\n\r\n\tremoveCustomerFromAllHouseholds(c:Case, customerId:string) : void {\r\n\t\tconst households = this.getHouseholdsByCustomerId(c, customerId);\r\n\t\thouseholds.forEach(hh => {this.removeHouseholdMember(c, hh, customerId)});\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\taddHouseholdMember(household:Household, customerId:string) : void {\r\n\t\tif( !household.members )\r\n\t\t\thousehold.members = [];\r\n\r\n\t\tvar member = {\r\n\t\t\tid: this.idService.newGuid(),\r\n\t\t\thouseholdMember: customerId\r\n\t\t};\r\n\t\tthis.stateService.listAdd(household.members, member);\r\n\t\tthis.update(household);\r\n\t}\r\n\r\n\tremoveHouseholdMember(c: Case, household:Household, customerId:string) : void {\r\n\t\tif( !household.members )\r\n\t\t\treturn;\r\n\r\n\t\tvar member = this.getMember(household, customerId);\r\n\t\tif( member ) {\r\n\r\n\t\t\t// Remove member from extloans\r\n\t\t\tif( this.extLoanService ) {\r\n\t\t\t\tthis.extLoanService.removeLoanOwnerForHousehold(c, household, customerId);\r\n\t\t\t}\r\n\r\n\t\t\t// Remove member from maintenance costs.\r\n\t\t\tif( this.maintenanceCostService ) {\r\n\t\t\t\tthis.maintenanceCostService.removeLoanOwnerForHousehold(c, household, customerId);\r\n\t\t\t}\r\n\r\n\t\t\tthis.stateService.listRemove(household.members, member);\r\n\t\t\tthis.update(household);\r\n\t\t}\r\n\t}\r\n\r\n\tgetMember(household: Household, customerId: string) : HouseholdMember|undefined {\r\n\t\tif( !household.members )\r\n\t\t\treturn;\r\n\t\t\r\n\t\tfor( let householdMember of household.members ) {\r\n\t\t\tif( householdMember.householdMember && this.guardService.compareCustomerId(householdMember.householdMember, customerId) )\r\n\t\t\t\treturn householdMember;\r\n\t\t}\r\n\t\treturn;\r\n\t}\r\n\r\n\tsetNumberOfChildrenAtHome(c: Case, household: Household, numberOfChildrenAtHome: number) {\r\n\t\tif( household.numberOfChildrenAtHome !== numberOfChildrenAtHome ) {\r\n\t\t\tif( numberOfChildrenAtHome<=0 ) {\r\n\t\t\t\thousehold.numberOfChildrenAtHome = 0;\r\n\t\t\t\thousehold.children = undefined;\r\n\t\t\t} else {\r\n\t\t\t\tif( !household.children )\r\n\t\t\t\t\thousehold.children = [];\r\n\t\t\t\telse \r\n\t\t\t\t\thousehold.children.length = numberOfChildrenAtHome; \r\n\t\t\t\tfor( let i=0; i {\r\n\t\t\t\tvr.add({validator:this.childHasAge, object:child, ok: this.childHasAge(child)});\r\n\t\t\t\tvr.add({validator:this.childHasPartial, object:child, ok: this.childHasPartial(child)});\r\n\t\t\t})\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tchildHasAge(child: Child): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isNumber(child.childsAge) && g.isZeroOrGreater(child.childsAge);\r\n\t}\r\n\r\n\tchildHasPartial(child: Child): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(child.partInHousehold);\r\n\t}\r\n\r\n\thasValidMembers(x: Household): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasLengthGreaterThan(x.members,0) && g.hasLengthLessThan(x.members,3);\r\n\t}\r\n\r\n\thasNumberOfChildren(x: Household): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isNumber(x.numberOfChildrenAtHome) \r\n\t\t\t&& (\r\n\t\t\t\tx.numberOfChildrenAtHome===0 \r\n\t\t\t\t|| (x.children && x.children.length===x.numberOfChildrenAtHome ? true:false)\r\n\t\t\t);\r\n\t}\r\n\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { Case } from '../models/SelmaModels';\r\nimport { Collateral } from \"../models/selmamodels/Collateral\";\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { GuardService } from './GuardService';\r\nimport { IdService } from './IdService';\r\n\r\n/*\r\nHandles all logic for Collateral.\r\n*/\r\nexport class CollateralService extends BaseService {\r\n\r\n\tprivate stateService: StateService;\r\n\tprivate smelpoService: SMELPOService;\r\n\tprivate guardService: GuardService;\r\n\r\n\tconstructor(stateService: StateService, smelpoService: SMELPOService, \r\n\t\tguardService: GuardService, private idService:IdService) {\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.smelpoService = smelpoService;\r\n\t\tthis.guardService = guardService;\r\n\t}\r\n\r\n\tupdate(collateral: Collateral|Case): void {\r\n\t\tthis.stateService.update(collateral);\r\n\t}\r\n\r\n\taddCollateral(c: Case, collateral: Collateral): void {\r\n\t\tif (!c.collaterals) \r\n\t\t\tc.collaterals = [];\r\n\r\n\t\tthis.stateService.listAdd(c.collaterals, collateral);\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tremoveCollateral(c: Case, collateral: Collateral): void {\r\n\t\tif( !c.collaterals )\r\n\t\t\treturn;\r\n\t\tthis.stateService.listRemove(c.collaterals, collateral);\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tremoveAllCollaterals(c: Case): void {\r\n\t\tif( !c.collaterals || c.collaterals.length===0 )\r\n\t\t\treturn;\r\n\t\tc.collaterals = undefined;\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\thasCollateral(c: Case): boolean {\r\n\t\treturn this.guardService.hasLengthGreaterThanZero(c.collaterals);\r\n\t}\r\n\r\n\tvalidateCollateral(c: Case, x: Collateral): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\r\n\t\tif(!x.postponeCollateralCode) {\r\n\t\t\tvr.add({validator:this.hasMunicipality, object:x, ok: this.hasMunicipality(x)});\r\n\t\t\tvr.add({validator:this.hasCode, object:x, ok: this.hasCode(x)});\r\n\t\t}\r\n\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tvalidateCollaterals(c:Case): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tif ( c.collaterals ) {\r\n\t\t\tc.collaterals.forEach(x => {\r\n\t\t\t\tvar r = this.validateCollateral(c, x);\r\n\t\t\t\tvr.addResult(r);\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\thasMunicipality(x: Collateral): boolean {\r\n\t\treturn !this.guardService.isUnvaluedOrEmpty(x.municipality);\r\n\t}\r\n\r\n\thasCode(x: Collateral): boolean {\r\n\t\treturn !this.guardService.isUnvaluedOrEmpty(x.code);\r\n\t}\r\n\r\n\tneedsForestryPlan(x: Collateral):boolean {\r\n\t\treturn false; // TODO: implement.\r\n\t}\r\n\r\n\tensureMinimumCollaterals(c: Case): void {\r\n\t\tif( !c.collaterals )\r\n\t\t\tc.collaterals = [];\r\n\r\n\t\tif( c.collaterals.length<1 ) {\r\n\t\t\tlet collateral:Collateral = this.newCollateral();\r\n\t\t\tc.collaterals.push(collateral);\r\n\t\t\tthis.update(c);\r\n\t\t}\r\n\t}\r\n\r\n\tnewCollateral(): Collateral {\r\n\t\tlet collateral:Collateral = {};\r\n\t\treturn collateral;\r\n\t}\r\n\r\n}\r\n","import { BaseService } from './BaseService';\r\n\r\nexport class ArrayService extends BaseService {\r\n\r\n\tconstructor() {\r\n\t\tsuper();\r\n\t}\r\n\r\n\tfirst(list:T[], match: (item:T) => boolean): T|undefined {\r\n\t\tfor(let i = 0, len=list.length; i(list:T[], match: (item:T) => boolean): boolean {\r\n\t\tfor(let i = 0, len=list.length; i(list: Array, keyGetter: (input: V) => K) : Map> {\r\n\r\n\t\tconst map = new Map>();\r\n\r\n\t\tlist.forEach((item) => {\r\n\t\t\tconst key = keyGetter(item);\r\n\t\t\tconst collection = map.get(key);\r\n\t\t\tif (!collection) {\r\n\t\t\t\tmap.set(key, [item]);\r\n\t\t\t} else {\r\n\t\t\t\tcollection.push(item);\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\treturn map;\r\n\t}\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { Case, PersonalEconomy, LPEmploymentEnum } from '../models/SelmaModels';\r\nimport { Applicant } from \"../models/selmamodels/Applicant\";\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { GuardService } from './GuardService';\r\nimport { IdService } from './IdService';\r\n\r\nexport class PersonalEconomyService extends BaseService {\r\n\tprivate stateService: StateService;\r\n\tprivate smelpoService: SMELPOService;\r\n\tprivate guardService: GuardService;\r\n\r\n\tconstructor(stateService: StateService, smelpoService: SMELPOService, guardService: GuardService, private idService:IdService) {\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.smelpoService = smelpoService;\r\n\t\tthis.guardService = guardService;\r\n\t}\r\n\r\n\tupdate(personalEconomy: PersonalEconomy|Case): void {\r\n\t\tthis.stateService.update(personalEconomy);\r\n\t}\r\n\r\n\t\r\n\taddPersonalEconomy(c:Case, personalEconomy: PersonalEconomy): void {\r\n\t\tif( !c.personalEconomies )\r\n\t\t\tc.personalEconomies = [];\r\n\r\n\t\tc.personalEconomies.push(personalEconomy);\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tnewPersonalEconomy(c:Case, applicant: Applicant): PersonalEconomy {\r\n\t\tconst personalEconomy = {\r\n\t\t\tid: this.idService.newGuid(),\r\n\t\t\tprocessId: c.id,\r\n\t\t\tcustomerId: applicant.customerId\r\n\t\t}\r\n\t\treturn personalEconomy;\r\n\t}\r\n\r\n\tensurePersonalEconomy(c:Case, applicant: Applicant): PersonalEconomy {\r\n\t\tlet personalEconomy = this.getPersonalEconomy(c, applicant);\r\n\t\tif( !personalEconomy ) {\r\n\t\t\tpersonalEconomy = this.newPersonalEconomy(c, applicant);\r\n\t\t\tthis.addPersonalEconomy(c, personalEconomy);\r\n\t\t}\r\n\t\treturn personalEconomy;\r\n\t}\r\n\r\n\tgetPersonalEconomy(c:Case, applicant: Applicant): PersonalEconomy | undefined {\r\n\t\tif( !c.personalEconomies || c.personalEconomies.length===0 )\r\n\t\t\treturn undefined;\r\n\t\t\r\n\t\tconst r = c.personalEconomies.filter(x => x.customerId===applicant.customerId);\r\n\t\tif( r.length===1 )\r\n\t\t\treturn r[0];\r\n\t\treturn undefined;\r\n\t}\r\n\r\n\tsetTypeOfEmployment(c:Case, personalEconomy: PersonalEconomy, typeOfEmployment:LPEmploymentEnum|undefined): void {\r\n\t\tif( personalEconomy.typeOfEmployment===typeOfEmployment) {\r\n\t\t\treturn; // Already set.\r\n\t\t}\r\n\r\n\t\tpersonalEconomy.typeOfEmployment = typeOfEmployment;\r\n\r\n\t\tif( this.mayHaveIncomeOfEmployment(personalEconomy)) {\r\n\t\t\tif( !this.needsEmployerInformation(personalEconomy) ) {\r\n\t\t\t\tthis.clearEmployerInformation(personalEconomy);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tthis.update(personalEconomy);\r\n\t}\r\n\r\n\tneedsIncomeOfEmployment(personalEconomy: PersonalEconomy): boolean {\r\n\t\tif( personalEconomy.typeOfEmployment===LPEmploymentEnum.PERMANENT\r\n\t\t\t|| personalEconomy.typeOfEmployment===LPEmploymentEnum.TEMPORARY\r\n\t\t\t|| personalEconomy.typeOfEmployment===LPEmploymentEnum.PROBATIONARY\r\n\t\t\t|| personalEconomy.typeOfEmployment===LPEmploymentEnum.PENSION\t\r\n\t\t\t|| personalEconomy.typeOfEmployment===LPEmploymentEnum.STUDENT_AID\r\n\t\t\t|| personalEconomy.typeOfEmployment===LPEmploymentEnum.UNEMPLOYMENT_INSURANCE ) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\tmayHaveIncomeOfEmployment(personalEconomy: PersonalEconomy): boolean {\r\n\t\tif( personalEconomy.typeOfEmployment===LPEmploymentEnum.SELF_EMPLOYED ) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\tneedsEmployerInformation(personalEconomy: PersonalEconomy): boolean {\r\n\t\tif( personalEconomy.typeOfEmployment===LPEmploymentEnum.PERMANENT\r\n\t\t\t|| personalEconomy.typeOfEmployment===LPEmploymentEnum.TEMPORARY\r\n\t\t\t|| personalEconomy.typeOfEmployment===LPEmploymentEnum.SELF_EMPLOYED\r\n\t\t\t|| personalEconomy.typeOfEmployment===LPEmploymentEnum.PROBATIONARY \r\n\t\t\t) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\tsetYearOfEmployment(personalEconomy: PersonalEconomy, year: number|undefined) {\r\n\t\tpersonalEconomy.yearOfEmployment = year;\r\n\t\tif ( !this.needsMonthOfEmployment(personalEconomy) ) {\r\n\t\t\tpersonalEconomy.monthOfEmployment = undefined;\r\n\t\t}\r\n\t\tthis.update(personalEconomy);\r\n\t}\r\n\r\n\tneedsMonthOfEmployment(personalEconomy: PersonalEconomy): boolean {\r\n\t\tif( !this.needsEmployerInformation(personalEconomy) )\r\n\t\t\treturn false;\r\n\r\n\t\tconst thisYear = new Date().getFullYear();\r\n\t\tif( personalEconomy.yearOfEmployment && personalEconomy.yearOfEmployment>=(thisYear-1) ) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\tclearEmploymentInformation(personalEconomy: PersonalEconomy):void {\r\n\t\tthis.clearIncomeOfEmployment(personalEconomy);\r\n\t\tthis.clearEmployerInformation(personalEconomy);\r\n\t}\r\n\r\n\tclearIncomeOfEmployment(personalEconomy: PersonalEconomy):void {\r\n\t\tpersonalEconomy.income = undefined;\r\n\t\tthis.update(personalEconomy);\r\n\t}\r\n\r\n\tclearEmployerInformation(personalEconomy: PersonalEconomy):void {\r\n\t\tpersonalEconomy.employer = undefined;\r\n\t\tpersonalEconomy.yearOfEmployment = undefined;\r\n\t\tpersonalEconomy.monthOfEmployment = undefined;\r\n\t\tthis.update(personalEconomy);\r\n\t}\r\n\r\n\thasEmploymentInformation(personalEconomy: PersonalEconomy):boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(personalEconomy.income)\r\n\t\t\t|| g.hasValue(personalEconomy.employer)\r\n\t\t\t|| g.hasValue(personalEconomy.yearOfEmployment)\r\n\t\t\t|| g.hasValue(personalEconomy.monthOfEmployment);\r\n\t}\r\n\r\n\tgetEmploymentDate(pe: PersonalEconomy):Date|undefined {\r\n\t\tif( !this.needsEmployerInformation(pe) )\r\n\t\t\treturn;\r\n\r\n\t\tlet year = pe.yearOfEmployment;\r\n\t\tif( !year )\r\n\t\t\treturn;\r\n\r\n\t\tconst needsMonthOfEmployment = this.needsMonthOfEmployment(pe);\r\n\t\tif( needsMonthOfEmployment && !pe.monthOfEmployment)\r\n\t\t\treturn;\r\n\r\n\t\tlet month = needsMonthOfEmployment?(pe.monthOfEmployment||1):1;\r\n\r\n\t\tlet date = new Date(year, month, 1);\r\n\t\treturn date;\r\n\t}\r\n\r\n\tneedsProofOfEmployment(pe: PersonalEconomy):boolean {\r\n\t\tif( pe.typeOfEmployment===LPEmploymentEnum.PERMANENT ) {\r\n\t\t\tconst date = this.getEmploymentDate(pe);\r\n\t\t\tconst now = new Date();\r\n\t\t\tconst limit = new Date(now.getFullYear()-1, now.getMonth(), now.getDate());\r\n\t\t\tif( date && this.guardService.isAfterDate(date, limit)) {\r\n\t\t\t\treturn true;\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\tvalidateApplicantPersonalEconomy(c:Case, applicant: Applicant):ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tconst hasPersonalEconomy = this.hasPersonalEconomy(c, applicant);\r\n\t\tvr.add({validator:this.hasPersonalEconomy, object:applicant, ok:hasPersonalEconomy});\r\n\t\tif( hasPersonalEconomy ) {\r\n\t\t\tlet personalEconomy = this.getPersonalEconomy(c, applicant);\r\n\t\t\tif( personalEconomy)\r\n\t\t\t\tvr.addResult(this.validatePersonalEconomy(personalEconomy));\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\thasPersonalEconomy(c:Case, applicant: Applicant): boolean {\r\n\t\tlet r = this.getPersonalEconomy(c, applicant);\r\n\t\treturn r ? true:false;\r\n\t}\r\n\r\n\tprivate validatePersonalEconomy(personalEconomy: PersonalEconomy):ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tlet hasTypeOfEmployement = this.hasTypeOfEmployment(personalEconomy);\r\n\t\tvr.add({validator:this.hasTypeOfEmployment, object:personalEconomy, ok:hasTypeOfEmployement});\r\n\r\n\t\tif( this.needsIncomeOfEmployment(personalEconomy) ) {\r\n\t\t\tvr.add({validator:this.hasIncome, object:personalEconomy, ok:this.hasIncome(personalEconomy)});\r\n\t\t\tif( this.needsEmployerInformation(personalEconomy) ) {\r\n\t\t\t\tthis.validateEmployerInformation(vr, personalEconomy);\r\n\t\t\t}\r\n\t\t}\r\n\t\telse if ( this.mayHaveIncomeOfEmployment(personalEconomy) ) {\r\n\t\t\tif( this.hasEmploymentInformation(personalEconomy)) {\r\n\t\t\t\tif( this.needsEmployerInformation(personalEconomy) ) {\r\n\t\t\t\t\tthis.validateEmployerInformation(vr, personalEconomy);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn vr;\r\n\t}\r\n\tprivate validateEmployerInformation(vr:ValidationResult, personalEconomy: PersonalEconomy):void {\r\n\t\tvr.add({validator:this.hasEmployer, object:personalEconomy, ok:this.hasEmployer(personalEconomy)});\r\n\t\tvr.add({validator:this.hasEmploymentYear, object:personalEconomy, ok:this.hasEmploymentYear(personalEconomy)});\r\n\t\tif( this.needsMonthOfEmployment(personalEconomy) ) {\r\n\t\t\tvr.add({validator:this.hasEmploymentMonth, object:personalEconomy, ok:this.hasEmploymentMonth(personalEconomy)});\r\n\t\t}\r\n\t}\r\n\thasTypeOfEmployment(personalEconomy: PersonalEconomy):boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(personalEconomy.typeOfEmployment);\r\n\t}\r\n\thasIncome(personalEconomy: PersonalEconomy):boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isGreaterThanOrEqual(personalEconomy.income, 0);\r\n\t}\r\n\thasEmployer(personalEconomy: PersonalEconomy):boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasLengthGreaterThan(personalEconomy.employer, 0);\r\n\t}\r\n\thasEmploymentYear(personalEconomy: PersonalEconomy):boolean {\r\n\t\tconst g = this.guardService;\r\n\t\tconst year = personalEconomy.yearOfEmployment;\r\n\t\tif( g.isNumber(year) && year && year > 1900 ) {\r\n\t\t\tconst thisYear = new Date().getFullYear();\r\n\t\t\tif( year<=thisYear )\r\n\t\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\thasEmploymentMonth(personalEconomy: PersonalEconomy):boolean {\r\n\t\tconst g = this.guardService;\r\n\t\tconst month = personalEconomy.monthOfEmployment;\r\n\t\treturn g.isNumber(month) && month && month>=1 && month<=12 ? true:false;\r\n\t}\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { Guarantor, Case } from '../models/SelmaModels';\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { GuardService } from './GuardService';\r\nimport { IdService } from './IdService';\r\n\r\n/*\r\nHandles all logic for Guarantor.\r\n*/\r\nexport class GuarantorService extends BaseService {\r\n\r\n\tprivate stateService: StateService;\r\n\tprivate smelpoService: SMELPOService;\r\n\tprivate guardService: GuardService;\r\n\r\n\tconstructor(stateService: StateService, smelpoService: SMELPOService,\r\n\t\tguardService: GuardService, private idService:IdService) {\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.smelpoService = smelpoService;\r\n\t\tthis.guardService = guardService;\r\n\t}\r\n\r\n\tupdate(guarantor: Guarantor|Case): void {\r\n\t\tthis.stateService.update(guarantor);\r\n\t}\r\n\r\n\tensureMinimumGuarantors(c: Case): void {\r\n\t\tif( !c.guarantors || c.guarantors.length<1 ) {\r\n\t\t\tlet guarantor = this.newGuarantor();\r\n\t\t\tthis.addGuarantor(c, guarantor);\r\n\t\t}\r\n\t}\r\n\r\n\taddGuarantor(c: Case, guarantor:Guarantor): void {\r\n\t\tif( !c.guarantors )\r\n\t\t\tc.guarantors = [];\r\n\r\n\t\tc.guarantors.push(guarantor);\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tnewGuarantor() : Guarantor {\r\n\t\treturn {\r\n\t\t\tid: this.idService.newGuid()\r\n\t\t}\r\n\t}\r\n\r\n\thasGuarantor(c: Case): boolean {\r\n\t\treturn this.guardService.hasLengthGreaterThanZero(c.guarantors);\r\n\t}\r\n\r\n\tremoveGuarantor(c: Case, guarantor: Guarantor) {\r\n\t\tif(!c.guarantors)\r\n\t\t\treturn;\r\n\t\tthis.stateService.listRemove(c.guarantors, guarantor)\r\n\t\tthis.update(guarantor);\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tremoveAllGuarantors(c: Case): void {\r\n\t\tif( !c.guarantors || c.guarantors.length===0 )\r\n\t\t\treturn;\r\n\t\tc.guarantors = undefined;\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tvalidateGuarantor(c: Case, x: Guarantor): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tvr.add({validator:this.hasName, object:x, ok: this.hasName(x)});\r\n\t\tvr.add({validator:this.hasPhone, object:x, ok: this.hasPhone(x)});\r\n\t\tvr.add({validator:this.hasCustomerId, object:x, ok: this.hasCustomerId(x)});\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tvalidateGuarantors(c:Case): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tif (c.guarantors) {\r\n\t\t\tc.guarantors?.forEach(x => {\r\n\t\t\t\tvr.addResult(this.validateGuarantor(c, x));\r\n\t\t\t})\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\thasName(x: Guarantor): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isString(x.name) && this.guardService.hasLengthGreaterThan(x.name, 1);\r\n\t}\r\n\r\n\thasPhone(x: Guarantor): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(x.phone) && this.guardService.hasLengthGreaterThan(x.phone, 5);\r\n\t}\r\n\r\n\thasCustomerId(x: Guarantor): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\tconst ret = x.guarantorCustomerId && g.isString(x.guarantorCustomerId) && g.isValidSsn(x.guarantorCustomerId) ? true : false;\r\n\t\treturn ret;\r\n\t}\r\n}\r\n","import { TextService } from \"../../services/TextService\"\r\n\r\nexport interface UINamed {\r\n\tname: string;\r\n\tnameTextkey: string;\r\n}\r\n\r\nexport function getUIName(uiNamed: UINamed, textService: TextService) : string {\r\n\tvar name = textService.text(uiNamed.nameTextkey);\r\n\tif( name )\r\n\t\treturn name;\r\n\telse\r\n\t\treturn uiNamed.name;\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { Case, EUSupport, EUSupportEnum } from '../models/SelmaModels';\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { GuardService } from './GuardService';\r\nimport { IdService } from './IdService';\r\nimport { uiEUSupports } from '../models/UiModels';\r\nimport { TextService } from './TextService';\r\nimport { getUIName } from '../models/uimodels/UINamed';\r\n\r\n/*\r\nHandles all logic for EuSupport.\r\n*/\r\nexport class EuSupportService extends BaseService {\r\n\r\n\r\n\tprivate stateService: StateService;\r\n\tprivate smelpoService: SMELPOService;\r\n\tprivate guardService: GuardService;\r\n\r\n\tconstructor(stateService: StateService, smelpoService: SMELPOService, \r\n\t\tguardService: GuardService, private idService:IdService, private textService: TextService) {\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.smelpoService = smelpoService;\r\n\t\tthis.guardService = guardService;\r\n\t}\r\n\r\n\tupdate(euSupport: EUSupport|Case): void {\r\n\t\tthis.stateService.update(euSupport);\r\n\t}\r\n\r\n\tgetThisYearsEuSupports(c: Case): EUSupport[] {\r\n\t\tif( !c.euSupports )\r\n\t\t\treturn [];\r\n\r\n\t\tconst thisYear = new Date().getFullYear().toString();\r\n\t\treturn c.euSupports.filter(x=> {return x.supportYear && x.supportYear===thisYear})\r\n\t}\r\n\r\n\tensureMinimumEuSupports(c: Case): void {\r\n\t\tif( !c.euSupports )\r\n\t\t\tc.euSupports = [];\r\n\r\n\t\tconst euSupports = this.getThisYearsEuSupports(c);\r\n\t\tif( euSupports.length<1 ) {\r\n\t\t\tlet euSupport = this.newEuSupport();\r\n\t\t\tc.euSupports.push(euSupport);\r\n\t\t\tthis.update(c);\r\n\t\t}\r\n\t}\r\n\r\n\thasEuSupport(c: Case): boolean {\r\n\t\treturn this.guardService.hasLengthGreaterThanZero(c.euSupports);\r\n\t}\r\n\r\n\tremoveAllEuSupports(c: Case): void {\r\n\t\tif( !c.euSupports || c.euSupports.length===0 )\r\n\t\t\treturn;\r\n\t\tc.euSupports = undefined;\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tnewEuSupport() : EUSupport {\r\n\t\tconst thisYear = new Date().getFullYear().toString();\r\n\t\treturn {\r\n\t\t\tid: this.idService.newGuid(),\r\n\t\t\tsupportYear: thisYear\r\n\t\t}\r\n\t}\r\n\r\n\tvalidateEuSupport(c: Case, x: EUSupport): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tvr.add({validator:this.hasType, object:x, ok: this.hasType(x)});\r\n\t\tvr.add({validator:this.hasAmount, object:x, ok: this.hasAmount(x)});\r\n\t\tvr.add({validator:this.hasValidYear, object:x, ok: this.hasValidYear(x)});\r\n\t\treturn vr;\r\n\t}\r\n\r\n\thasType(x: EUSupport): boolean {\r\n\t\treturn this.guardService.hasValue(x.euType);\r\n\t}\r\n\r\n\thasAmount(x: EUSupport): boolean {\r\n\t\treturn this.guardService.isGreaterThanZero(x.supportAmount);\r\n\t}\r\n\r\n\thasValidYear(x: EUSupport): boolean {\r\n\t\tconst validYear = new Date().getFullYear().toString();\r\n\t\treturn x.supportYear===validYear;\r\n\t}\r\n\r\n\tgetEuTypeDisplayName(euType: EUSupportEnum | undefined): string {\r\n\t\tvar r = uiEUSupports.find(x => x.type===euType);\r\n\t\tif( r)\r\n\t\t\treturn getUIName(r, this.textService);\r\n\t\telse \r\n\t\t\treturn \"\";\r\n\t}\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { Case, ExtLoan, Household } from '../models/SelmaModels';\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { GuardService } from './GuardService';\r\nimport { ApplicantService } from './ApplicantService';\r\nimport { IdService } from './IdService';\r\nimport { TypeOfLoan } from '../libs/SMELPOClient';\r\n\r\n/*\r\nHandles all logic for ExtLoan.\r\n*/\r\nexport class ExtLoanService extends BaseService {\r\n\tprivate stateService: StateService;\r\n\tprivate smelpoService: SMELPOService;\r\n\tprivate guardService: GuardService;\r\n\r\n\tconstructor(stateService: StateService, smelpoService: SMELPOService, \r\n\t\tguardService: GuardService, private applicantService:ApplicantService, private idService:IdService) {\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.smelpoService = smelpoService;\r\n\t\tthis.guardService = guardService;\r\n\t} \r\n\r\n\tupdate(extLoan: ExtLoan|Case): void {\r\n\t\tthis.stateService.update(extLoan);\r\n\t}\r\n\r\n\tnewExtLoan() : ExtLoan {\r\n\t\treturn {\r\n\t\t\tid: this.idService.newGuid()\r\n\t\t};\r\n\t}\r\n\t\r\n\taddExtLoan(c: Case, extLoan: ExtLoan) {\r\n\t\tif( !c.extLoans )\r\n\t\t\tc.extLoans = [];\r\n\t\tc.extLoans.push(extLoan); \r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tremoveExtLoan(c: Case, extLoan: ExtLoan): void {\r\n\t\tif (!c.extLoans) \r\n\t\t\treturn;\r\n\t\telse {\r\n\t\t\tthis.stateService.listRemove(c.extLoans, extLoan);\r\n\t\t\tthis.update(c);\r\n\t\t}\r\n\t}\r\n\r\n\r\n\tgetExtLoansByCustomerId(c:Case, customerId: string) : ExtLoan[] {\r\n\t\tif( !c.extLoans )\r\n\t\t\treturn [];\r\n\r\n\t\tconst r = c.extLoans.filter(x=>{\r\n\t\t\treturn this.isExtLoanOwner(x, customerId)\r\n\t\t});\r\n\t\treturn r;\r\n\t}\r\n\r\n\tremoveExtLoansForHousehold(c: Case, household: Household) {\r\n\t\t// TODO: Only works as long as we have one household!\r\n\t\tif( c.extLoans ) {\r\n\t\t\tthis.stateService.listRemoveAll(c.extLoans);\r\n\t\t\tthis.update(c);\r\n\t\t} \r\n\t}\r\n\r\n\tremoveAllExtLoans(c:Case):void {\r\n\t\tif( c.extLoans ) {\r\n\t\t\tthis.stateService.listRemoveAll(c.extLoans);\r\n\t\t\tthis.update(c);\r\n\t\t} \r\n\t}\r\n\r\n\tremoveLoanOwnerForHousehold(c:Case, household:Household, customerId:string) : void {\r\n\t\tvar extLoans = this.getExtLoansByCustomerId(c, /*household,*/ customerId);\r\n\t\tif( extLoans ) {\r\n\t\t\textLoans.forEach(x => {\r\n\t\t\t\tthis.removeLoanOwner(x, customerId);\r\n\t\t\t})\r\n\t\t}\r\n\t}\r\n\r\n\tremoveLoanOwner(extLoan:ExtLoan, customerId:string) : void {\r\n\t\tif( extLoan.loanOwners ) {\r\n\t\t\tif( 0!==this.stateService.listRemoveWhere(extLoan.loanOwners, \r\n\t\t\t\tx => this.guardService.compareCustomerId(x.customerId, customerId)) ) {\r\n\t\t\t\t\tthis.update(extLoan);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tisExtLoanOwner(extLoan:ExtLoan, customerId:string) : boolean {\r\n\t\tif( !extLoan.loanOwners )\r\n\t\t\treturn false;\r\n\t\t\r\n\t\tfor( let extLoanMember of extLoan.loanOwners ) {\r\n\t\t\tif( this.guardService.compareCustomerId(extLoanMember.customerId, customerId) )\r\n\t\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\tvalidateExtLoan(c: Case, x: ExtLoan): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tconst hasType = this.hasType(x);\r\n\t\tvr.add({validator:this.hasType, object:x, ok: hasType});\r\n\t\tif( hasType ) {\r\n\t\t\tvr.add({validator:this.hasValidLoanOwners, object:x, ok: this.hasValidLoanOwners(x)});\r\n\r\n\t\t\tconst isStudentLoan = this.isStudentLoan(x);\r\n\t\t\tif( isStudentLoan ) {\r\n\t\t\t\tvr.add({validator:this.hasMonthlyCost, object:x, ok: this.hasMonthlyCost(x)});\r\n\t\t\t} else {\r\n\t\t\t\tvr.add({validator:this.hasAmount, object:x, ok: this.hasAmount(x)});\r\n\t\t\t\tvr.add({validator:this.hasRedeem, object:x, ok: this.hasRedeem(x)});\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\thasType(x: ExtLoan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(x.type);\r\n\t}\r\n\r\n\tisStudentLoan(x: ExtLoan):boolean {\r\n\t\treturn x.type==TypeOfLoan.Studieln; // see uiExtLoanTypes\r\n\t}\r\n\r\n\t// Used for student loans. \r\n\thasMonthlyCost(x: ExtLoan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isGreaterThanZero(x.monthlyCost);\r\n\t}\r\n\r\n\t// Used for everything except student loans. \r\n\thasAmount(x: ExtLoan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isGreaterThanZero(x.amount);\r\n\t}\r\n\r\n\thasRedeem(x: ExtLoan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(x.redeemLoan);\r\n\t}\r\n\r\n\thasValidLoanOwners(x: ExtLoan): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasLengthGreaterThan(x.loanOwners,0);\r\n\t}\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { Case, MaintenanceCost, MaintenanceHouse, Applicant, LoanOwner, Household } from '../models/SelmaModels';\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { GuardService } from './GuardService';\r\nimport { ApplicantService } from './ApplicantService';\r\nimport { IdService } from './IdService';\r\nimport { TypeOfHouse } from '../libs/SMELPOClient';\r\n\r\n/*\r\nHandles all logic for MaintenanceCost.\r\n*/\r\nexport class MaintenanceCostService extends BaseService {\r\n\tprivate stateService: StateService;\r\n\tprivate smelpoService: SMELPOService;\r\n\tprivate guardService: GuardService;\r\n\r\n\tconstructor(stateService: StateService, smelpoService: SMELPOService, \r\n\t\tguardService: GuardService, private applicantService:ApplicantService, private idService:IdService) {\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.smelpoService = smelpoService;\r\n\t\tthis.guardService = guardService;\r\n\t} \r\n\r\n\tupdate(maintenanceCost: MaintenanceCost|MaintenanceHouse|Case|LoanOwner): void { \r\n\t\tthis.stateService.update(maintenanceCost);\r\n\t}\r\n\r\n\tnewMaintenanceCost(c: Case, applicant:Applicant) : MaintenanceCost {\r\n\t\treturn {\r\n\t\t\tid: this.idService.newGuid(), \r\n\t\t\tcustomerId: applicant.customerId,\r\n\t\t\ttypeofhouses: [\r\n\t\t\t\tthis.newMaintenanceHouse(c)\r\n\t\t\t]\r\n\t\t};\r\n\t}\r\n\r\n\tnewMaintenanceHouse(c: Case) : MaintenanceHouse {\r\n\t\treturn {\r\n\t\t};\r\n\t}\r\n\t\r\n\taddMaintenanceCost(c: Case, maintenanceCost: MaintenanceCost) {\r\n\t\tif( !c.maintenanceCosts )\r\n\t\t\tc.maintenanceCosts = [];\r\n\t\tc.maintenanceCosts.push(maintenanceCost); \r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tremoveMaintenanceCost(c: Case, maintenanceCost: MaintenanceCost): void {\r\n\t\tif (!c.maintenanceCosts) \r\n\t\t\treturn;\r\n\t\telse {\r\n\t\t\tthis.stateService.listRemove(c.maintenanceCosts, maintenanceCost);\r\n\t\t\tthis.update(c);\r\n\t\t}\r\n\t}\r\n\r\n\tremoveMaintenanceCostsForHousehold(c: Case, household: Household) {\r\n\t\t// TODO: Only works as long as we have one household!\r\n\t\tif( c.maintenanceCosts ) {\r\n\t\t\tthis.stateService.listRemoveAll(c.maintenanceCosts);\r\n\t\t\tthis.update(c);\r\n\t\t}\r\n\t}\r\n\r\n\t\r\n\tremoveAllMaintenanceCosts(c: Case) {\r\n\t\tif( c.maintenanceCosts ) {\r\n\t\t\tthis.stateService.listRemoveAll(c.maintenanceCosts);\r\n\t\t\tthis.update(c);\r\n\t\t}\r\n\t}\r\n\r\n\r\n\tensureMaintenanceHouse(c:Case, maintenanceCost: MaintenanceCost) : MaintenanceHouse {\r\n\t\tif( !maintenanceCost.typeofhouses)\r\n\t\t\tmaintenanceCost.typeofhouses = [];\r\n\r\n\t\tif( maintenanceCost.typeofhouses.length===0 ) {\r\n\t\t\tmaintenanceCost.typeofhouses.push(this.newMaintenanceHouse(c));\r\n\t\t\tthis.update(maintenanceCost);\r\n\t\t}\r\n\r\n\t\treturn maintenanceCost.typeofhouses[0];\r\n\t}\r\n\r\n\tgetLoanOwnersOwnershipPartSum(maintenanceHouse: MaintenanceHouse):number {\r\n\t\tlet sum = 0;\r\n\t\tif( maintenanceHouse.loanOwners ) {\r\n\t\t\tmaintenanceHouse.loanOwners.forEach(x => {\r\n\t\t\t\tsum += (x.ownershipPart||0);\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn sum;\r\n\t}\r\n\r\n\tensureLoanOwner(maintenanceHouse: MaintenanceHouse, customerId: string):LoanOwner {\r\n\t\tif (!maintenanceHouse.loanOwners)\r\n\t\t\tmaintenanceHouse.loanOwners = [];\r\n\t\t\r\n\t\tconst g = this.guardService;\r\n\t\tlet loanOwner = maintenanceHouse.loanOwners.find(x => g.compareCustomerId(x.customerId, customerId));\r\n\t\tif( !loanOwner ) {\r\n\t\t\tconst sum = this.getLoanOwnersOwnershipPartSum(maintenanceHouse);\r\n\t\t\tconst rest = 100-sum;\r\n\t\t\tconst ownershipPart = rest>0?rest:0;\r\n\t\t\tloanOwner = {\r\n\t\t\t\tcustomerId: customerId,\r\n\t\t\t\townershipPart: ownershipPart\r\n\t\t\t}\r\n\t\t\tmaintenanceHouse.loanOwners.push(loanOwner);\r\n\t\t\tthis.update(maintenanceHouse);\r\n\t\t}\r\n\t\treturn loanOwner;\r\n\t}\r\n\r\n\tremoveLoanOwnerForHousehold(c:Case, household:Household, customerId:string) : void {\r\n\t\tvar maintenanceHouses = this.getMaintenanceHousesByCustomerId(c, /*household,*/ customerId);\r\n\t\tif( maintenanceHouses && maintenanceHouses.length ) {\r\n\t\t\tmaintenanceHouses.forEach(x => {\r\n\t\t\t\tthis.removeLoanOwnerByCustomerId(x, customerId);\r\n\t\t\t})\r\n\t\t}\r\n\t}\r\n\r\n\tgetMaintenanceHousesByCustomerId(c:Case, customerId: string) : MaintenanceHouse[] {\r\n\t\tif( !c.maintenanceCosts )\r\n\t\t\treturn [];\r\n\t\t\r\n\t\tvar maintenanceHouses:MaintenanceHouse[] = c.maintenanceCosts\r\n\t\t\t.map(x => x.typeofhouses??[])\r\n\t\t\t.flat();\r\n\r\n\t\tconst r = maintenanceHouses.filter(x => {\r\n\t\t\treturn this.isLoanOwner(x, customerId)\r\n\t\t});\r\n\t\treturn r;\r\n\t}\r\n\r\n\tisLoanOwner(maintenanceHouse:MaintenanceHouse, customerId:string) : boolean {\r\n\t\tif( !maintenanceHouse.loanOwners )\r\n\t\t\treturn false;\r\n\t\t\r\n\t\tfor( let loanOwner of maintenanceHouse.loanOwners ) {\r\n\t\t\tif( this.guardService.compareCustomerId(loanOwner.customerId, customerId) )\r\n\t\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\tremoveLoanOwnerByCustomerId(maintenanceHouse: MaintenanceHouse, customerId:string) : void {\r\n\t\tif( maintenanceHouse.loanOwners ) {\r\n\t\t\tif( 0!==this.stateService.listRemoveWhere(maintenanceHouse.loanOwners, \r\n\t\t\t\tx => this.guardService.compareCustomerId(x.customerId, customerId)) ) {\r\n\t\t\t\t\tthis.update(maintenanceHouse);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tremoveLoanOwner(maintenanceHouse: MaintenanceHouse, loanOwner: LoanOwner):void {\r\n\t\tif( !maintenanceHouse.loanOwners )\r\n\t\t\treturn;\r\n\t\tthis.stateService.listRemove(maintenanceHouse.loanOwners, loanOwner);\r\n\t\tthis.update(maintenanceHouse);\r\n\t}\r\n\r\n\tvalidateMaintenanceCost(c: Case, x: MaintenanceCost): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tvr.add({validator:this.hasCustomerId, object:x, ok: this.hasCustomerId(x)});\r\n\r\n\t\tconst hasTypesOfHouses = this.hasTypesOfHouses(x);\r\n\t\tvr.add({validator:this.hasTypesOfHouses, object:x, ok: hasTypesOfHouses});\r\n\t\tif( hasTypesOfHouses && x.typeofhouses ) {\r\n\t\t\tx.typeofhouses.forEach(h => {\r\n\t\t\t\tvr.addResult(this.validateMaintenanceHouse(c,h));\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tprivate validateMaintenanceHouse(c:Case, h: MaintenanceHouse) : ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tconst hasSetHouseType = this.hasSetHouseType(h);\r\n\t\tvr.add({validator:this.hasSetHouseType, object:h, ok: hasSetHouseType});\r\n\t\tvr.add({validator:this.hasSetKeepHouse, object:h, ok: this.hasSetKeepHouse(h)});\r\n\t\tconst keepHouse = this.hasKeepHouse(h);\r\n\t\tif( hasSetHouseType && keepHouse ) {\r\n\t\t\tif( h.houseType===TypeOfHouse.Hyresrtt ) {\r\n\t\t\t\tvr.add({validator:this.hasMaintenanceCost, object:h, ok: this.hasMaintenanceCost(h)});\r\n\t\t\t} else {\r\n\t\t\t\tif( h.houseType===TypeOfHouse.Bostadsrtt ) {\r\n\t\t\t\t\tvr.add({validator:this.hasMaintenanceCost, object:h, ok: this.hasMaintenanceCost(h)});\r\n\t\t\t\t}\r\n\t\t\t\tvr.add({validator:this.hasSetLoanInOtherInstitute, object:h, ok:this.hasSetLoanInOtherInstitute(h)});\r\n\t\t\t\tif( this.hasLoanInOtherInstitute(h) ) {\r\n\t\t\t\t\tvr.add({validator:this.hasSetRedeemHouseLoan, object:h, ok: this.hasSetRedeemHouseLoan(h)});\r\n\t\t\t\t\tvr.add({validator:this.hasHouseLoanAmount, object:h, ok: this.hasHouseLoanAmount(h)});\r\n\t\t\t\t\tvr.add({validator:this.hasHouseLoanOwners, object:h, ok: this.hasHouseLoanOwners(h)});\r\n\t\t\t\t\tif( h.loanOwners && h.loanOwners.length>0 ) {\r\n\t\t\t\t\t\tlet partSum = 0;\r\n\t\t\t\t\t\th.loanOwners.forEach(lo => {\r\n\t\t\t\t\t\t\tvr.add({validator:this.hasHouseLoanOwnersOwnershipPart, object:lo, ok: this.hasHouseLoanOwnersOwnershipPart(lo)});\r\n\t\t\t\t\t\t\tpartSum += lo.ownershipPart||0;\r\n\t\t\t\t\t\t\tif( partSum > 100 ) {\r\n\t\t\t\t\t\t\t\tvr.add({validator:this.hasHouseLoanOwnersOwnershipPartBelow100InSum, object:lo, ok: false});\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t})\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\thasHouseLoanOwners(h: MaintenanceHouse): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasLengthGreaterThan(h.loanOwners, 0);\r\n\t}\r\n\r\n\thasHouseLoanOwnersOwnershipPart(lo: LoanOwner): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isInRange(lo.ownershipPart,0,100) && g.isGreaterThanZero(lo.ownershipPart);\r\n\t}\r\n\r\n\thasHouseLoanOwnersOwnershipPartBelow100InSum(lo: LoanOwner, accumulatedSum:number): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isInRange(lo.ownershipPart,0,100);\r\n\t}\r\n\r\n\thasSetLoanInOtherInstitute(h: MaintenanceHouse): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(h.loanInOtherInstitute);\r\n\t}\r\n\r\n\thasLoanInOtherInstitute(h: MaintenanceHouse): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(h.loanInOtherInstitute) && h.loanInOtherInstitute===true;\r\n\t}\r\n\r\n\thasMaintenanceCost(h: MaintenanceHouse): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isZeroOrGreater(h.maintenanceCost);\r\n\t}\r\n\r\n\thasHouseLoanAmount(h: MaintenanceHouse): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.isZeroOrGreater(h.houseLoanAmount);\r\n\t}\r\n\r\n\thasCustomerId(x: MaintenanceCost): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn x.customerId && g.isString(x.customerId) && g.isValidSsn(x.customerId) ? true : false;\r\n\t}\r\n\r\n\thasTypesOfHouses(x: MaintenanceCost): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasLengthGreaterThan(x.typeofhouses, 0);\r\n\t}\r\n\r\n\thasSetHouseType(x: MaintenanceHouse): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(x.houseType);\r\n\t}\r\n\r\n\thasSetKeepHouse(x: MaintenanceHouse): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(x.keepHouse);\r\n\t}\r\n\r\n\thasKeepHouse(x: MaintenanceHouse): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(x.keepHouse) && x.keepHouse===true;\r\n\t}\r\n\r\n\t\r\n\thasSetRedeemHouseLoan(x: MaintenanceHouse): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(x.redeemLoan);\r\n\t}\r\n\r\n\thasRedeemHouseLoan(x: MaintenanceHouse): boolean {\r\n\t\tconst g = this.guardService;\r\n\t\treturn g.hasValue(x.redeemLoan) && x.redeemLoan===true;\r\n\t}\r\n\r\n/*\r\n\tgetMaintenanceCostsByHouseholdId(c:Case, householdId: string) : MaintenanceCost[] {\r\n\t\tif( !c.maintenanceCosts )\r\n\t\t\treturn [];\r\n\r\n\t\tconst r = c.maintenanceCosts.filter(x=>{\r\n\t\t\treturn this.isMaintenanceCostOwner(x, customerId)\r\n\t\t});\r\n\t\treturn r;\r\n\t}\r\n\r\n\tisMaintenanceCostOwner(maintenanceCost:MaintenanceCost, customerId:string) : boolean {\r\n\t\tif( !maintenanceCost.loanOwners )\r\n\t\t\treturn false;\r\n\t\t\r\n\t\tfor( let maintenanceCostMember of maintenanceCost.householdId ) {\r\n\t\t\tif( maintenanceCostMember.customerId==customerId )\r\n\t\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}*/\r\n}\r\n","import { UIKeyed } from \"./UIKeyed\";\r\nimport { UINamed } from \"./UINamed\";\r\n\r\nexport interface UIAttachmentType extends UIKeyed, UINamed {\r\n}\r\n\r\nexport const uiAttachmentTypes:UIAttachmentType[] = [\r\n\t{ key: 'FORESTRYPLAN', name: \"Skogsbruksplan\", nameTextkey: \"UIAttachmentType_FORESTRYPLAN\" }, // SKOGSBRUKSPLAN\r\n\t{ key: 'PROOFOFEMPLOYMENT', name: \"Anställningsbevis\", nameTextkey: \"UIAttachmentType_PROOFOFEMPLOYMENT\" }, // ANSTÄLLNINGSBEVIS\r\n\t{ key: 'EUSUPPORT', name: \"EU-stöd\", nameTextkey: \"UIAttachmentType_EUSUPPORT\" }, // EU-STÖD\r\n\t{ key: 'COMPANYBUDGET', name: \"Företagsbudget\", nameTextkey: \"UIAttachmentType_COMPANYBUDGET\" }, // Företagsbudget\r\n\t{ key: 'COMPANYTAXRETURN', name: \"Inkomstdeklaration med samtliga bilagor\", nameTextkey: \"UIAttachmentType_COMPANYTAXRETURN\" }, // Inkomstdeklaration med samtliga bilagor\r\n\t{ key: 'COMPANYFINREPORT', name: \"Bokslut med resultat- och balansräkning\", nameTextkey: \"UIAttachmentType_COMPANYFINREPORT\" }, // Bokslut med resultat- och balansräkning \r\n\t{ key: 'ANNUALACCOUNT', name:\"Inkomst med samtliga bilagor eller bokslut med resultat och balansräkning\", nameTextkey: \"UIAttachmentType_ANNUALACCOUNT\"}, // En sammanslagning av COMPANYTAXRETURN och COMPANYFINREPORT\r\n\t{ key: 'BUILDINGESTIMATE', name: \"Byggnadskalkyl\", nameTextkey: \"UIAttachmentType_BUILDINGESTIMATE\" }, // Kalkyl för nybyggnad, utbyggnad, renovering. Se Aims.\r\n\t{ key: 'OTHER', name: \"Övrigt\", nameTextkey: \"UIAttachmentType_OTHER\" } \r\n];\r\n","import { BaseService } from './BaseService';\r\nimport { Case, AttachmentRequest, Attachment } from '../models/SelmaModels';\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { GuardService } from './GuardService';\r\nimport { IdService } from './IdService';\r\nimport { ApplicantService } from './ApplicantService';\r\nimport { CompanyService } from './CompanyService';\r\nimport { PersonalEconomyService } from './PersonalEconomyService';\r\nimport { uiAttachmentTypes } from '../models/uimodels/UIAttachmentType';\r\nimport { UiModelConverter } from '../models/UiModelConverter';\r\nimport { EuSupportService } from './EuSupportService';\r\nimport { LoanService } from './LoanService';\r\nimport { CompanyEconomyService } from './CompanyEconomyService';\r\nimport { CollateralService } from './CollateralService';\r\nimport { TextService } from './TextService';\r\nimport { getUIName } from '../models/uimodels/UINamed';\r\nimport { ConfigurationService } from './ConfigurationService';\r\nimport { BudgetService } from './BudgetService';\r\n\r\n/*\r\nHandles all logic for attachments.\r\n*/\r\nexport class AttachmentService extends BaseService {\r\n\r\n\tprivate url: string;\r\n\tpublic budgetService?: BudgetService;\r\n\r\n\tconstructor(\r\n\t\tprivate stateService: StateService,\r\n\t\tprivate smelpoService: SMELPOService,\r\n\t\tprivate guardService: GuardService,\r\n\t\tprivate applicantService: ApplicantService,\r\n\t\tprivate personalEconomyService: PersonalEconomyService,\r\n\t\tprivate companyService: CompanyService,\r\n\t\tprivate companyEconomyService: CompanyEconomyService,\r\n\t\tprivate configurationService: ConfigurationService,\r\n\t\tprivate collateralService: CollateralService,\r\n\t\tprivate idService: IdService,\r\n\t\tprivate loanService: LoanService,\r\n\t\tprivate textService: TextService,\r\n\t\turl: string) {\r\n\t\tsuper();\r\n\t\tthis.url = url + \"/attachments\";\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.smelpoService = smelpoService;\r\n\t\tthis.guardService = guardService;\r\n\t}\r\n\r\n\tprivate update(item: Case | AttachmentRequest): void {\r\n\t\tthis.stateService.update(item);\r\n\t}\r\n\r\n\tprivate postFile(\r\n\t\top: string,\r\n\t\trequest: AttachmentRequest,\r\n\t\tc: Case,\r\n\t\tfile: File\r\n\t): Promise {\r\n\t\tvar formData = new FormData();\r\n\r\n\t\tformData.append('customerId', request.customerId || '');\r\n\t\tformData.append('requestType', request.requestType);\r\n\t\tformData.append('requestVariation', request.requestVariation || '');\r\n\t\tformData.append('required', request.required === true ? 'true' : 'false');\r\n\t\tformData.append('processId', c.id);\r\n\t\tformData.append('file', file);\r\n\r\n\t\treturn fetch(this.url + '/' + op, {\r\n\t\t\tmethod: 'POST',\r\n\t\t\tcache: 'no-cache',\r\n\t\t\tcredentials: 'include', //include cookies\r\n\t\t\t//mode: 'cors',\r\n\t\t\theaders: {\r\n\t\t\t\tAccept: 'application/json',\r\n\t\t\t\t//'Content-Type': 'application/json'\r\n\t\t\t},\r\n\t\t\tbody: formData,\r\n\t\t})\r\n\t\t\t.then((result) => {\r\n\t\t\t\treturn result.json();\r\n\t\t\t})\r\n\t\t\t.then((result) => {\r\n\t\t\t\tlet postResult: T = result;\r\n\t\t\t\treturn postResult;\r\n\t\t\t});\r\n\t}\r\n\r\n\tprivate get(op: string): Promise {\r\n\t\treturn fetch(this.url + '/' + op, {\r\n\t\t\tmethod: \"POST\",\r\n\t\t\tcache: 'no-cache',\r\n\t\t\tcredentials: 'include', //include cookies\r\n\t\t\t//mode: 'cors',\r\n\t\t\theaders: {\r\n\t\t\t\t'Accept': 'application/json',\r\n\t\t\t\t'Content-Type': 'application/json'\r\n\t\t\t},\r\n\t\t\t//body: file\r\n\t\t})\r\n\t\t\t.then(result => {\r\n\t\t\t\treturn result.json();\r\n\t\t\t})\r\n\t\t\t.then((result) => {\r\n\t\t\t\tlet bidResult: T = result;\r\n\t\t\t\treturn bidResult;\r\n\t\t\t});\r\n\t}\r\n\r\n\tprivate post(op: string): Promise {\r\n\t\treturn fetch(this.url + '/' + op, {\r\n\t\t\tmethod: \"POST\",\r\n\t\t\tcache: 'no-cache',\r\n\t\t\tcredentials: 'include', //include cookies\r\n\t\t\t//mode: 'cors',\r\n\t\t\theaders: {\r\n\t\t\t\t'Accept': 'application/json',\r\n\t\t\t\t'Content-Type': 'application/json'\r\n\t\t\t},\r\n\t\t\t//body: file\r\n\t\t})\r\n\t\t\t.then(result => {\r\n\t\t\t\treturn result.json();\r\n\t\t\t})\r\n\t\t\t.then((result) => {\r\n\t\t\t\tlet bidResult: T = result;\r\n\t\t\t\treturn bidResult;\r\n\t\t\t});\r\n\t}\r\n\r\n\r\n\tdownloadAttachment(c: Case, attachmentId: string): void {\r\n\t\tthis.redirectToDownloadUrl(c.id, attachmentId);\r\n\t}\r\n\r\n\tremoveAttachment(c: Case, attachmentId: string): Promise {\r\n\t\treturn this.post(\"delete?id=\" + attachmentId + \"&processId=\" + c.id)\r\n\t\t\t.then(result => {\r\n\t\t\t\tif (result) {\r\n\t\t\t\t\tif (c.attachments) {\r\n\t\t\t\t\t\tlet a = this.findAttachmentInArray(c.attachments, attachmentId);\r\n\t\t\t\t\t\tif (a) {\r\n\t\t\t\t\t\t\tthis.stateService.listRemove(c.attachments, a);\r\n\t\t\t\t\t\t\tthis.update(c);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\treturn c;\r\n\t\t\t})\r\n\t}\r\n\r\n\tfindAttachmentInArray(attachments: Attachment[], attachmentId: string): Attachment | undefined {\r\n\t\tlet r = attachments.filter(x => {\r\n\t\t\treturn x.id == attachmentId;\r\n\t\t})\r\n\t\tif (r.length === 1)\r\n\t\t\treturn r[0];\r\n\t\telse\r\n\t\t\treturn;\r\n\t}\r\n\r\n\tprivate redirectToDownloadUrl(processId: string, fileId: string) {\r\n\t\tconst protectAgainstPageLeave = this.configurationService.protectAgainstPageLeave();\r\n\t\tif (protectAgainstPageLeave)\r\n\t\t\tthis.configurationService.setProtectAgainstPageLeave(false);\r\n\t\tconst url = this.url + '/' + \"download?processId=\" + encodeURIComponent(processId) + \"&id=\" + encodeURIComponent(fileId);\r\n\t\tdocument.location.href = url;\r\n\t\tif (protectAgainstPageLeave)\r\n\t\t\tthis.configurationService.setProtectAgainstPageLeave(true);\r\n\t}\r\n\r\n\tuploadAttachment(c: Case, attachmentRequest: AttachmentRequest, file: File): Promise {\r\n\t\treturn this.postFile(\"upload\", attachmentRequest, c, file)\r\n\t\t\t.then((result: Attachment) => {\r\n\t\t\t\tif (!c.attachments)\r\n\t\t\t\t\tc.attachments = [];\r\n\t\t\t\tconst a = result;\r\n\t\t\t\tc.attachments.push(a);\r\n\t\t\t\tthis.update(c);\r\n\t\t\t\treturn result;\r\n\t\t\t});\r\n\t}\r\n\r\n\tprivate addAttachmentRequestNoUpdate(c: Case, attachmentRequest: AttachmentRequest): void {\r\n\t\tif (!c.attachmentRequests)\r\n\t\t\tc.attachmentRequests = [];\r\n\r\n\t\tc.attachmentRequests.push(attachmentRequest);\r\n\t}\r\n\r\n\taddAttachmentRequest(c: Case, attachmentRequest: AttachmentRequest): void {\r\n\t\tthis.addAttachmentRequestNoUpdate(c, attachmentRequest);\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tensureAttachmentRequest(c: Case, attachmentRequest: AttachmentRequest, considerRequestVariation: boolean = true): void {\r\n\t\tif (!c.attachmentRequests) {\r\n\t\t\tc.attachmentRequests = [attachmentRequest];\r\n\t\t} else {\r\n\t\t\tlet ars = this.findAttachmentRequests(c, attachmentRequest.requestType, attachmentRequest.requestVariation, attachmentRequest.customerId, considerRequestVariation);\r\n\t\t\tif (ars.length === 0) {\r\n\t\t\t\tthis.addAttachmentRequest(c, attachmentRequest);\r\n\t\t\t} else {\r\n\t\t\t\tvar ar = ars[0];\r\n\t\t\t\tif (ar.required !== attachmentRequest.required) {\r\n\t\t\t\t\tar.required = attachmentRequest.required; // update missmatching value.\r\n\t\t\t\t\tthis.update(ar);\r\n\t\t\t\t\tthis.update(c);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tgetAttachmentRequestsByType(c: Case, requestType: string): AttachmentRequest[] | undefined {\r\n\t\tif (!c.attachmentRequests) return;\r\n\t\tlet r = c.attachmentRequests.filter(x => x.requestType === requestType);\r\n\t\treturn r;\r\n\t}\r\n\r\n\tgetAttachmentsByType(c: Case, requestType: string): Attachment[] {\r\n\t\tif (!c.attachments) return [];\r\n\t\tlet r = c.attachments.filter(x => x.requestType === requestType);\r\n\t\treturn r;\r\n\t}\r\n\r\n\tprivate findAttachmentRequests(c: Case, requestType: string, requestVariation: string, customerId: string | undefined, considerRequestVariation: boolean = false): AttachmentRequest[] {\r\n\t\tif (!c.attachmentRequests) return [];\r\n\t\tlet r = c.attachmentRequests.filter(x => {\r\n\t\t\tconst sameRequstVariation = (x.requestVariation || '') == (requestVariation || '');\r\n\t\t\tif (!considerRequestVariation || sameRequstVariation) {\r\n\t\t\t\tif (x.requestType === requestType) {\r\n\t\t\t\t\tif ((customerId || '') == (x.customerId || '')) {\r\n\t\t\t\t\t\treturn true;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\treturn false;\r\n\t\t});\r\n\t\treturn r;\r\n\t}\r\n\r\n\r\n\tfindAttachments(c: Case, requestType: string, requestVariation: string, customerId: string | undefined): Attachment[] {\r\n\t\tif (!c.attachments) return [];\r\n\t\tlet r = c.attachments.filter(x => {\r\n\t\t\t//if( x.requestType===requestType && (x.requestVariation||'')==(requestVariation||'') ) {\r\n\t\t\tif (this.compareEffectiveRequestType(x.requestType || '', requestType)) {\r\n\t\t\t\tif ((customerId || '') == (x.customerId || '')) {\r\n\t\t\t\t\treturn true;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\treturn false;\r\n\t\t});\r\n\t\treturn r;\r\n\t}\r\n\r\n\thasAttachments(c: Case, requestType: string, requestVariation: string, customerId: string | undefined): boolean {\r\n\t\tlet r = this.findAttachments(c, requestType, requestVariation, customerId);\r\n\t\tif (r.length > 0)\r\n\t\t\treturn true;\r\n\t\telse\r\n\t\t\treturn false;\r\n\t}\r\n\r\n\tattachmentRequestHasAttachments(c: Case, x: AttachmentRequest): boolean {\r\n\t\tlet r = this.hasAttachments(c, x.requestType, x.requestVariation, x.customerId);\r\n\t\treturn r;\r\n\t}\r\n\r\n\tvalidateAttachmentRequests(c: Case): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tif (c.attachmentRequests && c.attachmentRequests.length > 0) {\r\n\t\t\tvr.addResult(this.validateAttachmentRequestsInArray(c, c.attachmentRequests));\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tvalidateAttachmentRequestsByRequestType(c: Case, requestType: string): ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tif (c.attachmentRequests && c.attachmentRequests.length > 0) {\r\n\t\t\tlet r = c.attachmentRequests.filter(x => this.compareEffectiveRequestType(x.requestType, requestType));\r\n\t\t\tvr.addResult(this.validateAttachmentRequestsInArray(c, r));\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\t// Returns true if request types are effectively the same.\r\n\tcompareEffectiveRequestType(requestTypeA: string, requestTypeB: string): boolean {\r\n\t\treturn this.getEffectiveRequestType(requestTypeA) == this.getEffectiveRequestType(requestTypeB);\r\n\t}\r\n\r\n\tgetEffectiveRequestType(requestType: string): string {\r\n\t\tif (requestType == \"COMPANYFINREPORT\" || requestType == \"COMPANYTAXRETURN\")\r\n\t\t\treturn \"ANNUALACCOUNT\";\r\n\t\treturn requestType;\r\n\t}\r\n\r\n\tprivate validateAttachmentRequestsInArray(c: Case, attachmentRequests: AttachmentRequest[]): ValidationResult {\r\n\t\tconst vr = new ValidationResult();\r\n\t\tif (attachmentRequests.length > 0) {\r\n\t\t\tattachmentRequests.forEach(x => {\r\n\t\t\t\tif (x.required === true) {\r\n\t\t\t\t\tvr.add({ validator: this.attachmentRequestHasAttachments, object: x, ok: this.attachmentRequestHasAttachments(c, x) });\r\n\t\t\t\t\t//console.log(\"validateAttachmentRequestsInArray\", x, this.attachmentRequestHasAttachments(c, x))\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\r\n\r\n\t/*\r\n\tSSL-103, SSL-80\r\n\tCOMPANYBUDGET - Budget\tOmsättning i företaget = JA, och ej manuellt ifylld budget\r\n\tCOMPANYTAXRETURN - Inkomstdeklaration med samtliga bilagor\tOmsättning i företaget= JA (om inte bokslut är uppladdat)\r\n\tCOMPANYFINREPORT - Bokslut med resultat- och balansräkning \tOmsättning i företaget=JA (och inte inkomstdeklaration är uppladdad)\r\n\tBUILDINGESTIMATE - Kalkyl för utbyggnad\tMinst ett syfte i ärendet är utbyggnad\r\n\tBUILDINGESTIMATE - Kalkyl för renovering\tMinst ett syfte i ärendet är renovering\r\n\tBUILDINGESTIMATE - Kalkyl för nybyggnation\tMinst ett syfte i ärendet är nybyggnation\r\n\tFORESTRYPLAN - Skogsbruksplan\tManuellt, info till kund \"Om det är en skogsfastighet....\" \r\n\tPROOFOFEMPLOYMENT - Anställningsbevis\tHar en ny tjänst - anställd < 12 mån.\r\n\tEUSUPPORT - Beräkningsunderlaget från rådgivningsföretag\tHar angivit EU-stöd som säkerhet\r\n\tEUSUPPORT - Jordbruksverkets mottagningskvitto\tHar angivit EU-stöd som säkerhet\r\n\tEUSUPPORT - Föregående årsbesked från Jordbruksverket\tHar angivit EU-stöd som säkerhet\r\n\tEUSUPPORT - Sammanställning Sam-internet \tHar angivit EU-stöd som säkerhet\r\n\tOTHER - Andra bilagor (*inkl förklaring, typ \"Om du har andra bilagor som kan vara av värde i kreditprövningen kan du även skicka in dessa\".)\tKänner att inget av ovanstående passar in men har behov att bifoga material för att ladda upp dokument.\r\n\t*/\r\n\t/*\r\n\t\"UIAttachmentType_FORESTRYPLAN\": \"Skogsbruksplan\",\r\n\t\"UIAttachmentType_PROOFOFEMPLOYMENT\": \"Anställningsbevis\",\r\n\t\"UIAttachmentType_EUSUPPORT\":\"EU-stöd\",\r\n\t\"UIAttachmentType_COMPANYBUDGET\": \"Företagsbudget\",\r\n\t\"UIAttachmentType_COMPANYTAXRETURN\": \"Inkomstdeklaration med samtliga bilagor\",\r\n\t\"UIAttachmentType_COMPANYFINREPORT\": \"Bokslut med resultat- och balansräkning\",\r\n\t\"UIAttachmentType_BUILDINGESTIMATE\": \"Byggnadskalkyl\",\r\n\t\"UIAttachmentType_OTHER\": \"Övrigt\",\r\n\t\"UIAttachmentType_ANNUALACCOUNT\": \"Inkomst med samtliga bilagor eller bokslut med resultat och balansräkning\",\r\n\t*/\r\n\tensureCorrectAttachmentRequests(c: Case) {\r\n\r\n\t\tif (this.budgetService) {\r\n\t\t\tthis.budgetService.ensureBudgetAttachmentRequests(c);\r\n\t\t}\r\n\r\n\t\t// Inkomstdeklaration med samtliga bilagor\tOmsättning i företaget=JA (om inte bokslut är uppladdat)\r\n\t\t// Bokslut med resultat- och balansräkning \tOmsättning i företaget=JA (och inte inkomstdeklaration är uppladdad)\r\n\t\tif (c.companies && c.companyEconomies) {\r\n\t\t\tconst companyEconomyService = this.companyEconomyService;\r\n\t\t\tc.companies.forEach(company => {\r\n\t\t\t\tconst companyEconomy = companyEconomyService.getCompanyEconomy(c, company);\r\n\t\t\t\tif (!companyEconomy)\r\n\t\t\t\t\treturn;\r\n\r\n\t\t\t\tconst hasRevenue = companyEconomyService.hasRevenue(companyEconomy);\r\n\t\t\t\tif (hasRevenue) {\r\n\t\t\t\t\tconst requestVariation = company.name || UiModelConverter.prettyOrgNr(company.orgNumber);\r\n\t\t\t\t\tconst customerId = company.orgNumber;\r\n\r\n\t\t\t\t\t// Begär ANNUALACCOUNT istället för finreport/taxreturn\r\n\t\t\t\t\tthis.ensureAttachmentRequest(c, {\r\n\t\t\t\t\t\tid: this.idService.newGuid(),\r\n\t\t\t\t\t\tcustomerId: customerId,\r\n\t\t\t\t\t\trequestType: \"ANNUALACCOUNT\",\r\n\t\t\t\t\t\trequestVariation: '',\r\n\t\t\t\t\t\trequired: true\r\n\t\t\t\t\t})\r\n\r\n\r\n\t\t\t\t\t//if( !hasUploadedCompanyTaxReturn ) {\r\n\t\t\t\t\t// this.ensureAttachmentRequest(c, {\r\n\t\t\t\t\t// \tid: this.idService.newGuid(),\r\n\t\t\t\t\t// \t\tcustomerId: customerId,\r\n\t\t\t\t\t// \t\trequestType:\"COMPANYFINREPORT\",\r\n\t\t\t\t\t// \t\trequestVariation: companyFinReportVariationText,\r\n\t\t\t\t\t// \t\trequired: !hasUploadedCompanyTaxReturn\r\n\t\t\t\t\t// })\r\n\t\t\t\t\t//}\r\n\t\t\t\t\t//if( !hasUploadedCompanyFinReport ) {\r\n\t\t\t\t\t// this.ensureAttachmentRequest(c, {\r\n\t\t\t\t\t// \tid: this.idService.newGuid(),\r\n\t\t\t\t\t// \t\tcustomerId: customerId,\r\n\t\t\t\t\t// \t\trequestType:\"COMPANYTAXRETURN\",\r\n\t\t\t\t\t// \t\trequestVariation: companyTaxReturnVariationText,\r\n\t\t\t\t\t// \t\trequired: !hasUploadedCompanyFinReport\r\n\t\t\t\t\t// })\r\n\t\t\t\t\t//}\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\r\n\r\n\t\t// Kalkyl för nybyggnation\tMinst ett syfte i ärendet är nybyggnation\r\n\t\t// Kalkyl för utbyggnad\tMinst ett syfte i ärendet är utbyggnad\r\n\t\t// Kalkyl för renovering\tMinst ett syfte i ärendet är renovering\r\n\t\tif (c.loan && c.loan.aims) {\r\n\t\t\tconst loanService = this.loanService;\r\n\r\n\t\t\tc.loan.aims.forEach(x => {\r\n\t\t\t\tconst needsAttachment = (x.aimCategory == \"Nybyggnad\" || x.aimCategory == \"Renovering\" || x.aimCategory == \"Tillbyggnad\") && x.aimDetail && x.aimDetail != \"\";\r\n\t\t\t\tif (needsAttachment) {\r\n\t\t\t\t\tconst aimCategoryName = loanService.getAimCategoryName(x.aimCategory);\r\n\t\t\t\t\tconst aimDetailName = loanService.getAimDetailName(x.aimCategory, x.aimDetail);\r\n\t\t\t\t\tlet requestVariation = aimCategoryName + \", \" + aimDetailName;\r\n\r\n\t\t\t\t\tthis.ensureAttachmentRequest(c, {\r\n\t\t\t\t\t\tid: this.idService.newGuid(),\r\n\t\t\t\t\t\tcustomerId: undefined,\r\n\t\t\t\t\t\trequestType: \"BUILDINGESTIMATE\",\r\n\t\t\t\t\t\trequestVariation: requestVariation,\r\n\t\t\t\t\t\trequired: true\r\n\t\t\t\t\t})\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\r\n\r\n\t\t// Anställningsbevis\tHar en ny tjänst - anställd < 12 mån.\r\n\t\tif (c.applicants) {\r\n\t\t\tc.applicants.forEach(applicant => {\r\n\t\t\t\tconst isPersonOrPersonalCompany = this.applicantService.isPhysicum(c, applicant);\r\n\t\t\t\tif (isPersonOrPersonalCompany) {\r\n\t\t\t\t\tconst pe = this.personalEconomyService.getPersonalEconomy(c, applicant);\r\n\t\t\t\t\tif (pe) {\r\n\t\t\t\t\t\tconst needsProofOfEmployment = this.personalEconomyService.needsProofOfEmployment(pe);\r\n\t\t\t\t\t\tif (needsProofOfEmployment) {\r\n\t\t\t\t\t\t\tthis.ensureAttachmentRequest(c, {\r\n\t\t\t\t\t\t\t\tid: this.idService.newGuid(),\r\n\t\t\t\t\t\t\t\tcustomerId: applicant.customerId,\r\n\t\t\t\t\t\t\t\trequestType: \"PROOFOFEMPLOYMENT\",\r\n\t\t\t\t\t\t\t\trequestVariation: \"\",\r\n\t\t\t\t\t\t\t\trequired: true\r\n\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\t// Skogsbruksplan.\r\n\t\tif (c.collaterals && c.collaterals.length > 0) {\r\n\t\t\tconst collateralService = this.collateralService;\r\n\t\t\t// USE IN THE FUTURE.\r\n\t\t\t// c.collaterals.forEach(x => {\r\n\t\t\t// \tconst needsForestryPlan = collateralService.needsForestryPlan(x);\r\n\t\t\t// \tif( needsForestryPlan ) {\r\n\t\t\t// \t\tthis.ensureAttachmentRequest(c,{\r\n\t\t\t// \t\t\tid: this.idService.newGuid(),\r\n\t\t\t// \t\t\t\trequestType:\"FORESTRYPLAN\",\r\n\t\t\t// \t\t\t\trequestVariation: \"Skogsbruksplan\",\r\n\t\t\t// \t\t\t\trequired: true\r\n\t\t\t// \t\t});\r\n\t\t\t// \t}\r\n\t\t\t// })\r\n\r\n\t\t\t// Simple logic. See SSL-419.\r\n\t\t\tthis.ensureAttachmentRequest(c, {\r\n\t\t\t\tid: this.idService.newGuid(),\r\n\t\t\t\trequestType: \"FORESTRYPLAN\",\r\n\t\t\t\trequestVariation: \"Skogsbruksplan\",\r\n\t\t\t\trequired: false\r\n\t\t\t});\r\n\t\t}\r\n\r\n\r\n\r\n\t\t// Beräkningsunderlaget från rådgivningsföretag:\tHar angivit EU-stöd som säkerhet\r\n\t\t// Jordbruksverkets mottagningskvitto:\tHar angivit EU-stöd som säkerhet\r\n\t\t// Föregående årsbesked från Jordbruksverket:\tHar angivit EU-stöd som säkerhet\r\n\t\t// Sammanställning Sam-internet: \tHar angivit EU-stöd som säkerhet\r\n\t\tif (c.euSupports && c.euSupports.length > 0) {\r\n\r\n\t\t\tc.euSupports.forEach(x => {\r\n\r\n\t\t\t\t//let variator = \"\"; // TODO: maybe add euType name here.\r\n\r\n\t\t\t\tthis.ensureAttachmentRequest(c, {\r\n\t\t\t\t\tid: this.idService.newGuid(),\r\n\t\t\t\t\trequestType: \"EUSUPPORT\",\r\n\t\t\t\t\trequestVariation: \"Beräkningsunderlag från rådgivningsföretag\",\r\n\t\t\t\t\trequired: true\r\n\t\t\t\t});\r\n\r\n\t\t\t\t// DISME-558 Ändra texter i SME - legacy support for old variation text \"Jordbruksverkets mottagningskvitto\" 20210621 /RH\r\n\t\t\t\t//TODO: Remove the if-statement after 20210921\r\n\t\t\t\tlet hasLegacyBoardOfAgricultureRecieptAttachmentRequest = this.findAttachmentRequests(c, \"EUSUPPORT\", \"Jordbruksverkets mottagningskvitto\", undefined, true).length > 0;\r\n\t\t\t\tif (hasLegacyBoardOfAgricultureRecieptAttachmentRequest == false) {\r\n\t\t\t\t\tthis.ensureAttachmentRequest(c, {\r\n\t\t\t\t\t\tid: this.idService.newGuid(),\r\n\t\t\t\t\t\trequestType: \"EUSUPPORT\",\r\n\t\t\t\t\t\t//requestVariation:\"Jordbruksverkets mottagningskvitto\",\r\n\t\t\t\t\t\trequestVariation: \"Mottagningskvitto från Jordbruksverket\",\r\n\t\t\t\t\t\trequired: true\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\r\n\t\t\t\tthis.ensureAttachmentRequest(c, {\r\n\t\t\t\t\tid: this.idService.newGuid(),\r\n\t\t\t\t\trequestType: \"EUSUPPORT\",\r\n\t\t\t\t\trequestVariation: \"Föregående årsbesked från Jordbruksverket\",\r\n\t\t\t\t\trequired: true\r\n\t\t\t\t});\r\n\r\n\r\n\t\t\t\t// DISME-558 Ändra texter i SME - legacy support for old variation text \"Sammanställning Sam-internet\" 20210621 /RH\r\n\t\t\t\t//TODO: Remove the if-statement after 20210921\r\n\t\t\t\tlet hasLegacySamInternetAttachmentRequest = this.findAttachmentRequests(c, \"EUSUPPORT\", \"Sammanställning Sam-internet\", undefined, true).length > 0;\r\n\t\t\t\tif (hasLegacySamInternetAttachmentRequest == false) {\r\n\t\t\t\t\tthis.ensureAttachmentRequest(c, {\r\n\t\t\t\t\t\tid: this.idService.newGuid(),\r\n\t\t\t\t\t\trequestType: \"EUSUPPORT\",\r\n\t\t\t\t\t\t//requestVariation: \"Sammanställning Sam-internet\",\r\n\t\t\t\t\t\trequestVariation: \"Sammanställning Sam-internet (samansökan)\",\r\n\t\t\t\t\t\trequired: true\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t})\r\n\t\t}\r\n\r\n\t\t// Övrigt.\r\n\t\tthis.ensureAttachmentRequest(c, {\r\n\t\t\tid: this.idService.newGuid(),\r\n\t\t\trequestType: \"OTHER\",\r\n\t\t\trequestVariation: \"\",\r\n\t\t\trequired: false\r\n\t\t});\r\n\r\n\t\tthis.stateService.update(c);\r\n\t}\r\n\r\n\tgetAttachmentRequestTypeDisplayName(attachmentRequest: AttachmentRequest): string {\r\n\t\tlet name = this.getAttachmentRequestTypeName(attachmentRequest.requestType);\r\n\t\t// if( attachmentRequest.requestVariation && attachmentRequest.requestVariation.length>0 ) {\r\n\t\t// \tname += ', '+attachmentRequest.requestVariation;\r\n\t\t// }\r\n\t\tif (attachmentRequest.customerId && attachmentRequest.customerId.length > 0) {\r\n\t\t\tname += ' ' + this.textService.textOrEmpty(\"For\") + ' ' + UiModelConverter.prettyCustomerId(attachmentRequest.customerId);\r\n\t\t}\r\n\t\treturn name;\r\n\t}\r\n\r\n\tgetAttachmentRequestTypeName(requestType: string): string {\r\n\t\tconst r = uiAttachmentTypes.filter(x => {\r\n\t\t\treturn x.key == requestType;\r\n\t\t});\r\n\t\tif (r.length === 1)\r\n\t\t\treturn getUIName(r[0], this.textService);\r\n\t\treturn \"\";\r\n\t}\r\n\r\n\tgetAttachmentTypeDisplayName(attachment: Attachment): string {\r\n\t\tlet name = this.getAttachmentRequestTypeName(attachment.requestType || '');\r\n\t\t// if( attachment.requestVariation && attachment.requestVariation.length>0 ) {\r\n\t\t// \tname += ' '+attachment.requestVariation;\r\n\t\t// }\r\n\t\tif (attachment.customerId && attachment.customerId.length > 0) {\r\n\t\t\tname += ' ' + this.textService.textOrEmpty(\"For\") + ' ' + UiModelConverter.prettyCustomerId(attachment.customerId);\r\n\t\t}\r\n\t\treturn name;\r\n\t}\r\n\r\n\tfilterRequiredAttachmentRequests(attachmentRequests: AttachmentRequest[] | undefined, required: boolean | undefined): AttachmentRequest[] {\r\n\t\tif (!attachmentRequests || attachmentRequests.length === 0)\r\n\t\t\treturn [];\r\n\t\tif (required == undefined)\r\n\t\t\treturn attachmentRequests;\r\n\t\tlet r = attachmentRequests.filter(x => x.required === required);\r\n\t\treturn r;\r\n\t}\r\n\r\n\tfilterOutAttachments(attachments: Attachment[] | undefined, removeAttachments: any[] | undefined): Attachment[] | undefined {\r\n\t\tif (!attachments || attachments.length === 0 || !removeAttachments || removeAttachments.length === 0)\r\n\t\t\treturn attachments;\r\n\r\n\t\tlet r = attachments.filter(x => {\r\n\t\t\treturn removeAttachments.findIndex(remove => x === remove) === -1;\r\n\t\t})\r\n\t\treturn r;\r\n\t}\r\n\r\n\tfilterOutAttachmentsByRequestType(attachments: Attachment[] | undefined, requestType: string): Attachment[] | undefined {\r\n\t\tif (!attachments || attachments.length === 0)\r\n\t\t\treturn attachments;\r\n\r\n\t\tlet r = attachments.filter(x => {\r\n\t\t\treturn x.requestType != requestType;\r\n\t\t})\r\n\t\treturn r;\r\n\t}\r\n\r\n\tfilterOutAttachmentRequestsByRequestType(attachmentRequests: AttachmentRequest[] | undefined, requestType: string): AttachmentRequest[] | undefined {\r\n\t\tif (!attachmentRequests || attachmentRequests.length === 0)\r\n\t\t\treturn attachmentRequests;\r\n\r\n\t\tlet r = attachmentRequests.filter(x => {\r\n\t\t\treturn x.requestType != requestType;\r\n\t\t})\r\n\t\treturn r;\r\n\t}\r\n\r\n\tgetAttachmentsByAttachmentRequest(c: Case, attachmentRequest: AttachmentRequest): Attachment[] {\r\n\t\tif (!c.attachments)\r\n\t\t\treturn [];\r\n\t\tlet x = attachmentRequest;\r\n\t\tlet r = this.findAttachments(c, x.requestType, x.requestVariation, x.customerId);\r\n\t\treturn r;\r\n\t}\r\n\r\n\tgetAttachmentsByAttachmentRequests(c: Case, attachmentRequests: AttachmentRequest[]): Attachment[] {\r\n\t\tif (!c.attachments)\r\n\t\t\treturn [];\r\n\t\tlet attachments: Attachment[] = [];\r\n\t\tattachmentRequests.forEach(x => {\r\n\t\t\tlet r = this.getAttachmentsByAttachmentRequest(c, x);\r\n\t\t\tif (r.length > 0)\r\n\t\t\t\tr.forEach(y => { attachments.push(y); });\r\n\t\t})\r\n\t\treturn attachments;\r\n\t}\r\n\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport {\r\n\tCase,\r\n\tCompanyEconomy,\r\n\tBudget,\r\n\tBudgetYear,\r\n} from '../models/SelmaModels';\r\nimport { SMELPOService } from './SMELPOService';\r\nimport { StateService } from './StateService';\r\nimport { GuardService } from './GuardService';\r\nimport { IdService } from './IdService';\r\nimport { CompanyEconomyService } from './CompanyEconomyService';\r\nimport { UiModelConverter } from '../models/UiModelConverter';\r\nimport { AttachmentService } from './AttachmentService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\n\r\n/*\r\nHandles all logic for Budget, BudgetYears.\r\n*/\r\nexport class BudgetService extends BaseService {\r\n\r\n\tprivate stateService: StateService;\r\n\tprivate smelpoService: SMELPOService;\r\n\tprivate guardService: GuardService;\r\n\r\n\tconstructor(\r\n\t\tstateService: StateService, \r\n\t\tsmelpoService: SMELPOService,\r\n\t\tguardService: GuardService, \r\n\t\tprivate idService: IdService,\r\n\t\tprivate companyEconomyService: CompanyEconomyService,\r\n\t\tprivate attachmentService: AttachmentService\r\n\t) {\r\n\t\tsuper();\r\n\t\tthis.stateService = stateService;\r\n\t\tthis.smelpoService = smelpoService;\r\n\t\tthis.guardService = guardService;\r\n\t}\r\n\r\n\tupdate(companyEconomy: Case | CompanyEconomy | Budget | BudgetYear): void {\r\n\t\tthis.stateService.update(companyEconomy);\r\n\t}\r\n\r\n\tgetBudgetByCompanyEconomy(c:Case, companyEconomy:CompanyEconomy) : Budget|undefined {\r\n\t\tif( !c.budgets )\r\n\t\t\treturn;\r\n\t\tconst r = c.budgets.filter(x => x.companyEconomyId===companyEconomy.id);\r\n\t\tif( r.length===1 ) \r\n\t\t\treturn r[0];\r\n\t\telse\r\n\t\t\treturn;\r\n\t}\r\n\r\n\tensureBudgetsForAllCompanyEconomies(c: Case): void {\r\n\t\tif( !c.companyEconomies )\r\n\t\t\treturn;\r\n\t\tc.companyEconomies.forEach(x => {\r\n\t\t\tthis.ensureBudget(c, x);\r\n\t\t})\r\n\t}\r\n\r\n\tensureBudget(c: Case, companyEconomy:CompanyEconomy): Budget {\r\n\t\tlet budget = this.getBudgetByCompanyEconomy(c, companyEconomy);\r\n\t\tif( !budget ) {\r\n\t\t\tbudget = {\r\n\t\t\t\tcompanyEconomyId: companyEconomy.id\r\n\t\t\t};\r\n\t\t\tthis.addBudget(c,budget);\r\n\t\t}\r\n\r\n\t\tthis.ensureRequiredBudgetYears(companyEconomy, budget);\r\n\t\treturn budget;\r\n\t}\r\n\r\n\taddBudget(c: Case, budget: Budget):void {\r\n\t\tif (!c.budgets) {\r\n\t\t\tc.budgets = [];\r\n\t\t}\r\n\t\tthis.stateService.listAdd(c.budgets, budget);\r\n\t\tthis.update(c);\r\n\t}\r\n\r\n\tremoveBudget(c: Case, budget: Budget):void {\r\n\t\tif (!c.budgets)\r\n\t\t\treturn;\r\n\r\n\t\tthis.stateService.listRemove(c.budgets, budget);\r\n\t\tthis.stateService.update(c);\r\n\t}\r\n\r\n\t// TODO: Different budget year requirements for different types of companies?\r\n\tprivate getRequiredYearsOfBudget(): number[] {\r\n\t\tconst thisYear = new Date().getFullYear();\r\n\t\tconst minYearsOfBudget = 2;\r\n\t\tconst firstYear = thisYear;\r\n\t\tconst lastYear = thisYear + minYearsOfBudget-1;\r\n\r\n\t\tlet years: number[] = [];\r\n\t\tfor (let year = firstYear; year <= lastYear; year++) {\r\n\t\t\tyears.push(year);\r\n\t\t}\r\n\t\treturn years;\r\n\t}\r\n\r\n\tgetRequiredBudgetYears(\r\n\t\tbudget: Budget\r\n\t): { year: number; budgetYear: BudgetYear | undefined }[] {\r\n\t\tlet years = this.getRequiredYearsOfBudget();\r\n\t\tlet r = years.map((year) => {\r\n\t\t\treturn {\r\n\t\t\t\tyear: year,\r\n\t\t\t\tbudgetYear: this.getBudgetYearByYear(budget, year),\r\n\t\t\t};\r\n\t\t});\r\n\t\treturn r;\r\n\t}\r\n\r\n\tprivate ensureRequiredBudgetYears(\r\n\t\tcompanyEconomy: CompanyEconomy,\r\n\t\tbudget: Budget\r\n\t): void {\r\n\t\tthis.getRequiredYearsOfBudget().forEach((year) => {\r\n\t\t\tthis.ensureBudgetYear(companyEconomy, budget, year);\r\n\t\t});\r\n\t}\r\n\r\n\tprivate ensureBudgetYear(\r\n\t\tcompanyEconomy: CompanyEconomy,\r\n\t\tbudget: Budget,\r\n\t\tyear: number\r\n\t): BudgetYear {\r\n\t\tlet budgetYear: BudgetYear | undefined;\r\n\t\tif (!budget.budgetYears) budget.budgetYears = [];\r\n\t\telse budgetYear = this.getBudgetYearByYear(budget, year);\r\n\t\tif (!budgetYear) {\r\n\t\t\tbudgetYear = {\r\n\t\t\t\tyear: year,\r\n\t\t\t};\r\n\t\t\tbudget.budgetYears.push(budgetYear);\r\n\t\t\tthis.update(budgetYear);\r\n\t\t\tthis.update(companyEconomy);\r\n\t\t}\r\n\t\treturn budgetYear;\r\n\t}\r\n\r\n\tgetBudgetYearByYear(budget: Budget, year: number): BudgetYear | undefined {\r\n\t\tif (!budget.budgetYears) return;\r\n\t\tlet brs = budget.budgetYears.filter((x) => x.year === year);\r\n\t\tif (brs.length === 1) {\r\n\t\t\treturn brs[0];\r\n\t\t} else {\r\n\t\t\treturn;\r\n\t\t}\r\n\t}\r\n\r\n\tensureBudgetAttachmentRequests(c:Case) {\r\n\t\tif( c.companies ) {\r\n\t\t\tc.companies.forEach(company => {\r\n\t\t\t\t\r\n\t\t\t\tlet v = company.name||UiModelConverter.prettyOrgNr(company.orgNumber);\r\n\r\n\t\t\t\tlet years = this.getRequiredYearsOfBudget();\r\n\t\t\t\tyears.forEach(year => { \r\n\t\t\t\t\tconst requestVariation = v + \", år \" + year;\r\n\t\t\t\t\tthis.attachmentService.ensureAttachmentRequest(c, {\r\n\t\t\t\t\t\tid: this.idService.newGuid(),\r\n\t\t\t\t\t\tcustomerId: company.orgNumber,\r\n\t\t\t\t\t\trequestType:\"COMPANYBUDGET\",\r\n\t\t\t\t\t\trequestVariation: requestVariation\r\n\t\t\t\t\t});\r\n\t\t\t\t})\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\r\n\tvalidateBudgets(c: Case): ValidationResult {\r\n\t\tconst vr = new ValidationResult();\r\n\t\tif( c.companyEconomies ) {\r\n\t\t\tc.companyEconomies.forEach(companyEconomy => {\r\n\t\t\t\tconst companyEconomyHasBudget = this.companyEconomyHasBudget(c, companyEconomy);\r\n\t\t\t\tvr.add({object:companyEconomy, validator:this.companyEconomyHasBudget, ok: companyEconomyHasBudget});\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n\tcompanyEconomyHasBudget(c:Case, companyEconomy: CompanyEconomy):boolean {\r\n\t\treturn this.getBudgetByCompanyEconomy(c, companyEconomy)!==undefined;\r\n\t}\r\n\r\n}\r\n","import { BaseService } from './BaseService';\r\nimport { Case, Summary } from '../models/SelmaModels';\r\nimport { StateService } from './StateService';\r\nimport { ValidationResult } from '../utils/ValidationResult';\r\nimport { GuardService } from './GuardService';\r\nimport { IdService } from './IdService';\r\nimport { CaseIdStatus } from '../libs/SMELPOClient';\r\n\r\n/*\r\nHandles all logic for Summary.\r\n*/\r\nexport class SummaryService extends BaseService {\r\n\tconstructor(private stateService: StateService, \r\n\t\tprivate guardService: GuardService, private idService:IdService) {\r\n\t\tsuper();\r\n\t} \r\n\r\n\t\r\n\tupdate(x: Summary|Case): void {\r\n\t\tthis.stateService.update(x);\r\n\t}\r\n\r\n\tensureSummary(c:Case) : Summary {\r\n\t\tif( !c.summary ) {\r\n\t\t\tc.summary = {\r\n\t\t\t}\r\n\t\t\tthis.update(c.summary);\r\n\t\t}\r\n\t\treturn c.summary;\r\n\t}\r\n\r\n\tcanApproveCase(c:Case) : boolean {\r\n\t\treturn this.hasCheckedSummaryApproveInformationHandling(c)\r\n\t\t\t&& this.hasCheckedSummaryGuranteeCorrectInformation(c);\r\n\t}\r\n\r\n\thasCheckedSummaryApproveInformationHandling(c:Case) : boolean {\r\n\t\tif( c.status===CaseIdStatus.STARTEDBYAPPLICANT && c.summary ) {\r\n\t\t\treturn c.summary.approveInformationHandling===true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\thasCheckedSummaryGuranteeCorrectInformation(c:Case) : boolean {\r\n\t\tif( c.status===CaseIdStatus.STARTEDBYAPPLICANT && c.summary ) {\r\n\t\t\treturn c.summary.guaranteeCorrectInformation===true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\thasSentCaseToApproval(c:Case) : boolean {\r\n\t\tif( c.status!==CaseIdStatus.STARTEDBYAPPLICANT ) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\r\n\tvalidateSummary(c:Case) : ValidationResult {\r\n\t\tlet vr = new ValidationResult();\r\n\t\tif( c.status===CaseIdStatus.STARTEDBYAPPLICANT ) {\r\n\t\t\tvr.add({validator:this.hasCheckedSummaryApproveInformationHandling, object:c, ok: this.hasCheckedSummaryApproveInformationHandling(c)});\r\n\t\t\tvr.add({validator:this.hasCheckedSummaryGuranteeCorrectInformation, object:c, ok: this.hasCheckedSummaryGuranteeCorrectInformation(c)});\r\n\t\t\t//vr.add({validator:this.hasSentCaseToApproval, object:c, ok: this.hasSentCaseToApproval(c)});\r\n\t\t} else if( c.status===CaseIdStatus.READYFOROFFICER || c.status===CaseIdStatus.CLOSEDBYOFFICER ) {\r\n\t\t\tvr.add({validator:this.hasSentCaseToApproval, object:c, ok: this.hasSentCaseToApproval(c)});\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n}\r\n","import { BaseService } from \"./BaseService\";\r\nimport { GuardService } from \"./GuardService\";\r\n\r\nexport class ConvertService extends BaseService {\r\n\tprivate guard:GuardService;\r\n\r\n\tconstructor(guardService:GuardService) {\r\n\t\tsuper();\r\n\t\tthis.guard = guardService;\r\n\t}\r\n\r\n\tnumberToIntegerThousandSeparatedString(value: number, separator: string = \"\\u0020\"): string {\r\n\t\tif (this.guard.isUndefined(value) || value === null)\r\n\t\t\treturn \"\";\r\n\r\n\t\tvar v = Math.round(value);\r\n\r\n\t\tif (v > -1000 && v < 1000)\r\n\t\t\treturn value.toString();\r\n\r\n\t\tvar str = value.toString();\r\n\r\n\t\t// Add thousands separator. \r\n\t\t// Originally it was the unicode character \"\\u2009\" == THIN SPACE\r\n\t\t// but it was replaced with a regular space \"\\u0200\" since Safari on iOS\r\n\t\t// couldn't render thin space.\r\n\t\tfor (var i = str.length - 3; i > 0; i -= 3) {\r\n\t\t\tstr = str.substring(0, i) + separator + str.substring(i);\r\n\t\t}\r\n\r\n\t\treturn str;\r\n\t}\r\n\r\n\tintegerThousandSeparatedStringToNumber(value: string): number|null {\r\n\t\tif (this.guard.isUndefined(value) || value === null)\r\n\t\t\treturn null;\r\n\r\n\t\tvalue = value.replace(/\\D/g, \"\");\r\n\r\n\t\tvar num = parseFloat(value);\r\n\t\tif (isNaN(num))\r\n\t\t\treturn null;\r\n\r\n\t\treturn num;\r\n\t}\r\n\r\n\t// Takes an ssn on any form. returns it in normalized form: YYYYMMDDNNNN.\r\n\ttoNormalizedSsn(ssn: string): string {\r\n\t\tif (!this.guard.isString(ssn))\r\n\t\t\treturn ssn;\r\n\t\tif (ssn.length === 12) // YYYYMMDDNNNN\r\n\t\t\treturn ssn;\r\n\t\tif (ssn.length === 13) // YYYYMMDD-NNNN\r\n\t\t\treturn ssn.replace(/-/, \"\");\r\n\t\tif (ssn.length === 10)// YYMMDDNNNN\r\n\t\t\treturn \"19\" + ssn;\r\n\t\tif (ssn.length === 11)// YYMMDD-NNNN\r\n\t\t\treturn \"19\" + ssn.replace(/-/, \"\");\r\n\t\treturn ssn;\r\n\t}\r\n\r\n\t// Takes an ssn on any form. returns it in normalized form: YYYYMMDD-NNNN.\r\n\ttoPrettyNormalizedSsn(ssn: string): string {\r\n\t\tif (!this.guard.isString(ssn))\r\n\t\t\treturn ssn;\r\n\t\tssn = this.toNormalizedSsn(ssn);\r\n\t\tif (ssn.length === 12) // YYYYMMDDNNNN\r\n\t\t\tssn = ssn.substr(0, 8) + \"-\" + ssn.substr(8, 4); // YYYYMMDD-NNNN\r\n\t\treturn ssn;\r\n\t}\r\n\r\n\tgetSsnDate(ssn: string): Date|null {\r\n\t\tif (!ssn || ssn.length === 0)\r\n\t\t\treturn null;\r\n\r\n\t\tssn = this.toNormalizedSsn(ssn.replace('-', ''));\r\n\t\tif (ssn.length !== 12)\r\n\t\t\treturn null;\r\n\r\n\t\tlet year = parseInt(ssn.substr(0, 4));\r\n\t\tlet month = parseInt(ssn.substr(4, 2));\r\n\t\tlet day = parseInt(ssn.substr(6, 2));\r\n\r\n\t\treturn new Date(year, month, day);\r\n\t}\r\n\r\n\tgetAgeByDate(date: Date, now?: Date):number {\r\n\t\tif (!now)\r\n\t\t\tnow = new Date();\r\n\r\n\t\tvar ageDifMs = now.getTime() - date.getTime();\r\n\t\tvar ageDate = new Date(ageDifMs); // miliseconds from epoch\r\n\t\treturn Math.abs(ageDate.getUTCFullYear() - 1970);\r\n\t}\r\n\r\n\tgetAgeBySsn(ssn: string): number {\r\n\t\tlet ssnDate = this.getSsnDate(ssn);\r\n\t\tif (!ssnDate)\r\n\t\t\treturn -9999;\r\n\r\n\t\treturn this.getAgeByDate(ssnDate);\r\n\t}\r\n\r\n\ttoIsoDateString(value: Date): string {\r\n\t\tlet yyyy = value.getFullYear().toString();\r\n\t\tlet mm = (value.getMonth() + 1).toString(); // getMonth() is zero-based \r\n\t\tlet dd = value.getDate().toString();\r\n\t\treturn yyyy + \"-\" + (mm[1] ? mm : \"0\" + mm[0]) + \"-\" + (dd[1] ? dd : \"0\" + dd[0]) + \"T00:00:00.000Z\";\r\n\t}\r\n\r\n\t\r\n\tformatBytes = (bytes:number, decimals:number = 0): string => {\r\n\t\tif (bytes === 0) return '0 bytes';\r\n\r\n\t\tconst k = 1000;\r\n\t\tconst dm = decimals < 0 ? 0 : decimals;\r\n\t\tconst sizes = ['bytes', 'kB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'];\r\n\r\n\t\tconst i = Math.floor(Math.log(bytes) / Math.log(k));\r\n\r\n\t\treturn parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + ' ' + sizes[i];\r\n\t}\r\n}","\r\nimport { Case, KycApplicant } from \"../models/SelmaModels\";\r\nimport { ValidationResult } from \"../utils/ValidationResult\";\r\nimport { ApplicantService } from \"./ApplicantService\";\r\nimport { BaseService } from \"./BaseService\";\r\n\r\n\r\ninterface GetKYCStatusResponse {\r\n caseId: string,\r\n applicants: KycApplicant[]\r\n}\r\n\r\nexport default class KycService extends BaseService {\r\n\r\n private applicantService: ApplicantService;\r\n private url: string;\r\n\r\n constructor(url: string, applicantService: ApplicantService) {\r\n\t\tsuper();\r\n this.applicantService = applicantService;\r\n this.url = url;\r\n\t} \r\n\r\n validateStatus(status:string):boolean \r\n { \r\n return status === \"Completed\" || status === \"COMPLETED\"\r\n }\r\n\r\n private validateKyc({questionnaireStatus} :KycApplicant) : boolean {\r\n return this.validateStatus(questionnaireStatus);\r\n }\r\n\r\n private validateKycInArray(x: KycApplicant[]): ValidationResult {\r\n const vr = new ValidationResult();\r\n\t\tif (x.length > 0) {\r\n\t\t\tx.forEach(x => {\r\n\t\t\t\tvr.add({ validator: this.validateKyc, object: x, ok: this.validateKyc(x) });\r\n\t\t\t})\r\n\t\t}\r\n else {\r\n vr.add({ validator: () => {}, object: x, ok: false})\r\n }\r\n\t\treturn vr;\r\n }\r\n\r\n showKycForCase(c:Case): boolean {\r\n const showPepForApplicants = c.applicants?.map(a => this.applicantService.showPepForApplicant(a)).filter(x => x === true);\r\n\t\tif(showPepForApplicants == undefined || showPepForApplicants.length === 0) {\r\n\t\t\treturn true;\r\n\t\t}\t\t\r\n\t\treturn false;\r\n }\r\n\r\n validateCaseKyc(c: Case): ValidationResult {\r\n \r\n\t\tlet vr = new ValidationResult();\r\n\t\tif (c.kycApplicantsStatus) {\r\n\t\t\tvr.addResult(this.validateKycInArray(c.kycApplicantsStatus));\r\n\t\t}\r\n\t\treturn vr;\r\n\t}\r\n\r\n private async getKycStatus(caseId: string|undefined):Promise {\r\n try {\r\n \r\n if(caseId) {\r\n var result = await fetch(`${this.url}/loanProcess/getkycstatus/${caseId}`, {\r\n method:'GET',\r\n cache: 'no-cache',\r\n credentials: \"include\",\r\n headers: {\r\n 'Accept': 'application/json',\r\n 'Content-Type': 'application/json'\r\n }});\r\n const data: GetKYCStatusResponse = await result.json();\r\n \r\n if(data.applicants == null || data.applicants == undefined) \r\n data.applicants = [];\r\n \r\n return data;\r\n }\r\n\r\n return {\r\n caseId: caseId ?? '',\r\n applicants: []\r\n };\r\n }\r\n catch {\r\n return {\r\n caseId: caseId ?? '',\r\n applicants: []\r\n };\r\n }\r\n }\r\n\r\n async getKycForCase(c: Case): Promise { return await this.getKycStatus(c.lpCaseId); }\r\n}","\r\n\r\nexport interface ServerSession {\r\n\tisLoggedIn: boolean;\r\n\tisAdmin: boolean;\r\n\tssn: string;\r\n\tfirstName: string;\r\n\tlastName: string;\r\n\tcanSignIn: boolean,\r\n\tisUnderAge: boolean\r\n}\r\n\r\nexport default class OidcService {\r\n\r\n private url: string;\r\n\r\n\tconstructor(url: string) {\r\n\t\tthis.url = url;\r\n\t}\r\n\r\n\t// Log out current session.\r\n\tlogout(): Promise {\r\n\t\treturn this.post('Logout', {\r\n\t\t}).then(result => {\r\n\t\t\treturn result;\r\n\t\t});\r\n\t}\r\n\r\n\t// Get session info from server.\r\n\tgetSession(): Promise {\r\n\t\treturn this.get('Session')\r\n\t\t\t.then(result => {\r\n\t\t\t\treturn result;\r\n\t\t\t}).catch(_ => {\r\n\t\t\t\treturn {\r\n\t\t\t\t\tisLoggedIn: false,\r\n\t\t\t\t\tisAdmin: false,\r\n\t\t\t\t\tcanSignIn: false,\r\n\t\t\t\t\tisUnderAge: false,\r\n\t\t\t\t\tfirstName: '',\r\n\t\t\t\t\tlastName: '',\r\n\t\t\t\t\tssn: ''\r\n\t\t\t\t} as ServerSession;\r\n\t\t\t});\r\n\t}\r\n\r\n\t// Get user login status.\r\n\tcanLogIn(): Promise {\r\n\t\treturn this.get('CanLogIn')\r\n\t\t\t.then(result => {\r\n\t\t\t\treturn result;\r\n\t\t\t});\r\n\t}\r\n\r\n\r\n\tprivate post(op: string, body: any): Promise {\r\n\t\tlet bodyJson = JSON.stringify(body);\r\n\t\treturn fetch(this.url + '/' + op, {\r\n\t\t\tmethod: \"POST\",\r\n\t\t\tcache: 'no-cache',\r\n\t\t\tcredentials: 'include', //include cookies\r\n\t\t\theaders: {\r\n\t\t\t\t'Accept': 'application/json',\r\n\t\t\t\t'Content-Type': 'application/json'\r\n\t\t\t},\r\n\t\t\tbody: bodyJson\r\n\t\t})\r\n\t\t\t.then(result => {\r\n\t\t\t\treturn result.json();\r\n\t\t\t})\r\n\t\t\t.then((result) => {\r\n\t\t\t\tlet bidResult: T = result;\r\n\t\t\t\treturn bidResult;\r\n\t\t\t});\r\n\t}\r\n\r\n\r\n\tprivate get(op: string): Promise {\r\n\t\treturn fetch(this.url + '/' + op, {\r\n\t\t\tmethod: \"GET\",\r\n\t\t\tcache: 'no-cache',\r\n\t\t\tcredentials: 'include', //include cookies\r\n\t\t\theaders: {\r\n\t\t\t\t'Accept': 'application/json'\r\n\t\t\t},\r\n\t\t})\r\n\t\t\t.then(result => {\r\n\t\t\t\treturn result.json();\r\n\t\t\t})\r\n\t\t\t.then((result) => {\r\n\t\t\t\tlet bidResult: T = result;\r\n\t\t\t\treturn bidResult;\r\n\t\t\t});\r\n\t}\r\n}","import { UiLanguageService } from '../services/UiLanguageService';\r\nimport { SessionService } from '../services/SessionService';\r\nimport { SMELPOService } from '../services/SMELPOService';\r\nimport { TextService } from '../services/TextService';\r\nimport {\r\n\tConfigurationService,\r\n\tConfiguration,\r\n} from '../services/ConfigurationService';\r\nimport { GuardService } from '../services/GuardService';\r\nimport { StateService } from '../services/StateService';\r\nimport { CaseService } from '../services/CaseService';\r\nimport { ApplicantService } from '../services/ApplicantService';\r\nimport { StepService } from '../services/StepService';\r\nimport { CompanyEconomyService } from '../services/CompanyEconomyService';\r\nimport { CompanyService } from '../services/CompanyService';\r\nimport { LoanService } from '../services/LoanService';\r\nimport { HouseholdService } from '../services/HouseholdService';\r\nimport { CollateralService } from '../services/CollateralService';\r\nimport { IdService } from '../services/IdService';\r\nimport { ArrayService } from '../services/ArrayService';\r\nimport { PersonalEconomyService } from '../services/PersonalEconomyService';\r\nimport { GuarantorService } from '../services/GuarantorService';\r\nimport { EuSupportService } from '../services/EuSupportService';\r\nimport { ExtLoanService } from '../services/ExtLoanService';\r\nimport { MaintenanceCostService } from '../services/MaintenanceCostService';\r\nimport { AttachmentService } from '../services/AttachmentService';\r\nimport { BudgetService } from '../services/BudgetService';\r\nimport { SummaryService } from '../services/SummaryService';\r\nimport { ConvertService } from '../services/ConvertService';\r\nimport KycService from '../services/KycService';\r\nimport OidcService from '../services/OidcService';\r\n\r\nexport class Application {\r\n\tservices: ApplicationServices;\r\n\r\n\tprivate constructor() {\r\n\t\tthis.services = {} as ApplicationServices;\r\n\t}\r\n\r\n\tstatic instance: Application;\r\n\tstatic alloc(): Application {\r\n\t\treturn (this.instance = new Application());\r\n\t}\r\n\r\n\tinit(): Promise {\r\n\t\tconst stateService = new StateService();\r\n\t\tconst configurationService = new ConfigurationService(stateService);\r\n\r\n\t\tlet configuration: Configuration;\r\n\t\tlet textService: TextService;\r\n\t\treturn configurationService\r\n\t\t\t.load('/config.json')\r\n\t\t\t.then((result) => {\r\n\t\t\t\tconfiguration = result;\r\n\r\n\t\t\t\tconst uiLanguageService = new UiLanguageService(configurationService);\r\n\t\t\t\ttextService = new TextService(stateService, uiLanguageService);\r\n\t\t\t\tconst loadingTexts = textService.useLanguage('sv-SE');\r\n\t\t\t\treturn loadingTexts;\r\n\r\n\t\t\t}).then(uiLanguage => {\r\n\t\t\t\tconst oidcService = new OidcService(configuration.oidcBaseUrl);\r\n\t\t\t\tconst sessionService = new SessionService(stateService, oidcService, configurationService);\r\n\t\t\t\tconst smelpoService = new SMELPOService(configuration.lpBaseUrl, sessionService);\r\n\t\t\t\tconst guardService = new GuardService();\r\n\t\t\t\tconst idService = new IdService();\r\n\t\t\t\tconst arrayService = new ArrayService();\r\n\t\t\t\tconst convertService = new ConvertService(guardService);\r\n\t\t\t\tguardService.convertService = convertService;\r\n\t\t\t\tconst applicantService = new ApplicantService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tidService,\r\n\t\t\t\t\tconfigurationService\r\n\t\t\t\t);\r\n\t\t\t\tconst kycService = new KycService(\r\n\t\t\t\t\tconfiguration.lpBaseUrl, \r\n\t\t\t\t\tapplicantService\r\n\t\t\t\t);\r\n\t\t\t\tconst personalEconomyService = new PersonalEconomyService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tidService\r\n\t\t\t\t);\r\n\t\t\t\tconst loanService = new LoanService(\r\n\t\t\t\t\tthis,\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService\r\n\t\t\t\t);\r\n\t\t\t\tconst caseService = new CaseService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tapplicantService,\r\n\t\t\t\t\tkycService,\r\n\t\t\t\t\tidService,\r\n\t\t\t\t\tsessionService,\r\n\t\t\t\t\tconfigurationService\r\n\t\t\t\t);\r\n\t\t\t\tconst collateralService = new CollateralService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tidService\r\n\t\t\t\t);\r\n\t\t\t\tconst guarantorService = new GuarantorService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tidService\r\n\t\t\t\t);\r\n\t\t\t\tconst euSupportService = new EuSupportService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tidService,\r\n\t\t\t\t\ttextService\r\n\t\t\t\t);\r\n\t\t\t\tconst householdService = new HouseholdService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tapplicantService,\r\n\t\t\t\t\tidService\r\n\t\t\t\t);\r\n\t\t\t\tapplicantService.householdService = householdService;\r\n\t\t\t\tconst extLoanService = new ExtLoanService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tapplicantService,\r\n\t\t\t\t\tidService\r\n\t\t\t\t);\r\n\t\t\t\tconst maintenanceCostService = new MaintenanceCostService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tapplicantService,\r\n\t\t\t\t\tidService\r\n\t\t\t\t);\r\n\t\t\t\tconst companyService = new CompanyService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tidService,\r\n\t\t\t\t\tapplicantService,\r\n\t\t\t\t\tconvertService\r\n\t\t\t\t);\r\n\t\t\t\tapplicantService.companyService = companyService;\r\n\t\t\t\thouseholdService.companyService = companyService;\r\n\t\t\t\thouseholdService.extLoanService = extLoanService;\r\n\t\t\t\thouseholdService.maintenanceCostService = maintenanceCostService;\r\n\t\t\t\tconst companyEconomyService = new CompanyEconomyService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tcaseService,\r\n\t\t\t\t\tcompanyService,\r\n\t\t\t\t\tidService,\r\n\t\t\t\t\tapplicantService\r\n\t\t\t\t);\r\n\t\t\t\tcompanyService.companyEconomyService = companyEconomyService;\r\n\t\t\t\tconst attachmentService = new AttachmentService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tapplicantService,\r\n\t\t\t\t\tpersonalEconomyService,\r\n\t\t\t\t\tcompanyService,\r\n\t\t\t\t\tcompanyEconomyService,\r\n\t\t\t\t\tconfigurationService,\r\n\t\t\t\t\tcollateralService,\r\n\t\t\t\t\tidService,\r\n\t\t\t\t\tloanService,\r\n\t\t\t\t\ttextService,\r\n\t\t\t\t\tconfiguration.smeBaseUrl\r\n\t\t\t\t);\r\n\t\t\t\tcaseService.attachmentService = attachmentService;\r\n\t\t\t\tconst budgetService = new BudgetService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tsmelpoService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tidService,\r\n\t\t\t\t\tcompanyEconomyService,\r\n\t\t\t\t\tattachmentService\r\n\t\t\t\t);\r\n\t\t\t\tcompanyEconomyService.budgetService = budgetService;\r\n\t\t\t\tattachmentService.budgetService = budgetService;\r\n\t\t\t\tconst summaryService = new SummaryService(\r\n\t\t\t\t\tstateService,\r\n\t\t\t\t\tguardService,\r\n\t\t\t\t\tidService\r\n\t\t\t\t);\r\n\t\t\t\tconst stepService = new StepService(this, textService, applicantService);\r\n\r\n\t\t\t\tthis.services = {\r\n\t\t\t\t\tstateService: stateService,\r\n\t\t\t\t\tconfigurationService: configurationService,\r\n\t\t\t\t\ttextService: textService,\r\n\t\t\t\t\tsessionService: sessionService,\r\n\t\t\t\t\tguardService: guardService,\r\n\t\t\t\t\tidService: idService,\r\n\t\t\t\t\tarrayService: arrayService,\r\n\t\t\t\t\tconvertService: convertService,\r\n\t\t\t\t\tcaseService: caseService,\r\n\t\t\t\t\tloanService: loanService,\r\n\t\t\t\t\tapplicantService: applicantService,\r\n\t\t\t\t\tpersonalEconomyService: personalEconomyService,\r\n\t\t\t\t\thouseholdService: householdService,\r\n\t\t\t\t\tmaintenanceCostService: maintenanceCostService,\r\n\t\t\t\t\textLoanService: extLoanService,\r\n\t\t\t\t\tcollateralService: collateralService,\r\n\t\t\t\t\tguarantorService: guarantorService,\r\n\t\t\t\t\teuSupportService: euSupportService,\r\n\t\t\t\t\tcompanyService: companyService,\r\n\t\t\t\t\tcompanyEconomyService: companyEconomyService,\r\n\t\t\t\t\tbudgetService: budgetService,\r\n\t\t\t\t\tattachmentService: attachmentService,\r\n\t\t\t\t\tsummaryService: summaryService,\r\n\t\t\t\t\tstepService: stepService,\r\n\t\t\t\t\tkycService: kycService,\r\n\t\t\t\t\toidcService: oidcService\r\n\r\n\t\t\t\t} as ApplicationServices;\r\n\t\t\t\treturn this.services;\r\n\t\t\t})\r\n\t\t\t.then((services) => {\r\n\t\t\t\tstateService.state.loaded = true;\r\n\t\t\t\tstateService.update(stateService.state);\r\n\t\t\t\t//return this.services.sessionService.loadSession();\r\n\t\t\t})\r\n\t\t\t.catch((error) => {\r\n\t\t\t\t// console.log(error);\r\n\t\t\t})\r\n\t\t\t.then(() => {\r\n\t\t\t\treturn this;\r\n\t\t\t});\r\n\t}\r\n}\r\n\r\nexport interface ApplicationServices {\r\n\tstateService: StateService;\r\n\tconfigurationService: ConfigurationService;\r\n\ttextService: TextService;\r\n\tsessionService: SessionService;\r\n\tidService: IdService;\r\n\tarrayService: ArrayService;\r\n\tconvertService: ConvertService;\r\n\tguardService: GuardService;\r\n\tcaseService: CaseService;\r\n\tapplicantService: ApplicantService;\r\n\tpersonalEconomyService: PersonalEconomyService;\r\n\tloanService: LoanService;\r\n\tcompanyService: CompanyService;\r\n\tcompanyEconomyService: CompanyEconomyService;\r\n\tbudgetService: BudgetService;\r\n\tcollateralService: CollateralService;\r\n\tguarantorService: GuarantorService;\r\n\teuSupportService: EuSupportService;\r\n\thouseholdService: HouseholdService;\r\n\tmaintenanceCostService: MaintenanceCostService;\r\n\textLoanService: ExtLoanService;\r\n\tattachmentService: AttachmentService;\r\n\tsummaryService: SummaryService;\r\n\tstepService: StepService;\r\n\tkycService: KycService;\r\n\toidcService: OidcService;\r\n}\r\n","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = getClass;\n\nvar _flexboxgrid = require('flexboxgrid2/flexboxgrid2.css');\n\nvar _flexboxgrid2 = _interopRequireDefault(_flexboxgrid);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction getClass(className) {\n return _flexboxgrid2.default && _flexboxgrid2.default[className] ? _flexboxgrid2.default[className] : className;\n}","/**\n * Copyright (c) 2013-present, Facebook, Inc.\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\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\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\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\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\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = createProps;\nfunction createProps(propTypes, props, classNames) {\n var newProps = {};\n\n Object.keys(props).filter(function (key) {\n return key === 'children' || !propTypes[key];\n }).forEach(function (key) {\n return newProps[key] = props[key];\n });\n\n var className = classNames.filter(function (cn) {\n return cn;\n }).join(' ');\n return Object.assign({}, newProps, { className: className });\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.ViewportSizeType = exports.ColumnSizeType = undefined;\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar ColumnSizeType = exports.ColumnSizeType = _propTypes2.default.oneOfType([_propTypes2.default.number, _propTypes2.default.bool]);\nvar ViewportSizeType = exports.ViewportSizeType = _propTypes2.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']);","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getRowProps = getRowProps;\nexports.default = Row;\n\nvar _classNames = require('../classNames');\n\nvar _classNames2 = _interopRequireDefault(_classNames);\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _createProps = require('../createProps');\n\nvar _createProps2 = _interopRequireDefault(_createProps);\n\nvar _types = require('../types');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar rowKeys = ['start', 'center', 'end', 'top', 'middle', 'bottom', 'around', 'between'];\n\nvar propTypes = {\n reverse: _propTypes2.default.bool,\n start: _types.ViewportSizeType,\n center: _types.ViewportSizeType,\n end: _types.ViewportSizeType,\n top: _types.ViewportSizeType,\n middle: _types.ViewportSizeType,\n bottom: _types.ViewportSizeType,\n around: _types.ViewportSizeType,\n between: _types.ViewportSizeType,\n className: _propTypes2.default.string,\n tagName: _propTypes2.default.string,\n children: _propTypes2.default.node\n};\n\nfunction getRowClassNames(props) {\n var modificators = [props.className, (0, _classNames2.default)('row')];\n\n for (var i = 0; i < rowKeys.length; ++i) {\n var key = rowKeys[i];\n var value = props[key];\n if (value) {\n modificators.push((0, _classNames2.default)(key + '-' + value));\n }\n }\n\n if (props.reverse) {\n modificators.push((0, _classNames2.default)('reverse'));\n }\n\n return modificators;\n}\n\nfunction getRowProps(props) {\n return (0, _createProps2.default)(propTypes, props, getRowClassNames(props));\n}\n\nfunction Row(props) {\n return _react2.default.createElement(props.tagName || 'div', getRowProps(props));\n}\n\nRow.propTypes = propTypes;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getColumnProps = getColumnProps;\nexports.default = Col;\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _createProps = require('../createProps');\n\nvar _createProps2 = _interopRequireDefault(_createProps);\n\nvar _classNames = require('../classNames');\n\nvar _classNames2 = _interopRequireDefault(_classNames);\n\nvar _types = require('../types');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nvar propTypes = {\n xs: _types.ColumnSizeType,\n sm: _types.ColumnSizeType,\n md: _types.ColumnSizeType,\n lg: _types.ColumnSizeType,\n xl: _types.ColumnSizeType,\n xsOffset: _propTypes2.default.number,\n smOffset: _propTypes2.default.number,\n mdOffset: _propTypes2.default.number,\n lgOffset: _propTypes2.default.number,\n xlOffset: _propTypes2.default.number,\n first: _types.ViewportSizeType,\n last: _types.ViewportSizeType,\n className: _propTypes2.default.string,\n tagName: _propTypes2.default.string,\n children: _propTypes2.default.node\n};\n\nvar classMap = {\n xs: 'col-xs',\n sm: 'col-sm',\n md: 'col-md',\n lg: 'col-lg',\n xl: 'col-xl',\n xsOffset: 'col-xs-offset',\n smOffset: 'col-sm-offset',\n mdOffset: 'col-md-offset',\n lgOffset: 'col-lg-offset',\n xlOffset: 'col-xl-offset'\n};\n\nfunction isInteger(value) {\n return typeof value === 'number' && isFinite(value) && Math.floor(value) === value;\n}\n\nfunction getColClassNames(props) {\n var extraClasses = [];\n\n if (props.className) {\n extraClasses.push(props.className);\n }\n\n if (props.first) {\n extraClasses.push((0, _classNames2.default)('first-' + props.first));\n }\n\n if (props.last) {\n extraClasses.push((0, _classNames2.default)('last-' + props.last));\n }\n\n return Object.keys(props).filter(function (key) {\n return classMap[key];\n }).map(function (key) {\n return (0, _classNames2.default)(isInteger(props[key]) ? classMap[key] + '-' + props[key] : classMap[key]);\n }).concat(extraClasses);\n}\n\nfunction getColumnProps(props) {\n return (0, _createProps2.default)(propTypes, props, getColClassNames(props));\n}\n\nfunction Col(props) {\n var tagName = props.tagName,\n columnProps = _objectWithoutProperties(props, ['tagName']);\n\n return _react2.default.createElement(tagName || 'div', getColumnProps(columnProps));\n}\n\nCol.propTypes = propTypes;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = Grid;\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _createProps = require('../createProps');\n\nvar _createProps2 = _interopRequireDefault(_createProps);\n\nvar _classNames = require('../classNames');\n\nvar _classNames2 = _interopRequireDefault(_classNames);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar propTypes = {\n fluid: _propTypes2.default.bool,\n className: _propTypes2.default.string,\n tagName: _propTypes2.default.string,\n children: _propTypes2.default.node\n};\n\nfunction Grid(props) {\n var containerClass = (0, _classNames2.default)(props.fluid ? 'container-fluid' : 'container');\n var classNames = [props.className, containerClass];\n\n return _react2.default.createElement(props.tagName || 'div', (0, _createProps2.default)(propTypes, props, classNames));\n}\n\nGrid.propTypes = propTypes;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getColumnProps = exports.Col = exports.getRowProps = exports.Row = exports.Grid = undefined;\n\nvar _Row2 = require('./components/Row');\n\nObject.defineProperty(exports, 'getRowProps', {\n enumerable: true,\n get: function get() {\n return _Row2.getRowProps;\n }\n});\n\nvar _Col2 = require('./components/Col');\n\nObject.defineProperty(exports, 'getColumnProps', {\n enumerable: true,\n get: function get() {\n return _Col2.getColumnProps;\n }\n});\n\nvar _Grid2 = require('./components/Grid');\n\nvar _Grid3 = _interopRequireDefault(_Grid2);\n\nvar _Row3 = _interopRequireDefault(_Row2);\n\nvar _Col3 = _interopRequireDefault(_Col2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.Grid = _Grid3.default;\nexports.Row = _Row3.default;\nexports.Col = _Col3.default;","import { Component } from 'react';\r\n\r\nexport abstract class BaseComponent \r\n\textends Component {\r\n\t\tconstructor(props:TProps) {\r\n\t\t\tsuper(props);\r\n\t\t}\r\n}","import { BaseComponent } from './BaseComponent';\r\nimport { Application } from '../models/AppModels';\r\nimport { Objserver, ObsCallback } from '../utils/Objserver';\r\n\r\ninterface TExtendedState {\r\n\trefreshed?: Date;\r\n}\r\n\r\nexport abstract class AppComponent<\r\n\tTProps = any,\r\n\tTState = any,\r\n\tTSS = any\r\n> extends BaseComponent {\r\n\tprotected application: Application;\r\n\r\n\tconstructor(props: TProps) {\r\n\t\tsuper(props);\r\n\t\tthis.application = Application.instance;\r\n\t}\r\n\r\n\tonUnmount(func): void {\r\n\t\tlet cwu = this.componentWillUnmount;\r\n\t\tthis.componentWillUnmount = function () {\r\n\t\t\tif (cwu) cwu();\r\n\t\t\tfunc();\r\n\t\t};\r\n\t}\r\n\r\n\tobserveUpdate(obj: any): void {\r\n\t\tthis.specificObserveUpdate(\r\n\t\t\tApplication.instance.services.stateService.stateObjserver,\r\n\t\t\tobj\r\n\t\t);\r\n\t}\r\n\tobserveDeepUpdate(obj: any): void {\r\n\t\tthis.specificObserveDeepUpdate(\r\n\t\t\tApplication.instance.services.stateService.stateObjserver,\r\n\t\t\tobj\r\n\t\t);\r\n\t}\r\n\r\n\tobserve(obj: any, func: ObsCallback): void {\r\n\t\tthis.specificObserve(\r\n\t\t\tApplication.instance.services.stateService.stateObjserver,\r\n\t\t\tobj,\r\n\t\t\tfunc\r\n\t\t);\r\n\t}\r\n\tobserveDeep(obj: any, func: ObsCallback): void {\r\n\t\tthis.specificObserveDeep(\r\n\t\t\tApplication.instance.services.stateService.stateObjserver,\r\n\t\t\tobj,\r\n\t\t\tfunc\r\n\t\t);\r\n\t}\r\n\r\n\tprotected refresh(): void {\r\n\t\tthis.setState({\r\n\t\t\trefreshed: new Date(),\r\n\t\t} as TState & TExtendedState);\r\n\t}\r\n\r\n\tprivate specificObserveUpdate(objserver: Objserver, obj: any): void {\r\n\t\tconst t = this;\r\n\t\tthis.observe(obj, (event) => {\r\n\t\t\tt.setState({\r\n\t\t\t\trefreshed: new Date(),\r\n\t\t\t} as TState & TExtendedState);\r\n\t\t});\r\n\t}\r\n\tprivate specificObserveDeepUpdate(objserver: Objserver, obj: any): void {\r\n\t\tconst t = this;\r\n\t\tthis.observeDeep(obj, (event) => {\r\n\t\t\tt.setState({\r\n\t\t\t\trefreshed: new Date(),\r\n\t\t\t} as TState & TExtendedState);\r\n\t\t});\r\n\t}\r\n\r\n\tprivate specificObserve(\r\n\t\tobjserver: Objserver,\r\n\t\tobj: any,\r\n\t\tfunc: ObsCallback\r\n\t): void {\r\n\t\tif (!obj) return;\r\n\t\tlet unobserve = objserver.observe(obj, func);\r\n\t\tthis.onUnmount(unobserve);\r\n\t}\r\n\tprivate specificObserveDeep(\r\n\t\tobjserver: Objserver,\r\n\t\tobj: any,\r\n\t\tfunc: ObsCallback\r\n\t): void {\r\n\t\tif (!obj) return;\r\n\t\tlet unobserve = objserver.observeDeep(obj, func);\r\n\t\tthis.onUnmount(unobserve);\r\n\t}\r\n}\r\n","import React from 'react';\r\nimport { AppComponent } from '../../AppComponent';\r\n\r\ninterface Props {\r\n\tk: string;\r\n\tclassName?: string;\r\n}\r\n\r\n// Displays a translated HTML fragment in the DOM.\r\nexport class THtml extends AppComponent {\r\n\tstatic defaultProps = {\r\n\t\tclassName: 'Thtml',\r\n\t};\r\n\r\n\tconstructor(props: Props) {\r\n\t\tsuper(props);\r\n\t}\r\n\trender() {\r\n\t\tconst textService = this.application.services.textService;\r\n\t\tconst t = textService && textService.text(this.props.k);\r\n\t\tif (t && t.length > 0) {\r\n\t\t\treturn (\r\n\t\t\t\t\r\n\t\t\t);\r\n\t\t} else {\r\n\t\t\treturn null;\r\n\t\t}\r\n\t}\r\n}\r\n","function _setPrototypeOf(t, e) {\n return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) {\n return t.__proto__ = e, t;\n }, _setPrototypeOf(t, e);\n}\nexport { _setPrototypeOf as default };","import setPrototypeOf from \"./setPrototypeOf.js\";\nfunction _inheritsLoose(t, o) {\n t.prototype = Object.create(o.prototype), t.prototype.constructor = t, setPrototypeOf(t, o);\n}\nexport { _inheritsLoose as default };","function _extends() {\n return _extends = Object.assign ? Object.assign.bind() : function (n) {\n for (var e = 1; e < arguments.length; e++) {\n var t = arguments[e];\n for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);\n }\n return n;\n }, _extends.apply(null, arguments);\n}\nexport { _extends as default };","function isAbsolute(pathname) {\n return pathname.charAt(0) === '/';\n}\n\n// About 1.5x faster than the two-arg version of Array#splice()\nfunction spliceOne(list, index) {\n for (var i = index, k = i + 1, n = list.length; k < n; i += 1, k += 1) {\n list[i] = list[k];\n }\n\n list.pop();\n}\n\n// This implementation is based heavily on node's url.parse\nfunction resolvePathname(to, from) {\n if (from === undefined) from = '';\n\n var toParts = (to && to.split('/')) || [];\n var fromParts = (from && from.split('/')) || [];\n\n var isToAbs = to && isAbsolute(to);\n var isFromAbs = from && isAbsolute(from);\n var mustEndAbs = isToAbs || isFromAbs;\n\n if (to && isAbsolute(to)) {\n // to is absolute\n fromParts = toParts;\n } else if (toParts.length) {\n // to is relative, drop the filename\n fromParts.pop();\n fromParts = fromParts.concat(toParts);\n }\n\n if (!fromParts.length) return '/';\n\n var hasTrailingSlash;\n if (fromParts.length) {\n var last = fromParts[fromParts.length - 1];\n hasTrailingSlash = last === '.' || last === '..' || last === '';\n } else {\n hasTrailingSlash = false;\n }\n\n var up = 0;\n for (var i = fromParts.length; i >= 0; i--) {\n var part = fromParts[i];\n\n if (part === '.') {\n spliceOne(fromParts, i);\n } else if (part === '..') {\n spliceOne(fromParts, i);\n up++;\n } else if (up) {\n spliceOne(fromParts, i);\n up--;\n }\n }\n\n if (!mustEndAbs) for (; up--; up) fromParts.unshift('..');\n\n if (\n mustEndAbs &&\n fromParts[0] !== '' &&\n (!fromParts[0] || !isAbsolute(fromParts[0]))\n )\n fromParts.unshift('');\n\n var result = fromParts.join('/');\n\n if (hasTrailingSlash && result.substr(-1) !== '/') result += '/';\n\n return result;\n}\n\nexport default resolvePathname;\n","function valueOf(obj) {\n return obj.valueOf ? obj.valueOf() : Object.prototype.valueOf.call(obj);\n}\n\nfunction valueEqual(a, b) {\n // Test for strict equality first.\n if (a === b) return true;\n\n // Otherwise, if either of them == null they are not equal.\n if (a == null || b == null) return false;\n\n if (Array.isArray(a)) {\n return (\n Array.isArray(b) &&\n a.length === b.length &&\n a.every(function(item, index) {\n return valueEqual(item, b[index]);\n })\n );\n }\n\n if (typeof a === 'object' || typeof b === 'object') {\n var aValue = valueOf(a);\n var bValue = valueOf(b);\n\n if (aValue !== a || bValue !== b) return valueEqual(aValue, bValue);\n\n return Object.keys(Object.assign({}, a, b)).every(function(key) {\n return valueEqual(a[key], b[key]);\n });\n }\n\n return false;\n}\n\nexport default valueEqual;\n","var isProduction = process.env.NODE_ENV === 'production';\nvar prefix = 'Invariant failed';\nfunction invariant(condition, message) {\n if (condition) {\n return;\n }\n if (isProduction) {\n throw new Error(prefix);\n }\n var provided = typeof message === 'function' ? message() : message;\n var value = provided ? \"\".concat(prefix, \": \").concat(provided) : prefix;\n throw new Error(value);\n}\n\nexport { invariant as default };\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport resolvePathname from 'resolve-pathname';\nimport valueEqual from 'value-equal';\nimport warning from 'tiny-warning';\nimport invariant from 'tiny-invariant';\n\nfunction addLeadingSlash(path) {\n return path.charAt(0) === '/' ? path : '/' + path;\n}\nfunction stripLeadingSlash(path) {\n return path.charAt(0) === '/' ? path.substr(1) : path;\n}\nfunction hasBasename(path, prefix) {\n return path.toLowerCase().indexOf(prefix.toLowerCase()) === 0 && '/?#'.indexOf(path.charAt(prefix.length)) !== -1;\n}\nfunction stripBasename(path, prefix) {\n return hasBasename(path, prefix) ? path.substr(prefix.length) : path;\n}\nfunction stripTrailingSlash(path) {\n return path.charAt(path.length - 1) === '/' ? path.slice(0, -1) : path;\n}\nfunction parsePath(path) {\n var pathname = path || '/';\n var search = '';\n var hash = '';\n var hashIndex = pathname.indexOf('#');\n\n if (hashIndex !== -1) {\n hash = pathname.substr(hashIndex);\n pathname = pathname.substr(0, hashIndex);\n }\n\n var searchIndex = pathname.indexOf('?');\n\n if (searchIndex !== -1) {\n search = pathname.substr(searchIndex);\n pathname = pathname.substr(0, searchIndex);\n }\n\n return {\n pathname: pathname,\n search: search === '?' ? '' : search,\n hash: hash === '#' ? '' : hash\n };\n}\nfunction createPath(location) {\n var pathname = location.pathname,\n search = location.search,\n hash = location.hash;\n var path = pathname || '/';\n if (search && search !== '?') path += search.charAt(0) === '?' ? search : \"?\" + search;\n if (hash && hash !== '#') path += hash.charAt(0) === '#' ? hash : \"#\" + hash;\n return path;\n}\n\nfunction createLocation(path, state, key, currentLocation) {\n var location;\n\n if (typeof path === 'string') {\n // Two-arg form: push(path, state)\n location = parsePath(path);\n location.state = state;\n } else {\n // One-arg form: push(location)\n location = _extends({}, path);\n if (location.pathname === undefined) location.pathname = '';\n\n if (location.search) {\n if (location.search.charAt(0) !== '?') location.search = '?' + location.search;\n } else {\n location.search = '';\n }\n\n if (location.hash) {\n if (location.hash.charAt(0) !== '#') location.hash = '#' + location.hash;\n } else {\n location.hash = '';\n }\n\n if (state !== undefined && location.state === undefined) location.state = state;\n }\n\n try {\n location.pathname = decodeURI(location.pathname);\n } catch (e) {\n if (e instanceof URIError) {\n throw new URIError('Pathname \"' + location.pathname + '\" could not be decoded. ' + 'This is likely caused by an invalid percent-encoding.');\n } else {\n throw e;\n }\n }\n\n if (key) location.key = key;\n\n if (currentLocation) {\n // Resolve incomplete/relative pathname relative to current location.\n if (!location.pathname) {\n location.pathname = currentLocation.pathname;\n } else if (location.pathname.charAt(0) !== '/') {\n location.pathname = resolvePathname(location.pathname, currentLocation.pathname);\n }\n } else {\n // When there is no prior location and pathname is empty, set it to /\n if (!location.pathname) {\n location.pathname = '/';\n }\n }\n\n return location;\n}\nfunction locationsAreEqual(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash && a.key === b.key && valueEqual(a.state, b.state);\n}\n\nfunction createTransitionManager() {\n var prompt = null;\n\n function setPrompt(nextPrompt) {\n process.env.NODE_ENV !== \"production\" ? warning(prompt == null, 'A history supports only one prompt at a time') : void 0;\n prompt = nextPrompt;\n return function () {\n if (prompt === nextPrompt) prompt = null;\n };\n }\n\n function confirmTransitionTo(location, action, getUserConfirmation, callback) {\n // TODO: If another transition starts while we're still confirming\n // the previous one, we may end up in a weird state. Figure out the\n // best way to handle this.\n if (prompt != null) {\n var result = typeof prompt === 'function' ? prompt(location, action) : prompt;\n\n if (typeof result === 'string') {\n if (typeof getUserConfirmation === 'function') {\n getUserConfirmation(result, callback);\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, 'A history needs a getUserConfirmation function in order to use a prompt message') : void 0;\n callback(true);\n }\n } else {\n // Return false from a transition hook to cancel the transition.\n callback(result !== false);\n }\n } else {\n callback(true);\n }\n }\n\n var listeners = [];\n\n function appendListener(fn) {\n var isActive = true;\n\n function listener() {\n if (isActive) fn.apply(void 0, arguments);\n }\n\n listeners.push(listener);\n return function () {\n isActive = false;\n listeners = listeners.filter(function (item) {\n return item !== listener;\n });\n };\n }\n\n function notifyListeners() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n listeners.forEach(function (listener) {\n return listener.apply(void 0, args);\n });\n }\n\n return {\n setPrompt: setPrompt,\n confirmTransitionTo: confirmTransitionTo,\n appendListener: appendListener,\n notifyListeners: notifyListeners\n };\n}\n\nvar canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\nfunction getConfirmation(message, callback) {\n callback(window.confirm(message)); // eslint-disable-line no-alert\n}\n/**\n * Returns true if the HTML5 history API is supported. Taken from Modernizr.\n *\n * https://github.com/Modernizr/Modernizr/blob/master/LICENSE\n * https://github.com/Modernizr/Modernizr/blob/master/feature-detects/history.js\n * changed to avoid false negatives for Windows Phones: https://github.com/reactjs/react-router/issues/586\n */\n\nfunction supportsHistory() {\n var ua = window.navigator.userAgent;\n if ((ua.indexOf('Android 2.') !== -1 || ua.indexOf('Android 4.0') !== -1) && ua.indexOf('Mobile Safari') !== -1 && ua.indexOf('Chrome') === -1 && ua.indexOf('Windows Phone') === -1) return false;\n return window.history && 'pushState' in window.history;\n}\n/**\n * Returns true if browser fires popstate on hash change.\n * IE10 and IE11 do not.\n */\n\nfunction supportsPopStateOnHashChange() {\n return window.navigator.userAgent.indexOf('Trident') === -1;\n}\n/**\n * Returns false if using go(n) with hash history causes a full page reload.\n */\n\nfunction supportsGoWithoutReloadUsingHash() {\n return window.navigator.userAgent.indexOf('Firefox') === -1;\n}\n/**\n * Returns true if a given popstate event is an extraneous WebKit event.\n * Accounts for the fact that Chrome on iOS fires real popstate events\n * containing undefined state when pressing the back button.\n */\n\nfunction isExtraneousPopstateEvent(event) {\n return event.state === undefined && navigator.userAgent.indexOf('CriOS') === -1;\n}\n\nvar PopStateEvent = 'popstate';\nvar HashChangeEvent = 'hashchange';\n\nfunction getHistoryState() {\n try {\n return window.history.state || {};\n } catch (e) {\n // IE 11 sometimes throws when accessing window.history.state\n // See https://github.com/ReactTraining/history/pull/289\n return {};\n }\n}\n/**\n * Creates a history object that uses the HTML5 history API including\n * pushState, replaceState, and the popstate event.\n */\n\n\nfunction createBrowserHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Browser history needs a DOM') : invariant(false) : void 0;\n var globalHistory = window.history;\n var canUseHistory = supportsHistory();\n var needsHashChangeListener = !supportsPopStateOnHashChange();\n var _props = props,\n _props$forceRefresh = _props.forceRefresh,\n forceRefresh = _props$forceRefresh === void 0 ? false : _props$forceRefresh,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n\n function getDOMLocation(historyState) {\n var _ref = historyState || {},\n key = _ref.key,\n state = _ref.state;\n\n var _window$location = window.location,\n pathname = _window$location.pathname,\n search = _window$location.search,\n hash = _window$location.hash;\n var path = pathname + search + hash;\n process.env.NODE_ENV !== \"production\" ? warning(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : void 0;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path, state, key);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function handlePopState(event) {\n // Ignore extraneous popstate events in WebKit.\n if (isExtraneousPopstateEvent(event)) return;\n handlePop(getDOMLocation(event.state));\n }\n\n function handleHashChange() {\n handlePop(getDOMLocation(getHistoryState()));\n }\n\n var forceNextPop = false;\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of keys we've seen in sessionStorage.\n // Instead, we just default to 0 for keys we don't know.\n\n var toIndex = allKeys.indexOf(toLocation.key);\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allKeys.indexOf(fromLocation.key);\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n }\n\n var initialLocation = getDOMLocation(getHistoryState());\n var allKeys = [initialLocation.key]; // Public interface\n\n function createHref(location) {\n return basename + createPath(location);\n }\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.pushState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.href = href;\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n var nextKeys = allKeys.slice(0, prevIndex + 1);\n nextKeys.push(location.key);\n allKeys = nextKeys;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Browser history cannot push state in browsers that do not support HTML5 history') : void 0;\n window.location.href = href;\n }\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.replaceState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.replace(href);\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n if (prevIndex !== -1) allKeys[prevIndex] = location.key;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Browser history cannot replace state in browsers that do not support HTML5 history') : void 0;\n window.location.replace(href);\n }\n });\n }\n\n function go(n) {\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.addEventListener(HashChangeEvent, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.removeEventListener(HashChangeEvent, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nvar HashChangeEvent$1 = 'hashchange';\nvar HashPathCoders = {\n hashbang: {\n encodePath: function encodePath(path) {\n return path.charAt(0) === '!' ? path : '!/' + stripLeadingSlash(path);\n },\n decodePath: function decodePath(path) {\n return path.charAt(0) === '!' ? path.substr(1) : path;\n }\n },\n noslash: {\n encodePath: stripLeadingSlash,\n decodePath: addLeadingSlash\n },\n slash: {\n encodePath: addLeadingSlash,\n decodePath: addLeadingSlash\n }\n};\n\nfunction stripHash(url) {\n var hashIndex = url.indexOf('#');\n return hashIndex === -1 ? url : url.slice(0, hashIndex);\n}\n\nfunction getHashPath() {\n // We can't use window.location.hash here because it's not\n // consistent across browsers - Firefox will pre-decode it!\n var href = window.location.href;\n var hashIndex = href.indexOf('#');\n return hashIndex === -1 ? '' : href.substring(hashIndex + 1);\n}\n\nfunction pushHashPath(path) {\n window.location.hash = path;\n}\n\nfunction replaceHashPath(path) {\n window.location.replace(stripHash(window.location.href) + '#' + path);\n}\n\nfunction createHashHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Hash history needs a DOM') : invariant(false) : void 0;\n var globalHistory = window.history;\n var canGoWithoutReload = supportsGoWithoutReloadUsingHash();\n var _props = props,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$hashType = _props.hashType,\n hashType = _props$hashType === void 0 ? 'slash' : _props$hashType;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n var _HashPathCoders$hashT = HashPathCoders[hashType],\n encodePath = _HashPathCoders$hashT.encodePath,\n decodePath = _HashPathCoders$hashT.decodePath;\n\n function getDOMLocation() {\n var path = decodePath(getHashPath());\n process.env.NODE_ENV !== \"production\" ? warning(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : void 0;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n var forceNextPop = false;\n var ignorePath = null;\n\n function locationsAreEqual$$1(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash;\n }\n\n function handleHashChange() {\n var path = getHashPath();\n var encodedPath = encodePath(path);\n\n if (path !== encodedPath) {\n // Ensure we always have a properly-encoded hash.\n replaceHashPath(encodedPath);\n } else {\n var location = getDOMLocation();\n var prevLocation = history.location;\n if (!forceNextPop && locationsAreEqual$$1(prevLocation, location)) return; // A hashchange doesn't always == location change.\n\n if (ignorePath === createPath(location)) return; // Ignore this change; we already setState in push/replace.\n\n ignorePath = null;\n handlePop(location);\n }\n }\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of paths we've seen in sessionStorage.\n // Instead, we just default to 0 for paths we don't know.\n\n var toIndex = allPaths.lastIndexOf(createPath(toLocation));\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allPaths.lastIndexOf(createPath(fromLocation));\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n } // Ensure the hash is encoded properly before doing anything else.\n\n\n var path = getHashPath();\n var encodedPath = encodePath(path);\n if (path !== encodedPath) replaceHashPath(encodedPath);\n var initialLocation = getDOMLocation();\n var allPaths = [createPath(initialLocation)]; // Public interface\n\n function createHref(location) {\n var baseTag = document.querySelector('base');\n var href = '';\n\n if (baseTag && baseTag.getAttribute('href')) {\n href = stripHash(window.location.href);\n }\n\n return href + '#' + encodePath(basename + createPath(location));\n }\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Hash history cannot push state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a PUSH, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n pushHashPath(encodedPath);\n var prevIndex = allPaths.lastIndexOf(createPath(history.location));\n var nextPaths = allPaths.slice(0, prevIndex + 1);\n nextPaths.push(path);\n allPaths = nextPaths;\n setState({\n action: action,\n location: location\n });\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, 'Hash history cannot PUSH the same path; a new entry will not be added to the history stack') : void 0;\n setState();\n }\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Hash history cannot replace state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a REPLACE, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n replaceHashPath(encodedPath);\n }\n\n var prevIndex = allPaths.indexOf(createPath(history.location));\n if (prevIndex !== -1) allPaths[prevIndex] = path;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n process.env.NODE_ENV !== \"production\" ? warning(canGoWithoutReload, 'Hash history go(n) causes a full page reload in this browser') : void 0;\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(HashChangeEvent$1, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(HashChangeEvent$1, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nfunction clamp(n, lowerBound, upperBound) {\n return Math.min(Math.max(n, lowerBound), upperBound);\n}\n/**\n * Creates a history object that stores locations in memory.\n */\n\n\nfunction createMemoryHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n var _props = props,\n getUserConfirmation = _props.getUserConfirmation,\n _props$initialEntries = _props.initialEntries,\n initialEntries = _props$initialEntries === void 0 ? ['/'] : _props$initialEntries,\n _props$initialIndex = _props.initialIndex,\n initialIndex = _props$initialIndex === void 0 ? 0 : _props$initialIndex,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = history.entries.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var index = clamp(initialIndex, 0, initialEntries.length - 1);\n var entries = initialEntries.map(function (entry) {\n return typeof entry === 'string' ? createLocation(entry, undefined, createKey()) : createLocation(entry, undefined, entry.key || createKey());\n }); // Public interface\n\n var createHref = createPath;\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var prevIndex = history.index;\n var nextIndex = prevIndex + 1;\n var nextEntries = history.entries.slice(0);\n\n if (nextEntries.length > nextIndex) {\n nextEntries.splice(nextIndex, nextEntries.length - nextIndex, location);\n } else {\n nextEntries.push(location);\n }\n\n setState({\n action: action,\n location: location,\n index: nextIndex,\n entries: nextEntries\n });\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n history.entries[history.index] = location;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n var nextIndex = clamp(history.index + n, 0, history.entries.length - 1);\n var action = 'POP';\n var location = history.entries[nextIndex];\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location,\n index: nextIndex\n });\n } else {\n // Mimic the behavior of DOM histories by\n // causing a render after a cancelled POP.\n setState();\n }\n });\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n function canGo(n) {\n var nextIndex = history.index + n;\n return nextIndex >= 0 && nextIndex < history.entries.length;\n }\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n return transitionManager.setPrompt(prompt);\n }\n\n function listen(listener) {\n return transitionManager.appendListener(listener);\n }\n\n var history = {\n length: entries.length,\n action: 'POP',\n location: entries[index],\n index: index,\n entries: entries,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n canGo: canGo,\n block: block,\n listen: listen\n };\n return history;\n}\n\nexport { createBrowserHistory, createHashHistory, createMemoryHistory, createLocation, locationsAreEqual, parsePath, createPath };\n","module.exports = Array.isArray || function (arr) {\n return Object.prototype.toString.call(arr) == '[object Array]';\n};\n","var isarray = require('isarray')\n\n/**\n * Expose `pathToRegexp`.\n */\nmodule.exports = pathToRegexp\nmodule.exports.parse = parse\nmodule.exports.compile = compile\nmodule.exports.tokensToFunction = tokensToFunction\nmodule.exports.tokensToRegExp = tokensToRegExp\n\n/**\n * The main path matching regexp utility.\n *\n * @type {RegExp}\n */\nvar PATH_REGEXP = new RegExp([\n // Match escaped characters that would otherwise appear in future matches.\n // This allows the user to escape special characters that won't transform.\n '(\\\\\\\\.)',\n // Match Express-style parameters and un-named parameters with a prefix\n // and optional suffixes. Matches appear as:\n //\n // \"/:test(\\\\d+)?\" => [\"/\", \"test\", \"\\d+\", undefined, \"?\", undefined]\n // \"/route(\\\\d+)\" => [undefined, undefined, undefined, \"\\d+\", undefined, undefined]\n // \"/*\" => [\"/\", undefined, undefined, undefined, undefined, \"*\"]\n '([\\\\/.])?(?:(?:\\\\:(\\\\w+)(?:\\\\(((?:\\\\\\\\.|[^\\\\\\\\()])+)\\\\))?|\\\\(((?:\\\\\\\\.|[^\\\\\\\\()])+)\\\\))([+*?])?|(\\\\*))'\n].join('|'), 'g')\n\n/**\n * Parse a string for the raw tokens.\n *\n * @param {string} str\n * @param {Object=} options\n * @return {!Array}\n */\nfunction parse (str, options) {\n var tokens = []\n var key = 0\n var index = 0\n var path = ''\n var defaultDelimiter = options && options.delimiter || '/'\n var res\n\n while ((res = PATH_REGEXP.exec(str)) != null) {\n var m = res[0]\n var escaped = res[1]\n var offset = res.index\n path += str.slice(index, offset)\n index = offset + m.length\n\n // Ignore already escaped sequences.\n if (escaped) {\n path += escaped[1]\n continue\n }\n\n var next = str[index]\n var prefix = res[2]\n var name = res[3]\n var capture = res[4]\n var group = res[5]\n var modifier = res[6]\n var asterisk = res[7]\n\n // Push the current path onto the tokens.\n if (path) {\n tokens.push(path)\n path = ''\n }\n\n var partial = prefix != null && next != null && next !== prefix\n var repeat = modifier === '+' || modifier === '*'\n var optional = modifier === '?' || modifier === '*'\n var delimiter = prefix || defaultDelimiter\n var pattern = capture || group\n var prevText = prefix || (typeof tokens[tokens.length - 1] === 'string' ? tokens[tokens.length - 1] : '')\n\n tokens.push({\n name: name || key++,\n prefix: prefix || '',\n delimiter: delimiter,\n optional: optional,\n repeat: repeat,\n partial: partial,\n asterisk: !!asterisk,\n pattern: pattern ? escapeGroup(pattern) : (asterisk ? '.*' : restrictBacktrack(delimiter, prevText))\n })\n }\n\n // Match any characters still remaining.\n if (index < str.length) {\n path += str.substr(index)\n }\n\n // If the path exists, push it onto the end.\n if (path) {\n tokens.push(path)\n }\n\n return tokens\n}\n\nfunction restrictBacktrack(delimiter, prevText) {\n if (!prevText || prevText.indexOf(delimiter) > -1) {\n return '[^' + escapeString(delimiter) + ']+?'\n }\n\n return escapeString(prevText) + '|(?:(?!' + escapeString(prevText) + ')[^' + escapeString(delimiter) + '])+?'\n}\n\n/**\n * Compile a string to a template function for the path.\n *\n * @param {string} str\n * @param {Object=} options\n * @return {!function(Object=, Object=)}\n */\nfunction compile (str, options) {\n return tokensToFunction(parse(str, options), options)\n}\n\n/**\n * Prettier encoding of URI path segments.\n *\n * @param {string}\n * @return {string}\n */\nfunction encodeURIComponentPretty (str) {\n return encodeURI(str).replace(/[\\/?#]/g, function (c) {\n return '%' + c.charCodeAt(0).toString(16).toUpperCase()\n })\n}\n\n/**\n * Encode the asterisk parameter. Similar to `pretty`, but allows slashes.\n *\n * @param {string}\n * @return {string}\n */\nfunction encodeAsterisk (str) {\n return encodeURI(str).replace(/[?#]/g, function (c) {\n return '%' + c.charCodeAt(0).toString(16).toUpperCase()\n })\n}\n\n/**\n * Expose a method for transforming tokens into the path function.\n */\nfunction tokensToFunction (tokens, options) {\n // Compile all the tokens into regexps.\n var matches = new Array(tokens.length)\n\n // Compile all the patterns before compilation.\n for (var i = 0; i < tokens.length; i++) {\n if (typeof tokens[i] === 'object') {\n matches[i] = new RegExp('^(?:' + tokens[i].pattern + ')$', flags(options))\n }\n }\n\n return function (obj, opts) {\n var path = ''\n var data = obj || {}\n var options = opts || {}\n var encode = options.pretty ? encodeURIComponentPretty : encodeURIComponent\n\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i]\n\n if (typeof token === 'string') {\n path += token\n\n continue\n }\n\n var value = data[token.name]\n var segment\n\n if (value == null) {\n if (token.optional) {\n // Prepend partial segment prefixes.\n if (token.partial) {\n path += token.prefix\n }\n\n continue\n } else {\n throw new TypeError('Expected \"' + token.name + '\" to be defined')\n }\n }\n\n if (isarray(value)) {\n if (!token.repeat) {\n throw new TypeError('Expected \"' + token.name + '\" to not repeat, but received `' + JSON.stringify(value) + '`')\n }\n\n if (value.length === 0) {\n if (token.optional) {\n continue\n } else {\n throw new TypeError('Expected \"' + token.name + '\" to not be empty')\n }\n }\n\n for (var j = 0; j < value.length; j++) {\n segment = encode(value[j])\n\n if (!matches[i].test(segment)) {\n throw new TypeError('Expected all \"' + token.name + '\" to match \"' + token.pattern + '\", but received `' + JSON.stringify(segment) + '`')\n }\n\n path += (j === 0 ? token.prefix : token.delimiter) + segment\n }\n\n continue\n }\n\n segment = token.asterisk ? encodeAsterisk(value) : encode(value)\n\n if (!matches[i].test(segment)) {\n throw new TypeError('Expected \"' + token.name + '\" to match \"' + token.pattern + '\", but received \"' + segment + '\"')\n }\n\n path += token.prefix + segment\n }\n\n return path\n }\n}\n\n/**\n * Escape a regular expression string.\n *\n * @param {string} str\n * @return {string}\n */\nfunction escapeString (str) {\n return str.replace(/([.+*?=^!:${}()[\\]|\\/\\\\])/g, '\\\\$1')\n}\n\n/**\n * Escape the capturing group by escaping special characters and meaning.\n *\n * @param {string} group\n * @return {string}\n */\nfunction escapeGroup (group) {\n return group.replace(/([=!:$\\/()])/g, '\\\\$1')\n}\n\n/**\n * Attach the keys as a property of the regexp.\n *\n * @param {!RegExp} re\n * @param {Array} keys\n * @return {!RegExp}\n */\nfunction attachKeys (re, keys) {\n re.keys = keys\n return re\n}\n\n/**\n * Get the flags for a regexp from the options.\n *\n * @param {Object} options\n * @return {string}\n */\nfunction flags (options) {\n return options && options.sensitive ? '' : 'i'\n}\n\n/**\n * Pull out keys from a regexp.\n *\n * @param {!RegExp} path\n * @param {!Array} keys\n * @return {!RegExp}\n */\nfunction regexpToRegexp (path, keys) {\n // Use a negative lookahead to match only capturing groups.\n var groups = path.source.match(/\\((?!\\?)/g)\n\n if (groups) {\n for (var i = 0; i < groups.length; i++) {\n keys.push({\n name: i,\n prefix: null,\n delimiter: null,\n optional: false,\n repeat: false,\n partial: false,\n asterisk: false,\n pattern: null\n })\n }\n }\n\n return attachKeys(path, keys)\n}\n\n/**\n * Transform an array into a regexp.\n *\n * @param {!Array} path\n * @param {Array} keys\n * @param {!Object} options\n * @return {!RegExp}\n */\nfunction arrayToRegexp (path, keys, options) {\n var parts = []\n\n for (var i = 0; i < path.length; i++) {\n parts.push(pathToRegexp(path[i], keys, options).source)\n }\n\n var regexp = new RegExp('(?:' + parts.join('|') + ')', flags(options))\n\n return attachKeys(regexp, keys)\n}\n\n/**\n * Create a path regexp from string input.\n *\n * @param {string} path\n * @param {!Array} keys\n * @param {!Object} options\n * @return {!RegExp}\n */\nfunction stringToRegexp (path, keys, options) {\n return tokensToRegExp(parse(path, options), keys, options)\n}\n\n/**\n * Expose a function for taking tokens and returning a RegExp.\n *\n * @param {!Array} tokens\n * @param {(Array|Object)=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction tokensToRegExp (tokens, keys, options) {\n if (!isarray(keys)) {\n options = /** @type {!Object} */ (keys || options)\n keys = []\n }\n\n options = options || {}\n\n var strict = options.strict\n var end = options.end !== false\n var route = ''\n\n // Iterate over the tokens and create our regexp string.\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i]\n\n if (typeof token === 'string') {\n route += escapeString(token)\n } else {\n var prefix = escapeString(token.prefix)\n var capture = '(?:' + token.pattern + ')'\n\n keys.push(token)\n\n if (token.repeat) {\n capture += '(?:' + prefix + capture + ')*'\n }\n\n if (token.optional) {\n if (!token.partial) {\n capture = '(?:' + prefix + '(' + capture + '))?'\n } else {\n capture = prefix + '(' + capture + ')?'\n }\n } else {\n capture = prefix + '(' + capture + ')'\n }\n\n route += capture\n }\n }\n\n var delimiter = escapeString(options.delimiter || '/')\n var endsWithDelimiter = route.slice(-delimiter.length) === delimiter\n\n // In non-strict mode we allow a slash at the end of match. If the path to\n // match already ends with a slash, we remove it for consistency. The slash\n // is valid at the end of a path match, not in the middle. This is important\n // in non-ending mode, where \"/test/\" shouldn't match \"/test//route\".\n if (!strict) {\n route = (endsWithDelimiter ? route.slice(0, -delimiter.length) : route) + '(?:' + delimiter + '(?=$))?'\n }\n\n if (end) {\n route += '$'\n } else {\n // In non-ending mode, we need the capturing groups to match as much as\n // possible by using a positive lookahead to the end or next path segment.\n route += strict && endsWithDelimiter ? '' : '(?=' + delimiter + '|$)'\n }\n\n return attachKeys(new RegExp('^' + route, flags(options)), keys)\n}\n\n/**\n * Normalize the given path string, returning a regular expression.\n *\n * An empty array can be passed in for the keys, which will hold the\n * placeholder key descriptions. For example, using `/user/:id`, `keys` will\n * contain `[{ name: 'id', delimiter: '/', optional: false, repeat: false }]`.\n *\n * @param {(string|RegExp|Array)} path\n * @param {(Array|Object)=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction pathToRegexp (path, keys, options) {\n if (!isarray(keys)) {\n options = /** @type {!Object} */ (keys || options)\n keys = []\n }\n\n options = options || {}\n\n if (path instanceof RegExp) {\n return regexpToRegexp(path, /** @type {!Array} */ (keys))\n }\n\n if (isarray(path)) {\n return arrayToRegexp(/** @type {!Array} */ (path), /** @type {!Array} */ (keys), options)\n }\n\n return stringToRegexp(/** @type {string} */ (path), /** @type {!Array} */ (keys), options)\n}\n","/** @license React v16.13.1\n * react-is.production.min.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';var b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?\nSymbol.for(\"react.suspense_list\"):60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.block\"):60121,w=b?Symbol.for(\"react.fundamental\"):60117,x=b?Symbol.for(\"react.responder\"):60118,y=b?Symbol.for(\"react.scope\"):60119;\nfunction z(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function A(a){return z(a)===m}exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;\nexports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;exports.isAsyncMode=function(a){return A(a)||z(a)===l};exports.isConcurrentMode=A;exports.isContextConsumer=function(a){return z(a)===k};exports.isContextProvider=function(a){return z(a)===h};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return z(a)===n};exports.isFragment=function(a){return z(a)===e};exports.isLazy=function(a){return z(a)===t};\nexports.isMemo=function(a){return z(a)===r};exports.isPortal=function(a){return z(a)===d};exports.isProfiler=function(a){return z(a)===g};exports.isStrictMode=function(a){return z(a)===f};exports.isSuspense=function(a){return z(a)===p};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===w||a.$$typeof===x||a.$$typeof===y||a.$$typeof===v)};exports.typeOf=z;\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","function _objectWithoutPropertiesLoose(r, e) {\n if (null == r) return {};\n var t = {};\n for (var n in r) if ({}.hasOwnProperty.call(r, n)) {\n if (e.includes(n)) continue;\n t[n] = r[n];\n }\n return t;\n}\nexport { _objectWithoutPropertiesLoose as default };","'use strict';\n\nvar reactIs = require('react-is');\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\nTYPE_STATICS[reactIs.Memo] = MEMO_STATICS;\n\nfunction getStatics(component) {\n // React v16.11 and below\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n } // React v16.12 and above\n\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n","import _inheritsLoose from '@babel/runtime/helpers/esm/inheritsLoose';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { createMemoryHistory, createLocation, locationsAreEqual, createPath } from 'history';\nimport warning from 'tiny-warning';\nimport invariant from 'tiny-invariant';\nimport _extends from '@babel/runtime/helpers/esm/extends';\nimport pathToRegexp from 'path-to-regexp';\nimport { isValidElementType } from 'react-is';\nimport _objectWithoutPropertiesLoose from '@babel/runtime/helpers/esm/objectWithoutPropertiesLoose';\nimport hoistStatics from 'hoist-non-react-statics';\n\nvar MAX_SIGNED_31_BIT_INT = 1073741823;\nvar commonjsGlobal = typeof globalThis !== \"undefined\" // 'global proper'\n? // eslint-disable-next-line no-undef\nglobalThis : typeof window !== \"undefined\" ? window // Browser\n: typeof global !== \"undefined\" ? global // node.js\n: {};\n\nfunction getUniqueId() {\n var key = \"__global_unique_id__\";\n return commonjsGlobal[key] = (commonjsGlobal[key] || 0) + 1;\n} // Inlined Object.is polyfill.\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n\n\nfunction objectIs(x, y) {\n if (x === y) {\n return x !== 0 || 1 / x === 1 / y;\n } else {\n // eslint-disable-next-line no-self-compare\n return x !== x && y !== y;\n }\n}\n\nfunction createEventEmitter(value) {\n var handlers = [];\n return {\n on: function on(handler) {\n handlers.push(handler);\n },\n off: function off(handler) {\n handlers = handlers.filter(function (h) {\n return h !== handler;\n });\n },\n get: function get() {\n return value;\n },\n set: function set(newValue, changedBits) {\n value = newValue;\n handlers.forEach(function (handler) {\n return handler(value, changedBits);\n });\n }\n };\n}\n\nfunction onlyChild(children) {\n return Array.isArray(children) ? children[0] : children;\n}\n\nfunction createReactContext(defaultValue, calculateChangedBits) {\n var _Provider$childContex, _Consumer$contextType;\n\n var contextProp = \"__create-react-context-\" + getUniqueId() + \"__\";\n\n var Provider = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(Provider, _React$Component);\n\n function Provider() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n _this.emitter = createEventEmitter(_this.props.value);\n return _this;\n }\n\n var _proto = Provider.prototype;\n\n _proto.getChildContext = function getChildContext() {\n var _ref;\n\n return _ref = {}, _ref[contextProp] = this.emitter, _ref;\n };\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n if (this.props.value !== nextProps.value) {\n var oldValue = this.props.value;\n var newValue = nextProps.value;\n var changedBits;\n\n if (objectIs(oldValue, newValue)) {\n changedBits = 0; // No change\n } else {\n changedBits = typeof calculateChangedBits === \"function\" ? calculateChangedBits(oldValue, newValue) : MAX_SIGNED_31_BIT_INT;\n\n if (process.env.NODE_ENV !== \"production\") {\n process.env.NODE_ENV !== \"production\" ? warning((changedBits & MAX_SIGNED_31_BIT_INT) === changedBits, \"calculateChangedBits: Expected the return value to be a \" + \"31-bit integer. Instead received: \" + changedBits) : void 0;\n }\n\n changedBits |= 0;\n\n if (changedBits !== 0) {\n this.emitter.set(nextProps.value, changedBits);\n }\n }\n }\n };\n\n _proto.render = function render() {\n return this.props.children;\n };\n\n return Provider;\n }(React.Component);\n\n Provider.childContextTypes = (_Provider$childContex = {}, _Provider$childContex[contextProp] = PropTypes.object.isRequired, _Provider$childContex);\n\n var Consumer = /*#__PURE__*/function (_React$Component2) {\n _inheritsLoose(Consumer, _React$Component2);\n\n function Consumer() {\n var _this2;\n\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n _this2 = _React$Component2.call.apply(_React$Component2, [this].concat(args)) || this;\n _this2.observedBits = void 0;\n _this2.state = {\n value: _this2.getValue()\n };\n\n _this2.onUpdate = function (newValue, changedBits) {\n var observedBits = _this2.observedBits | 0;\n\n if ((observedBits & changedBits) !== 0) {\n _this2.setState({\n value: _this2.getValue()\n });\n }\n };\n\n return _this2;\n }\n\n var _proto2 = Consumer.prototype;\n\n _proto2.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var observedBits = nextProps.observedBits;\n this.observedBits = observedBits === undefined || observedBits === null ? MAX_SIGNED_31_BIT_INT // Subscribe to all changes by default\n : observedBits;\n };\n\n _proto2.componentDidMount = function componentDidMount() {\n if (this.context[contextProp]) {\n this.context[contextProp].on(this.onUpdate);\n }\n\n var observedBits = this.props.observedBits;\n this.observedBits = observedBits === undefined || observedBits === null ? MAX_SIGNED_31_BIT_INT // Subscribe to all changes by default\n : observedBits;\n };\n\n _proto2.componentWillUnmount = function componentWillUnmount() {\n if (this.context[contextProp]) {\n this.context[contextProp].off(this.onUpdate);\n }\n };\n\n _proto2.getValue = function getValue() {\n if (this.context[contextProp]) {\n return this.context[contextProp].get();\n } else {\n return defaultValue;\n }\n };\n\n _proto2.render = function render() {\n return onlyChild(this.props.children)(this.state.value);\n };\n\n return Consumer;\n }(React.Component);\n\n Consumer.contextTypes = (_Consumer$contextType = {}, _Consumer$contextType[contextProp] = PropTypes.object, _Consumer$contextType);\n return {\n Provider: Provider,\n Consumer: Consumer\n };\n}\n\n// MIT License\nvar createContext = React.createContext || createReactContext;\n\n// TODO: Replace with React.createContext once we can assume React 16+\n\nvar createNamedContext = function createNamedContext(name) {\n var context = createContext();\n context.displayName = name;\n return context;\n};\n\nvar historyContext = /*#__PURE__*/createNamedContext(\"Router-History\");\n\nvar context = /*#__PURE__*/createNamedContext(\"Router\");\n\n/**\n * The public API for putting history on context.\n */\n\nvar Router = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(Router, _React$Component);\n\n Router.computeRootMatch = function computeRootMatch(pathname) {\n return {\n path: \"/\",\n url: \"/\",\n params: {},\n isExact: pathname === \"/\"\n };\n };\n\n function Router(props) {\n var _this;\n\n _this = _React$Component.call(this, props) || this;\n _this.state = {\n location: props.history.location\n }; // This is a bit of a hack. We have to start listening for location\n // changes here in the constructor in case there are any s\n // on the initial render. If there are, they will replace/push when\n // they mount and since cDM fires in children before parents, we may\n // get a new location before the is mounted.\n\n _this._isMounted = false;\n _this._pendingLocation = null;\n\n if (!props.staticContext) {\n _this.unlisten = props.history.listen(function (location) {\n _this._pendingLocation = location;\n });\n }\n\n return _this;\n }\n\n var _proto = Router.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n var _this2 = this;\n\n this._isMounted = true;\n\n if (this.unlisten) {\n // Any pre-mount location changes have been captured at\n // this point, so unregister the listener.\n this.unlisten();\n }\n\n if (!this.props.staticContext) {\n this.unlisten = this.props.history.listen(function (location) {\n if (_this2._isMounted) {\n _this2.setState({\n location: location\n });\n }\n });\n }\n\n if (this._pendingLocation) {\n this.setState({\n location: this._pendingLocation\n });\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n if (this.unlisten) {\n this.unlisten();\n this._isMounted = false;\n this._pendingLocation = null;\n }\n };\n\n _proto.render = function render() {\n return /*#__PURE__*/React.createElement(context.Provider, {\n value: {\n history: this.props.history,\n location: this.state.location,\n match: Router.computeRootMatch(this.state.location.pathname),\n staticContext: this.props.staticContext\n }\n }, /*#__PURE__*/React.createElement(historyContext.Provider, {\n children: this.props.children || null,\n value: this.props.history\n }));\n };\n\n return Router;\n}(React.Component);\n\nif (process.env.NODE_ENV !== \"production\") {\n Router.propTypes = {\n children: PropTypes.node,\n history: PropTypes.object.isRequired,\n staticContext: PropTypes.object\n };\n\n Router.prototype.componentDidUpdate = function (prevProps) {\n process.env.NODE_ENV !== \"production\" ? warning(prevProps.history === this.props.history, \"You cannot change \") : void 0;\n };\n}\n\n/**\n * The public API for a that stores location in memory.\n */\n\nvar MemoryRouter = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(MemoryRouter, _React$Component);\n\n function MemoryRouter() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n _this.history = createMemoryHistory(_this.props);\n return _this;\n }\n\n var _proto = MemoryRouter.prototype;\n\n _proto.render = function render() {\n return /*#__PURE__*/React.createElement(Router, {\n history: this.history,\n children: this.props.children\n });\n };\n\n return MemoryRouter;\n}(React.Component);\n\nif (process.env.NODE_ENV !== \"production\") {\n MemoryRouter.propTypes = {\n initialEntries: PropTypes.array,\n initialIndex: PropTypes.number,\n getUserConfirmation: PropTypes.func,\n keyLength: PropTypes.number,\n children: PropTypes.node\n };\n\n MemoryRouter.prototype.componentDidMount = function () {\n process.env.NODE_ENV !== \"production\" ? warning(!this.props.history, \" ignores the history prop. To use a custom history, \" + \"use `import { Router }` instead of `import { MemoryRouter as Router }`.\") : void 0;\n };\n}\n\nvar Lifecycle = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(Lifecycle, _React$Component);\n\n function Lifecycle() {\n return _React$Component.apply(this, arguments) || this;\n }\n\n var _proto = Lifecycle.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n if (this.props.onMount) this.props.onMount.call(this, this);\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n if (this.props.onUpdate) this.props.onUpdate.call(this, this, prevProps);\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n if (this.props.onUnmount) this.props.onUnmount.call(this, this);\n };\n\n _proto.render = function render() {\n return null;\n };\n\n return Lifecycle;\n}(React.Component);\n\n/**\n * The public API for prompting the user before navigating away from a screen.\n */\n\nfunction Prompt(_ref) {\n var message = _ref.message,\n _ref$when = _ref.when,\n when = _ref$when === void 0 ? true : _ref$when;\n return /*#__PURE__*/React.createElement(context.Consumer, null, function (context) {\n !context ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"You should not use outside a \") : invariant(false) : void 0;\n if (!when || context.staticContext) return null;\n var method = context.history.block;\n return /*#__PURE__*/React.createElement(Lifecycle, {\n onMount: function onMount(self) {\n self.release = method(message);\n },\n onUpdate: function onUpdate(self, prevProps) {\n if (prevProps.message !== message) {\n self.release();\n self.release = method(message);\n }\n },\n onUnmount: function onUnmount(self) {\n self.release();\n },\n message: message\n });\n });\n}\n\nif (process.env.NODE_ENV !== \"production\") {\n var messageType = PropTypes.oneOfType([PropTypes.func, PropTypes.string]);\n Prompt.propTypes = {\n when: PropTypes.bool,\n message: messageType.isRequired\n };\n}\n\nvar cache = {};\nvar cacheLimit = 10000;\nvar cacheCount = 0;\n\nfunction compilePath(path) {\n if (cache[path]) return cache[path];\n var generator = pathToRegexp.compile(path);\n\n if (cacheCount < cacheLimit) {\n cache[path] = generator;\n cacheCount++;\n }\n\n return generator;\n}\n/**\n * Public API for generating a URL pathname from a path and parameters.\n */\n\n\nfunction generatePath(path, params) {\n if (path === void 0) {\n path = \"/\";\n }\n\n if (params === void 0) {\n params = {};\n }\n\n return path === \"/\" ? path : compilePath(path)(params, {\n pretty: true\n });\n}\n\n/**\n * The public API for navigating programmatically with a component.\n */\n\nfunction Redirect(_ref) {\n var computedMatch = _ref.computedMatch,\n to = _ref.to,\n _ref$push = _ref.push,\n push = _ref$push === void 0 ? false : _ref$push;\n return /*#__PURE__*/React.createElement(context.Consumer, null, function (context) {\n !context ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"You should not use outside a \") : invariant(false) : void 0;\n var history = context.history,\n staticContext = context.staticContext;\n var method = push ? history.push : history.replace;\n var location = createLocation(computedMatch ? typeof to === \"string\" ? generatePath(to, computedMatch.params) : _extends({}, to, {\n pathname: generatePath(to.pathname, computedMatch.params)\n }) : to); // When rendering in a static context,\n // set the new location immediately.\n\n if (staticContext) {\n method(location);\n return null;\n }\n\n return /*#__PURE__*/React.createElement(Lifecycle, {\n onMount: function onMount() {\n method(location);\n },\n onUpdate: function onUpdate(self, prevProps) {\n var prevLocation = createLocation(prevProps.to);\n\n if (!locationsAreEqual(prevLocation, _extends({}, location, {\n key: prevLocation.key\n }))) {\n method(location);\n }\n },\n to: to\n });\n });\n}\n\nif (process.env.NODE_ENV !== \"production\") {\n Redirect.propTypes = {\n push: PropTypes.bool,\n from: PropTypes.string,\n to: PropTypes.oneOfType([PropTypes.string, PropTypes.object]).isRequired\n };\n}\n\nvar cache$1 = {};\nvar cacheLimit$1 = 10000;\nvar cacheCount$1 = 0;\n\nfunction compilePath$1(path, options) {\n var cacheKey = \"\" + options.end + options.strict + options.sensitive;\n var pathCache = cache$1[cacheKey] || (cache$1[cacheKey] = {});\n if (pathCache[path]) return pathCache[path];\n var keys = [];\n var regexp = pathToRegexp(path, keys, options);\n var result = {\n regexp: regexp,\n keys: keys\n };\n\n if (cacheCount$1 < cacheLimit$1) {\n pathCache[path] = result;\n cacheCount$1++;\n }\n\n return result;\n}\n/**\n * Public API for matching a URL pathname to a path.\n */\n\n\nfunction matchPath(pathname, options) {\n if (options === void 0) {\n options = {};\n }\n\n if (typeof options === \"string\" || Array.isArray(options)) {\n options = {\n path: options\n };\n }\n\n var _options = options,\n path = _options.path,\n _options$exact = _options.exact,\n exact = _options$exact === void 0 ? false : _options$exact,\n _options$strict = _options.strict,\n strict = _options$strict === void 0 ? false : _options$strict,\n _options$sensitive = _options.sensitive,\n sensitive = _options$sensitive === void 0 ? false : _options$sensitive;\n var paths = [].concat(path);\n return paths.reduce(function (matched, path) {\n if (!path && path !== \"\") return null;\n if (matched) return matched;\n\n var _compilePath = compilePath$1(path, {\n end: exact,\n strict: strict,\n sensitive: sensitive\n }),\n regexp = _compilePath.regexp,\n keys = _compilePath.keys;\n\n var match = regexp.exec(pathname);\n if (!match) return null;\n var url = match[0],\n values = match.slice(1);\n var isExact = pathname === url;\n if (exact && !isExact) return null;\n return {\n path: path,\n // the path used to match\n url: path === \"/\" && url === \"\" ? \"/\" : url,\n // the matched portion of the URL\n isExact: isExact,\n // whether or not we matched exactly\n params: keys.reduce(function (memo, key, index) {\n memo[key.name] = values[index];\n return memo;\n }, {})\n };\n }, null);\n}\n\nfunction isEmptyChildren(children) {\n return React.Children.count(children) === 0;\n}\n\nfunction evalChildrenDev(children, props, path) {\n var value = children(props);\n process.env.NODE_ENV !== \"production\" ? warning(value !== undefined, \"You returned `undefined` from the `children` function of \" + (\", but you \") + \"should have returned a React element or `null`\") : void 0;\n return value || null;\n}\n/**\n * The public API for matching a single path and rendering.\n */\n\n\nvar Route = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(Route, _React$Component);\n\n function Route() {\n return _React$Component.apply(this, arguments) || this;\n }\n\n var _proto = Route.prototype;\n\n _proto.render = function render() {\n var _this = this;\n\n return /*#__PURE__*/React.createElement(context.Consumer, null, function (context$1) {\n !context$1 ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"You should not use outside a \") : invariant(false) : void 0;\n var location = _this.props.location || context$1.location;\n var match = _this.props.computedMatch ? _this.props.computedMatch // already computed the match for us\n : _this.props.path ? matchPath(location.pathname, _this.props) : context$1.match;\n\n var props = _extends({}, context$1, {\n location: location,\n match: match\n });\n\n var _this$props = _this.props,\n children = _this$props.children,\n component = _this$props.component,\n render = _this$props.render; // Preact uses an empty array as children by\n // default, so use null if that's the case.\n\n if (Array.isArray(children) && isEmptyChildren(children)) {\n children = null;\n }\n\n return /*#__PURE__*/React.createElement(context.Provider, {\n value: props\n }, props.match ? children ? typeof children === \"function\" ? process.env.NODE_ENV !== \"production\" ? evalChildrenDev(children, props, _this.props.path) : children(props) : children : component ? /*#__PURE__*/React.createElement(component, props) : render ? render(props) : null : typeof children === \"function\" ? process.env.NODE_ENV !== \"production\" ? evalChildrenDev(children, props, _this.props.path) : children(props) : null);\n });\n };\n\n return Route;\n}(React.Component);\n\nif (process.env.NODE_ENV !== \"production\") {\n Route.propTypes = {\n children: PropTypes.oneOfType([PropTypes.func, PropTypes.node]),\n component: function component(props, propName) {\n if (props[propName] && !isValidElementType(props[propName])) {\n return new Error(\"Invalid prop 'component' supplied to 'Route': the prop is not a valid React component\");\n }\n },\n exact: PropTypes.bool,\n location: PropTypes.object,\n path: PropTypes.oneOfType([PropTypes.string, PropTypes.arrayOf(PropTypes.string)]),\n render: PropTypes.func,\n sensitive: PropTypes.bool,\n strict: PropTypes.bool\n };\n\n Route.prototype.componentDidMount = function () {\n process.env.NODE_ENV !== \"production\" ? warning(!(this.props.children && !isEmptyChildren(this.props.children) && this.props.component), \"You should not use and in the same route; will be ignored\") : void 0;\n process.env.NODE_ENV !== \"production\" ? warning(!(this.props.children && !isEmptyChildren(this.props.children) && this.props.render), \"You should not use and in the same route; will be ignored\") : void 0;\n process.env.NODE_ENV !== \"production\" ? warning(!(this.props.component && this.props.render), \"You should not use and in the same route; will be ignored\") : void 0;\n };\n\n Route.prototype.componentDidUpdate = function (prevProps) {\n process.env.NODE_ENV !== \"production\" ? warning(!(this.props.location && !prevProps.location), ' elements should not change from uncontrolled to controlled (or vice versa). You initially used no \"location\" prop and then provided one on a subsequent render.') : void 0;\n process.env.NODE_ENV !== \"production\" ? warning(!(!this.props.location && prevProps.location), ' elements should not change from controlled to uncontrolled (or vice versa). You provided a \"location\" prop initially but omitted it on a subsequent render.') : void 0;\n };\n}\n\nfunction addLeadingSlash(path) {\n return path.charAt(0) === \"/\" ? path : \"/\" + path;\n}\n\nfunction addBasename(basename, location) {\n if (!basename) return location;\n return _extends({}, location, {\n pathname: addLeadingSlash(basename) + location.pathname\n });\n}\n\nfunction stripBasename(basename, location) {\n if (!basename) return location;\n var base = addLeadingSlash(basename);\n if (location.pathname.indexOf(base) !== 0) return location;\n return _extends({}, location, {\n pathname: location.pathname.substr(base.length)\n });\n}\n\nfunction createURL(location) {\n return typeof location === \"string\" ? location : createPath(location);\n}\n\nfunction staticHandler(methodName) {\n return function () {\n process.env.NODE_ENV !== \"production\" ? invariant(false, \"You cannot %s with \", methodName) : invariant(false) ;\n };\n}\n\nfunction noop() {}\n/**\n * The public top-level API for a \"static\" , so-called because it\n * can't actually change the current location. Instead, it just records\n * location changes in a context object. Useful mainly in testing and\n * server-rendering scenarios.\n */\n\n\nvar StaticRouter = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(StaticRouter, _React$Component);\n\n function StaticRouter() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n\n _this.handlePush = function (location) {\n return _this.navigateTo(location, \"PUSH\");\n };\n\n _this.handleReplace = function (location) {\n return _this.navigateTo(location, \"REPLACE\");\n };\n\n _this.handleListen = function () {\n return noop;\n };\n\n _this.handleBlock = function () {\n return noop;\n };\n\n return _this;\n }\n\n var _proto = StaticRouter.prototype;\n\n _proto.navigateTo = function navigateTo(location, action) {\n var _this$props = this.props,\n _this$props$basename = _this$props.basename,\n basename = _this$props$basename === void 0 ? \"\" : _this$props$basename,\n _this$props$context = _this$props.context,\n context = _this$props$context === void 0 ? {} : _this$props$context;\n context.action = action;\n context.location = addBasename(basename, createLocation(location));\n context.url = createURL(context.location);\n };\n\n _proto.render = function render() {\n var _this$props2 = this.props,\n _this$props2$basename = _this$props2.basename,\n basename = _this$props2$basename === void 0 ? \"\" : _this$props2$basename,\n _this$props2$context = _this$props2.context,\n context = _this$props2$context === void 0 ? {} : _this$props2$context,\n _this$props2$location = _this$props2.location,\n location = _this$props2$location === void 0 ? \"/\" : _this$props2$location,\n rest = _objectWithoutPropertiesLoose(_this$props2, [\"basename\", \"context\", \"location\"]);\n\n var history = {\n createHref: function createHref(path) {\n return addLeadingSlash(basename + createURL(path));\n },\n action: \"POP\",\n location: stripBasename(basename, createLocation(location)),\n push: this.handlePush,\n replace: this.handleReplace,\n go: staticHandler(\"go\"),\n goBack: staticHandler(\"goBack\"),\n goForward: staticHandler(\"goForward\"),\n listen: this.handleListen,\n block: this.handleBlock\n };\n return /*#__PURE__*/React.createElement(Router, _extends({}, rest, {\n history: history,\n staticContext: context\n }));\n };\n\n return StaticRouter;\n}(React.Component);\n\nif (process.env.NODE_ENV !== \"production\") {\n StaticRouter.propTypes = {\n basename: PropTypes.string,\n context: PropTypes.object,\n location: PropTypes.oneOfType([PropTypes.string, PropTypes.object])\n };\n\n StaticRouter.prototype.componentDidMount = function () {\n process.env.NODE_ENV !== \"production\" ? warning(!this.props.history, \" ignores the history prop. To use a custom history, \" + \"use `import { Router }` instead of `import { StaticRouter as Router }`.\") : void 0;\n };\n}\n\n/**\n * The public API for rendering the first that matches.\n */\n\nvar Switch = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(Switch, _React$Component);\n\n function Switch() {\n return _React$Component.apply(this, arguments) || this;\n }\n\n var _proto = Switch.prototype;\n\n _proto.render = function render() {\n var _this = this;\n\n return /*#__PURE__*/React.createElement(context.Consumer, null, function (context) {\n !context ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"You should not use outside a \") : invariant(false) : void 0;\n var location = _this.props.location || context.location;\n var element, match; // We use React.Children.forEach instead of React.Children.toArray().find()\n // here because toArray adds keys to all child elements and we do not want\n // to trigger an unmount/remount for two s that render the same\n // component at different URLs.\n\n React.Children.forEach(_this.props.children, function (child) {\n if (match == null && /*#__PURE__*/React.isValidElement(child)) {\n element = child;\n var path = child.props.path || child.props.from;\n match = path ? matchPath(location.pathname, _extends({}, child.props, {\n path: path\n })) : context.match;\n }\n });\n return match ? /*#__PURE__*/React.cloneElement(element, {\n location: location,\n computedMatch: match\n }) : null;\n });\n };\n\n return Switch;\n}(React.Component);\n\nif (process.env.NODE_ENV !== \"production\") {\n Switch.propTypes = {\n children: PropTypes.node,\n location: PropTypes.object\n };\n\n Switch.prototype.componentDidUpdate = function (prevProps) {\n process.env.NODE_ENV !== \"production\" ? warning(!(this.props.location && !prevProps.location), ' elements should not change from uncontrolled to controlled (or vice versa). You initially used no \"location\" prop and then provided one on a subsequent render.') : void 0;\n process.env.NODE_ENV !== \"production\" ? warning(!(!this.props.location && prevProps.location), ' elements should not change from controlled to uncontrolled (or vice versa). You provided a \"location\" prop initially but omitted it on a subsequent render.') : void 0;\n };\n}\n\n/**\n * A public higher-order component to access the imperative API\n */\n\nfunction withRouter(Component) {\n var displayName = \"withRouter(\" + (Component.displayName || Component.name) + \")\";\n\n var C = function C(props) {\n var wrappedComponentRef = props.wrappedComponentRef,\n remainingProps = _objectWithoutPropertiesLoose(props, [\"wrappedComponentRef\"]);\n\n return /*#__PURE__*/React.createElement(context.Consumer, null, function (context) {\n !context ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"You should not use <\" + displayName + \" /> outside a \") : invariant(false) : void 0;\n return /*#__PURE__*/React.createElement(Component, _extends({}, remainingProps, context, {\n ref: wrappedComponentRef\n }));\n });\n };\n\n C.displayName = displayName;\n C.WrappedComponent = Component;\n\n if (process.env.NODE_ENV !== \"production\") {\n C.propTypes = {\n wrappedComponentRef: PropTypes.oneOfType([PropTypes.string, PropTypes.func, PropTypes.object])\n };\n }\n\n return hoistStatics(C, Component);\n}\n\nvar useContext = React.useContext;\nfunction useHistory() {\n if (process.env.NODE_ENV !== \"production\") {\n !(typeof useContext === \"function\") ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"You must use React >= 16.8 in order to use useHistory()\") : invariant(false) : void 0;\n }\n\n return useContext(historyContext);\n}\nfunction useLocation() {\n if (process.env.NODE_ENV !== \"production\") {\n !(typeof useContext === \"function\") ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"You must use React >= 16.8 in order to use useLocation()\") : invariant(false) : void 0;\n }\n\n return useContext(context).location;\n}\nfunction useParams() {\n if (process.env.NODE_ENV !== \"production\") {\n !(typeof useContext === \"function\") ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"You must use React >= 16.8 in order to use useParams()\") : invariant(false) : void 0;\n }\n\n var match = useContext(context).match;\n return match ? match.params : {};\n}\nfunction useRouteMatch(path) {\n if (process.env.NODE_ENV !== \"production\") {\n !(typeof useContext === \"function\") ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"You must use React >= 16.8 in order to use useRouteMatch()\") : invariant(false) : void 0;\n }\n\n var location = useLocation();\n var match = useContext(context).match;\n return path ? matchPath(location.pathname, path) : match;\n}\n\nif (process.env.NODE_ENV !== \"production\") {\n if (typeof window !== \"undefined\") {\n var global$1 = window;\n var key = \"__react_router_build__\";\n var buildNames = {\n cjs: \"CommonJS\",\n esm: \"ES modules\",\n umd: \"UMD\"\n };\n\n if (global$1[key] && global$1[key] !== \"esm\") {\n var initialBuildName = buildNames[global$1[key]];\n var secondaryBuildName = buildNames[\"esm\"]; // TODO: Add link to article that explains in detail how to avoid\n // loading 2 different builds.\n\n throw new Error(\"You are loading the \" + secondaryBuildName + \" build of React Router \" + (\"on a page that is already running the \" + initialBuildName + \" \") + \"build, so things won't work right.\");\n }\n\n global$1[key] = \"esm\";\n }\n}\n\nexport { MemoryRouter, Prompt, Redirect, Route, Router, StaticRouter, Switch, historyContext as __HistoryContext, context as __RouterContext, generatePath, matchPath, useHistory, useLocation, useParams, useRouteMatch, withRouter };\n//# sourceMappingURL=react-router.js.map\n","import { Router, __RouterContext, matchPath } from 'react-router';\nexport { MemoryRouter, Prompt, Redirect, Route, Router, StaticRouter, Switch, generatePath, matchPath, useHistory, useLocation, useParams, useRouteMatch, withRouter } from 'react-router';\nimport _inheritsLoose from '@babel/runtime/helpers/esm/inheritsLoose';\nimport React from 'react';\nimport { createBrowserHistory, createHashHistory, createLocation, createPath } from 'history';\nimport PropTypes from 'prop-types';\nimport warning from 'tiny-warning';\nimport _extends from '@babel/runtime/helpers/esm/extends';\nimport _objectWithoutPropertiesLoose from '@babel/runtime/helpers/esm/objectWithoutPropertiesLoose';\nimport invariant from 'tiny-invariant';\n\n/**\n * The public API for a that uses HTML5 history.\n */\n\nvar BrowserRouter = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(BrowserRouter, _React$Component);\n\n function BrowserRouter() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n _this.history = createBrowserHistory(_this.props);\n return _this;\n }\n\n var _proto = BrowserRouter.prototype;\n\n _proto.render = function render() {\n return /*#__PURE__*/React.createElement(Router, {\n history: this.history,\n children: this.props.children\n });\n };\n\n return BrowserRouter;\n}(React.Component);\n\nif (process.env.NODE_ENV !== \"production\") {\n BrowserRouter.propTypes = {\n basename: PropTypes.string,\n children: PropTypes.node,\n forceRefresh: PropTypes.bool,\n getUserConfirmation: PropTypes.func,\n keyLength: PropTypes.number\n };\n\n BrowserRouter.prototype.componentDidMount = function () {\n process.env.NODE_ENV !== \"production\" ? warning(!this.props.history, \" ignores the history prop. To use a custom history, \" + \"use `import { Router }` instead of `import { BrowserRouter as Router }`.\") : void 0;\n };\n}\n\n/**\n * The public API for a that uses window.location.hash.\n */\n\nvar HashRouter = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(HashRouter, _React$Component);\n\n function HashRouter() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n _this.history = createHashHistory(_this.props);\n return _this;\n }\n\n var _proto = HashRouter.prototype;\n\n _proto.render = function render() {\n return /*#__PURE__*/React.createElement(Router, {\n history: this.history,\n children: this.props.children\n });\n };\n\n return HashRouter;\n}(React.Component);\n\nif (process.env.NODE_ENV !== \"production\") {\n HashRouter.propTypes = {\n basename: PropTypes.string,\n children: PropTypes.node,\n getUserConfirmation: PropTypes.func,\n hashType: PropTypes.oneOf([\"hashbang\", \"noslash\", \"slash\"])\n };\n\n HashRouter.prototype.componentDidMount = function () {\n process.env.NODE_ENV !== \"production\" ? warning(!this.props.history, \" ignores the history prop. To use a custom history, \" + \"use `import { Router }` instead of `import { HashRouter as Router }`.\") : void 0;\n };\n}\n\nvar resolveToLocation = function resolveToLocation(to, currentLocation) {\n return typeof to === \"function\" ? to(currentLocation) : to;\n};\nvar normalizeToLocation = function normalizeToLocation(to, currentLocation) {\n return typeof to === \"string\" ? createLocation(to, null, null, currentLocation) : to;\n};\n\nvar forwardRefShim = function forwardRefShim(C) {\n return C;\n};\n\nvar forwardRef = React.forwardRef;\n\nif (typeof forwardRef === \"undefined\") {\n forwardRef = forwardRefShim;\n}\n\nfunction isModifiedEvent(event) {\n return !!(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);\n}\n\nvar LinkAnchor = forwardRef(function (_ref, forwardedRef) {\n var innerRef = _ref.innerRef,\n navigate = _ref.navigate,\n _onClick = _ref.onClick,\n rest = _objectWithoutPropertiesLoose(_ref, [\"innerRef\", \"navigate\", \"onClick\"]);\n\n var target = rest.target;\n\n var props = _extends({}, rest, {\n onClick: function onClick(event) {\n try {\n if (_onClick) _onClick(event);\n } catch (ex) {\n event.preventDefault();\n throw ex;\n }\n\n if (!event.defaultPrevented && // onClick prevented default\n event.button === 0 && ( // ignore everything but left clicks\n !target || target === \"_self\") && // let browser handle \"target=_blank\" etc.\n !isModifiedEvent(event) // ignore clicks with modifier keys\n ) {\n event.preventDefault();\n navigate();\n }\n }\n }); // React 15 compat\n\n\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.ref = innerRef;\n }\n /* eslint-disable-next-line jsx-a11y/anchor-has-content */\n\n\n return /*#__PURE__*/React.createElement(\"a\", props);\n});\n\nif (process.env.NODE_ENV !== \"production\") {\n LinkAnchor.displayName = \"LinkAnchor\";\n}\n/**\n * The public API for rendering a history-aware .\n */\n\n\nvar Link = forwardRef(function (_ref2, forwardedRef) {\n var _ref2$component = _ref2.component,\n component = _ref2$component === void 0 ? LinkAnchor : _ref2$component,\n replace = _ref2.replace,\n to = _ref2.to,\n innerRef = _ref2.innerRef,\n rest = _objectWithoutPropertiesLoose(_ref2, [\"component\", \"replace\", \"to\", \"innerRef\"]);\n\n return /*#__PURE__*/React.createElement(__RouterContext.Consumer, null, function (context) {\n !context ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"You should not use outside a \") : invariant(false) : void 0;\n var history = context.history;\n var location = normalizeToLocation(resolveToLocation(to, context.location), context.location);\n var href = location ? history.createHref(location) : \"\";\n\n var props = _extends({}, rest, {\n href: href,\n navigate: function navigate() {\n var location = resolveToLocation(to, context.location);\n var isDuplicateNavigation = createPath(context.location) === createPath(normalizeToLocation(location));\n var method = replace || isDuplicateNavigation ? history.replace : history.push;\n method(location);\n }\n }); // React 15 compat\n\n\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.innerRef = innerRef;\n }\n\n return /*#__PURE__*/React.createElement(component, props);\n });\n});\n\nif (process.env.NODE_ENV !== \"production\") {\n var toType = PropTypes.oneOfType([PropTypes.string, PropTypes.object, PropTypes.func]);\n var refType = PropTypes.oneOfType([PropTypes.string, PropTypes.func, PropTypes.shape({\n current: PropTypes.any\n })]);\n Link.displayName = \"Link\";\n Link.propTypes = {\n innerRef: refType,\n onClick: PropTypes.func,\n replace: PropTypes.bool,\n target: PropTypes.string,\n to: toType.isRequired\n };\n}\n\nvar forwardRefShim$1 = function forwardRefShim(C) {\n return C;\n};\n\nvar forwardRef$1 = React.forwardRef;\n\nif (typeof forwardRef$1 === \"undefined\") {\n forwardRef$1 = forwardRefShim$1;\n}\n\nfunction joinClassnames() {\n for (var _len = arguments.length, classnames = new Array(_len), _key = 0; _key < _len; _key++) {\n classnames[_key] = arguments[_key];\n }\n\n return classnames.filter(function (i) {\n return i;\n }).join(\" \");\n}\n/**\n * A wrapper that knows if it's \"active\" or not.\n */\n\n\nvar NavLink = forwardRef$1(function (_ref, forwardedRef) {\n var _ref$ariaCurrent = _ref[\"aria-current\"],\n ariaCurrent = _ref$ariaCurrent === void 0 ? \"page\" : _ref$ariaCurrent,\n _ref$activeClassName = _ref.activeClassName,\n activeClassName = _ref$activeClassName === void 0 ? \"active\" : _ref$activeClassName,\n activeStyle = _ref.activeStyle,\n classNameProp = _ref.className,\n exact = _ref.exact,\n isActiveProp = _ref.isActive,\n locationProp = _ref.location,\n sensitive = _ref.sensitive,\n strict = _ref.strict,\n styleProp = _ref.style,\n to = _ref.to,\n innerRef = _ref.innerRef,\n rest = _objectWithoutPropertiesLoose(_ref, [\"aria-current\", \"activeClassName\", \"activeStyle\", \"className\", \"exact\", \"isActive\", \"location\", \"sensitive\", \"strict\", \"style\", \"to\", \"innerRef\"]);\n\n return /*#__PURE__*/React.createElement(__RouterContext.Consumer, null, function (context) {\n !context ? process.env.NODE_ENV !== \"production\" ? invariant(false, \"You should not use outside a \") : invariant(false) : void 0;\n var currentLocation = locationProp || context.location;\n var toLocation = normalizeToLocation(resolveToLocation(to, currentLocation), currentLocation);\n var path = toLocation.pathname; // Regex taken from: https://github.com/pillarjs/path-to-regexp/blob/master/index.js#L202\n\n var escapedPath = path && path.replace(/([.+*?=^!:${}()[\\]|/\\\\])/g, \"\\\\$1\");\n var match = escapedPath ? matchPath(currentLocation.pathname, {\n path: escapedPath,\n exact: exact,\n sensitive: sensitive,\n strict: strict\n }) : null;\n var isActive = !!(isActiveProp ? isActiveProp(match, currentLocation) : match);\n var className = typeof classNameProp === \"function\" ? classNameProp(isActive) : classNameProp;\n var style = typeof styleProp === \"function\" ? styleProp(isActive) : styleProp;\n\n if (isActive) {\n className = joinClassnames(className, activeClassName);\n style = _extends({}, style, activeStyle);\n }\n\n var props = _extends({\n \"aria-current\": isActive && ariaCurrent || null,\n className: className,\n style: style,\n to: toLocation\n }, rest); // React 15 compat\n\n\n if (forwardRefShim$1 !== forwardRef$1) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.innerRef = innerRef;\n }\n\n return /*#__PURE__*/React.createElement(Link, props);\n });\n});\n\nif (process.env.NODE_ENV !== \"production\") {\n NavLink.displayName = \"NavLink\";\n var ariaCurrentType = PropTypes.oneOf([\"page\", \"step\", \"location\", \"date\", \"time\", \"true\", \"false\"]);\n NavLink.propTypes = _extends({}, Link.propTypes, {\n \"aria-current\": ariaCurrentType,\n activeClassName: PropTypes.string,\n activeStyle: PropTypes.object,\n className: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n exact: PropTypes.bool,\n isActive: PropTypes.func,\n location: PropTypes.object,\n sensitive: PropTypes.bool,\n strict: PropTypes.bool,\n style: PropTypes.oneOfType([PropTypes.object, PropTypes.func])\n });\n}\n\nexport { BrowserRouter, HashRouter, Link, NavLink };\n//# sourceMappingURL=react-router-dom.js.map\n","import React from 'react';\r\nimport { AppComponent } from '../../AppComponent';\r\n\r\ninterface Props {\r\n\tk: string;\r\n}\r\n\r\n// Displays a translated text in the DOM.\r\nexport class T extends AppComponent {\r\n\tconstructor(props: Props) {\r\n\t\tsuper(props);\r\n\t}\r\n\trender() {\r\n\t\tlet textService = this.application.services.textService;\r\n\t\treturn (\r\n\t\t\t<>{textService && textService.textOrEmpty(this.props.k)}\r\n\t\t);\r\n\t}\r\n}\r\n\r\n","import React from 'react';\r\nimport './Bottom.scss';\r\nimport { THtml } from '../../widget/display/THtml';\r\nimport { withRouter, RouteComponentProps } from 'react-router-dom';\r\nimport { Row, Col } from 'react-flexbox-grid';\r\nimport { T } from '../../widget/display/T';\r\n\r\ninterface Props extends RouteComponentProps { }\r\n\r\nconst Bottom: React.FunctionComponent = (props) => {\r\n\t// No footer on case or admin pages\r\n\tconst path = props.location.pathname;\r\n\tif (path === \"/case\" || path === \"/admin\") return null;\r\n\r\n\treturn (\r\n\t\t\r\n\t\t\t\r\n\t\t\t\t
\r\n\t\t\t\t\t
\r\n\t\t\t\t\t\t
\r\n\t\t\t\t\t\t\t
\r\n\t\t\t\t\t\t\t\t

\r\n\t\t\t\t\t\t\t
\r\n\t\t\t\t\t\t\t
\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t
\r\n\t\t\t\t\t\t
\r\n\t\t\t\t\t
\r\n\t\t\t\t
\r\n\t\t\t\r\n\t\t
\r\n\t);\r\n};\r\n\r\nexport default withRouter(Bottom);\r\n","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = require('prop-types');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar BrowserDetection = function (_React$Component) {\n _inherits(BrowserDetection, _React$Component);\n\n function BrowserDetection() {\n var _ref;\n\n _classCallCheck(this, BrowserDetection);\n\n for (var _len = arguments.length, params = Array(_len), _key = 0; _key < _len; _key++) {\n params[_key] = arguments[_key];\n }\n\n var _this = _possibleConstructorReturn(this, (_ref = BrowserDetection.__proto__ || Object.getPrototypeOf(BrowserDetection)).call.apply(_ref, [this].concat(params)));\n\n _initialiseProps.call(_this);\n\n var isAndroid = navigator.userAgent.toLowerCase().indexOf('android') !== -1;\n var isGoogleBot = navigator.userAgent.toLowerCase().indexOf('googlebot') !== -1;\n // eslint-disable-next-line\n var isIE = /*@cc_on!@*/false || !!document.documentMode;\n var isEdge = !isIE && !!window.StyleMedia;\n var isFirefox = typeof InstallTrigger !== 'undefined';\n var isOpera = !!window.opr && !!window.opr.addons || !!window.opera || navigator.userAgent.indexOf(' OPR/') >= 0;\n var isChrome = !isGoogleBot && !isEdge && !isOpera && !!window.chrome && (!!window.chrome.webstore || navigator.vendor.toLowerCase().indexOf('google inc.') !== -1);\n var isSafari = !isChrome && navigator.userAgent.toLowerCase().indexOf('safari') !== -1;\n var isBlink = (isChrome || isOpera) && !!window.CSS;\n var browser = void 0;\n\n if (isIE) {\n browser = 'ie';\n } else if (isEdge) {\n browser = 'edge';\n } else if (isFirefox) {\n browser = 'firefox';\n } else if (isOpera) {\n browser = 'opera';\n } else if (isChrome) {\n browser = 'chrome';\n } else if (isSafari) {\n browser = 'safari';\n } else if (isBlink) {\n browser = 'blink';\n } else if (isGoogleBot) {\n browser = 'googlebot';\n } else {\n browser = 'unknown';\n }\n\n _this.state = {\n browser: browser,\n isAndroid: isAndroid\n };\n _this.state.children = _this.renderChildren();\n return _this;\n }\n\n _createClass(BrowserDetection, [{\n key: 'render',\n value: function render() {\n return this.props.once ? this.state.children : this.renderChildren();\n }\n }]);\n\n return BrowserDetection;\n}(_react2.default.Component);\n\nBrowserDetection.defaultProps = {\n once: true\n};\nBrowserDetection.propTypes = {\n children: _propTypes.object.isRequired,\n once: _propTypes.bool\n};\n\nvar _initialiseProps = function _initialiseProps() {\n var _this2 = this;\n\n this.renderChildren = function () {\n var children = _this2.props.children;\n var _state = _this2.state,\n browser = _state.browser,\n isAndroid = _state.isAndroid;\n\n var render = (isAndroid ? children['android-' + browser] || children.android : null) || children[browser] || children.default || function () {\n return null;\n };\n return render(browser);\n };\n};\n\nexports.default = BrowserDetection;","/* eslint-disable react/display-name */\r\nimport React from 'react';\r\nimport BrowserDetection from 'react-browser-detection';\r\nimport './BirdLoader.scss';\r\n\r\nexport enum gifBackground {\r\n\t'white' = 'white',\r\n\t'hintOfRedGray' = 'hintOfRedGray',\r\n\t'waferGray' = 'waferGray',\r\n\t'botticelliBlue' = 'botticelliBlue'\r\n}\r\n\r\ninterface Props {\r\n\tgifBackground?: gifBackground;\r\n}\r\n\r\nexport const BirdLoader: React.FunctionComponent = (props) => {\r\n\tconst browserHandler = {\r\n\t\tie: () => {\r\n\t\t\tswitch (props.gifBackground) {\r\n\t\t\t\tcase 'hintOfRedGray':\r\n\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t);\r\n\t\t\t\tcase 'waferGray':\r\n\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t);\r\n\t\t\t\tcase 'botticelliBlue':\r\n\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t);\r\n\t\t\t\tdefault:\r\n\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t);\r\n\t\t\t}\r\n\t\t},\r\n\t\tdefault: () =>
,\r\n\t};\r\n\r\n\treturn (\r\n\t\t
\r\n\t\t\t{browserHandler}\r\n\t\t
\r\n\t);\r\n};\r\n\r\nBirdLoader.defaultProps = {\r\n\tgifBackground: gifBackground.white,\r\n};\r\n","import React from 'react';\r\nimport { BaseComponent } from '../BaseComponent';\r\nimport {\r\n\tBirdLoader,\r\n\tgifBackground,\r\n} from '../widget/display/BirdLoader/BirdLoader';\r\nimport './LoadingPage.scss';\r\n\r\ninterface Props {}\r\n\r\nexport class LoadingPage extends BaseComponent {\r\n\tinterval;\r\n\r\n\tconstructor(props: Props) {\r\n\t\tsuper(props);\r\n\r\n\t\tthis.state = { showLoadingAnimation: false };\r\n\t}\r\n\r\n\tcomponentDidMount() {\r\n\t\tthis.interval = setTimeout(() => {\r\n\t\t\tthis.setState({\r\n\t\t\t\tshowLoadingAnimation: true,\r\n\t\t\t});\r\n\t\t}, 500);\r\n\t}\r\n\r\n\tcomponentWillUnmount() {\r\n\t\tclearTimeout(this.interval);\r\n\t}\r\n\r\n\trender() {\r\n\t\treturn (\r\n\t\t\t
\r\n\t\t\t\t{this.state.showLoadingAnimation ? (\r\n\t\t\t\t\t\r\n\t\t\t\t) : null}\r\n\t\t\t
\r\n\t\t);\r\n\t}\r\n}\r\n","/*!\n\tCopyright (c) 2018 Jed Watson.\n\tLicensed under the MIT License (MIT), see\n\thttp://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames () {\n\t\tvar classes = '';\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (arg) {\n\t\t\t\tclasses = appendClass(classes, parseValue(arg));\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction parseValue (arg) {\n\t\tif (typeof arg === 'string' || typeof arg === 'number') {\n\t\t\treturn arg;\n\t\t}\n\n\t\tif (typeof arg !== 'object') {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (Array.isArray(arg)) {\n\t\t\treturn classNames.apply(null, arg);\n\t\t}\n\n\t\tif (arg.toString !== Object.prototype.toString && !arg.toString.toString().includes('[native code]')) {\n\t\t\treturn arg.toString();\n\t\t}\n\n\t\tvar classes = '';\n\n\t\tfor (var key in arg) {\n\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\tclasses = appendClass(classes, key);\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction appendClass (value, newClass) {\n\t\tif (!newClass) {\n\t\t\treturn value;\n\t\t}\n\t\n\t\tif (value) {\n\t\t\treturn value + ' ' + newClass;\n\t\t}\n\t\n\t\treturn value + newClass;\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n","/* eslint-disable react/prop-types */\r\nimport React from 'react';\r\nimport ClassNames from 'classnames';\r\nimport { Application } from '../../../../models/AppModels';\r\nimport './Button.scss';\r\n\r\ninterface Props {\r\n\tlabelTextkey?: string;\r\n\tlabel?:string;\r\n\tclassName?: string;\r\n\tid?: string;\r\n\tname?: string;\r\n\tonClick?: React.MouseEventHandler; //(React.MouseEvent) => void;\r\n\ttype?: 'submit' | 'reset' | 'button';\r\n\tvalue?: string | number;\r\n\tstyle?: 'normal' | 'round' | 'link' | 'icon';\r\n\tenabled?: boolean;\r\n\ttitle?: string | undefined;\r\n\tautofocus?: boolean;\r\n}\r\n\r\nexport const Button: React.FunctionComponent = (props) => {\r\n\tconst className = ClassNames(\r\n\t\tprops.className, {\r\n\t\tround: props.style === 'round',\r\n\t\tlink: props.style === 'link',\r\n\t\ticon: props.style === 'icon'\r\n\t});\r\n\r\n\tlet label = (props.labelTextkey?Application.instance.services.textService.textOrEmpty(props.labelTextkey):'');\r\n\tif( props.label ) {\r\n\t\tif( label.length===0)\r\n\t\t\tlabel = props.label;\r\n\t\telse\r\n\t\t\tlabel += ' ' + props.label;\r\n\t}\r\n\r\n\treturn (\r\n\t\t\r\n\t\t\t{props.style === 'round' ? null : (\r\n\t\t\t\t{label}\r\n\t\t\t)}\r\n\t\t\r\n\t);\r\n};\r\n\r\n\r\n\r\n// Default props\r\nButton.defaultProps = {\r\n\tenabled: true,\r\n\tclassName: 'Button',\r\n\ttype: 'button',\r\n\tstyle: 'normal',\r\n\tautofocus: false,\r\n};\r\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport _objectWithoutPropertiesLoose from '@babel/runtime/helpers/esm/objectWithoutPropertiesLoose';\nimport React, { useState, useCallback, forwardRef, useRef, useEffect, useImperativeHandle, useMemo } from 'react';\n\nconst is = {\n arr: Array.isArray,\n obj: a => Object.prototype.toString.call(a) === '[object Object]',\n fun: a => typeof a === 'function',\n str: a => typeof a === 'string',\n num: a => typeof a === 'number',\n und: a => a === void 0,\n nul: a => a === null,\n set: a => a instanceof Set,\n map: a => a instanceof Map,\n\n equ(a, b) {\n if (typeof a !== typeof b) return false;\n if (is.str(a) || is.num(a)) return a === b;\n if (is.obj(a) && is.obj(b) && Object.keys(a).length + Object.keys(b).length === 0) return true;\n let i;\n\n for (i in a) if (!(i in b)) return false;\n\n for (i in b) if (a[i] !== b[i]) return false;\n\n return is.und(i) ? a === b : true;\n }\n\n};\nfunction merge(target, lowercase) {\n if (lowercase === void 0) {\n lowercase = true;\n }\n\n return object => (is.arr(object) ? object : Object.keys(object)).reduce((acc, element) => {\n const key = lowercase ? element[0].toLowerCase() + element.substring(1) : element;\n acc[key] = target(key);\n return acc;\n }, target);\n}\nfunction useForceUpdate() {\n const _useState = useState(false),\n f = _useState[1];\n\n const forceUpdate = useCallback(() => f(v => !v), []);\n return forceUpdate;\n}\nfunction withDefault(value, defaultValue) {\n return is.und(value) || is.nul(value) ? defaultValue : value;\n}\nfunction toArray(a) {\n return !is.und(a) ? is.arr(a) ? a : [a] : [];\n}\nfunction callProp(obj) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n return is.fun(obj) ? obj(...args) : obj;\n}\n\nfunction getForwardProps(props) {\n const to = props.to,\n from = props.from,\n config = props.config,\n onStart = props.onStart,\n onRest = props.onRest,\n onFrame = props.onFrame,\n children = props.children,\n reset = props.reset,\n reverse = props.reverse,\n force = props.force,\n immediate = props.immediate,\n delay = props.delay,\n attach = props.attach,\n destroyed = props.destroyed,\n interpolateTo = props.interpolateTo,\n ref = props.ref,\n lazy = props.lazy,\n forward = _objectWithoutPropertiesLoose(props, [\"to\", \"from\", \"config\", \"onStart\", \"onRest\", \"onFrame\", \"children\", \"reset\", \"reverse\", \"force\", \"immediate\", \"delay\", \"attach\", \"destroyed\", \"interpolateTo\", \"ref\", \"lazy\"]);\n\n return forward;\n}\n\nfunction interpolateTo(props) {\n const forward = getForwardProps(props);\n if (is.und(forward)) return _extends({\n to: forward\n }, props);\n const rest = Object.keys(props).reduce((a, k) => !is.und(forward[k]) ? a : _extends({}, a, {\n [k]: props[k]\n }), {});\n return _extends({\n to: forward\n }, rest);\n}\nfunction handleRef(ref, forward) {\n if (forward) {\n // If it's a function, assume it's a ref callback\n if (is.fun(forward)) forward(ref);else if (is.obj(forward)) {\n forward.current = ref;\n }\n }\n\n return ref;\n}\n\nclass Animated {\n constructor() {\n this.payload = void 0;\n this.children = [];\n }\n\n getAnimatedValue() {\n return this.getValue();\n }\n\n getPayload() {\n return this.payload || this;\n }\n\n attach() {}\n\n detach() {}\n\n getChildren() {\n return this.children;\n }\n\n addChild(child) {\n if (this.children.length === 0) this.attach();\n this.children.push(child);\n }\n\n removeChild(child) {\n const index = this.children.indexOf(child);\n this.children.splice(index, 1);\n if (this.children.length === 0) this.detach();\n }\n\n}\nclass AnimatedArray extends Animated {\n constructor() {\n super(...arguments);\n this.payload = [];\n\n this.attach = () => this.payload.forEach(p => p instanceof Animated && p.addChild(this));\n\n this.detach = () => this.payload.forEach(p => p instanceof Animated && p.removeChild(this));\n }\n\n}\nclass AnimatedObject extends Animated {\n constructor() {\n super(...arguments);\n this.payload = {};\n\n this.attach = () => Object.values(this.payload).forEach(s => s instanceof Animated && s.addChild(this));\n\n this.detach = () => Object.values(this.payload).forEach(s => s instanceof Animated && s.removeChild(this));\n }\n\n getValue(animated) {\n if (animated === void 0) {\n animated = false;\n }\n\n const payload = {};\n\n for (const key in this.payload) {\n const value = this.payload[key];\n if (animated && !(value instanceof Animated)) continue;\n payload[key] = value instanceof Animated ? value[animated ? 'getAnimatedValue' : 'getValue']() : value;\n }\n\n return payload;\n }\n\n getAnimatedValue() {\n return this.getValue(true);\n }\n\n}\n\nlet applyAnimatedValues;\nfunction injectApplyAnimatedValues(fn, transform) {\n applyAnimatedValues = {\n fn,\n transform\n };\n}\nlet colorNames;\nfunction injectColorNames(names) {\n colorNames = names;\n}\nlet requestFrame = cb => typeof window !== 'undefined' ? window.requestAnimationFrame(cb) : -1;\nlet cancelFrame = id => {\n typeof window !== 'undefined' && window.cancelAnimationFrame(id);\n};\nfunction injectFrame(raf, caf) {\n requestFrame = raf;\n cancelFrame = caf;\n}\nlet interpolation;\nfunction injectStringInterpolator(fn) {\n interpolation = fn;\n}\nlet now = () => Date.now();\nfunction injectNow(nowFn) {\n now = nowFn;\n}\nlet defaultElement;\nfunction injectDefaultElement(el) {\n defaultElement = el;\n}\nlet animatedApi = node => node.current;\nfunction injectAnimatedApi(fn) {\n animatedApi = fn;\n}\nlet createAnimatedStyle;\nfunction injectCreateAnimatedStyle(factory) {\n createAnimatedStyle = factory;\n}\nlet manualFrameloop;\nfunction injectManualFrameloop(callback) {\n manualFrameloop = callback;\n}\n\nvar Globals = /*#__PURE__*/Object.freeze({\n get applyAnimatedValues () { return applyAnimatedValues; },\n injectApplyAnimatedValues: injectApplyAnimatedValues,\n get colorNames () { return colorNames; },\n injectColorNames: injectColorNames,\n get requestFrame () { return requestFrame; },\n get cancelFrame () { return cancelFrame; },\n injectFrame: injectFrame,\n get interpolation () { return interpolation; },\n injectStringInterpolator: injectStringInterpolator,\n get now () { return now; },\n injectNow: injectNow,\n get defaultElement () { return defaultElement; },\n injectDefaultElement: injectDefaultElement,\n get animatedApi () { return animatedApi; },\n injectAnimatedApi: injectAnimatedApi,\n get createAnimatedStyle () { return createAnimatedStyle; },\n injectCreateAnimatedStyle: injectCreateAnimatedStyle,\n get manualFrameloop () { return manualFrameloop; },\n injectManualFrameloop: injectManualFrameloop\n});\n\n/**\n * Wraps the `style` property with `AnimatedStyle`.\n */\n\nclass AnimatedProps extends AnimatedObject {\n constructor(props, callback) {\n super();\n this.update = void 0;\n this.payload = !props.style ? props : _extends({}, props, {\n style: createAnimatedStyle(props.style)\n });\n this.update = callback;\n this.attach();\n }\n\n}\n\nconst isFunctionComponent = val => is.fun(val) && !(val.prototype instanceof React.Component);\n\nconst createAnimatedComponent = Component => {\n const AnimatedComponent = forwardRef((props, ref) => {\n const forceUpdate = useForceUpdate();\n const mounted = useRef(true);\n const propsAnimated = useRef(null);\n const node = useRef(null);\n const attachProps = useCallback(props => {\n const oldPropsAnimated = propsAnimated.current;\n\n const callback = () => {\n let didUpdate = false;\n\n if (node.current) {\n didUpdate = applyAnimatedValues.fn(node.current, propsAnimated.current.getAnimatedValue());\n }\n\n if (!node.current || didUpdate === false) {\n // If no referenced node has been found, or the update target didn't have a\n // native-responder, then forceUpdate the animation ...\n forceUpdate();\n }\n };\n\n propsAnimated.current = new AnimatedProps(props, callback);\n oldPropsAnimated && oldPropsAnimated.detach();\n }, []);\n useEffect(() => () => {\n mounted.current = false;\n propsAnimated.current && propsAnimated.current.detach();\n }, []);\n useImperativeHandle(ref, () => animatedApi(node, mounted, forceUpdate));\n attachProps(props);\n\n const _getValue = propsAnimated.current.getValue(),\n scrollTop = _getValue.scrollTop,\n scrollLeft = _getValue.scrollLeft,\n animatedProps = _objectWithoutPropertiesLoose(_getValue, [\"scrollTop\", \"scrollLeft\"]); // Functions cannot have refs, see:\n // See: https://github.com/react-spring/react-spring/issues/569\n\n\n const refFn = isFunctionComponent(Component) ? undefined : childRef => node.current = handleRef(childRef, ref);\n return React.createElement(Component, _extends({}, animatedProps, {\n ref: refFn\n }));\n });\n return AnimatedComponent;\n};\n\nlet active = false;\nconst controllers = new Set();\n\nconst update = () => {\n if (!active) return false;\n let time = now();\n\n for (let controller of controllers) {\n let isActive = false;\n\n for (let configIdx = 0; configIdx < controller.configs.length; configIdx++) {\n let config = controller.configs[configIdx];\n let endOfAnimation, lastTime;\n\n for (let valIdx = 0; valIdx < config.animatedValues.length; valIdx++) {\n let animation = config.animatedValues[valIdx]; // If an animation is done, skip, until all of them conclude\n\n if (animation.done) continue;\n let from = config.fromValues[valIdx];\n let to = config.toValues[valIdx];\n let position = animation.lastPosition;\n let isAnimated = to instanceof Animated;\n let velocity = Array.isArray(config.initialVelocity) ? config.initialVelocity[valIdx] : config.initialVelocity;\n if (isAnimated) to = to.getValue(); // Conclude animation if it's either immediate, or from-values match end-state\n\n if (config.immediate) {\n animation.setValue(to);\n animation.done = true;\n continue;\n } // Break animation when string values are involved\n\n\n if (typeof from === 'string' || typeof to === 'string') {\n animation.setValue(to);\n animation.done = true;\n continue;\n }\n\n if (config.duration !== void 0) {\n /** Duration easing */\n position = from + config.easing((time - animation.startTime) / config.duration) * (to - from);\n endOfAnimation = time >= animation.startTime + config.duration;\n } else if (config.decay) {\n /** Decay easing */\n position = from + velocity / (1 - 0.998) * (1 - Math.exp(-(1 - 0.998) * (time - animation.startTime)));\n endOfAnimation = Math.abs(animation.lastPosition - position) < 0.1;\n if (endOfAnimation) to = position;\n } else {\n /** Spring easing */\n lastTime = animation.lastTime !== void 0 ? animation.lastTime : time;\n velocity = animation.lastVelocity !== void 0 ? animation.lastVelocity : config.initialVelocity; // If we lost a lot of frames just jump to the end.\n\n if (time > lastTime + 64) lastTime = time; // http://gafferongames.com/game-physics/fix-your-timestep/\n\n let numSteps = Math.floor(time - lastTime);\n\n for (let i = 0; i < numSteps; ++i) {\n let force = -config.tension * (position - to);\n let damping = -config.friction * velocity;\n let acceleration = (force + damping) / config.mass;\n velocity = velocity + acceleration * 1 / 1000;\n position = position + velocity * 1 / 1000;\n } // Conditions for stopping the spring animation\n\n\n let isOvershooting = config.clamp && config.tension !== 0 ? from < to ? position > to : position < to : false;\n let isVelocity = Math.abs(velocity) <= config.precision;\n let isDisplacement = config.tension !== 0 ? Math.abs(to - position) <= config.precision : true;\n endOfAnimation = isOvershooting || isVelocity && isDisplacement;\n animation.lastVelocity = velocity;\n animation.lastTime = time;\n } // Trails aren't done until their parents conclude\n\n\n if (isAnimated && !config.toValues[valIdx].done) endOfAnimation = false;\n\n if (endOfAnimation) {\n // Ensure that we end up with a round value\n if (animation.value !== to) position = to;\n animation.done = true;\n } else isActive = true;\n\n animation.setValue(position);\n animation.lastPosition = position;\n } // Keep track of updated values only when necessary\n\n\n if (controller.props.onFrame) controller.values[config.name] = config.interpolation.getValue();\n } // Update callbacks in the end of the frame\n\n\n if (controller.props.onFrame) controller.props.onFrame(controller.values); // Either call onEnd or next frame\n\n if (!isActive) {\n controllers.delete(controller);\n controller.stop(true);\n }\n } // Loop over as long as there are controllers ...\n\n\n if (controllers.size) {\n if (manualFrameloop) manualFrameloop();else requestFrame(update);\n } else {\n active = false;\n }\n\n return active;\n};\n\nconst start = controller => {\n if (!controllers.has(controller)) controllers.add(controller);\n\n if (!active) {\n active = true;\n if (manualFrameloop) requestFrame(manualFrameloop);else requestFrame(update);\n }\n};\n\nconst stop = controller => {\n if (controllers.has(controller)) controllers.delete(controller);\n};\n\nfunction createInterpolator(range, output, extrapolate) {\n if (typeof range === 'function') {\n return range;\n }\n\n if (Array.isArray(range)) {\n return createInterpolator({\n range,\n output: output,\n extrapolate\n });\n }\n\n if (interpolation && typeof range.output[0] === 'string') {\n return interpolation(range);\n }\n\n const config = range;\n const outputRange = config.output;\n const inputRange = config.range || [0, 1];\n const extrapolateLeft = config.extrapolateLeft || config.extrapolate || 'extend';\n const extrapolateRight = config.extrapolateRight || config.extrapolate || 'extend';\n\n const easing = config.easing || (t => t);\n\n return input => {\n const range = findRange(input, inputRange);\n return interpolate(input, inputRange[range], inputRange[range + 1], outputRange[range], outputRange[range + 1], easing, extrapolateLeft, extrapolateRight, config.map);\n };\n}\n\nfunction interpolate(input, inputMin, inputMax, outputMin, outputMax, easing, extrapolateLeft, extrapolateRight, map) {\n let result = map ? map(input) : input; // Extrapolate\n\n if (result < inputMin) {\n if (extrapolateLeft === 'identity') return result;else if (extrapolateLeft === 'clamp') result = inputMin;\n }\n\n if (result > inputMax) {\n if (extrapolateRight === 'identity') return result;else if (extrapolateRight === 'clamp') result = inputMax;\n }\n\n if (outputMin === outputMax) return outputMin;\n if (inputMin === inputMax) return input <= inputMin ? outputMin : outputMax; // Input Range\n\n if (inputMin === -Infinity) result = -result;else if (inputMax === Infinity) result = result - inputMin;else result = (result - inputMin) / (inputMax - inputMin); // Easing\n\n result = easing(result); // Output Range\n\n if (outputMin === -Infinity) result = -result;else if (outputMax === Infinity) result = result + outputMin;else result = result * (outputMax - outputMin) + outputMin;\n return result;\n}\n\nfunction findRange(input, inputRange) {\n for (var i = 1; i < inputRange.length - 1; ++i) if (inputRange[i] >= input) break;\n\n return i - 1;\n}\n\nclass AnimatedInterpolation extends AnimatedArray {\n constructor(parents, range, output, extrapolate) {\n super();\n this.calc = void 0;\n this.payload = parents instanceof AnimatedArray && !(parents instanceof AnimatedInterpolation) ? parents.getPayload() : Array.isArray(parents) ? parents : [parents];\n this.calc = createInterpolator(range, output, extrapolate);\n }\n\n getValue() {\n return this.calc(...this.payload.map(value => value.getValue()));\n }\n\n updateConfig(range, output, extrapolate) {\n this.calc = createInterpolator(range, output, extrapolate);\n }\n\n interpolate(range, output, extrapolate) {\n return new AnimatedInterpolation(this, range, output, extrapolate);\n }\n\n}\n\nconst interpolate$1 = (parents, range, output) => parents && new AnimatedInterpolation(parents, range, output);\n\nconst config = {\n default: {\n tension: 170,\n friction: 26\n },\n gentle: {\n tension: 120,\n friction: 14\n },\n wobbly: {\n tension: 180,\n friction: 12\n },\n stiff: {\n tension: 210,\n friction: 20\n },\n slow: {\n tension: 280,\n friction: 60\n },\n molasses: {\n tension: 280,\n friction: 120\n }\n};\n\n/** API\n * useChain(references, timeSteps, timeFrame)\n */\n\nfunction useChain(refs, timeSteps, timeFrame) {\n if (timeFrame === void 0) {\n timeFrame = 1000;\n }\n\n const previous = useRef();\n useEffect(() => {\n if (is.equ(refs, previous.current)) refs.forEach((_ref) => {\n let current = _ref.current;\n return current && current.start();\n });else if (timeSteps) {\n refs.forEach((_ref2, index) => {\n let current = _ref2.current;\n\n if (current) {\n const ctrls = current.controllers;\n\n if (ctrls.length) {\n const t = timeFrame * timeSteps[index];\n ctrls.forEach(ctrl => {\n ctrl.queue = ctrl.queue.map(e => _extends({}, e, {\n delay: e.delay + t\n }));\n ctrl.start();\n });\n }\n }\n });\n } else refs.reduce((q, _ref3, rI) => {\n let current = _ref3.current;\n return q = q.then(() => current.start());\n }, Promise.resolve());\n previous.current = refs;\n });\n}\n\n/**\n * Animated works by building a directed acyclic graph of dependencies\n * transparently when you render your Animated components.\n *\n * new Animated.Value(0)\n * .interpolate() .interpolate() new Animated.Value(1)\n * opacity translateY scale\n * style transform\n * View#234 style\n * View#123\n *\n * A) Top Down phase\n * When an AnimatedValue is updated, we recursively go down through this\n * graph in order to find leaf nodes: the views that we flag as needing\n * an update.\n *\n * B) Bottom Up phase\n * When a view is flagged as needing an update, we recursively go back up\n * in order to build the new value that it needs. The reason why we need\n * this two-phases process is to deal with composite props such as\n * transform which can receive values from multiple parents.\n */\nfunction addAnimatedStyles(node, styles) {\n if ('update' in node) {\n styles.add(node);\n } else {\n node.getChildren().forEach(child => addAnimatedStyles(child, styles));\n }\n}\n\nclass AnimatedValue extends Animated {\n constructor(_value) {\n var _this;\n\n super();\n _this = this;\n this.animatedStyles = new Set();\n this.value = void 0;\n this.startPosition = void 0;\n this.lastPosition = void 0;\n this.lastVelocity = void 0;\n this.startTime = void 0;\n this.lastTime = void 0;\n this.done = false;\n\n this.setValue = function (value, flush) {\n if (flush === void 0) {\n flush = true;\n }\n\n _this.value = value;\n if (flush) _this.flush();\n };\n\n this.value = _value;\n this.startPosition = _value;\n this.lastPosition = _value;\n }\n\n flush() {\n if (this.animatedStyles.size === 0) {\n addAnimatedStyles(this, this.animatedStyles);\n }\n\n this.animatedStyles.forEach(animatedStyle => animatedStyle.update());\n }\n\n clearStyles() {\n this.animatedStyles.clear();\n }\n\n getValue() {\n return this.value;\n }\n\n interpolate(range, output, extrapolate) {\n return new AnimatedInterpolation(this, range, output, extrapolate);\n }\n\n}\n\nclass AnimatedValueArray extends AnimatedArray {\n constructor(values) {\n super();\n this.payload = values.map(n => new AnimatedValue(n));\n }\n\n setValue(value, flush) {\n if (flush === void 0) {\n flush = true;\n }\n\n if (Array.isArray(value)) {\n if (value.length === this.payload.length) {\n value.forEach((v, i) => this.payload[i].setValue(v, flush));\n }\n } else {\n this.payload.forEach(p => p.setValue(value, flush));\n }\n }\n\n getValue() {\n return this.payload.map(v => v.getValue());\n }\n\n interpolate(range, output) {\n return new AnimatedInterpolation(this, range, output);\n }\n\n}\n\nlet G = 0;\n\nclass Controller {\n constructor() {\n this.id = void 0;\n this.idle = true;\n this.hasChanged = false;\n this.guid = 0;\n this.local = 0;\n this.props = {};\n this.merged = {};\n this.animations = {};\n this.interpolations = {};\n this.values = {};\n this.configs = [];\n this.listeners = [];\n this.queue = [];\n this.localQueue = void 0;\n\n this.getValues = () => this.interpolations;\n\n this.id = G++;\n }\n /** update(props)\n * This function filters input props and creates an array of tasks which are executed in .start()\n * Each task is allowed to carry a delay, which means it can execute asnychroneously */\n\n\n update(args) {\n //this._id = n + this.id\n if (!args) return this; // Extract delay and the to-prop from props\n\n const _ref = interpolateTo(args),\n _ref$delay = _ref.delay,\n delay = _ref$delay === void 0 ? 0 : _ref$delay,\n to = _ref.to,\n props = _objectWithoutPropertiesLoose(_ref, [\"delay\", \"to\"]);\n\n if (is.arr(to) || is.fun(to)) {\n // If config is either a function or an array queue it up as is\n this.queue.push(_extends({}, props, {\n delay,\n to\n }));\n } else if (to) {\n // Otherwise go through each key since it could be delayed individually\n let ops = {};\n Object.entries(to).forEach((_ref2) => {\n let k = _ref2[0],\n v = _ref2[1];\n\n // Fetch delay and create an entry, consisting of the to-props, the delay, and basic props\n const entry = _extends({\n to: {\n [k]: v\n },\n delay: callProp(delay, k)\n }, props);\n\n const previous = ops[entry.delay] && ops[entry.delay].to;\n ops[entry.delay] = _extends({}, ops[entry.delay], entry, {\n to: _extends({}, previous, entry.to)\n });\n });\n this.queue = Object.values(ops);\n } // Sort queue, so that async calls go last\n\n\n this.queue = this.queue.sort((a, b) => a.delay - b.delay); // Diff the reduced props immediately (they'll contain the from-prop and some config)\n\n this.diff(props);\n return this;\n }\n /** start(onEnd)\n * This function either executes a queue, if present, or starts the frameloop, which animates */\n\n\n start(onEnd) {\n // If a queue is present we must excecute it\n if (this.queue.length) {\n this.idle = false; // Updates can interrupt trailing queues, in that case we just merge values\n\n if (this.localQueue) {\n this.localQueue.forEach((_ref3) => {\n let _ref3$from = _ref3.from,\n from = _ref3$from === void 0 ? {} : _ref3$from,\n _ref3$to = _ref3.to,\n to = _ref3$to === void 0 ? {} : _ref3$to;\n if (is.obj(from)) this.merged = _extends({}, from, this.merged);\n if (is.obj(to)) this.merged = _extends({}, this.merged, to);\n });\n } // The guid helps us tracking frames, a new queue over an old one means an override\n // We discard async calls in that caseÍ\n\n\n const local = this.local = ++this.guid;\n const queue = this.localQueue = this.queue;\n this.queue = []; // Go through each entry and execute it\n\n queue.forEach((_ref4, index) => {\n let delay = _ref4.delay,\n props = _objectWithoutPropertiesLoose(_ref4, [\"delay\"]);\n\n const cb = finished => {\n if (index === queue.length - 1 && local === this.guid && finished) {\n this.idle = true;\n if (this.props.onRest) this.props.onRest(this.merged);\n }\n\n if (onEnd) onEnd();\n }; // Entries can be delayed, ansyc or immediate\n\n\n let async = is.arr(props.to) || is.fun(props.to);\n\n if (delay) {\n setTimeout(() => {\n if (local === this.guid) {\n if (async) this.runAsync(props, cb);else this.diff(props).start(cb);\n }\n }, delay);\n } else if (async) this.runAsync(props, cb);else this.diff(props).start(cb);\n });\n } // Otherwise we kick of the frameloop\n else {\n if (is.fun(onEnd)) this.listeners.push(onEnd);\n if (this.props.onStart) this.props.onStart();\n start(this);\n }\n\n return this;\n }\n\n stop(finished) {\n this.listeners.forEach(onEnd => onEnd(finished));\n this.listeners = [];\n return this;\n }\n /** Pause sets onEnd listeners free, but also removes the controller from the frameloop */\n\n\n pause(finished) {\n this.stop(true);\n if (finished) stop(this);\n return this;\n }\n\n runAsync(_ref5, onEnd) {\n var _this = this;\n\n let delay = _ref5.delay,\n props = _objectWithoutPropertiesLoose(_ref5, [\"delay\"]);\n\n const local = this.local; // If \"to\" is either a function or an array it will be processed async, therefor \"to\" should be empty right now\n // If the view relies on certain values \"from\" has to be present\n\n let queue = Promise.resolve(undefined);\n\n if (is.arr(props.to)) {\n for (let i = 0; i < props.to.length; i++) {\n const index = i;\n\n const fresh = _extends({}, props, interpolateTo(props.to[index]));\n\n if (is.arr(fresh.config)) fresh.config = fresh.config[index];\n queue = queue.then(() => {\n //this.stop()\n if (local === this.guid) return new Promise(r => this.diff(fresh).start(r));\n });\n }\n } else if (is.fun(props.to)) {\n let index = 0;\n let last;\n queue = queue.then(() => props.to( // next(props)\n p => {\n const fresh = _extends({}, props, interpolateTo(p));\n\n if (is.arr(fresh.config)) fresh.config = fresh.config[index];\n index++; //this.stop()\n\n if (local === this.guid) return last = new Promise(r => this.diff(fresh).start(r));\n return;\n }, // cancel()\n function (finished) {\n if (finished === void 0) {\n finished = true;\n }\n\n return _this.stop(finished);\n }).then(() => last));\n }\n\n queue.then(onEnd);\n }\n\n diff(props) {\n this.props = _extends({}, this.props, props);\n let _this$props = this.props,\n _this$props$from = _this$props.from,\n from = _this$props$from === void 0 ? {} : _this$props$from,\n _this$props$to = _this$props.to,\n to = _this$props$to === void 0 ? {} : _this$props$to,\n _this$props$config = _this$props.config,\n config = _this$props$config === void 0 ? {} : _this$props$config,\n reverse = _this$props.reverse,\n attach = _this$props.attach,\n reset = _this$props.reset,\n immediate = _this$props.immediate; // Reverse values when requested\n\n if (reverse) {\n var _ref6 = [to, from];\n from = _ref6[0];\n to = _ref6[1];\n } // This will collect all props that were ever set, reset merged props when necessary\n\n\n this.merged = _extends({}, from, this.merged, to);\n this.hasChanged = false; // Attachment handling, trailed springs can \"attach\" themselves to a previous spring\n\n let target = attach && attach(this); // Reduces input { name: value } pairs into animated values\n\n this.animations = Object.entries(this.merged).reduce((acc, _ref7) => {\n let name = _ref7[0],\n value = _ref7[1];\n // Issue cached entries, except on reset\n let entry = acc[name] || {}; // Figure out what the value is supposed to be\n\n const isNumber = is.num(value);\n const isString = is.str(value) && !value.startsWith('#') && !/\\d/.test(value) && !colorNames[value];\n const isArray = is.arr(value);\n const isInterpolation = !isNumber && !isArray && !isString;\n let fromValue = !is.und(from[name]) ? from[name] : value;\n let toValue = isNumber || isArray ? value : isString ? value : 1;\n let toConfig = callProp(config, name);\n if (target) toValue = target.animations[name].parent;\n let parent = entry.parent,\n interpolation$$1 = entry.interpolation,\n toValues = toArray(target ? toValue.getPayload() : toValue),\n animatedValues;\n let newValue = value;\n if (isInterpolation) newValue = interpolation({\n range: [0, 1],\n output: [value, value]\n })(1);\n let currentValue = interpolation$$1 && interpolation$$1.getValue(); // Change detection flags\n\n const isFirst = is.und(parent);\n const isActive = !isFirst && entry.animatedValues.some(v => !v.done);\n const currentValueDiffersFromGoal = !is.equ(newValue, currentValue);\n const hasNewGoal = !is.equ(newValue, entry.previous);\n const hasNewConfig = !is.equ(toConfig, entry.config); // Change animation props when props indicate a new goal (new value differs from previous one)\n // and current values differ from it. Config changes trigger a new update as well (though probably shouldn't?)\n\n if (reset || hasNewGoal && currentValueDiffersFromGoal || hasNewConfig) {\n // Convert regular values into animated values, ALWAYS re-use if possible\n if (isNumber || isString) parent = interpolation$$1 = entry.parent || new AnimatedValue(fromValue);else if (isArray) parent = interpolation$$1 = entry.parent || new AnimatedValueArray(fromValue);else if (isInterpolation) {\n let prev = entry.interpolation && entry.interpolation.calc(entry.parent.value);\n prev = prev !== void 0 && !reset ? prev : fromValue;\n\n if (entry.parent) {\n parent = entry.parent;\n parent.setValue(0, false);\n } else parent = new AnimatedValue(0);\n\n const range = {\n output: [prev, value]\n };\n\n if (entry.interpolation) {\n interpolation$$1 = entry.interpolation;\n entry.interpolation.updateConfig(range);\n } else interpolation$$1 = parent.interpolate(range);\n }\n toValues = toArray(target ? toValue.getPayload() : toValue);\n animatedValues = toArray(parent.getPayload());\n if (reset && !isInterpolation) parent.setValue(fromValue, false);\n this.hasChanged = true; // Reset animated values\n\n animatedValues.forEach(value => {\n value.startPosition = value.value;\n value.lastPosition = value.value;\n value.lastVelocity = isActive ? value.lastVelocity : undefined;\n value.lastTime = isActive ? value.lastTime : undefined;\n value.startTime = now();\n value.done = false;\n value.animatedStyles.clear();\n }); // Set immediate values\n\n if (callProp(immediate, name)) {\n parent.setValue(isInterpolation ? toValue : value, false);\n }\n\n return _extends({}, acc, {\n [name]: _extends({}, entry, {\n name,\n parent,\n interpolation: interpolation$$1,\n animatedValues,\n toValues,\n previous: newValue,\n config: toConfig,\n fromValues: toArray(parent.getValue()),\n immediate: callProp(immediate, name),\n initialVelocity: withDefault(toConfig.velocity, 0),\n clamp: withDefault(toConfig.clamp, false),\n precision: withDefault(toConfig.precision, 0.01),\n tension: withDefault(toConfig.tension, 170),\n friction: withDefault(toConfig.friction, 26),\n mass: withDefault(toConfig.mass, 1),\n duration: toConfig.duration,\n easing: withDefault(toConfig.easing, t => t),\n decay: toConfig.decay\n })\n });\n } else {\n if (!currentValueDiffersFromGoal) {\n // So ... the current target value (newValue) appears to be different from the previous value,\n // which normally constitutes an update, but the actual value (currentValue) matches the target!\n // In order to resolve this without causing an animation update we silently flag the animation as done,\n // which it technically is. Interpolations also needs a config update with their target set to 1.\n if (isInterpolation) {\n parent.setValue(1, false);\n interpolation$$1.updateConfig({\n output: [newValue, newValue]\n });\n }\n\n parent.done = true;\n this.hasChanged = true;\n return _extends({}, acc, {\n [name]: _extends({}, acc[name], {\n previous: newValue\n })\n });\n }\n\n return acc;\n }\n }, this.animations);\n\n if (this.hasChanged) {\n // Make animations available to frameloop\n this.configs = Object.values(this.animations);\n this.values = {};\n this.interpolations = {};\n\n for (let key in this.animations) {\n this.interpolations[key] = this.animations[key].interpolation;\n this.values[key] = this.animations[key].interpolation.getValue();\n }\n }\n\n return this;\n }\n\n destroy() {\n this.stop();\n this.props = {};\n this.merged = {};\n this.animations = {};\n this.interpolations = {};\n this.values = {};\n this.configs = [];\n this.local = 0;\n }\n\n}\n\n/** API\n * const props = useSprings(number, [{ ... }, { ... }, ...])\n * const [props, set] = useSprings(number, (i, controller) => ({ ... }))\n */\n\nconst useSprings = (length, props) => {\n const mounted = useRef(false);\n const ctrl = useRef();\n const isFn = is.fun(props); // The controller maintains the animation values, starts and stops animations\n\n const _useMemo = useMemo(() => {\n // Remove old controllers\n if (ctrl.current) {\n ctrl.current.map(c => c.destroy());\n ctrl.current = undefined;\n }\n\n let ref;\n return [new Array(length).fill().map((_, i) => {\n const ctrl = new Controller();\n const newProps = isFn ? callProp(props, i, ctrl) : props[i];\n if (i === 0) ref = newProps.ref;\n ctrl.update(newProps);\n if (!ref) ctrl.start();\n return ctrl;\n }), ref];\n }, [length]),\n controllers = _useMemo[0],\n ref = _useMemo[1];\n\n ctrl.current = controllers; // The hooks reference api gets defined here ...\n\n const api = useImperativeHandle(ref, () => ({\n start: () => Promise.all(ctrl.current.map(c => new Promise(r => c.start(r)))),\n stop: finished => ctrl.current.forEach(c => c.stop(finished)),\n\n get controllers() {\n return ctrl.current;\n }\n\n })); // This function updates the controllers\n\n const updateCtrl = useMemo(() => updateProps => ctrl.current.map((c, i) => {\n c.update(isFn ? callProp(updateProps, i, c) : updateProps[i]);\n if (!ref) c.start();\n }), [length]); // Update controller if props aren't functional\n\n useEffect(() => {\n if (mounted.current) {\n if (!isFn) updateCtrl(props);\n } else if (!ref) ctrl.current.forEach(c => c.start());\n }); // Update mounted flag and destroy controller on unmount\n\n useEffect(() => (mounted.current = true, () => ctrl.current.forEach(c => c.destroy())), []); // Return animated props, or, anim-props + the update-setter above\n\n const propValues = ctrl.current.map(c => c.getValues());\n return isFn ? [propValues, updateCtrl, finished => ctrl.current.forEach(c => c.pause(finished))] : propValues;\n};\n\n/** API\n * const props = useSpring({ ... })\n * const [props, set] = useSpring(() => ({ ... }))\n */\n\nconst useSpring = props => {\n const isFn = is.fun(props);\n\n const _useSprings = useSprings(1, isFn ? props : [props]),\n result = _useSprings[0],\n set = _useSprings[1],\n pause = _useSprings[2];\n\n return isFn ? [result[0], set, pause] : result;\n};\n\n/** API\n * const trails = useTrail(number, { ... })\n * const [trails, set] = useTrail(number, () => ({ ... }))\n */\n\nconst useTrail = (length, props) => {\n const mounted = useRef(false);\n const isFn = is.fun(props);\n const updateProps = callProp(props);\n const instances = useRef();\n\n const _useSprings = useSprings(length, (i, ctrl) => {\n if (i === 0) instances.current = [];\n instances.current.push(ctrl);\n return _extends({}, updateProps, {\n config: callProp(updateProps.config, i),\n attach: i > 0 && (() => instances.current[i - 1])\n });\n }),\n result = _useSprings[0],\n set = _useSprings[1],\n pause = _useSprings[2]; // Set up function to update controller\n\n\n const updateCtrl = useMemo(() => props => set((i, ctrl) => {\n const last = props.reverse ? i === 0 : length - 1 === i;\n const attachIdx = props.reverse ? i + 1 : i - 1;\n const attachController = instances.current[attachIdx];\n return _extends({}, props, {\n config: callProp(props.config || updateProps.config, i),\n attach: attachController && (() => attachController)\n });\n }), [length, updateProps.reverse]); // Update controller if props aren't functional\n\n useEffect(() => void (mounted.current && !isFn && updateCtrl(props))); // Update mounted flag and destroy controller on unmount\n\n useEffect(() => void (mounted.current = true), []);\n return isFn ? [result, updateCtrl, pause] : result;\n};\n\n/** API\n * const transitions = useTransition(items, itemKeys, { ... })\n * const [transitions, update] = useTransition(items, itemKeys, () => ({ ... }))\n */\n\nlet guid = 0;\nconst ENTER = 'enter';\nconst LEAVE = 'leave';\nconst UPDATE = 'update';\n\nconst mapKeys = (items, keys) => (typeof keys === 'function' ? items.map(keys) : toArray(keys)).map(String);\n\nconst get = props => {\n let items = props.items,\n _props$keys = props.keys,\n keys = _props$keys === void 0 ? item => item : _props$keys,\n rest = _objectWithoutPropertiesLoose(props, [\"items\", \"keys\"]);\n\n items = toArray(items !== void 0 ? items : null);\n return _extends({\n items,\n keys: mapKeys(items, keys)\n }, rest);\n};\n\nfunction useTransition(input, keyTransform, config) {\n const props = _extends({\n items: input,\n keys: keyTransform || (i => i)\n }, config);\n\n const _get = get(props),\n _get$lazy = _get.lazy,\n lazy = _get$lazy === void 0 ? false : _get$lazy,\n _get$unique = _get.unique,\n _get$reset = _get.reset,\n reset = _get$reset === void 0 ? false : _get$reset,\n enter = _get.enter,\n leave = _get.leave,\n update = _get.update,\n onDestroyed = _get.onDestroyed,\n keys = _get.keys,\n items = _get.items,\n onFrame = _get.onFrame,\n _onRest = _get.onRest,\n onStart = _get.onStart,\n ref = _get.ref,\n extra = _objectWithoutPropertiesLoose(_get, [\"lazy\", \"unique\", \"reset\", \"enter\", \"leave\", \"update\", \"onDestroyed\", \"keys\", \"items\", \"onFrame\", \"onRest\", \"onStart\", \"ref\"]);\n\n const forceUpdate = useForceUpdate();\n const mounted = useRef(false);\n const state = useRef({\n mounted: false,\n first: true,\n deleted: [],\n current: {},\n transitions: [],\n prevProps: {},\n paused: !!props.ref,\n instances: !mounted.current && new Map(),\n forceUpdate\n });\n useImperativeHandle(props.ref, () => ({\n start: () => Promise.all(Array.from(state.current.instances).map((_ref) => {\n let c = _ref[1];\n return new Promise(r => c.start(r));\n })),\n stop: finished => Array.from(state.current.instances).forEach((_ref2) => {\n let c = _ref2[1];\n return c.stop(finished);\n }),\n\n get controllers() {\n return Array.from(state.current.instances).map((_ref3) => {\n let c = _ref3[1];\n return c;\n });\n }\n\n })); // Update state\n\n state.current = diffItems(state.current, props);\n\n if (state.current.changed) {\n // Update state\n state.current.transitions.forEach(transition => {\n const slot = transition.slot,\n from = transition.from,\n to = transition.to,\n config = transition.config,\n trail = transition.trail,\n key = transition.key,\n item = transition.item;\n if (!state.current.instances.has(key)) state.current.instances.set(key, new Controller()); // update the map object\n\n const ctrl = state.current.instances.get(key);\n\n const newProps = _extends({}, extra, {\n to,\n from,\n config,\n ref,\n onRest: values => {\n if (state.current.mounted) {\n if (transition.destroyed) {\n // If no ref is given delete destroyed items immediately\n if (!ref && !lazy) cleanUp(state, key);\n if (onDestroyed) onDestroyed(item);\n } // A transition comes to rest once all its springs conclude\n\n\n const curInstances = Array.from(state.current.instances);\n const active = curInstances.some((_ref4) => {\n let c = _ref4[1];\n return !c.idle;\n });\n if (!active && (ref || lazy) && state.current.deleted.length > 0) cleanUp(state);\n if (_onRest) _onRest(item, slot, values);\n }\n },\n onStart: onStart && (() => onStart(item, slot)),\n onFrame: onFrame && (values => onFrame(item, slot, values)),\n delay: trail,\n reset: reset && slot === ENTER // Update controller\n\n });\n\n ctrl.update(newProps);\n if (!state.current.paused) ctrl.start();\n });\n }\n\n useEffect(() => {\n state.current.mounted = mounted.current = true;\n return () => {\n state.current.mounted = mounted.current = false;\n Array.from(state.current.instances).map((_ref5) => {\n let c = _ref5[1];\n return c.destroy();\n });\n state.current.instances.clear();\n };\n }, []);\n return state.current.transitions.map((_ref6) => {\n let item = _ref6.item,\n slot = _ref6.slot,\n key = _ref6.key;\n return {\n item,\n key,\n state: slot,\n props: state.current.instances.get(key).getValues()\n };\n });\n}\n\nfunction cleanUp(state, filterKey) {\n const deleted = state.current.deleted;\n\n for (let _ref7 of deleted) {\n let key = _ref7.key;\n\n const filter = t => t.key !== key;\n\n if (is.und(filterKey) || filterKey === key) {\n state.current.instances.delete(key);\n state.current.transitions = state.current.transitions.filter(filter);\n state.current.deleted = state.current.deleted.filter(filter);\n }\n }\n\n state.current.forceUpdate();\n}\n\nfunction diffItems(_ref8, props) {\n let first = _ref8.first,\n prevProps = _ref8.prevProps,\n state = _objectWithoutPropertiesLoose(_ref8, [\"first\", \"prevProps\"]);\n\n let _get2 = get(props),\n items = _get2.items,\n keys = _get2.keys,\n initial = _get2.initial,\n from = _get2.from,\n enter = _get2.enter,\n leave = _get2.leave,\n update = _get2.update,\n _get2$trail = _get2.trail,\n trail = _get2$trail === void 0 ? 0 : _get2$trail,\n unique = _get2.unique,\n config = _get2.config,\n _get2$order = _get2.order,\n order = _get2$order === void 0 ? [ENTER, LEAVE, UPDATE] : _get2$order;\n\n let _get3 = get(prevProps),\n _keys = _get3.keys,\n _items = _get3.items;\n\n let current = _extends({}, state.current);\n\n let deleted = [...state.deleted]; // Compare next keys with current keys\n\n let currentKeys = Object.keys(current);\n let currentSet = new Set(currentKeys);\n let nextSet = new Set(keys);\n let added = keys.filter(item => !currentSet.has(item));\n let removed = state.transitions.filter(item => !item.destroyed && !nextSet.has(item.originalKey)).map(i => i.originalKey);\n let updated = keys.filter(item => currentSet.has(item));\n let delay = -trail;\n\n while (order.length) {\n const changeType = order.shift();\n\n switch (changeType) {\n case ENTER:\n {\n added.forEach((key, index) => {\n // In unique mode, remove fading out transitions if their key comes in again\n if (unique && deleted.find(d => d.originalKey === key)) deleted = deleted.filter(t => t.originalKey !== key);\n const keyIndex = keys.indexOf(key);\n const item = items[keyIndex];\n const slot = first && initial !== void 0 ? 'initial' : ENTER;\n current[key] = {\n slot,\n originalKey: key,\n key: unique ? String(key) : guid++,\n item,\n trail: delay = delay + trail,\n config: callProp(config, item, slot),\n from: callProp(first ? initial !== void 0 ? initial || {} : from : from, item),\n to: callProp(enter, item)\n };\n });\n break;\n }\n\n case LEAVE:\n {\n removed.forEach(key => {\n const keyIndex = _keys.indexOf(key);\n\n const item = _items[keyIndex];\n const slot = LEAVE;\n deleted.unshift(_extends({}, current[key], {\n slot,\n destroyed: true,\n left: _keys[Math.max(0, keyIndex - 1)],\n right: _keys[Math.min(_keys.length, keyIndex + 1)],\n trail: delay = delay + trail,\n config: callProp(config, item, slot),\n to: callProp(leave, item)\n }));\n delete current[key];\n });\n break;\n }\n\n case UPDATE:\n {\n updated.forEach(key => {\n const keyIndex = keys.indexOf(key);\n const item = items[keyIndex];\n const slot = UPDATE;\n current[key] = _extends({}, current[key], {\n item,\n slot,\n trail: delay = delay + trail,\n config: callProp(config, item, slot),\n to: callProp(update, item)\n });\n });\n break;\n }\n }\n }\n\n let out = keys.map(key => current[key]); // This tries to restore order for deleted items by finding their last known siblings\n // only using the left sibling to keep order placement consistent for all deleted items\n\n deleted.forEach((_ref9) => {\n let left = _ref9.left,\n right = _ref9.right,\n item = _objectWithoutPropertiesLoose(_ref9, [\"left\", \"right\"]);\n\n let pos; // Was it the element on the left, if yes, move there ...\n\n if ((pos = out.findIndex(t => t.originalKey === left)) !== -1) pos += 1; // And if nothing else helps, move it to the start ¯\\_(ツ)_/¯\n\n pos = Math.max(0, pos);\n out = [...out.slice(0, pos), item, ...out.slice(pos)];\n });\n return _extends({}, state, {\n changed: added.length || removed.length || updated.length,\n first: first && added.length === 0,\n transitions: out,\n current,\n deleted,\n prevProps: props\n });\n}\n\nclass AnimatedStyle extends AnimatedObject {\n constructor(style) {\n if (style === void 0) {\n style = {};\n }\n\n super();\n\n if (style.transform && !(style.transform instanceof Animated)) {\n style = applyAnimatedValues.transform(style);\n }\n\n this.payload = style;\n }\n\n}\n\n// http://www.w3.org/TR/css3-color/#svg-color\nconst colors = {\n transparent: 0x00000000,\n aliceblue: 0xf0f8ffff,\n antiquewhite: 0xfaebd7ff,\n aqua: 0x00ffffff,\n aquamarine: 0x7fffd4ff,\n azure: 0xf0ffffff,\n beige: 0xf5f5dcff,\n bisque: 0xffe4c4ff,\n black: 0x000000ff,\n blanchedalmond: 0xffebcdff,\n blue: 0x0000ffff,\n blueviolet: 0x8a2be2ff,\n brown: 0xa52a2aff,\n burlywood: 0xdeb887ff,\n burntsienna: 0xea7e5dff,\n cadetblue: 0x5f9ea0ff,\n chartreuse: 0x7fff00ff,\n chocolate: 0xd2691eff,\n coral: 0xff7f50ff,\n cornflowerblue: 0x6495edff,\n cornsilk: 0xfff8dcff,\n crimson: 0xdc143cff,\n cyan: 0x00ffffff,\n darkblue: 0x00008bff,\n darkcyan: 0x008b8bff,\n darkgoldenrod: 0xb8860bff,\n darkgray: 0xa9a9a9ff,\n darkgreen: 0x006400ff,\n darkgrey: 0xa9a9a9ff,\n darkkhaki: 0xbdb76bff,\n darkmagenta: 0x8b008bff,\n darkolivegreen: 0x556b2fff,\n darkorange: 0xff8c00ff,\n darkorchid: 0x9932ccff,\n darkred: 0x8b0000ff,\n darksalmon: 0xe9967aff,\n darkseagreen: 0x8fbc8fff,\n darkslateblue: 0x483d8bff,\n darkslategray: 0x2f4f4fff,\n darkslategrey: 0x2f4f4fff,\n darkturquoise: 0x00ced1ff,\n darkviolet: 0x9400d3ff,\n deeppink: 0xff1493ff,\n deepskyblue: 0x00bfffff,\n dimgray: 0x696969ff,\n dimgrey: 0x696969ff,\n dodgerblue: 0x1e90ffff,\n firebrick: 0xb22222ff,\n floralwhite: 0xfffaf0ff,\n forestgreen: 0x228b22ff,\n fuchsia: 0xff00ffff,\n gainsboro: 0xdcdcdcff,\n ghostwhite: 0xf8f8ffff,\n gold: 0xffd700ff,\n goldenrod: 0xdaa520ff,\n gray: 0x808080ff,\n green: 0x008000ff,\n greenyellow: 0xadff2fff,\n grey: 0x808080ff,\n honeydew: 0xf0fff0ff,\n hotpink: 0xff69b4ff,\n indianred: 0xcd5c5cff,\n indigo: 0x4b0082ff,\n ivory: 0xfffff0ff,\n khaki: 0xf0e68cff,\n lavender: 0xe6e6faff,\n lavenderblush: 0xfff0f5ff,\n lawngreen: 0x7cfc00ff,\n lemonchiffon: 0xfffacdff,\n lightblue: 0xadd8e6ff,\n lightcoral: 0xf08080ff,\n lightcyan: 0xe0ffffff,\n lightgoldenrodyellow: 0xfafad2ff,\n lightgray: 0xd3d3d3ff,\n lightgreen: 0x90ee90ff,\n lightgrey: 0xd3d3d3ff,\n lightpink: 0xffb6c1ff,\n lightsalmon: 0xffa07aff,\n lightseagreen: 0x20b2aaff,\n lightskyblue: 0x87cefaff,\n lightslategray: 0x778899ff,\n lightslategrey: 0x778899ff,\n lightsteelblue: 0xb0c4deff,\n lightyellow: 0xffffe0ff,\n lime: 0x00ff00ff,\n limegreen: 0x32cd32ff,\n linen: 0xfaf0e6ff,\n magenta: 0xff00ffff,\n maroon: 0x800000ff,\n mediumaquamarine: 0x66cdaaff,\n mediumblue: 0x0000cdff,\n mediumorchid: 0xba55d3ff,\n mediumpurple: 0x9370dbff,\n mediumseagreen: 0x3cb371ff,\n mediumslateblue: 0x7b68eeff,\n mediumspringgreen: 0x00fa9aff,\n mediumturquoise: 0x48d1ccff,\n mediumvioletred: 0xc71585ff,\n midnightblue: 0x191970ff,\n mintcream: 0xf5fffaff,\n mistyrose: 0xffe4e1ff,\n moccasin: 0xffe4b5ff,\n navajowhite: 0xffdeadff,\n navy: 0x000080ff,\n oldlace: 0xfdf5e6ff,\n olive: 0x808000ff,\n olivedrab: 0x6b8e23ff,\n orange: 0xffa500ff,\n orangered: 0xff4500ff,\n orchid: 0xda70d6ff,\n palegoldenrod: 0xeee8aaff,\n palegreen: 0x98fb98ff,\n paleturquoise: 0xafeeeeff,\n palevioletred: 0xdb7093ff,\n papayawhip: 0xffefd5ff,\n peachpuff: 0xffdab9ff,\n peru: 0xcd853fff,\n pink: 0xffc0cbff,\n plum: 0xdda0ddff,\n powderblue: 0xb0e0e6ff,\n purple: 0x800080ff,\n rebeccapurple: 0x663399ff,\n red: 0xff0000ff,\n rosybrown: 0xbc8f8fff,\n royalblue: 0x4169e1ff,\n saddlebrown: 0x8b4513ff,\n salmon: 0xfa8072ff,\n sandybrown: 0xf4a460ff,\n seagreen: 0x2e8b57ff,\n seashell: 0xfff5eeff,\n sienna: 0xa0522dff,\n silver: 0xc0c0c0ff,\n skyblue: 0x87ceebff,\n slateblue: 0x6a5acdff,\n slategray: 0x708090ff,\n slategrey: 0x708090ff,\n snow: 0xfffafaff,\n springgreen: 0x00ff7fff,\n steelblue: 0x4682b4ff,\n tan: 0xd2b48cff,\n teal: 0x008080ff,\n thistle: 0xd8bfd8ff,\n tomato: 0xff6347ff,\n turquoise: 0x40e0d0ff,\n violet: 0xee82eeff,\n wheat: 0xf5deb3ff,\n white: 0xffffffff,\n whitesmoke: 0xf5f5f5ff,\n yellow: 0xffff00ff,\n yellowgreen: 0x9acd32ff\n};\n\n// const INTEGER = '[-+]?\\\\d+';\nconst NUMBER = '[-+]?\\\\d*\\\\.?\\\\d+';\nconst PERCENTAGE = NUMBER + '%';\n\nfunction call() {\n for (var _len = arguments.length, parts = new Array(_len), _key = 0; _key < _len; _key++) {\n parts[_key] = arguments[_key];\n }\n\n return '\\\\(\\\\s*(' + parts.join(')\\\\s*,\\\\s*(') + ')\\\\s*\\\\)';\n}\n\nconst rgb = new RegExp('rgb' + call(NUMBER, NUMBER, NUMBER));\nconst rgba = new RegExp('rgba' + call(NUMBER, NUMBER, NUMBER, NUMBER));\nconst hsl = new RegExp('hsl' + call(NUMBER, PERCENTAGE, PERCENTAGE));\nconst hsla = new RegExp('hsla' + call(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER));\nconst hex3 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;\nconst hex4 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;\nconst hex6 = /^#([0-9a-fA-F]{6})$/;\nconst hex8 = /^#([0-9a-fA-F]{8})$/;\n\n/*\nhttps://github.com/react-community/normalize-css-color\n\nBSD 3-Clause License\n\nCopyright (c) 2016, React Community\nAll rights reserved.\n\nRedistribution and use in source and binary forms, with or without\nmodification, are permitted provided that the following conditions are met:\n\n* Redistributions of source code must retain the above copyright notice, this\n list of conditions and the following disclaimer.\n\n* Redistributions in binary form must reproduce the above copyright notice,\n this list of conditions and the following disclaimer in the documentation\n and/or other materials provided with the distribution.\n\n* Neither the name of the copyright holder nor the names of its\n contributors may be used to endorse or promote products derived from\n this software without specific prior written permission.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\nFOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\nDAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\nSERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\nCAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\nOR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\nOF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n*/\nfunction normalizeColor(color) {\n let match;\n\n if (typeof color === 'number') {\n return color >>> 0 === color && color >= 0 && color <= 0xffffffff ? color : null;\n } // Ordered based on occurrences on Facebook codebase\n\n\n if (match = hex6.exec(color)) return parseInt(match[1] + 'ff', 16) >>> 0;\n if (colors.hasOwnProperty(color)) return colors[color];\n\n if (match = rgb.exec(color)) {\n return (parse255(match[1]) << 24 | // r\n parse255(match[2]) << 16 | // g\n parse255(match[3]) << 8 | // b\n 0x000000ff) >>> // a\n 0;\n }\n\n if (match = rgba.exec(color)) {\n return (parse255(match[1]) << 24 | // r\n parse255(match[2]) << 16 | // g\n parse255(match[3]) << 8 | // b\n parse1(match[4])) >>> // a\n 0;\n }\n\n if (match = hex3.exec(color)) {\n return parseInt(match[1] + match[1] + // r\n match[2] + match[2] + // g\n match[3] + match[3] + // b\n 'ff', // a\n 16) >>> 0;\n } // https://drafts.csswg.org/css-color-4/#hex-notation\n\n\n if (match = hex8.exec(color)) return parseInt(match[1], 16) >>> 0;\n\n if (match = hex4.exec(color)) {\n return parseInt(match[1] + match[1] + // r\n match[2] + match[2] + // g\n match[3] + match[3] + // b\n match[4] + match[4], // a\n 16) >>> 0;\n }\n\n if (match = hsl.exec(color)) {\n return (hslToRgb(parse360(match[1]), // h\n parsePercentage(match[2]), // s\n parsePercentage(match[3]) // l\n ) | 0x000000ff) >>> // a\n 0;\n }\n\n if (match = hsla.exec(color)) {\n return (hslToRgb(parse360(match[1]), // h\n parsePercentage(match[2]), // s\n parsePercentage(match[3]) // l\n ) | parse1(match[4])) >>> // a\n 0;\n }\n\n return null;\n}\n\nfunction hue2rgb(p, q, t) {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1 / 6) return p + (q - p) * 6 * t;\n if (t < 1 / 2) return q;\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n}\n\nfunction hslToRgb(h, s, l) {\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n const r = hue2rgb(p, q, h + 1 / 3);\n const g = hue2rgb(p, q, h);\n const b = hue2rgb(p, q, h - 1 / 3);\n return Math.round(r * 255) << 24 | Math.round(g * 255) << 16 | Math.round(b * 255) << 8;\n}\n\nfunction parse255(str) {\n const int = parseInt(str, 10);\n if (int < 0) return 0;\n if (int > 255) return 255;\n return int;\n}\n\nfunction parse360(str) {\n const int = parseFloat(str);\n return (int % 360 + 360) % 360 / 360;\n}\n\nfunction parse1(str) {\n const num = parseFloat(str);\n if (num < 0) return 0;\n if (num > 1) return 255;\n return Math.round(num * 255);\n}\n\nfunction parsePercentage(str) {\n // parseFloat conveniently ignores the final %\n const int = parseFloat(str);\n if (int < 0) return 0;\n if (int > 100) return 1;\n return int / 100;\n}\n\nfunction colorToRgba(input) {\n let int32Color = normalizeColor(input);\n if (int32Color === null) return input;\n int32Color = int32Color || 0;\n let r = (int32Color & 0xff000000) >>> 24;\n let g = (int32Color & 0x00ff0000) >>> 16;\n let b = (int32Color & 0x0000ff00) >>> 8;\n let a = (int32Color & 0x000000ff) / 255;\n return `rgba(${r}, ${g}, ${b}, ${a})`;\n} // Problem: https://github.com/animatedjs/animated/pull/102\n// Solution: https://stackoverflow.com/questions/638565/parsing-scientific-notation-sensibly/658662\n\n\nconst stringShapeRegex = /[+\\-]?(?:0|[1-9]\\d*)(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?/g; // Covers rgb, rgba, hsl, hsla\n// Taken from https://gist.github.com/olmokramer/82ccce673f86db7cda5e\n\nconst colorRegex = /(#(?:[0-9a-f]{2}){2,4}|(#[0-9a-f]{3})|(rgb|hsl)a?\\((-?\\d+%?[,\\s]+){2,3}\\s*[\\d\\.]+%?\\))/gi; // Covers color names (transparent, blue, etc.)\n\nconst colorNamesRegex = new RegExp(`(${Object.keys(colors).join('|')})`, 'g');\n/**\n * Supports string shapes by extracting numbers so new values can be computed,\n * and recombines those values into new strings of the same shape. Supports\n * things like:\n *\n * rgba(123, 42, 99, 0.36) // colors\n * -45deg // values with units\n * 0 2px 2px 0px rgba(0, 0, 0, 0.12) // box shadows\n */\n\nconst createStringInterpolator = config => {\n // Replace colors with rgba\n const outputRange = config.output.map(rangeValue => rangeValue.replace(colorRegex, colorToRgba)).map(rangeValue => rangeValue.replace(colorNamesRegex, colorToRgba));\n const outputRanges = outputRange[0].match(stringShapeRegex).map(() => []);\n outputRange.forEach(value => {\n value.match(stringShapeRegex).forEach((number, i) => outputRanges[i].push(+number));\n });\n const interpolations = outputRange[0].match(stringShapeRegex).map((_value, i) => createInterpolator(_extends({}, config, {\n output: outputRanges[i]\n })));\n return input => {\n let i = 0;\n return outputRange[0] // 'rgba(0, 100, 200, 0)'\n // ->\n // 'rgba(${interpolations[0](input)}, ${interpolations[1](input)}, ...'\n .replace(stringShapeRegex, () => interpolations[i++](input)) // rgba requires that the r,g,b are integers.... so we want to round them, but we *dont* want to\n // round the opacity (4th column).\n .replace(/rgba\\(([0-9\\.-]+), ([0-9\\.-]+), ([0-9\\.-]+), ([0-9\\.-]+)\\)/gi, (_, p1, p2, p3, p4) => `rgba(${Math.round(p1)}, ${Math.round(p2)}, ${Math.round(p3)}, ${p4})`);\n };\n};\n\nlet isUnitlessNumber = {\n animationIterationCount: true,\n borderImageOutset: true,\n borderImageSlice: true,\n borderImageWidth: true,\n boxFlex: true,\n boxFlexGroup: true,\n boxOrdinalGroup: true,\n columnCount: true,\n columns: true,\n flex: true,\n flexGrow: true,\n flexPositive: true,\n flexShrink: true,\n flexNegative: true,\n flexOrder: true,\n gridRow: true,\n gridRowEnd: true,\n gridRowSpan: true,\n gridRowStart: true,\n gridColumn: true,\n gridColumnEnd: true,\n gridColumnSpan: true,\n gridColumnStart: true,\n fontWeight: true,\n lineClamp: true,\n lineHeight: true,\n opacity: true,\n order: true,\n orphans: true,\n tabSize: true,\n widows: true,\n zIndex: true,\n zoom: true,\n // SVG-related properties\n fillOpacity: true,\n floodOpacity: true,\n stopOpacity: true,\n strokeDasharray: true,\n strokeDashoffset: true,\n strokeMiterlimit: true,\n strokeOpacity: true,\n strokeWidth: true\n};\n\nconst prefixKey = (prefix, key) => prefix + key.charAt(0).toUpperCase() + key.substring(1);\n\nconst prefixes = ['Webkit', 'Ms', 'Moz', 'O'];\nisUnitlessNumber = Object.keys(isUnitlessNumber).reduce((acc, prop) => {\n prefixes.forEach(prefix => acc[prefixKey(prefix, prop)] = acc[prop]);\n return acc;\n}, isUnitlessNumber);\n\nfunction dangerousStyleValue(name, value, isCustomProperty) {\n if (value == null || typeof value === 'boolean' || value === '') return '';\n if (!isCustomProperty && typeof value === 'number' && value !== 0 && !(isUnitlessNumber.hasOwnProperty(name) && isUnitlessNumber[name])) return value + 'px'; // Presumes implicit 'px' suffix for unitless numbers\n\n return ('' + value).trim();\n}\n\nconst attributeCache = {};\ninjectCreateAnimatedStyle(style => new AnimatedStyle(style));\ninjectDefaultElement('div');\ninjectStringInterpolator(createStringInterpolator);\ninjectColorNames(colors);\ninjectApplyAnimatedValues((instance, props) => {\n if (instance.nodeType && instance.setAttribute !== undefined) {\n const style = props.style,\n children = props.children,\n scrollTop = props.scrollTop,\n scrollLeft = props.scrollLeft,\n attributes = _objectWithoutPropertiesLoose(props, [\"style\", \"children\", \"scrollTop\", \"scrollLeft\"]);\n\n const filter = instance.nodeName === 'filter' || instance.parentNode && instance.parentNode.nodeName === 'filter';\n if (scrollTop !== void 0) instance.scrollTop = scrollTop;\n if (scrollLeft !== void 0) instance.scrollLeft = scrollLeft; // Set textContent, if children is an animatable value\n\n if (children !== void 0) instance.textContent = children; // Set styles ...\n\n for (let styleName in style) {\n if (!style.hasOwnProperty(styleName)) continue;\n var isCustomProperty = styleName.indexOf('--') === 0;\n var styleValue = dangerousStyleValue(styleName, style[styleName], isCustomProperty);\n if (styleName === 'float') styleName = 'cssFloat';\n if (isCustomProperty) instance.style.setProperty(styleName, styleValue);else instance.style[styleName] = styleValue;\n } // Set attributes ...\n\n\n for (let name in attributes) {\n // Attributes are written in dash case\n const dashCase = filter ? name : attributeCache[name] || (attributeCache[name] = name.replace(/([A-Z])/g, n => '-' + n.toLowerCase()));\n if (typeof instance.getAttribute(dashCase) !== 'undefined') instance.setAttribute(dashCase, attributes[name]);\n }\n\n return;\n } else return false;\n}, style => style);\n\nconst domElements = ['a', 'abbr', 'address', 'area', 'article', 'aside', 'audio', 'b', 'base', 'bdi', 'bdo', 'big', 'blockquote', 'body', 'br', 'button', 'canvas', 'caption', 'cite', 'code', 'col', 'colgroup', 'data', 'datalist', 'dd', 'del', 'details', 'dfn', 'dialog', 'div', 'dl', 'dt', 'em', 'embed', 'fieldset', 'figcaption', 'figure', 'footer', 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'i', 'iframe', 'img', 'input', 'ins', 'kbd', 'keygen', 'label', 'legend', 'li', 'link', 'main', 'map', 'mark', 'menu', 'menuitem', 'meta', 'meter', 'nav', 'noscript', 'object', 'ol', 'optgroup', 'option', 'output', 'p', 'param', 'picture', 'pre', 'progress', 'q', 'rp', 'rt', 'ruby', 's', 'samp', 'script', 'section', 'select', 'small', 'source', 'span', 'strong', 'style', 'sub', 'summary', 'sup', 'table', 'tbody', 'td', 'textarea', 'tfoot', 'th', 'thead', 'time', 'title', 'tr', 'track', 'u', 'ul', 'var', 'video', 'wbr', // SVG\n'circle', 'clipPath', 'defs', 'ellipse', 'foreignObject', 'g', 'image', 'line', 'linearGradient', 'mask', 'path', 'pattern', 'polygon', 'polyline', 'radialGradient', 'rect', 'stop', 'svg', 'text', 'tspan'];\n// Extend animated with all the available THREE elements\nconst apply = merge(createAnimatedComponent, false);\nconst extendedAnimated = apply(domElements);\n\nexport { apply, config, update, extendedAnimated as animated, extendedAnimated as a, interpolate$1 as interpolate, Globals, useSpring, useTrail, useTransition, useChain, useSprings };\n","import React from 'react';\r\nimport { useSpring, animated } from 'react-spring';\r\nimport ClassNames from 'classnames';\r\n\r\nimport './StatusIndicator.scss';\r\n\r\ninterface ProgressCircleProps {\r\n\tchildren: object;\r\n\tflipped: boolean;\r\n};\r\n\r\ninterface Props {\r\n\tclassName?: string;\r\n\tordinal: number;\r\n\tprogress: number;\r\n\ticon?: string;\r\n\tsize: number;\r\n\tisCurrentStep?: boolean;\r\n}\r\n\r\n\r\nfunction stepCompleteIcon(progress): React.ReactNode {\r\n\tif (progress >= 1) {\r\n\t\treturn
;\r\n\t}\r\n\treturn null;\r\n}\r\n\r\nfunction round(value:number, precision:number):number {\r\n\tif (Number.isInteger(precision)) {\r\n\t\tvar shift = Math.pow(10, precision);\r\n\t\treturn Math.round(value * shift) / shift;\r\n\t} else {\r\n\t\treturn Math.round(value);\r\n\t}\r\n}\r\n\r\nexport const StatusIndicator: React.FunctionComponent = (props) => {\r\n\tconst strokeWidth = round(props.size * 0.08, 0);\r\n\tconst circleRadius = props.size / 2 - strokeWidth;\r\n\tconst statusIndicatorSizePx = `${props.size}px`;\r\n\tconst circleCenter = props.size / 2;\r\n\tconst circleCenterPx = `${circleCenter}px`;\r\n\tconst ordinalFontSize = `${round(circleCenter * 0.92, 0)}px`;\r\n\tconst circleRadiusPx = `${circleRadius}px`;\r\n\r\n\tconst max = round(Math.PI * circleRadius * 2, 2);\r\n\tconst current = round(max - max * props.progress, 2);\r\n\r\n\tconst StatusIndicatorClassName = ClassNames(props.className);\r\n\r\n\tconst iconClassName = ClassNames('icon', props.icon);\r\n\r\n\tconst isComplete = props.progress >= 1;\r\n\tconst isCurrent = props.isCurrentStep;\r\n\r\n\tconst ordinalClassName = ClassNames('ordinal', {\r\n\t\tcomplete: isComplete,\r\n\t\tcurrent: isCurrent\r\n\t});\r\n\r\n\tconst circleClassName = ClassNames('circle', {\r\n\t\tcomplete: isComplete,\r\n\t\tcurrent: isCurrent\r\n\t});\r\n\r\n\t// Other animations are handled using CSS\r\n\tconst animationProps = useSpring({ x: current, from: {x: max} });\r\n\r\n\treturn (\r\n\t\t\r\n\t\t\t
\r\n\t\t\t\t\r\n\t\t\t\t\t\r\n\t\t\t\t\t\r\n\t\t\t\t\r\n\t\t\t\t\r\n\t\t\t\t\t{props.ordinal}\r\n\t\t\t\t\r\n\t\t\t
\r\n\t\t\t{props.icon ? (\r\n\t\t\t\t
\r\n\t\t\t) : (\r\n\t\t\t\tstepCompleteIcon(props.progress)\r\n\t\t\t)}\r\n\t\t
\r\n\t);\r\n};\r\n\r\n\r\n// Default props\r\nStatusIndicator.defaultProps = {\r\n\tclassName: 'StatusIndicator',\r\n\ticon: '',\r\n\tsize: 48,\r\n\tisCurrentStep: false,\r\n};\r\n","import React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport Classnames from 'classnames';\r\nimport './Modal.scss';\r\nimport { Button } from '../../widget/input/Button/Button';\r\n\r\nexport enum OverlayStyles {\r\n\t'Transparent' = 'Transparent',\r\n\t'Darken' = 'Darken',\r\n}\r\n\r\nexport interface Props {\r\n\tmodalClassName?: string;\r\n\toverlayClassName?: string;\r\n\toverlayStyle?: OverlayStyles;\r\n\toverlayCloseOnClick?: boolean;\r\n\thandleClose?: (event: React.MouseEvent | React.MouseEvent) => void;\r\n}\r\n\r\nexport const Modal: React.FunctionComponent = (props) => {\r\n\tconst modalDomHandle = document.getElementById('modal-root');\r\n\r\n\tconst overlayClassNames = Classnames(\r\n\t\tprops.overlayClassName,\r\n\t\tprops.overlayStyle\r\n\t);\r\n\r\n\tconst handleOverlayClick = (event: React.MouseEvent) => {\r\n\t\tif (props.overlayCloseOnClick && props.handleClose) {\r\n\t\t\tprops.handleClose(event);\r\n\t\t}\r\n\t};\r\n\r\n\tconst handleCloseButtonClick = (\r\n\t\tevent: React.MouseEvent\r\n\t) => {\r\n\t\tif (props.handleClose) {\r\n\t\t\tprops.handleClose(event);\r\n\t\t}\r\n\t};\r\n\r\n\treturn ReactDOM.createPortal(\r\n\t\t
\r\n\t\t\t
\r\n\t\t\t\t\r\n\t\t\t\t{props.children}\r\n\t\t\t
\r\n\t\t
,\r\n\t\tmodalDomHandle\r\n\t);\r\n};\r\n\r\nModal.defaultProps = {\r\n\tmodalClassName: 'Modal',\r\n\toverlayClassName: 'ModalOverlay',\r\n\toverlayStyle: OverlayStyles.Darken,\r\n\toverlayCloseOnClick: true,\r\n};\r\n","import React from 'react';\r\nimport ClassNames from 'classnames';\r\nimport './ButtonGroup.scss';\r\n\r\nexport enum ButtonGroupLayout {\r\n\t'Stretch' = 'Stretch',\r\n\t'Nowrap' = 'Nowrap',\r\n}\r\n\r\ninterface Props {\r\n\tclassName?: string;\r\n\tlayout?: ButtonGroupLayout;\r\n}\r\n\r\nexport const ButtonGroup: React.FunctionComponent = (props) => {\r\n\tconst classNames = ClassNames(props.className, {\r\n\t\tStretch: props.layout === 'Stretch',\r\n\t\tNowrap: props.layout === 'Nowrap',\r\n\t});\r\n\r\n\treturn
{props.children}
;\r\n};\r\n\r\nButtonGroup.defaultProps = {\r\n\tlayout: undefined,\r\n\tclassName: 'ButtonGroup',\r\n};\r\n","import React, { useState } from 'react';\r\nimport { T } from '../../display/T';\r\nimport { Application } from '../../../../models/AppModels';\r\nimport { Button } from '../Button/Button';\r\nimport { Modal, OverlayStyles } from '../../../layout/Modal/Modal';\r\nimport { ButtonGroup, ButtonGroupLayout } from '../ButtonGroup/ButtonGroup';\r\n\r\nimport './DeleteButton.scss';\r\n\r\ninterface Props {\r\n\tlabelTextkey: string;\r\n\tlabel?: string;\r\n\tquestionTextkey?: string;\r\n\tonClick?: (event: React.MouseEvent) => void;\r\n\tenabled?: boolean;\r\n}\r\n\r\nexport const DeleteButton: React.FunctionComponent = (props) => {\r\n\tlet label = Application.instance.services.textService.textOrEmpty(\r\n\t\tprops.labelTextkey\r\n\t);\r\n\r\n\tif (props.label) {\r\n\t\tlabel += props.label;\r\n\t}\r\n\r\n\tconst [modal, setOpen] = useState({ isOpen: false });\r\n\r\n\tconst onClick = (\r\n\t\tevent: React.MouseEvent\r\n\t): void => {\r\n\t\tsetOpen((s) => {\r\n\t\t\treturn { isOpen: !s.isOpen };\r\n\t\t});\r\n\t};\r\n\r\n\tconst handleClickYes = (\r\n\t\tevent: React.MouseEvent\r\n\t): void => {\r\n\t\tsetOpen({ isOpen: false });\r\n\t\tif (props.onClick) props.onClick(event);\r\n\t};\r\n\r\n\tconst handleClickNo = (\r\n\t\tevent:\r\n\t\t\t| React.MouseEvent\r\n\t\t\t| React.MouseEvent\r\n\t): void => {\r\n\t\tsetOpen({ isOpen: false });\r\n\t};\r\n\r\n\tconst questionTextkey = props.questionTextkey;\r\n\r\n\tconst id =\r\n\t\t'deleteButton_' + Application.instance.services.idService.newIdString();\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t\t\r\n\t\t\t{modal.isOpen ? (\r\n\t\t\t\t\r\n\t\t\t\t\t
\r\n\t\t\t\t\t\t

{label}

\r\n\t\t\t\t\t\t

\r\n\t\t\t\t\t\t\t{questionTextkey ? (\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t) : (\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t

\r\n\t\t\t\t\t
\r\n\t\t\t\t\t
\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t
\r\n\t\t\t\t\r\n\t\t\t) : null}\r\n\t\t\r\n\t);\r\n};\r\n","import React from 'react';\r\nimport { Case as SelmaCase } from '../../../models/SelmaModels';\r\nimport { T } from '../../widget/display/T';\r\nimport { AppComponent } from '../../AppComponent';\r\nimport { Button } from '../../widget/input/Button/Button';\r\nimport { StatusIndicator } from '../../widget/display/StatusIndicator/StatusIndicator';\r\n\r\nimport './HomeCase.scss';\r\nimport { DeleteButton } from '../../widget/input/DeleteButton/DeleteButton';\r\n\r\ninterface Props {\r\n\tcase: SelmaCase;\r\n\tselectedCase: (c: SelmaCase) => void;\r\n\tdeletedCase: (c: SelmaCase) => void;\r\n}\r\n\r\nexport class HomeCase extends AppComponent {\r\n\tconstructor(props: Props) {\r\n\t\tsuper(props);\r\n\t}\r\n\r\n\tselectedCase = (event: React.MouseEvent): void => {\r\n\t\tthis.props.selectedCase(this.props.case);\r\n\t};\r\n\r\n\tdeleteCase = (event: React.MouseEvent): void => {\r\n\t\tthis.props.deletedCase(this.props.case);\r\n\t};\r\n\r\n\trender() {\r\n\r\n\t\tconst c = this.props.case;\r\n\t\tconst stepService = this.application.services.stepService;\r\n\t\tconst caseService = this.application.services.caseService;\r\n\r\n\t\tconst startStep = stepService.getStartStep(c);\r\n\t\tconst canDelete = caseService.canDeleteCase(c)\r\n\r\n\t\tlet ordinal = 0;\r\n\t\tlet progress = 0;\r\n\t\tlet statusText = '';\r\n\t\tlet needsComplement;\r\n\t\tif (startStep) {\r\n\t\t\tordinal = stepService.getStepOrdinal(startStep, c);\r\n\t\t\tprogress = stepService.calcStepProgress(startStep, c);\r\n\t\t\tstatusText = stepService.getStepStatusText(startStep);\r\n\t\t\tneedsComplement = stepService.stepNeedsComplement(startStep, c);\r\n\t\t}\r\n\r\n\t\tconst euSupportService = this.application.services.euSupportService;\r\n\r\n\t\tconst isServerCase = caseService.isServerCase(c);\r\n\r\n\t\treturn (\r\n\t\t\t
\r\n\t\t\t\t
\r\n\t\t\t\t\t

\r\n\t\t\t\t\t\t{isServerCase && <>{this.props.case.number}}\r\n\t\t\t\t\t\t{!isServerCase && }\r\n\t\t\t\t\t

\r\n\t\t\t\t\t{canDelete &&\r\n\t\t\t\t\t\t<>\r\n\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t}\r\n\t\t\t\t
\r\n\t\t\t\t
\r\n\t\t\t\t\t
\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t\t
{statusText}
\r\n\t\t\t\t\t
\r\n\t\t\t\t\t
    \r\n\t\t\t\t\t\t{this.props.case.applicants &&\r\n\t\t\t\t\t\t\tthis.props.case.applicants.map((x, ix) => (\r\n\t\t\t\t\t\t\t\t
  • \r\n\t\t\t\t\t\t\t\t\t{x.firstName || ''} {x.lastName || ''}\r\n\t\t\t\t\t\t\t\t
  • \r\n\t\t\t\t\t\t\t))\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\t{/*this.props.case.companies && false &&\r\n\t\t\t\t\t\t\tthis.props.case.companies.map((x, ix) => (\r\n\t\t\t\t\t\t\t\t
  • \r\n\t\t\t\t\t\t\t\t\t{x.name||''} {x.orgNumber||''}\r\n\t\t\t\t\t\t\t\t
  • \r\n\t\t\t\t\t\t\t))\r\n\t\t\t\t\t\t\t*/}\r\n\t\t\t\t\t\t{c.collaterals && c.collaterals.map((x, ix) => (\r\n\t\t\t\t\t\t\t
  • {x.name || ''} {x.municipality || ''}
  • \r\n\t\t\t\t\t\t))\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\t{c.euSupports && c.euSupports.map((x, ix) => (\r\n\t\t\t\t\t\t\t
  • {euSupportService.getEuTypeDisplayName(x.euType)}
  • \r\n\t\t\t\t\t\t))\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\t{c.guarantors && c.guarantors.map((x, ix) => (\r\n\t\t\t\t\t\t\t
  • {x.name || ''}
  • \r\n\t\t\t\t\t\t))\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t
\r\n\t\t\t\t
\r\n\t\t\t\t
\r\n\t\t\t\t\t\r\n\t\t\t\t
\r\n\t\t\t
\r\n\t\t);\r\n\t}\r\n}\r\n","import React from 'react';\r\nimport ClassNames from 'classnames';\r\nimport './PageContent.scss';\r\n\r\nexport enum PageStyle {\r\n\tGray,\r\n\tTransparent,\r\n\tBlue\r\n}\r\n\r\ninterface Props {\r\n\tstyle: PageStyle;\r\n\tclassName?: string;\r\n}\r\n\r\nexport const PageContent: React.FunctionComponent = (props) => {\r\n\tconst classNames = ClassNames(\r\n\t\t'PageContent',\r\n\t\tprops.className,\r\n\t\tPageStyle[props.style]\r\n\t);\r\n\r\n\treturn
{props.children}
;\r\n};\r\n","import React from 'react';\r\nimport './Required.scss';\r\n\r\nexport const Required: React.FunctionComponent = (props) => {\r\n\treturn (\r\n\t\t<> *\r\n\t);\r\n};\r\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = exports.isBrowser = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _reactDom = _interopRequireDefault(require(\"react-dom\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nvar useCreatePortal = typeof _reactDom[\"default\"].createPortal === 'function';\nvar isBrowser = typeof window !== 'undefined';\nexports.isBrowser = isBrowser;\n\nvar Portal =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inherits(Portal, _React$Component);\n\n function Portal(props) {\n var _this;\n\n _classCallCheck(this, Portal);\n\n _this = _possibleConstructorReturn(this, _getPrototypeOf(Portal).call(this, props));\n\n if (isBrowser) {\n _this.container = document.createElement('div');\n document.body.appendChild(_this.container);\n\n _this.renderLayer();\n }\n\n return _this;\n }\n\n _createClass(Portal, [{\n key: \"componentDidUpdate\",\n value: function componentDidUpdate() {\n this.renderLayer();\n }\n }, {\n key: \"componentWillUnmount\",\n value: function componentWillUnmount() {\n if (!useCreatePortal) {\n _reactDom[\"default\"].unmountComponentAtNode(this.container);\n }\n\n document.body.removeChild(this.container);\n }\n }, {\n key: \"renderLayer\",\n value: function renderLayer() {\n if (!useCreatePortal) {\n _reactDom[\"default\"].unstable_renderSubtreeIntoContainer(this, this.props.children, this.container);\n }\n }\n }, {\n key: \"render\",\n value: function render() {\n if (useCreatePortal) {\n return _reactDom[\"default\"].createPortal(this.props.children, this.container);\n }\n\n return null;\n }\n }]);\n\n return Portal;\n}(_react[\"default\"].Component);\n\nPortal.propTypes = {\n children: _propTypes[\"default\"].node.isRequired\n};\nvar _default = Portal;\nexports[\"default\"] = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getScrollTop = getScrollTop;\nexports.getScrollLeft = getScrollLeft;\nexports.getArrowSpacing = getArrowSpacing;\nexports.getScrollParent = getScrollParent;\nexports.noArrowDistance = exports.bodyPadding = exports.minArrowPadding = void 0;\n\n/**\n * a handful of shared functions and constants\n */\nvar minArrowPadding = 5;\nexports.minArrowPadding = minArrowPadding;\nvar bodyPadding = 10;\nexports.bodyPadding = bodyPadding;\nvar noArrowDistance = 3;\n/**\n * cross browser scroll positions\n */\n\nexports.noArrowDistance = noArrowDistance;\n\nfunction getScrollTop() {\n return window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0;\n}\n\nfunction getScrollLeft() {\n return window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft || 0;\n}\n\nfunction getArrowSpacing(props) {\n var defaultArrowSpacing = props.arrow ? props.arrowSize : noArrowDistance;\n return typeof props.distance === 'number' ? props.distance : defaultArrowSpacing;\n}\n/**\n * get first ancestor that might scroll\n */\n\n\nfunction getScrollParent(element) {\n var style = getComputedStyle(element);\n var scrollParent = window;\n\n if (style.position !== 'fixed') {\n var parent = element.parentElement;\n\n while (parent) {\n var parentStyle = getComputedStyle(parent);\n\n if (/(auto|scroll)/.test(parentStyle.overflow + parentStyle.overflowY + parentStyle.overflowX)) {\n scrollParent = parent;\n parent = undefined;\n } else {\n parent = parent.parentElement;\n }\n }\n }\n\n return scrollParent;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = getDirection;\n\nvar _functions = require(\"./functions\");\n\n/**\n * Checks the intended tip direction and falls back if not enough space\n */\nfunction checkLeftRightWidthSufficient(tip, target, distance, bodyPadding) {\n var targetRect = target.getBoundingClientRect();\n var deadSpace = Math.min(targetRect.left, document.documentElement.clientWidth - targetRect.right);\n return tip.offsetWidth + target.offsetWidth + distance + bodyPadding + deadSpace < document.documentElement.clientWidth;\n}\n\nfunction checkTargetSufficientlyVisible(target, tip, props) {\n var targetRect = target.getBoundingClientRect();\n var bottomOverhang = targetRect.bottom > window.innerHeight;\n var topOverhang = targetRect.top < 0; // if the target is taller than the viewport (and we know there's sufficient left/right width before this is called),\n // then go with the left/right direction as top/bottom will both be off screen\n\n if (topOverhang && bottomOverhang) {\n return true;\n } // if the target is bigger than the tip, we need to check if enough of the target is visible\n\n\n if (target.offsetHeight > tip.offsetHeight) {\n var halfTargetHeight = target.offsetHeight / 2;\n var arrowClearance = props.arrowSize + _functions.minArrowPadding;\n var bottomOverhangAmount = targetRect.bottom - window.innerHeight;\n var topOverhangAmount = -targetRect.top;\n var targetCenterToBottomOfWindow = halfTargetHeight - bottomOverhangAmount;\n var targetCenterToTopOfWindow = halfTargetHeight - topOverhangAmount;\n return targetCenterToBottomOfWindow >= arrowClearance && targetCenterToTopOfWindow >= arrowClearance;\n } // otherwise just check that the whole target is visible\n\n\n return !bottomOverhang && !topOverhang;\n}\n\nfunction checkForArrowOverhang(props, arrowStyles, bodyPadding) {\n var scrollLeft = (0, _functions.getScrollLeft)();\n var hasLeftClearance = arrowStyles.positionStyles.left - scrollLeft > bodyPadding;\n var hasRightClearance = arrowStyles.positionStyles.left + props.arrowSize * 2 < scrollLeft + document.documentElement.clientWidth - bodyPadding;\n return !hasLeftClearance || !hasRightClearance;\n}\n\nfunction getDirection(currentDirection, tip, target, props, bodyPadding, arrowStyles, recursive) {\n // can't switch until target is rendered\n if (!target) {\n return currentDirection;\n }\n\n var targetRect = target.getBoundingClientRect();\n var arrowSpacing = (0, _functions.getArrowSpacing)(props); // this is how much space is needed to display the tip above or below the target\n\n var heightOfTipWithArrow = tip.offsetHeight + arrowSpacing + bodyPadding;\n var spaceBelowTarget = window.innerHeight - targetRect.bottom;\n var spaceAboveTarget = targetRect.top;\n var hasSpaceBelow = spaceBelowTarget >= heightOfTipWithArrow;\n var hasSpaceAbove = spaceAboveTarget >= heightOfTipWithArrow;\n\n switch (currentDirection) {\n case 'right':\n // if the window is not wide enough try top (which falls back to down)\n if (!checkLeftRightWidthSufficient(tip, target, arrowSpacing, bodyPadding) || !checkTargetSufficientlyVisible(target, tip, props)) {\n return getDirection('up', tip, target, arrowSpacing, bodyPadding, arrowStyles, true);\n }\n\n if (document.documentElement.clientWidth - targetRect.right < tip.offsetWidth + arrowSpacing + bodyPadding) {\n return 'left';\n }\n\n return 'right';\n\n case 'left':\n // if the window is not wide enough try top (which falls back to down)\n if (!checkLeftRightWidthSufficient(tip, target, arrowSpacing, bodyPadding) || !checkTargetSufficientlyVisible(target, tip, props)) {\n return getDirection('up', tip, target, arrowSpacing, bodyPadding, arrowStyles, true);\n }\n\n if (targetRect.left < tip.offsetWidth + arrowSpacing + bodyPadding) {\n return 'right';\n }\n\n return 'left';\n\n case 'up':\n if (!recursive && arrowStyles && checkForArrowOverhang(props, arrowStyles, bodyPadding)) {\n return getDirection('left', tip, target, arrowSpacing, bodyPadding, arrowStyles, true);\n }\n\n if (!hasSpaceAbove) {\n if (hasSpaceBelow) {\n return 'down';\n }\n\n if (!recursive && checkLeftRightWidthSufficient(tip, target, arrowSpacing, bodyPadding)) {\n return getDirection('right', tip, target, arrowSpacing, bodyPadding, arrowStyles, true);\n }\n }\n\n return 'up';\n\n case 'down':\n default:\n if (!recursive && arrowStyles && checkForArrowOverhang(props, arrowStyles, bodyPadding)) {\n return getDirection('right', tip, target, arrowSpacing, bodyPadding, arrowStyles, true);\n }\n\n if (!hasSpaceBelow) {\n // if there's no space below, but space above, switch to that direction\n if (hasSpaceAbove) {\n return 'up'; // if there's not space above or below, check if there would be space left or right\n }\n\n if (!recursive && checkLeftRightWidthSufficient(tip, target, arrowSpacing, bodyPadding)) {\n return getDirection('right', tip, target, arrowSpacing, bodyPadding, arrowStyles, true);\n } // if there's no space in any direction, default to the original direction\n\n }\n\n return 'down';\n }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = positions;\n\nvar _getDirection = _interopRequireDefault(require(\"./getDirection\"));\n\nvar _functions = require(\"./functions\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**\n * Sets tip max width safely for mobile\n */\nfunction getTipMaxWidth() {\n return typeof document !== 'undefined' ? document.documentElement.clientWidth - _functions.bodyPadding * 2 : 1000;\n}\n/**\n * Parses align mode from direction if specified with hyphen, defaulting to middle if not -\n * e.g. 'left-start' is mode 'start' and 'left' would be the default of 'middle'\n */\n\n\nfunction parseAlignMode(direction) {\n var directionArray = direction.split('-');\n\n if (directionArray.length > 1) {\n return directionArray[1];\n }\n\n return 'middle';\n}\n/**\n * Gets wrapper's left position for top/bottom tooltips as well as needed width restriction\n */\n\n\nfunction getUpDownPosition(tip, target, state, direction, alignMode, props) {\n var left = -10000000;\n var top;\n var transform = state.showTip ? undefined : 'translateX(-10000000px)';\n var arrowSpacing = (0, _functions.getArrowSpacing)(props);\n\n if (tip) {\n // get wrapper left position\n var scrollLeft = (0, _functions.getScrollLeft)();\n var targetRect = target.getBoundingClientRect();\n var targetLeft = targetRect.left + scrollLeft;\n var halfTargetWidth = Math.round(target.offsetWidth / 2);\n var tipWidth = Math.min(getTipMaxWidth(), tip.offsetWidth);\n var arrowCenter = targetLeft + halfTargetWidth;\n var arrowLeft = arrowCenter - props.arrowSize;\n var arrowRight = arrowCenter + props.arrowSize;\n\n if (alignMode === 'start') {\n left = props.arrow ? Math.min(arrowLeft, targetLeft) : targetLeft;\n } else if (alignMode === 'end') {\n var rightWithArrow = Math.max(arrowRight, targetLeft + target.offsetWidth);\n var rightEdge = props.arrow ? rightWithArrow : targetLeft + target.offsetWidth;\n left = Math.max(rightEdge - tipWidth, _functions.bodyPadding + scrollLeft);\n } else {\n var centeredLeft = targetLeft + halfTargetWidth - Math.round(tipWidth / 2);\n var availableSpaceOnLeft = _functions.bodyPadding + scrollLeft;\n left = Math.max(centeredLeft, availableSpaceOnLeft);\n } // check for right overhang\n\n\n var rightOfTip = left + tipWidth;\n var rightOfScreen = scrollLeft + document.documentElement.clientWidth - _functions.bodyPadding;\n var rightOverhang = rightOfTip - rightOfScreen;\n\n if (rightOverhang > 0) {\n left -= rightOverhang;\n }\n\n if (direction === 'up') {\n top = targetRect.top + (0, _functions.getScrollTop)() - (tip.offsetHeight + arrowSpacing);\n } else {\n top = targetRect.bottom + (0, _functions.getScrollTop)() + arrowSpacing;\n }\n }\n\n return {\n left: left,\n top: top,\n transform: transform\n };\n}\n/**\n * gets top position for left/right arrows\n */\n\n\nfunction getLeftRightPosition(tip, target, state, direction, alignMode, props) {\n var left = -10000000;\n var top = 0;\n var transform = state.showTip ? undefined : 'translateX(-10000000px)';\n var arrowSpacing = (0, _functions.getArrowSpacing)(props);\n var arrowPadding = props.arrow ? _functions.minArrowPadding : 0;\n\n if (tip) {\n var scrollTop = (0, _functions.getScrollTop)();\n var scrollLeft = (0, _functions.getScrollLeft)();\n var targetRect = target.getBoundingClientRect();\n var targetTop = targetRect.top + scrollTop;\n var halfTargetHeight = Math.round(target.offsetHeight / 2);\n var arrowTop = targetTop + halfTargetHeight - props.arrowSize;\n var arrowBottom = targetRect.top + scrollTop + halfTargetHeight + props.arrowSize; // TODO: handle close to edges better\n\n if (alignMode === 'start') {\n top = props.arrow ? Math.min(targetTop, arrowTop) : targetTop;\n } else if (alignMode === 'end') {\n var topForBottomAlign = targetRect.bottom + scrollTop - tip.offsetHeight;\n top = props.arrow ? Math.max(topForBottomAlign, arrowBottom - tip.offsetHeight) : topForBottomAlign;\n } else {\n // default to middle, but don't go below body\n var centeredTop = Math.max(targetTop + halfTargetHeight - Math.round(tip.offsetHeight / 2), _functions.bodyPadding + scrollTop); // make sure it doesn't go below the arrow\n\n top = Math.min(centeredTop, arrowTop - arrowPadding);\n } // check for bottom overhang\n\n\n var bottomOverhang = top - scrollTop + tip.offsetHeight + _functions.bodyPadding - window.innerHeight;\n\n if (bottomOverhang > 0) {\n // try to add the body padding below the tip, but don't offset too far from the arrow\n top = Math.max(top - bottomOverhang, arrowBottom + arrowPadding - tip.offsetHeight);\n }\n\n if (direction === 'right') {\n left = targetRect.right + arrowSpacing + scrollLeft;\n } else {\n left = targetRect.left - arrowSpacing - tip.offsetWidth + scrollLeft;\n }\n }\n\n return {\n left: left,\n top: top,\n transform: transform\n };\n}\n/**\n * sets the Arrow styles based on direction\n */\n\n\nfunction getArrowStyles(target, tip, direction, state, props) {\n if (!target || !props.arrow) {\n return {\n positionStyles: {\n top: '0',\n left: '-10000000px'\n }\n };\n }\n\n var targetRect = target.getBoundingClientRect();\n var halfTargetHeight = Math.round(target.offsetHeight / 2);\n var halfTargetWidth = Math.round(target.offsetWidth / 2);\n var scrollTop = (0, _functions.getScrollTop)();\n var scrollLeft = (0, _functions.getScrollLeft)();\n var arrowSpacing = (0, _functions.getArrowSpacing)(props);\n var borderStyles = {};\n var positionStyles = {};\n\n switch (direction) {\n case 'right':\n borderStyles.borderTop = \"\".concat(props.arrowSize, \"px solid transparent\");\n borderStyles.borderBottom = \"\".concat(props.arrowSize, \"px solid transparent\");\n\n if (props.background) {\n borderStyles.borderRight = \"\".concat(props.arrowSize, \"px solid \").concat(props.background);\n } else {\n borderStyles.borderRightWidth = \"\".concat(props.arrowSize, \"px\");\n borderStyles.borderRightStyle = 'solid';\n }\n\n positionStyles.top = state.showTip && tip ? targetRect.top + scrollTop + halfTargetHeight - props.arrowSize : '-10000000px';\n positionStyles.left = targetRect.right + scrollLeft + arrowSpacing - props.arrowSize;\n break;\n\n case 'left':\n borderStyles.borderTop = \"\".concat(props.arrowSize, \"px solid transparent\");\n borderStyles.borderBottom = \"\".concat(props.arrowSize, \"px solid transparent\");\n\n if (props.background) {\n borderStyles.borderLeft = \"\".concat(props.arrowSize, \"px solid \").concat(props.background);\n } else {\n borderStyles.borderLeftWidth = \"\".concat(props.arrowSize, \"px\");\n borderStyles.borderLeftStyle = 'solid';\n }\n\n positionStyles.top = state.showTip && tip ? targetRect.top + scrollTop + halfTargetHeight - props.arrowSize : '-10000000px';\n positionStyles.left = targetRect.left + scrollLeft - arrowSpacing - 1;\n break;\n\n case 'up':\n borderStyles.borderLeft = \"\".concat(props.arrowSize, \"px solid transparent\");\n borderStyles.borderRight = \"\".concat(props.arrowSize, \"px solid transparent\"); // if color is styled with css, we need everything except border-color, if styled with props, we add entire border rule\n\n if (props.background) {\n borderStyles.borderTop = \"\".concat(props.arrowSize, \"px solid \").concat(props.background);\n } else {\n borderStyles.borderTopWidth = \"\".concat(props.arrowSize, \"px\");\n borderStyles.borderTopStyle = 'solid';\n }\n\n positionStyles.left = state.showTip && tip ? targetRect.left + scrollLeft + halfTargetWidth - props.arrowSize : '-10000000px';\n positionStyles.top = targetRect.top + scrollTop - arrowSpacing;\n break;\n\n case 'down':\n default:\n borderStyles.borderLeft = \"\".concat(props.arrowSize, \"px solid transparent\");\n borderStyles.borderRight = \"\".concat(props.arrowSize, \"px solid transparent\");\n\n if (props.background) {\n borderStyles.borderBottom = \"10px solid \".concat(props.background);\n } else {\n borderStyles.borderBottomWidth = \"\".concat(props.arrowSize, \"px\");\n borderStyles.borderBottomStyle = 'solid';\n }\n\n positionStyles.left = state.showTip && tip ? targetRect.left + scrollLeft + halfTargetWidth - props.arrowSize : '-10000000px';\n positionStyles.top = targetRect.bottom + scrollTop + arrowSpacing - props.arrowSize;\n break;\n }\n\n return {\n borderStyles: borderStyles,\n positionStyles: positionStyles\n };\n}\n/**\n * Returns the positions style rules\n */\n\n\nfunction positions(direction, forceDirection, tip, target, state, props) {\n var alignMode = parseAlignMode(direction);\n var trimmedDirection = direction.split('-')[0];\n var realDirection = trimmedDirection;\n\n if (!forceDirection && tip) {\n var testArrowStyles = props.arrow && getArrowStyles(target, tip, trimmedDirection, state, props);\n realDirection = (0, _getDirection[\"default\"])(trimmedDirection, tip, target, props, _functions.bodyPadding, testArrowStyles);\n }\n\n var maxWidth = getTipMaxWidth(); // force the tip to display the width we measured everything at when visible\n\n var width;\n\n if (tip) {\n // adding the exact width on the first render forces a bogus line break, so add 1px the first time\n var spacer = tip.style.width ? 0 : 1;\n width = Math.min(tip.offsetWidth, maxWidth) + spacer;\n }\n\n var tipPosition = realDirection === 'up' || realDirection === 'down' ? getUpDownPosition(tip, target, state, realDirection, alignMode, props) : getLeftRightPosition(tip, target, state, realDirection, alignMode, props);\n return {\n tip: _objectSpread({}, tipPosition, {\n maxWidth: maxWidth,\n width: width\n }),\n arrow: getArrowStyles(target, tip, realDirection, state, props),\n realDirection: realDirection\n };\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _Portal = _interopRequireWildcard(require(\"./Portal\"));\n\nvar _position = _interopRequireDefault(require(\"./position\"));\n\nvar _functions = require(\"./functions\");\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj[\"default\"] = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// default colors\nvar defaultColor = '#fff';\nvar defaultBg = '#333';\nvar resizeThrottle = 100;\nvar resizeThreshold = 5;\n\nvar stopProp = function stopProp(e) {\n return e.stopPropagation();\n};\n\nvar Tooltip =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inherits(Tooltip, _React$Component);\n\n _createClass(Tooltip, null, [{\n key: \"getDerivedStateFromProps\",\n value: function getDerivedStateFromProps(nextProps) {\n return _Portal.isBrowser && nextProps.isOpen ? {\n hasBeenShown: true\n } : null;\n }\n }]);\n\n function Tooltip() {\n var _this;\n\n _classCallCheck(this, Tooltip);\n\n _this = _possibleConstructorReturn(this, _getPrototypeOf(Tooltip).call(this));\n\n _defineProperty(_assertThisInitialized(_this), \"debounceTimeout\", false);\n\n _defineProperty(_assertThisInitialized(_this), \"hoverTimeout\", false);\n\n _this.state = {\n showTip: false,\n hasHover: false,\n ignoreShow: false,\n hasBeenShown: false\n };\n _this.showTip = _this.showTip.bind(_assertThisInitialized(_this));\n _this.hideTip = _this.hideTip.bind(_assertThisInitialized(_this));\n _this.checkHover = _this.checkHover.bind(_assertThisInitialized(_this));\n _this.toggleTip = _this.toggleTip.bind(_assertThisInitialized(_this));\n _this.startHover = _this.startHover.bind(_assertThisInitialized(_this));\n _this.endHover = _this.endHover.bind(_assertThisInitialized(_this));\n _this.listenResizeScroll = _this.listenResizeScroll.bind(_assertThisInitialized(_this));\n _this.handleResizeScroll = _this.handleResizeScroll.bind(_assertThisInitialized(_this));\n _this.bodyTouchStart = _this.bodyTouchStart.bind(_assertThisInitialized(_this));\n _this.bodyTouchEnd = _this.bodyTouchEnd.bind(_assertThisInitialized(_this));\n _this.targetTouchStart = _this.targetTouchStart.bind(_assertThisInitialized(_this));\n _this.targetTouchEnd = _this.targetTouchEnd.bind(_assertThisInitialized(_this));\n return _this;\n }\n\n _createClass(Tooltip, [{\n key: \"componentDidMount\",\n value: function componentDidMount() {\n // if the isOpen prop is passed on first render we need to immediately trigger a second render,\n // because the tip ref is needed to calculate the position\n if (this.props.isOpen) {\n // eslint-disable-next-line react/no-did-mount-set-state\n this.setState({\n isOpen: true\n });\n }\n\n this.scrollParent = (0, _functions.getScrollParent)(this.target);\n window.addEventListener('resize', this.listenResizeScroll);\n this.scrollParent.addEventListener('scroll', this.listenResizeScroll);\n window.addEventListener('touchstart', this.bodyTouchStart);\n window.addEventListener('touchEnd', this.bodyTouchEnd);\n }\n }, {\n key: \"componentDidUpdate\",\n value: function componentDidUpdate(_, prevState) {\n // older versions of react won't leverage getDerivedStateFromProps, TODO: remove when < 16.3 support is dropped\n if (!this.state.hasBeenShown && this.props.isOpen) {\n // eslint-disable-next-line react/no-did-update-set-state\n this.setState({\n hasBeenShown: true\n });\n return setTimeout(this.showTip, 0);\n } // we need to render once to get refs in place, then we can make the calculations on a followup render\n // this only has to happen the first time the tip is shown, and allows us to not render every tip on the page with initial render.\n\n\n if (!prevState.hasBeenShown && this.state.hasBeenShown) {\n this.showTip();\n }\n }\n }, {\n key: \"componentWillUnmount\",\n value: function componentWillUnmount() {\n window.removeEventListener('resize', this.listenResizeScroll);\n this.scrollParent.removeEventListener('scroll', this.listenResizeScroll);\n window.removeEventListener('touchstart', this.bodyTouchStart);\n window.removeEventListener('touchEnd', this.bodyTouchEnd);\n clearTimeout(this.debounceTimeout);\n clearTimeout(this.hoverTimeout);\n }\n }, {\n key: \"listenResizeScroll\",\n value: function listenResizeScroll() {\n clearTimeout(this.debounceTimeout);\n this.debounceTimeout = setTimeout(this.handleResizeScroll, resizeThrottle);\n\n if (this.state.targetTouch) {\n this.setState({\n targetTouch: undefined\n });\n }\n }\n }, {\n key: \"handleResizeScroll\",\n value: function handleResizeScroll() {\n if (this.state.showTip) {\n // if we're showing the tip and the resize was actually a signifigant change, then setState to re-render and calculate position\n var clientWidth = Math.round(document.documentElement.clientWidth / resizeThreshold) * resizeThreshold;\n this.setState({\n clientWidth: clientWidth\n });\n }\n }\n }, {\n key: \"targetTouchStart\",\n value: function targetTouchStart() {\n this.setState({\n targetTouch: true\n });\n }\n }, {\n key: \"targetTouchEnd\",\n value: function targetTouchEnd() {\n if (this.state.targetTouch) {\n this.toggleTip();\n }\n }\n }, {\n key: \"bodyTouchEnd\",\n value: function bodyTouchEnd() {\n if (this.state.targetTouch) {\n this.setState({\n targetTouch: undefined\n });\n }\n }\n }, {\n key: \"bodyTouchStart\",\n value: function bodyTouchStart(e) {\n // if it's a controlled tip we don't want to auto-dismiss, otherwise we just ignore taps inside the tip\n if (!(this.target && this.target.contains(e.target)) && !(this.tip && this.tip.contains(e.target)) && !this.props.isOpen) {\n this.hideTip();\n }\n }\n }, {\n key: \"toggleTip\",\n value: function toggleTip() {\n this.state.showTip ? this.hideTip() : this.showTip();\n }\n }, {\n key: \"showTip\",\n value: function showTip() {\n var _this2 = this;\n\n if (!this.state.hasBeenShown) {\n // this will render once, then fire componentDidUpdate, which will show the tip\n return this.setState({\n hasBeenShown: true\n });\n }\n\n if (!this.state.showTip) {\n this.setState({\n showTip: true\n }, function () {\n if (typeof _this2.props.onToggle === 'function') {\n _this2.props.onToggle(_this2.state.showTip);\n }\n });\n }\n }\n }, {\n key: \"hideTip\",\n value: function hideTip() {\n var _this3 = this;\n\n this.setState({\n hasHover: false\n });\n\n if (this.state.showTip) {\n this.setState({\n showTip: false\n }, function () {\n if (typeof _this3.props.onToggle === 'function') {\n _this3.props.onToggle(_this3.state.showTip);\n }\n });\n }\n }\n }, {\n key: \"startHover\",\n value: function startHover() {\n if (!this.state.ignoreShow) {\n this.setState({\n hasHover: true\n });\n clearTimeout(this.hoverTimeout);\n this.hoverTimeout = setTimeout(this.checkHover, this.props.hoverDelay);\n }\n }\n }, {\n key: \"endHover\",\n value: function endHover() {\n this.setState({\n hasHover: false\n });\n clearTimeout(this.hoverTimeout);\n this.hoverTimeout = setTimeout(this.checkHover, this.props.mouseOutDelay || this.props.hoverDelay);\n }\n }, {\n key: \"checkHover\",\n value: function checkHover() {\n this.state.hasHover ? this.showTip() : this.hideTip();\n }\n }, {\n key: \"render\",\n value: function render() {\n var _this4 = this;\n\n var _this$props = this.props,\n arrow = _this$props.arrow,\n arrowSize = _this$props.arrowSize,\n background = _this$props.background,\n className = _this$props.className,\n children = _this$props.children,\n color = _this$props.color,\n content = _this$props.content,\n direction = _this$props.direction,\n distance = _this$props.distance,\n eventOff = _this$props.eventOff,\n eventOn = _this$props.eventOn,\n eventToggle = _this$props.eventToggle,\n forceDirection = _this$props.forceDirection,\n isOpen = _this$props.isOpen,\n mouseOutDelay = _this$props.mouseOutDelay,\n padding = _this$props.padding,\n styles = _this$props.styles,\n TagName = _this$props.tagName,\n tipContentHover = _this$props.tipContentHover,\n tipContentClassName = _this$props.tipContentClassName,\n useDefaultStyles = _this$props.useDefaultStyles,\n useHover = _this$props.useHover,\n arrowContent = _this$props.arrowContent;\n var isControlledByProps = typeof isOpen !== 'undefined' && isOpen !== null;\n var showTip = isControlledByProps ? isOpen : this.state.showTip;\n\n var wrapperStyles = _objectSpread({\n position: 'relative'\n }, styles);\n\n var props = {\n style: wrapperStyles,\n ref: function ref(target) {\n _this4.target = target;\n },\n className: className\n };\n var portalProps = {\n // keep clicks on the tip from closing click controlled tips\n onClick: stopProp\n }; // event handling\n\n if (eventOff) {\n props[eventOff] = this.hideTip;\n }\n\n if (eventOn) {\n props[eventOn] = this.showTip;\n }\n\n if (eventToggle) {\n props[eventToggle] = this.toggleTip; // only use hover if they don't have a toggle event\n } else if (useHover && !isControlledByProps) {\n props.onMouseEnter = this.startHover;\n props.onMouseLeave = tipContentHover || mouseOutDelay ? this.endHover : this.hideTip;\n props.onTouchStart = this.targetTouchStart;\n props.onTouchEnd = this.targetTouchEnd;\n\n if (tipContentHover) {\n portalProps.onMouseEnter = this.startHover;\n portalProps.onMouseLeave = this.endHover;\n portalProps.onTouchStart = stopProp;\n }\n } // conditional rendering of tip\n\n\n var tipPortal;\n\n if (this.state.hasBeenShown) {\n var currentPositions = (0, _position[\"default\"])(direction, forceDirection, this.tip, this.target, _objectSpread({}, this.state, {\n showTip: showTip\n }), {\n background: useDefaultStyles ? defaultBg : background,\n arrow: arrow,\n arrowSize: arrowSize,\n distance: distance\n });\n\n var tipStyles = _objectSpread({}, currentPositions.tip, {\n background: useDefaultStyles ? defaultBg : background,\n color: useDefaultStyles ? defaultColor : color,\n padding: padding,\n boxSizing: 'border-box',\n zIndex: this.props.zIndex,\n position: 'absolute',\n display: 'inline-block'\n });\n\n var arrowStyles = _objectSpread({}, currentPositions.arrow.positionStyles, arrowContent ? {} : currentPositions.arrow.borderStyles, {\n position: 'absolute',\n width: '0px',\n height: '0px',\n zIndex: this.props.zIndex + 1\n });\n\n tipPortal = _react[\"default\"].createElement(_Portal[\"default\"], null, _react[\"default\"].createElement(\"div\", _extends({}, portalProps, {\n className: typeof tipContentClassName !== 'undefined' ? tipContentClassName : className\n }), _react[\"default\"].createElement(\"span\", {\n className: \"react-tooltip-lite\",\n style: tipStyles,\n ref: function ref(tip) {\n _this4.tip = tip;\n }\n }, content), _react[\"default\"].createElement(\"span\", {\n className: \"react-tooltip-lite-arrow react-tooltip-lite-\".concat(currentPositions.realDirection, \"-arrow\"),\n style: arrowStyles\n }, arrowContent)));\n }\n\n return _react[\"default\"].createElement(TagName, props, children, tipPortal);\n }\n }]);\n\n return Tooltip;\n}(_react[\"default\"].Component);\n\n_defineProperty(Tooltip, \"propTypes\", {\n arrow: _propTypes[\"default\"].bool,\n arrowSize: _propTypes[\"default\"].number,\n background: _propTypes[\"default\"].string,\n children: _propTypes[\"default\"].node.isRequired,\n className: _propTypes[\"default\"].string,\n color: _propTypes[\"default\"].string,\n content: _propTypes[\"default\"].node.isRequired,\n direction: _propTypes[\"default\"].string,\n distance: _propTypes[\"default\"].number,\n eventOff: _propTypes[\"default\"].string,\n eventOn: _propTypes[\"default\"].string,\n eventToggle: _propTypes[\"default\"].string,\n forceDirection: _propTypes[\"default\"].bool,\n hoverDelay: _propTypes[\"default\"].number,\n isOpen: _propTypes[\"default\"].bool,\n mouseOutDelay: _propTypes[\"default\"].number,\n padding: _propTypes[\"default\"].oneOfType([_propTypes[\"default\"].string, _propTypes[\"default\"].number]),\n styles: _propTypes[\"default\"].object,\n tagName: _propTypes[\"default\"].string,\n tipContentHover: _propTypes[\"default\"].bool,\n tipContentClassName: _propTypes[\"default\"].string,\n useDefaultStyles: _propTypes[\"default\"].bool,\n useHover: _propTypes[\"default\"].bool,\n zIndex: _propTypes[\"default\"].number,\n onToggle: _propTypes[\"default\"].func,\n arrowContent: _propTypes[\"default\"].node\n});\n\n_defineProperty(Tooltip, \"defaultProps\", {\n arrow: true,\n arrowSize: 10,\n background: '',\n className: '',\n color: '',\n direction: 'up',\n distance: undefined,\n eventOff: undefined,\n eventOn: undefined,\n eventToggle: undefined,\n forceDirection: false,\n hoverDelay: 200,\n isOpen: undefined,\n mouseOutDelay: undefined,\n padding: '10px',\n styles: {},\n tagName: 'div',\n tipContentHover: false,\n tipContentClassName: undefined,\n useDefaultStyles: false,\n useHover: true,\n zIndex: 1000,\n onToggle: undefined,\n arrowContent: null\n});\n\nvar _default = Tooltip;\nexports[\"default\"] = _default;","import React from 'react';\r\nimport Tooltip from 'react-tooltip-lite';\r\nimport { THtml } from '../THtml';\r\n\r\nimport './Help.scss';\r\n\r\ninterface Props {\r\n\tclassName?: string;\r\n\tdirection?: string;\r\n\teventOff?: string;\r\n\teventOn?: string;\r\n\teventToggle?: string;\r\n\tforceDirection?: boolean;\r\n\thelpTextkey?: string;\r\n\thelpText?: string;\r\n\ttipContentHover?: boolean;\r\n\tuseHover?: boolean;\r\n}\r\n\r\nexport const Help: React.FunctionComponent = (props) => {\r\n\r\n\treturn (\r\n\t\t\r\n\t\t\t\t\t{props.helpTextkey && } \r\n\t\t\t\t\t{props.helpText}\r\n\t\t\t\t
\r\n\t\t\t}\r\n\t\t\tdirection={props.direction}\r\n\t\t\tdistance={15}\r\n\t\t\teventOn={props.eventOn}\r\n\t\t\teventOff={props.eventOff}\r\n\t\t\teventToggle={props.eventToggle}\r\n\t\t\tforceDirection={props.forceDirection}\r\n\t\t\thoverDelay={100}\r\n\t\t\tpadding=\"0\"\r\n\t\t\ttagName=\"div\"\r\n\t\t\ttipContentHover={props.tipContentHover}\r\n\t\t\tuseDefaultStyles={false}\r\n\t\t\tuseHover={props.useHover}>\r\n\t\t\t
\r\n\t\t\r\n\t);\r\n}\r\n\r\nHelp.defaultProps = {\r\n\tclassName: 'Help',\r\n\tdirection: 'down',\r\n\teventOn: '',\r\n\teventOff: '',\r\n\teventToggle: '',\r\n\tforceDirection: false,\r\n\ttipContentHover: true,\r\n\tuseHover: true,\r\n};\r\n","import React from 'react';\r\nimport { T } from '../T';\r\nimport { Application } from '../../../../models/AppModels';\r\nimport { Required } from '../Required/Required';\r\nimport { Help } from '../Help/Help';\r\nimport './Heading.scss';\r\n\r\ninterface Props {\r\n\tlevel:number; \r\n\tlabelTextkey?: string;\r\n\tlabelText?: string;\r\n\thelpTextkey?: string;\r\n\thelpText?: string;\r\n\tclassName?: string; \r\n\trequired?: boolean; // adds a marker for required fields\r\n}\r\n\r\nexport const Heading: React.FunctionComponent = (props) => {\r\n\r\n\tconst hasValidHelpTextkey =\r\n\t\tprops.helpTextkey && Application.instance.services.textService.text(props.helpTextkey)\r\n\t\t\t? true\r\n\t\t\t: false;\r\n\r\n\r\n\tconst helpTextkey = props.helpTextkey || props.labelTextkey + \"_Help\";\r\n\tconst helpText = props.helpText;\r\n\r\n\tlet content = () => {\r\n\t\treturn (\r\n\t\t\t<>\r\n\t\t\t\t{props.labelTextkey && }\r\n\t\t\t\t{props.labelText && props.labelText}\r\n\t\t\t\t{props.required && }\r\n\t\t\t\t{(hasValidHelpTextkey || helpText) && (\r\n\t\t\t\t\t\r\n\t\t\t\t)}\r\n\t\t\t\r\n\t\t);\r\n\t}\r\n\r\n\tconst level = props.level;\r\n\r\n\treturn (\r\n\t\t<>\r\n\t\t{level===1 &&

{content()}

}\r\n\t\t{level===2 &&

{content()}

}\r\n\t\t{level===3 &&

{content()}

}\r\n\t\t{level===4 &&

{content()}

}\r\n\t\t\r\n\t);\r\n};\r\n\r\n// Default props\r\nHeading.defaultProps = {\r\n\tclassName: 'Heading',\r\n};\r\n","import React from 'react';\r\nimport { Case } from '../../../models/SelmaModels';\r\nimport { T } from '../../widget/display/T';\r\nimport { AppComponent } from '../../AppComponent';\r\nimport { HomeCase } from '../HomeCase/HomeCase';\r\nimport { PageContent, PageStyle } from '../../layout/PageContent/PageContent';\r\nimport { THtml } from '../../widget/display/THtml';\r\nimport { Button } from '../../widget/input/Button/Button';\r\nimport { RouteComponentProps, withRouter } from 'react-router';\r\n\r\nimport './HomePage.scss';\r\nimport { Heading } from '../../widget/display/Heading/Heading';\r\nimport { UiModelConverter } from '../../../models/UiModelConverter';\r\n\r\ninterface Props extends RouteComponentProps {\r\n\tcases: Case[];\r\n\tcase?: Case;\r\n\tselectedCase: (c: Case) => void;\r\n}\r\n\r\nclass HomePage extends AppComponent {\r\n\tcases: Case[];\r\n\r\n\tconstructor(props: Props) {\r\n\t\tsuper(props);\r\n\t\tthis.cases = this.props.cases;\r\n\t\tthis.observeUpdate(this.cases);\r\n\r\n\t\tconst caseService = this.application.services.caseService;\r\n\t\tif (!this.props.cases || !this.props.cases.length) {\r\n\t\t\tcaseService.loadCases().then(cases => {\r\n\t\t\t\tcaseService.appendKycStatusToCases(cases).then(cases => {\r\n\t\t\t\t\t// nothing.\r\n\t\t\t\t})\r\n\t\t\t})\r\n\t\t}\r\n\t}\r\n\r\n\tselectedCase = (c: Case): void => {\r\n\t\tthis.application.services.caseService.setCurrentCase(c);\r\n\t\tthis.redirectToCase(c);\r\n\t};\r\n\r\n\tredirectToCase(c: Case): any {\r\n\t\tthis.props.history.push('/case');\r\n\t}\r\n\r\n\taddCase = (event: React.MouseEvent): void => {\r\n\t\tthis.application.services.caseService\r\n\t\t\t.addNewCase()\r\n\t\t\t.then((c: Case) => {\r\n\t\t\t\treturn this.selectedCase(c);\r\n\t\t\t});\r\n\t};\r\n\r\n\tdeleteCase = (c: Case): void => {\r\n\t\tthis.application.services.caseService\r\n\t\t\t.deleteCase(this.props.cases, c);\r\n\t};\r\n\r\n\trender() {\r\n\t\tconst caseService = this.application.services.caseService;\r\n\t\tconst c = this.props.case;\r\n\t\tlet cases = this.props.cases; // this.cases; \r\n\t\tconst hasCases = cases && cases.length > 0;\r\n\r\n\t\tconst hasOngoingCase = caseService.hasOngoingCase(cases);\r\n\t\tconst tooYoung = UiModelConverter.getAgeBySsn(this.application.services.sessionService.getSsn()) < 18;\r\n\t\tconst canAddCase = !hasOngoingCase && !tooYoung;\r\n\r\n\t\treturn (\r\n\t\t\t
\r\n\t\t\t\t\r\n\t\t\t\t\t
\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t\t

\r\n\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t

\r\n\t\t\t\t\t
\r\n\t\t\t\t\t
\r\n\t\t\t\t\t\t{hasCases ? (\r\n\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t) : (\r\n\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t)}\r\n\t\t\t\t\t\t{hasCases &&\r\n\t\t\t\t\t\t\tthis.props.cases.map((x) => {\r\n\t\t\t\t\t\t\t\ttry {\r\n\t\t\t\t\t\t\t\t\treturn (\r\n\t\t\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t\t\t\t
\r\n\t\t\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t\t\t} catch {\r\n\t\t\t\t\t\t\t\t\treturn null;\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t})\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t\t{hasOngoingCase &&\r\n\t\t\t\t\t\t\t

\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t

\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\t{tooYoung &&\r\n\t\t\t\t\t\t\t

\r\n\t\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\t

\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t
\r\n\t\t\t\t\r\n\t\t\t
\r\n\t\t);\r\n\t}\r\n}\r\n\r\nexport default withRouter(HomePage);\r\n","import React from 'react';\r\nimport { PageContent, PageStyle } from '../layout/PageContent/PageContent';\r\nimport { Heading } from '../widget/display/Heading/Heading';\r\nimport { withRouter, RouteComponentProps } from 'react-router';\r\nimport './AccessDenied.scss';\r\nimport { THtml } from '../widget/display/THtml';\r\nimport { Application } from \"../../models/AppModels\";\r\n\r\ninterface AccessDeniedProps extends RouteComponentProps {}\r\n\r\nconst AccessDenied = (props: AccessDeniedProps) => {\r\n const application = Application.instance;\r\n var sessionService = application.services.sessionService;\r\n var isLoggedIn = sessionService.isLoggedIn();\r\n\r\n\treturn (\r\n\t\t
\r\n {\r\n isLoggedIn && (\r\n
\r\n \r\n

\r\n \r\n

\r\n
\r\n
)\r\n }\r\n\t\t
\r\n\t);\r\n};\r\n\r\nexport default withRouter(AccessDenied);\r\n","import React, { Component } from 'react';\r\nimport { AppComponent } from '../AppComponent';\r\nimport { T } from '../widget/display/T';\r\nimport { THtml } from '../widget/display/THtml';\r\nimport { Heading } from '../widget/display/Heading/Heading';\r\nimport { StepContext } from './CaseSteps';\r\n\r\ninterface Props {\r\n\tcontext: StepContext;\r\n\ttitleTextkey: string;\r\n\tdescriptionTextkey: string;\r\n}\r\n\r\nexport class StepHeader extends AppComponent {\r\n\tconstructor(props: Props) {\r\n\t\tsuper(props);\r\n\t}\r\n\r\n\trender() {\r\n\t\tconst c = this.props.context.case;\r\n\t\tlet helpText;\r\n\t\tif(c.number) {\r\n\t\t\thelpText = this.application.services.textService.textOrEmpty(\"Home_CaseN\") + c.number;\r\n\t\t\t\r\n\t\t\thelpText += \", ändrat \" + c.lastAccessedDate.toLocaleString();\r\n\t\t}\r\n\r\n\t\treturn (\r\n\t\t\t
\r\n\t\t\t\t\r\n\t\t\t\t

\r\n\t\t\t\t\t\r\n\t\t\t\t

\r\n\t\t\t
\r\n\t\t);\r\n\t}\r\n}\r\n","import React from 'react';\r\nimport { T } from '../T';\r\nimport { Required } from '../Required/Required';\r\nimport { Help } from '../Help/Help';\r\nimport { Application } from '../../../../models/AppModels';\r\nimport './Label.scss';\r\n\r\ninterface Props {\r\n\tlabelTextkey?: string;\r\n\tlabelText?: string;\r\n\tfor?: string;\r\n\tclassName?: string;\r\n\trequired?: boolean; // adds a marker for required fields\r\n}\r\n\r\nexport const Label: React.FunctionComponent = (props) => {\r\n\r\n\tconst helpTextkey = (props.labelTextkey) ? props.labelTextkey + '_Help' : null;\r\n\tconst hasValidHelpTextkey = (helpTextkey && Application.instance.services.textService.text(helpTextkey))\r\n\t\t\t? true\r\n\t\t\t: false;\r\n\r\n\treturn (\r\n\t\t\r\n\t\t\t{props.labelTextkey && }\r\n\t\t\t{props.labelText && props.labelText}\r\n\t\t\t{props.required && }\r\n\t\t\t{hasValidHelpTextkey && (\r\n\t\t\t\t\r\n\t\t\t)}\r\n\t\t\r\n\t);\r\n};\r\n\r\n\r\n// Default props\r\nLabel.defaultProps = {\r\n\tclassName: 'Label',\r\n};\r\n","import React from 'react';\r\nimport ClassNames from 'classnames';\r\nimport './FormUnit.scss';\r\n\r\nexport enum FormUnitPadding {\r\n\tNone = 'PaddingNone',\r\n\tSmall = 'PaddingSmall',\r\n\tNormal = 'PaddingNormal',\r\n\tLarge = 'PaddingLarge',\r\n\tXL = 'PaddingXL',\r\n}\r\n\r\nexport enum FormUnitSize {\r\n\tXlarge = 'SizeXLarge',\r\n\tLarge = 'SizeLarge',\r\n\tNormal = 'SizeNormal',\r\n\tSmall = 'SizeSmall',\r\n\tXSmall = 'SizeXSmall',\r\n}\r\n\r\nexport enum FormLeftMargin {\r\n\tNone = 'LeftMarginNone',\r\n\tNormal = 'LeftMarginNormal',\r\n}\r\n\r\ninterface Props {\r\n\tclassName?: string;\r\n\tpadding?: FormUnitPadding;\r\n\tleftMargin?: FormLeftMargin;\r\n\tsize?: FormUnitSize;\r\n\tflex?: boolean;\r\n}\r\n \r\nexport const FormUnit: React.FunctionComponent = (props) => {\r\n const classNames = ClassNames(\r\n\t\t\tprops.className,\r\n\t\t\tprops.size,\r\n\t\t\tprops.padding,\r\n\t\t\tprops.leftMargin,\r\n\t\t\t{ 'Flex': props.flex }\r\n\t\t);\r\n\r\n\r\n\treturn (\r\n\t\t\r\n\t\t\t{props.children}\r\n\t\t
\r\n\t);\r\n};\r\n\r\nFormUnit.defaultProps = {\r\n\tflex: false,\r\n\tclassName: 'FormUnit',\r\n\tsize: FormUnitSize.Normal,\r\n\tpadding: FormUnitPadding.Normal,\r\n\tleftMargin: FormLeftMargin.None\r\n};\r\n","import React from 'react';\r\nimport './Messages.scss';\r\nimport { T } from '../T';\r\nimport { Application } from '../../../../models/AppModels';\r\n\r\nexport interface MessageItem {\r\n\ttextkey?: string;\r\n\ttext?: string;\r\n\tok?:boolean;\r\n}\r\n\r\ninterface Props {\r\n\tclassName?: string;\r\n\titems: MessageItem[];\r\n\tlineBreak?:boolean;\r\n\tvisible?:boolean;\r\n}\r\n\r\nexport const Messages: React.FunctionComponent = (props) => {\r\n\tif(!props.items) \r\n\t\treturn null;\r\n\r\n\tif(props.visible === false)\r\n\t\treturn null;\r\n\r\n\tconst uq = 'message_'+Application.instance.services.idService.newIdString();\r\n\r\n\treturn (\r\n\t\t
\r\n\t\t{\r\n\t\t\tprops.items.map((x, ix) => {\r\n\t\t\t\tconst id = uq+'_'+ix;\r\n\t\t\t\treturn (\r\n\t\t\t\t\t{x.textkey && } {x.text} {props.lineBreak &&
}
\r\n\t\t\t\t);\r\n\t\t\t})\r\n\t\t}\r\n\t\t
\r\n\t);\r\n};\r\n\r\n// Default props\r\nMessages.defaultProps = {\r\n\tclassName: 'Messages',\r\n};\r\n","import React, { Children } from 'react';\r\nimport { AppComponent } from '../AppComponent';\r\nimport { Button } from '../widget/input/Button/Button';\r\nimport { ButtonGroup, ButtonGroupLayout } from '../widget/input/ButtonGroup/ButtonGroup';\r\nimport { StepContext } from './CaseSteps';\r\nimport { Messages, MessageItem } from '../widget/display/Messages/Messages';\r\nimport { T } from '../widget/display/T';\r\n\r\ninterface Props {\r\n\tcontext: StepContext;\r\n\tcanGoHome?: boolean;\r\n\tcanGoToPrev?: boolean;\r\n\tcanGoToNext?: boolean;\r\n\tgoHomeTextkey?: string;\r\n\tgoToPrevTextkey?: string;\r\n\tgoToNextTextkey?: string;\r\n\tonGoHome?: () => void;\r\n\tonGoToPrev?: () => void;\r\n\tonGoToNext?: () => void;\r\n\tonTriggerImmidiateValidation?: () => void;\r\n}\r\n\r\ninterface State {\r\n\thasTouchedNextButton?: boolean;\r\n}\r\n\r\nexport class StepFooter extends AppComponent {\r\n\tconstructor(props: Props) {\r\n\t\tsuper(props);\r\n\r\n\t\tthis.state = {\r\n\t\t\thasTouchedNextButton: false\r\n\t\t}\r\n\r\n\t}\r\n\r\n\tinnerGoToNext = (): void => {\r\n\r\n\t\tlet stepIsValid = this.props.context.getValidation().ok();\r\n\t\tif (stepIsValid === false) {\r\n\t\t\tthis.setState({ hasTouchedNextButton: true })\r\n\r\n\t\t\t// Trigger function for 'visible' validation of validators (if implemented in parent)\r\n\t\t\tif (this.props.onTriggerImmidiateValidation)\r\n\t\t\t\tthis.props.onTriggerImmidiateValidation();\r\n\r\n\t\t\treturn\r\n\t\t}\r\n\r\n\t\t// Trigger goToNext function\r\n\t\tif (this.props.onGoToNext)\r\n\t\t\tthis.props.onGoToNext();\r\n\r\n\t}\r\n\r\n\r\n\trender() {\r\n\r\n\t\tconst canSave = this.props.context.canSave();\r\n\r\n\t\tlet goHomeTextkey = this.props.goHomeTextkey\r\n\t\t\t? this.props.goHomeTextkey\r\n\t\t\t: 'GoHome';\r\n\t\tif (canSave) {\r\n\t\t\tgoHomeTextkey += \"WithSave\";\r\n\t\t}\r\n\r\n\t\tlet displayGenericErrorMessage = this.state.hasTouchedNextButton === true && this.props.context.getValidation().ok() !== true;\r\n\t\t// let goToPrevTextkey = this.props.goToPrevTextkey\r\n\t\t// \t? this.props.goToPrevTextkey\r\n\t\t// \t: 'GoToPrev';\r\n\t\tlet goToNextTextkey = this.props.goToNextTextkey\r\n\t\t\t? this.props.goToNextTextkey\r\n\t\t\t: 'GoToNext';\r\n\r\n\t\treturn (\r\n\t\t\t
\r\n\t\t\t\t\r\n\t\t\t\t\t{this.props.canGoHome !== undefined && (\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t)}\r\n\r\n\t\t\t\t\t{this.props.canGoToNext !== undefined && (\r\n\t\t\t\t\t\t<>\r\n\t\t\t\t\t\t\t this.innerGoToNext()}\r\n\t\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t\t\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t)}\r\n\t\t\t\t\r\n\r\n\t\t\t
\r\n\t\t)\r\n\r\n\t}\r\n}\r\n","/**\n * @license\n * Lodash \n * Copyright OpenJS Foundation and other contributors \n * Released under MIT license \n * Based on Underscore.js 1.8.3 \n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n;(function() {\n\n /** Used as a safe reference for `undefined` in pre-ES5 environments. */\n var undefined;\n\n /** Used as the semantic version number. */\n var VERSION = '4.17.21';\n\n /** Used as the size to enable large array optimizations. */\n var LARGE_ARRAY_SIZE = 200;\n\n /** Error message constants. */\n var CORE_ERROR_TEXT = 'Unsupported core-js use. Try https://npms.io/search?q=ponyfill.',\n FUNC_ERROR_TEXT = 'Expected a function',\n INVALID_TEMPL_VAR_ERROR_TEXT = 'Invalid `variable` option passed into `_.template`';\n\n /** Used to stand-in for `undefined` hash values. */\n var HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n /** Used as the maximum memoize cache size. */\n var MAX_MEMOIZE_SIZE = 500;\n\n /** Used as the internal argument placeholder. */\n var PLACEHOLDER = '__lodash_placeholder__';\n\n /** Used to compose bitmasks for cloning. */\n var CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n /** Used to compose bitmasks for value comparisons. */\n var COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n /** Used to compose bitmasks for function metadata. */\n var WRAP_BIND_FLAG = 1,\n WRAP_BIND_KEY_FLAG = 2,\n WRAP_CURRY_BOUND_FLAG = 4,\n WRAP_CURRY_FLAG = 8,\n WRAP_CURRY_RIGHT_FLAG = 16,\n WRAP_PARTIAL_FLAG = 32,\n WRAP_PARTIAL_RIGHT_FLAG = 64,\n WRAP_ARY_FLAG = 128,\n WRAP_REARG_FLAG = 256,\n WRAP_FLIP_FLAG = 512;\n\n /** Used as default options for `_.truncate`. */\n var DEFAULT_TRUNC_LENGTH = 30,\n DEFAULT_TRUNC_OMISSION = '...';\n\n /** Used to detect hot functions by number of calls within a span of milliseconds. */\n var HOT_COUNT = 800,\n HOT_SPAN = 16;\n\n /** Used to indicate the type of lazy iteratees. */\n var LAZY_FILTER_FLAG = 1,\n LAZY_MAP_FLAG = 2,\n LAZY_WHILE_FLAG = 3;\n\n /** Used as references for various `Number` constants. */\n var INFINITY = 1 / 0,\n MAX_SAFE_INTEGER = 9007199254740991,\n MAX_INTEGER = 1.7976931348623157e+308,\n NAN = 0 / 0;\n\n /** Used as references for the maximum length and index of an array. */\n var MAX_ARRAY_LENGTH = 4294967295,\n MAX_ARRAY_INDEX = MAX_ARRAY_LENGTH - 1,\n HALF_MAX_ARRAY_LENGTH = MAX_ARRAY_LENGTH >>> 1;\n\n /** Used to associate wrap methods with their bit flags. */\n var wrapFlags = [\n ['ary', WRAP_ARY_FLAG],\n ['bind', WRAP_BIND_FLAG],\n ['bindKey', WRAP_BIND_KEY_FLAG],\n ['curry', WRAP_CURRY_FLAG],\n ['curryRight', WRAP_CURRY_RIGHT_FLAG],\n ['flip', WRAP_FLIP_FLAG],\n ['partial', WRAP_PARTIAL_FLAG],\n ['partialRight', WRAP_PARTIAL_RIGHT_FLAG],\n ['rearg', WRAP_REARG_FLAG]\n ];\n\n /** `Object#toString` result references. */\n var argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n asyncTag = '[object AsyncFunction]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n domExcTag = '[object DOMException]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n nullTag = '[object Null]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n proxyTag = '[object Proxy]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n undefinedTag = '[object Undefined]',\n weakMapTag = '[object WeakMap]',\n weakSetTag = '[object WeakSet]';\n\n var 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 match empty string literals in compiled template source. */\n var reEmptyStringLeading = /\\b__p \\+= '';/g,\n reEmptyStringMiddle = /\\b(__p \\+=) '' \\+/g,\n reEmptyStringTrailing = /(__e\\(.*?\\)|\\b__t\\)) \\+\\n'';/g;\n\n /** Used to match HTML entities and HTML characters. */\n var reEscapedHtml = /&(?:amp|lt|gt|quot|#39);/g,\n reUnescapedHtml = /[&<>\"']/g,\n reHasEscapedHtml = RegExp(reEscapedHtml.source),\n reHasUnescapedHtml = RegExp(reUnescapedHtml.source);\n\n /** Used to match template delimiters. */\n var reEscape = /<%-([\\s\\S]+?)%>/g,\n reEvaluate = /<%([\\s\\S]+?)%>/g,\n reInterpolate = /<%=([\\s\\S]+?)%>/g;\n\n /** Used to match property names within property paths. */\n var reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/,\n rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n /**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\n var reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g,\n reHasRegExpChar = RegExp(reRegExpChar.source);\n\n /** Used to match leading whitespace. */\n var reTrimStart = /^\\s+/;\n\n /** Used to match a single whitespace character. */\n var reWhitespace = /\\s/;\n\n /** Used to match wrap detail comments. */\n var reWrapComment = /\\{(?:\\n\\/\\* \\[wrapped with .+\\] \\*\\/)?\\n?/,\n reWrapDetails = /\\{\\n\\/\\* \\[wrapped with (.+)\\] \\*/,\n reSplitDetails = /,? & /;\n\n /** Used to match words composed of alphanumeric characters. */\n var reAsciiWord = /[^\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\x7f]+/g;\n\n /**\n * Used to validate the `validate` option in `_.template` variable.\n *\n * Forbids characters which could potentially change the meaning of the function argument definition:\n * - \"(),\" (modification of function parameters)\n * - \"=\" (default value)\n * - \"[]{}\" (destructuring of function parameters)\n * - \"/\" (beginning of a comment)\n * - whitespace\n */\n var reForbiddenIdentifierChars = /[()=,{}\\[\\]\\/\\s]/;\n\n /** Used to match backslashes in property paths. */\n var reEscapeChar = /\\\\(\\\\)?/g;\n\n /**\n * Used to match\n * [ES template delimiters](http://ecma-international.org/ecma-262/7.0/#sec-template-literal-lexical-components).\n */\n var reEsTemplate = /\\$\\{([^\\\\}]*(?:\\\\.[^\\\\}]*)*)\\}/g;\n\n /** Used to match `RegExp` flags from their coerced string values. */\n var reFlags = /\\w*$/;\n\n /** Used to detect bad signed hexadecimal string values. */\n var reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n /** Used to detect binary string values. */\n var reIsBinary = /^0b[01]+$/i;\n\n /** Used to detect host constructors (Safari). */\n var reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n /** Used to detect octal string values. */\n var reIsOctal = /^0o[0-7]+$/i;\n\n /** Used to detect unsigned integer values. */\n var reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n /** Used to match Latin Unicode letters (excluding mathematical operators). */\n var reLatin = /[\\xc0-\\xd6\\xd8-\\xf6\\xf8-\\xff\\u0100-\\u017f]/g;\n\n /** Used to ensure capturing order of template delimiters. */\n var reNoMatch = /($^)/;\n\n /** Used to match unescaped characters in compiled string literals. */\n var reUnescapedString = /['\\n\\r\\u2028\\u2029\\\\]/g;\n\n /** Used to compose unicode character classes. */\n var rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsDingbatRange = '\\\\u2700-\\\\u27bf',\n rsLowerRange = 'a-z\\\\xdf-\\\\xf6\\\\xf8-\\\\xff',\n rsMathOpRange = '\\\\xac\\\\xb1\\\\xd7\\\\xf7',\n rsNonCharRange = '\\\\x00-\\\\x2f\\\\x3a-\\\\x40\\\\x5b-\\\\x60\\\\x7b-\\\\xbf',\n rsPunctuationRange = '\\\\u2000-\\\\u206f',\n rsSpaceRange = ' \\\\t\\\\x0b\\\\f\\\\xa0\\\\ufeff\\\\n\\\\r\\\\u2028\\\\u2029\\\\u1680\\\\u180e\\\\u2000\\\\u2001\\\\u2002\\\\u2003\\\\u2004\\\\u2005\\\\u2006\\\\u2007\\\\u2008\\\\u2009\\\\u200a\\\\u202f\\\\u205f\\\\u3000',\n rsUpperRange = 'A-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde',\n rsVarRange = '\\\\ufe0e\\\\ufe0f',\n rsBreakRange = rsMathOpRange + rsNonCharRange + rsPunctuationRange + rsSpaceRange;\n\n /** Used to compose unicode capture groups. */\n var rsApos = \"['\\u2019]\",\n rsAstral = '[' + rsAstralRange + ']',\n rsBreak = '[' + rsBreakRange + ']',\n rsCombo = '[' + rsComboRange + ']',\n rsDigits = '\\\\d+',\n rsDingbat = '[' + rsDingbatRange + ']',\n rsLower = '[' + rsLowerRange + ']',\n rsMisc = '[^' + rsAstralRange + rsBreakRange + rsDigits + rsDingbatRange + rsLowerRange + rsUpperRange + ']',\n rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n rsNonAstral = '[^' + rsAstralRange + ']',\n rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n rsUpper = '[' + rsUpperRange + ']',\n rsZWJ = '\\\\u200d';\n\n /** Used to compose unicode regexes. */\n var rsMiscLower = '(?:' + rsLower + '|' + rsMisc + ')',\n rsMiscUpper = '(?:' + rsUpper + '|' + rsMisc + ')',\n rsOptContrLower = '(?:' + rsApos + '(?:d|ll|m|re|s|t|ve))?',\n rsOptContrUpper = '(?:' + rsApos + '(?:D|LL|M|RE|S|T|VE))?',\n reOptMod = rsModifier + '?',\n rsOptVar = '[' + rsVarRange + ']?',\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n rsOrdLower = '\\\\d*(?:1st|2nd|3rd|(?![123])\\\\dth)(?=\\\\b|[A-Z_])',\n rsOrdUpper = '\\\\d*(?:1ST|2ND|3RD|(?![123])\\\\dTH)(?=\\\\b|[a-z_])',\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\n rsEmoji = '(?:' + [rsDingbat, rsRegional, rsSurrPair].join('|') + ')' + rsSeq,\n rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\n /** Used to match apostrophes. */\n var reApos = RegExp(rsApos, 'g');\n\n /**\n * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and\n * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols).\n */\n var reComboMark = RegExp(rsCombo, 'g');\n\n /** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\n var reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n\n /** Used to match complex or compound words. */\n var reUnicodeWord = RegExp([\n rsUpper + '?' + rsLower + '+' + rsOptContrLower + '(?=' + [rsBreak, rsUpper, '$'].join('|') + ')',\n rsMiscUpper + '+' + rsOptContrUpper + '(?=' + [rsBreak, rsUpper + rsMiscLower, '$'].join('|') + ')',\n rsUpper + '?' + rsMiscLower + '+' + rsOptContrLower,\n rsUpper + '+' + rsOptContrUpper,\n rsOrdUpper,\n rsOrdLower,\n rsDigits,\n rsEmoji\n ].join('|'), 'g');\n\n /** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */\n var reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboRange + rsVarRange + ']');\n\n /** Used to detect strings that need a more robust regexp to match words. */\n var reHasUnicodeWord = /[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;\n\n /** Used to assign default `context` object properties. */\n var contextProps = [\n 'Array', 'Buffer', 'DataView', 'Date', 'Error', 'Float32Array', 'Float64Array',\n 'Function', 'Int8Array', 'Int16Array', 'Int32Array', 'Map', 'Math', 'Object',\n 'Promise', 'RegExp', 'Set', 'String', 'Symbol', 'TypeError', 'Uint8Array',\n 'Uint8ClampedArray', 'Uint16Array', 'Uint32Array', 'WeakMap',\n '_', 'clearTimeout', 'isFinite', 'parseInt', 'setTimeout'\n ];\n\n /** Used to make template sourceURLs easier to identify. */\n var templateCounter = -1;\n\n /** Used to identify `toStringTag` values of typed arrays. */\n var typedArrayTags = {};\n typedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\n typedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\n typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\n typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\n typedArrayTags[uint32Tag] = true;\n typedArrayTags[argsTag] = typedArrayTags[arrayTag] =\n typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\n typedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\n typedArrayTags[errorTag] = typedArrayTags[funcTag] =\n typedArrayTags[mapTag] = typedArrayTags[numberTag] =\n typedArrayTags[objectTag] = typedArrayTags[regexpTag] =\n typedArrayTags[setTag] = typedArrayTags[stringTag] =\n typedArrayTags[weakMapTag] = false;\n\n /** Used to identify `toStringTag` values supported by `_.clone`. */\n var cloneableTags = {};\n cloneableTags[argsTag] = cloneableTags[arrayTag] =\n cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\n cloneableTags[boolTag] = cloneableTags[dateTag] =\n cloneableTags[float32Tag] = cloneableTags[float64Tag] =\n cloneableTags[int8Tag] = cloneableTags[int16Tag] =\n cloneableTags[int32Tag] = cloneableTags[mapTag] =\n cloneableTags[numberTag] = cloneableTags[objectTag] =\n cloneableTags[regexpTag] = cloneableTags[setTag] =\n cloneableTags[stringTag] = cloneableTags[symbolTag] =\n cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\n cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\n cloneableTags[errorTag] = cloneableTags[funcTag] =\n cloneableTags[weakMapTag] = false;\n\n /** Used to map Latin Unicode letters to basic Latin letters. */\n var deburredLetters = {\n // Latin-1 Supplement block.\n '\\xc0': 'A', '\\xc1': 'A', '\\xc2': 'A', '\\xc3': 'A', '\\xc4': 'A', '\\xc5': 'A',\n '\\xe0': 'a', '\\xe1': 'a', '\\xe2': 'a', '\\xe3': 'a', '\\xe4': 'a', '\\xe5': 'a',\n '\\xc7': 'C', '\\xe7': 'c',\n '\\xd0': 'D', '\\xf0': 'd',\n '\\xc8': 'E', '\\xc9': 'E', '\\xca': 'E', '\\xcb': 'E',\n '\\xe8': 'e', '\\xe9': 'e', '\\xea': 'e', '\\xeb': 'e',\n '\\xcc': 'I', '\\xcd': 'I', '\\xce': 'I', '\\xcf': 'I',\n '\\xec': 'i', '\\xed': 'i', '\\xee': 'i', '\\xef': 'i',\n '\\xd1': 'N', '\\xf1': 'n',\n '\\xd2': 'O', '\\xd3': 'O', '\\xd4': 'O', '\\xd5': 'O', '\\xd6': 'O', '\\xd8': 'O',\n '\\xf2': 'o', '\\xf3': 'o', '\\xf4': 'o', '\\xf5': 'o', '\\xf6': 'o', '\\xf8': 'o',\n '\\xd9': 'U', '\\xda': 'U', '\\xdb': 'U', '\\xdc': 'U',\n '\\xf9': 'u', '\\xfa': 'u', '\\xfb': 'u', '\\xfc': 'u',\n '\\xdd': 'Y', '\\xfd': 'y', '\\xff': 'y',\n '\\xc6': 'Ae', '\\xe6': 'ae',\n '\\xde': 'Th', '\\xfe': 'th',\n '\\xdf': 'ss',\n // Latin Extended-A block.\n '\\u0100': 'A', '\\u0102': 'A', '\\u0104': 'A',\n '\\u0101': 'a', '\\u0103': 'a', '\\u0105': 'a',\n '\\u0106': 'C', '\\u0108': 'C', '\\u010a': 'C', '\\u010c': 'C',\n '\\u0107': 'c', '\\u0109': 'c', '\\u010b': 'c', '\\u010d': 'c',\n '\\u010e': 'D', '\\u0110': 'D', '\\u010f': 'd', '\\u0111': 'd',\n '\\u0112': 'E', '\\u0114': 'E', '\\u0116': 'E', '\\u0118': 'E', '\\u011a': 'E',\n '\\u0113': 'e', '\\u0115': 'e', '\\u0117': 'e', '\\u0119': 'e', '\\u011b': 'e',\n '\\u011c': 'G', '\\u011e': 'G', '\\u0120': 'G', '\\u0122': 'G',\n '\\u011d': 'g', '\\u011f': 'g', '\\u0121': 'g', '\\u0123': 'g',\n '\\u0124': 'H', '\\u0126': 'H', '\\u0125': 'h', '\\u0127': 'h',\n '\\u0128': 'I', '\\u012a': 'I', '\\u012c': 'I', '\\u012e': 'I', '\\u0130': 'I',\n '\\u0129': 'i', '\\u012b': 'i', '\\u012d': 'i', '\\u012f': 'i', '\\u0131': 'i',\n '\\u0134': 'J', '\\u0135': 'j',\n '\\u0136': 'K', '\\u0137': 'k', '\\u0138': 'k',\n '\\u0139': 'L', '\\u013b': 'L', '\\u013d': 'L', '\\u013f': 'L', '\\u0141': 'L',\n '\\u013a': 'l', '\\u013c': 'l', '\\u013e': 'l', '\\u0140': 'l', '\\u0142': 'l',\n '\\u0143': 'N', '\\u0145': 'N', '\\u0147': 'N', '\\u014a': 'N',\n '\\u0144': 'n', '\\u0146': 'n', '\\u0148': 'n', '\\u014b': 'n',\n '\\u014c': 'O', '\\u014e': 'O', '\\u0150': 'O',\n '\\u014d': 'o', '\\u014f': 'o', '\\u0151': 'o',\n '\\u0154': 'R', '\\u0156': 'R', '\\u0158': 'R',\n '\\u0155': 'r', '\\u0157': 'r', '\\u0159': 'r',\n '\\u015a': 'S', '\\u015c': 'S', '\\u015e': 'S', '\\u0160': 'S',\n '\\u015b': 's', '\\u015d': 's', '\\u015f': 's', '\\u0161': 's',\n '\\u0162': 'T', '\\u0164': 'T', '\\u0166': 'T',\n '\\u0163': 't', '\\u0165': 't', '\\u0167': 't',\n '\\u0168': 'U', '\\u016a': 'U', '\\u016c': 'U', '\\u016e': 'U', '\\u0170': 'U', '\\u0172': 'U',\n '\\u0169': 'u', '\\u016b': 'u', '\\u016d': 'u', '\\u016f': 'u', '\\u0171': 'u', '\\u0173': 'u',\n '\\u0174': 'W', '\\u0175': 'w',\n '\\u0176': 'Y', '\\u0177': 'y', '\\u0178': 'Y',\n '\\u0179': 'Z', '\\u017b': 'Z', '\\u017d': 'Z',\n '\\u017a': 'z', '\\u017c': 'z', '\\u017e': 'z',\n '\\u0132': 'IJ', '\\u0133': 'ij',\n '\\u0152': 'Oe', '\\u0153': 'oe',\n '\\u0149': \"'n\", '\\u017f': 's'\n };\n\n /** Used to map characters to HTML entities. */\n var htmlEscapes = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": '''\n };\n\n /** Used to map HTML entities to characters. */\n var htmlUnescapes = {\n '&': '&',\n '<': '<',\n '>': '>',\n '"': '\"',\n ''': \"'\"\n };\n\n /** Used to escape characters for inclusion in compiled string literals. */\n var stringEscapes = {\n '\\\\': '\\\\',\n \"'\": \"'\",\n '\\n': 'n',\n '\\r': 'r',\n '\\u2028': 'u2028',\n '\\u2029': 'u2029'\n };\n\n /** Built-in method references without a dependency on `root`. */\n var freeParseFloat = parseFloat,\n freeParseInt = parseInt;\n\n /** Detect free variable `global` from Node.js. */\n var freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n /** Detect free variable `self`. */\n var freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n /** Used as a reference to the global object. */\n var root = freeGlobal || freeSelf || Function('return this')();\n\n /** Detect free variable `exports`. */\n var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n /** Detect free variable `module`. */\n var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n /** Detect the popular CommonJS extension `module.exports`. */\n var moduleExports = freeModule && freeModule.exports === freeExports;\n\n /** Detect free variable `process` from Node.js. */\n var freeProcess = moduleExports && freeGlobal.process;\n\n /** Used to access faster Node.js helpers. */\n var 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\n /* Node.js helper references. */\n var nodeIsArrayBuffer = nodeUtil && nodeUtil.isArrayBuffer,\n nodeIsDate = nodeUtil && nodeUtil.isDate,\n nodeIsMap = nodeUtil && nodeUtil.isMap,\n nodeIsRegExp = nodeUtil && nodeUtil.isRegExp,\n nodeIsSet = nodeUtil && nodeUtil.isSet,\n nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n /*--------------------------------------------------------------------------*/\n\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 */\n function 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\n /**\n * A specialized version of `baseAggregator` for arrays.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\n function arrayAggregator(array, setter, iteratee, accumulator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n var value = array[index];\n setter(accumulator, value, iteratee(value), array);\n }\n return accumulator;\n }\n\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 */\n function 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\n /**\n * A specialized version of `_.forEachRight` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\n function arrayEachRight(array, iteratee) {\n var length = array == null ? 0 : array.length;\n\n while (length--) {\n if (iteratee(array[length], length, array) === false) {\n break;\n }\n }\n return array;\n }\n\n /**\n * A specialized version of `_.every` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n * else `false`.\n */\n function arrayEvery(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (!predicate(array[index], index, array)) {\n return false;\n }\n }\n return true;\n }\n\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 */\n function 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\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 */\n function arrayIncludes(array, value) {\n var length = array == null ? 0 : array.length;\n return !!length && baseIndexOf(array, value, 0) > -1;\n }\n\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 */\n function 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\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 */\n function 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\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 */\n function 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\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 */\n function 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\n /**\n * A specialized version of `_.reduceRight` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the last element of `array` as\n * the initial value.\n * @returns {*} Returns the accumulated value.\n */\n function arrayReduceRight(array, iteratee, accumulator, initAccum) {\n var length = array == null ? 0 : array.length;\n if (initAccum && length) {\n accumulator = array[--length];\n }\n while (length--) {\n accumulator = iteratee(accumulator, array[length], length, array);\n }\n return accumulator;\n }\n\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 */\n function 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\n /**\n * Gets the size of an ASCII `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\n var asciiSize = baseProperty('length');\n\n /**\n * Converts an ASCII `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n function asciiToArray(string) {\n return string.split('');\n }\n\n /**\n * Splits an ASCII `string` into an array of its words.\n *\n * @private\n * @param {string} The string to inspect.\n * @returns {Array} Returns the words of `string`.\n */\n function asciiWords(string) {\n return string.match(reAsciiWord) || [];\n }\n\n /**\n * The base implementation of methods like `_.findKey` and `_.findLastKey`,\n * without support for iteratee shorthands, which iterates over `collection`\n * using `eachFunc`.\n *\n * @private\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @returns {*} Returns the found element or its key, else `undefined`.\n */\n function baseFindKey(collection, predicate, eachFunc) {\n var result;\n eachFunc(collection, function(value, key, collection) {\n if (predicate(value, key, collection)) {\n result = key;\n return false;\n }\n });\n return result;\n }\n\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 */\n function 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\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 */\n function baseIndexOf(array, value, fromIndex) {\n return value === value\n ? strictIndexOf(array, value, fromIndex)\n : baseFindIndex(array, baseIsNaN, fromIndex);\n }\n\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 */\n function 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\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 */\n function baseIsNaN(value) {\n return value !== value;\n }\n\n /**\n * The base implementation of `_.mean` and `_.meanBy` without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {number} Returns the mean.\n */\n function baseMean(array, iteratee) {\n var length = array == null ? 0 : array.length;\n return length ? (baseSum(array, iteratee) / length) : NAN;\n }\n\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 */\n function baseProperty(key) {\n return function(object) {\n return object == null ? undefined : object[key];\n };\n }\n\n /**\n * The base implementation of `_.propertyOf` without support for deep paths.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Function} Returns the new accessor function.\n */\n function basePropertyOf(object) {\n return function(key) {\n return object == null ? undefined : object[key];\n };\n }\n\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 */\n function 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\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 */\n function 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\n /**\n * The base implementation of `_.sum` and `_.sumBy` without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {number} Returns the sum.\n */\n function baseSum(array, iteratee) {\n var result,\n index = -1,\n length = array.length;\n\n while (++index < length) {\n var current = iteratee(array[index]);\n if (current !== undefined) {\n result = result === undefined ? current : (result + current);\n }\n }\n return result;\n }\n\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 */\n function 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\n /**\n * The base implementation of `_.toPairs` and `_.toPairsIn` which creates an array\n * of key-value pairs for `object` corresponding to the property names of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the key-value pairs.\n */\n function baseToPairs(object, props) {\n return arrayMap(props, function(key) {\n return [key, object[key]];\n });\n }\n\n /**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\n function baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n }\n\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 */\n function baseUnary(func) {\n return function(value) {\n return func(value);\n };\n }\n\n /**\n * The base implementation of `_.values` and `_.valuesIn` which creates an\n * array of `object` property values corresponding to the property names\n * of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the array of property values.\n */\n function baseValues(object, props) {\n return arrayMap(props, function(key) {\n return object[key];\n });\n }\n\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 */\n function cacheHas(cache, key) {\n return cache.has(key);\n }\n\n /**\n * Used by `_.trim` and `_.trimStart` to get the index of the first string symbol\n * that is not found in the character symbols.\n *\n * @private\n * @param {Array} strSymbols The string symbols to inspect.\n * @param {Array} chrSymbols The character symbols to find.\n * @returns {number} Returns the index of the first unmatched string symbol.\n */\n function charsStartIndex(strSymbols, chrSymbols) {\n var index = -1,\n length = strSymbols.length;\n\n while (++index < length && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\n return index;\n }\n\n /**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last string symbol\n * that is not found in the character symbols.\n *\n * @private\n * @param {Array} strSymbols The string symbols to inspect.\n * @param {Array} chrSymbols The character symbols to find.\n * @returns {number} Returns the index of the last unmatched string symbol.\n */\n function charsEndIndex(strSymbols, chrSymbols) {\n var index = strSymbols.length;\n\n while (index-- && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\n return index;\n }\n\n /**\n * Gets the number of `placeholder` occurrences in `array`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} placeholder The placeholder to search for.\n * @returns {number} Returns the placeholder count.\n */\n function countHolders(array, placeholder) {\n var length = array.length,\n result = 0;\n\n while (length--) {\n if (array[length] === placeholder) {\n ++result;\n }\n }\n return result;\n }\n\n /**\n * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A\n * letters to basic Latin letters.\n *\n * @private\n * @param {string} letter The matched letter to deburr.\n * @returns {string} Returns the deburred letter.\n */\n var deburrLetter = basePropertyOf(deburredLetters);\n\n /**\n * Used by `_.escape` to convert characters to HTML entities.\n *\n * @private\n * @param {string} chr The matched character to escape.\n * @returns {string} Returns the escaped character.\n */\n var escapeHtmlChar = basePropertyOf(htmlEscapes);\n\n /**\n * Used by `_.template` to escape characters for inclusion in compiled string literals.\n *\n * @private\n * @param {string} chr The matched character to escape.\n * @returns {string} Returns the escaped character.\n */\n function escapeStringChar(chr) {\n return '\\\\' + stringEscapes[chr];\n }\n\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 */\n function getValue(object, key) {\n return object == null ? undefined : object[key];\n }\n\n /**\n * Checks if `string` contains Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a symbol is found, else `false`.\n */\n function hasUnicode(string) {\n return reHasUnicode.test(string);\n }\n\n /**\n * Checks if `string` contains a word composed of Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a word is found, else `false`.\n */\n function hasUnicodeWord(string) {\n return reHasUnicodeWord.test(string);\n }\n\n /**\n * Converts `iterator` to an array.\n *\n * @private\n * @param {Object} iterator The iterator to convert.\n * @returns {Array} Returns the converted array.\n */\n function iteratorToArray(iterator) {\n var data,\n result = [];\n\n while (!(data = iterator.next()).done) {\n result.push(data.value);\n }\n return result;\n }\n\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 */\n function 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\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 */\n function overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n }\n\n /**\n * Replaces all `placeholder` elements in `array` with an internal placeholder\n * and returns an array of their indexes.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {*} placeholder The placeholder to replace.\n * @returns {Array} Returns the new array of placeholder indexes.\n */\n function replaceHolders(array, placeholder) {\n var index = -1,\n length = array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (value === placeholder || value === PLACEHOLDER) {\n array[index] = PLACEHOLDER;\n result[resIndex++] = index;\n }\n }\n return result;\n }\n\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 */\n function 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\n /**\n * Converts `set` to its value-value pairs.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the value-value pairs.\n */\n function setToPairs(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = [value, value];\n });\n return result;\n }\n\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 */\n function 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\n /**\n * A specialized version of `_.lastIndexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function strictLastIndexOf(array, value, fromIndex) {\n var index = fromIndex + 1;\n while (index--) {\n if (array[index] === value) {\n return index;\n }\n }\n return index;\n }\n\n /**\n * Gets the number of symbols in `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the string size.\n */\n function stringSize(string) {\n return hasUnicode(string)\n ? unicodeSize(string)\n : asciiSize(string);\n }\n\n /**\n * Converts `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n function stringToArray(string) {\n return hasUnicode(string)\n ? unicodeToArray(string)\n : asciiToArray(string);\n }\n\n /**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\n function trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n }\n\n /**\n * Used by `_.unescape` to convert HTML entities to characters.\n *\n * @private\n * @param {string} chr The matched character to unescape.\n * @returns {string} Returns the unescaped character.\n */\n var unescapeHtmlChar = basePropertyOf(htmlUnescapes);\n\n /**\n * Gets the size of a Unicode `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\n function unicodeSize(string) {\n var result = reUnicode.lastIndex = 0;\n while (reUnicode.test(string)) {\n ++result;\n }\n return result;\n }\n\n /**\n * Converts a Unicode `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n function unicodeToArray(string) {\n return string.match(reUnicode) || [];\n }\n\n /**\n * Splits a Unicode `string` into an array of its words.\n *\n * @private\n * @param {string} The string to inspect.\n * @returns {Array} Returns the words of `string`.\n */\n function unicodeWords(string) {\n return string.match(reUnicodeWord) || [];\n }\n\n /*--------------------------------------------------------------------------*/\n\n /**\n * Create a new pristine `lodash` function using the `context` object.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Util\n * @param {Object} [context=root] The context object.\n * @returns {Function} Returns a new `lodash` function.\n * @example\n *\n * _.mixin({ 'foo': _.constant('foo') });\n *\n * var lodash = _.runInContext();\n * lodash.mixin({ 'bar': lodash.constant('bar') });\n *\n * _.isFunction(_.foo);\n * // => true\n * _.isFunction(_.bar);\n * // => false\n *\n * lodash.isFunction(lodash.foo);\n * // => false\n * lodash.isFunction(lodash.bar);\n * // => true\n *\n * // Create a suped-up `defer` in Node.js.\n * var defer = _.runInContext({ 'setTimeout': setImmediate }).defer;\n */\n var runInContext = (function runInContext(context) {\n context = context == null ? root : _.defaults(root.Object(), context, _.pick(root, contextProps));\n\n /** Built-in constructor references. */\n var Array = context.Array,\n Date = context.Date,\n Error = context.Error,\n Function = context.Function,\n Math = context.Math,\n Object = context.Object,\n RegExp = context.RegExp,\n String = context.String,\n TypeError = context.TypeError;\n\n /** Used for built-in method references. */\n var arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n /** Used to detect overreaching core-js shims. */\n var coreJsData = context['__core-js_shared__'];\n\n /** Used to resolve the decompiled source of functions. */\n var funcToString = funcProto.toString;\n\n /** Used to check objects for own properties. */\n var hasOwnProperty = objectProto.hasOwnProperty;\n\n /** Used to generate unique IDs. */\n var idCounter = 0;\n\n /** Used to detect methods masquerading as native. */\n var maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n }());\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 */\n var nativeObjectToString = objectProto.toString;\n\n /** Used to infer the `Object` constructor. */\n var objectCtorString = funcToString.call(Object);\n\n /** Used to restore the original `_` reference in `_.noConflict`. */\n var oldDash = root._;\n\n /** Used to detect if a method is native. */\n var reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n );\n\n /** Built-in value references. */\n var Buffer = moduleExports ? context.Buffer : undefined,\n Symbol = context.Symbol,\n Uint8Array = context.Uint8Array,\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined,\n getPrototype = overArg(Object.getPrototypeOf, Object),\n objectCreate = Object.create,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice,\n spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined,\n symIterator = Symbol ? Symbol.iterator : undefined,\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n var defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n }());\n\n /** Mocked built-ins. */\n var ctxClearTimeout = context.clearTimeout !== root.clearTimeout && context.clearTimeout,\n ctxNow = Date && Date.now !== root.Date.now && Date.now,\n ctxSetTimeout = context.setTimeout !== root.setTimeout && context.setTimeout;\n\n /* Built-in method references for those with the same name as other `lodash` methods. */\n var nativeCeil = Math.ceil,\n nativeFloor = Math.floor,\n nativeGetSymbols = Object.getOwnPropertySymbols,\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n nativeIsFinite = context.isFinite,\n nativeJoin = arrayProto.join,\n nativeKeys = overArg(Object.keys, Object),\n nativeMax = Math.max,\n nativeMin = Math.min,\n nativeNow = Date.now,\n nativeParseInt = context.parseInt,\n nativeRandom = Math.random,\n nativeReverse = arrayProto.reverse;\n\n /* Built-in method references that are verified to be native. */\n var DataView = getNative(context, 'DataView'),\n Map = getNative(context, 'Map'),\n Promise = getNative(context, 'Promise'),\n Set = getNative(context, 'Set'),\n WeakMap = getNative(context, 'WeakMap'),\n nativeCreate = getNative(Object, 'create');\n\n /** Used to store function metadata. */\n var metaMap = WeakMap && new WeakMap;\n\n /** Used to lookup unminified function names. */\n var realNames = {};\n\n /** Used to detect maps, sets, and weakmaps. */\n var dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n /** Used to convert symbols to primitives and strings. */\n var symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a `lodash` object which wraps `value` to enable implicit method\n * chain sequences. Methods that operate on and return arrays, collections,\n * and functions can be chained together. Methods that retrieve a single value\n * or may return a primitive value will automatically end the chain sequence\n * and return the unwrapped value. Otherwise, the value must be unwrapped\n * with `_#value`.\n *\n * Explicit chain sequences, which must be unwrapped with `_#value`, may be\n * enabled using `_.chain`.\n *\n * The execution of chained methods is lazy, that is, it's deferred until\n * `_#value` is implicitly or explicitly called.\n *\n * Lazy evaluation allows several methods to support shortcut fusion.\n * Shortcut fusion is an optimization to merge iteratee calls; this avoids\n * the creation of intermediate arrays and can greatly reduce the number of\n * iteratee executions. Sections of a chain sequence qualify for shortcut\n * fusion if the section is applied to an array and iteratees accept only\n * one argument. The heuristic for whether a section qualifies for shortcut\n * fusion is subject to change.\n *\n * Chaining is supported in custom builds as long as the `_#value` method is\n * directly or indirectly included in the build.\n *\n * In addition to lodash methods, wrappers have `Array` and `String` methods.\n *\n * The wrapper `Array` methods are:\n * `concat`, `join`, `pop`, `push`, `shift`, `sort`, `splice`, and `unshift`\n *\n * The wrapper `String` methods are:\n * `replace` and `split`\n *\n * The wrapper methods that support shortcut fusion are:\n * `at`, `compact`, `drop`, `dropRight`, `dropWhile`, `filter`, `find`,\n * `findLast`, `head`, `initial`, `last`, `map`, `reject`, `reverse`, `slice`,\n * `tail`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, and `toArray`\n *\n * The chainable wrapper methods are:\n * `after`, `ary`, `assign`, `assignIn`, `assignInWith`, `assignWith`, `at`,\n * `before`, `bind`, `bindAll`, `bindKey`, `castArray`, `chain`, `chunk`,\n * `commit`, `compact`, `concat`, `conforms`, `constant`, `countBy`, `create`,\n * `curry`, `debounce`, `defaults`, `defaultsDeep`, `defer`, `delay`,\n * `difference`, `differenceBy`, `differenceWith`, `drop`, `dropRight`,\n * `dropRightWhile`, `dropWhile`, `extend`, `extendWith`, `fill`, `filter`,\n * `flatMap`, `flatMapDeep`, `flatMapDepth`, `flatten`, `flattenDeep`,\n * `flattenDepth`, `flip`, `flow`, `flowRight`, `fromPairs`, `functions`,\n * `functionsIn`, `groupBy`, `initial`, `intersection`, `intersectionBy`,\n * `intersectionWith`, `invert`, `invertBy`, `invokeMap`, `iteratee`, `keyBy`,\n * `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, `matchesProperty`,\n * `memoize`, `merge`, `mergeWith`, `method`, `methodOf`, `mixin`, `negate`,\n * `nthArg`, `omit`, `omitBy`, `once`, `orderBy`, `over`, `overArgs`,\n * `overEvery`, `overSome`, `partial`, `partialRight`, `partition`, `pick`,\n * `pickBy`, `plant`, `property`, `propertyOf`, `pull`, `pullAll`, `pullAllBy`,\n * `pullAllWith`, `pullAt`, `push`, `range`, `rangeRight`, `rearg`, `reject`,\n * `remove`, `rest`, `reverse`, `sampleSize`, `set`, `setWith`, `shuffle`,\n * `slice`, `sort`, `sortBy`, `splice`, `spread`, `tail`, `take`, `takeRight`,\n * `takeRightWhile`, `takeWhile`, `tap`, `throttle`, `thru`, `toArray`,\n * `toPairs`, `toPairsIn`, `toPath`, `toPlainObject`, `transform`, `unary`,\n * `union`, `unionBy`, `unionWith`, `uniq`, `uniqBy`, `uniqWith`, `unset`,\n * `unshift`, `unzip`, `unzipWith`, `update`, `updateWith`, `values`,\n * `valuesIn`, `without`, `wrap`, `xor`, `xorBy`, `xorWith`, `zip`,\n * `zipObject`, `zipObjectDeep`, and `zipWith`\n *\n * The wrapper methods that are **not** chainable by default are:\n * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clamp`, `clone`,\n * `cloneDeep`, `cloneDeepWith`, `cloneWith`, `conformsTo`, `deburr`,\n * `defaultTo`, `divide`, `each`, `eachRight`, `endsWith`, `eq`, `escape`,\n * `escapeRegExp`, `every`, `find`, `findIndex`, `findKey`, `findLast`,\n * `findLastIndex`, `findLastKey`, `first`, `floor`, `forEach`, `forEachRight`,\n * `forIn`, `forInRight`, `forOwn`, `forOwnRight`, `get`, `gt`, `gte`, `has`,\n * `hasIn`, `head`, `identity`, `includes`, `indexOf`, `inRange`, `invoke`,\n * `isArguments`, `isArray`, `isArrayBuffer`, `isArrayLike`, `isArrayLikeObject`,\n * `isBoolean`, `isBuffer`, `isDate`, `isElement`, `isEmpty`, `isEqual`,\n * `isEqualWith`, `isError`, `isFinite`, `isFunction`, `isInteger`, `isLength`,\n * `isMap`, `isMatch`, `isMatchWith`, `isNaN`, `isNative`, `isNil`, `isNull`,\n * `isNumber`, `isObject`, `isObjectLike`, `isPlainObject`, `isRegExp`,\n * `isSafeInteger`, `isSet`, `isString`, `isUndefined`, `isTypedArray`,\n * `isWeakMap`, `isWeakSet`, `join`, `kebabCase`, `last`, `lastIndexOf`,\n * `lowerCase`, `lowerFirst`, `lt`, `lte`, `max`, `maxBy`, `mean`, `meanBy`,\n * `min`, `minBy`, `multiply`, `noConflict`, `noop`, `now`, `nth`, `pad`,\n * `padEnd`, `padStart`, `parseInt`, `pop`, `random`, `reduce`, `reduceRight`,\n * `repeat`, `result`, `round`, `runInContext`, `sample`, `shift`, `size`,\n * `snakeCase`, `some`, `sortedIndex`, `sortedIndexBy`, `sortedLastIndex`,\n * `sortedLastIndexBy`, `startCase`, `startsWith`, `stubArray`, `stubFalse`,\n * `stubObject`, `stubString`, `stubTrue`, `subtract`, `sum`, `sumBy`,\n * `template`, `times`, `toFinite`, `toInteger`, `toJSON`, `toLength`,\n * `toLower`, `toNumber`, `toSafeInteger`, `toString`, `toUpper`, `trim`,\n * `trimEnd`, `trimStart`, `truncate`, `unescape`, `uniqueId`, `upperCase`,\n * `upperFirst`, `value`, and `words`\n *\n * @name _\n * @constructor\n * @category Seq\n * @param {*} value The value to wrap in a `lodash` instance.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var wrapped = _([1, 2, 3]);\n *\n * // Returns an unwrapped value.\n * wrapped.reduce(_.add);\n * // => 6\n *\n * // Returns a wrapped value.\n * var squares = wrapped.map(square);\n *\n * _.isArray(squares);\n * // => false\n *\n * _.isArray(squares.value());\n * // => true\n */\n function lodash(value) {\n if (isObjectLike(value) && !isArray(value) && !(value instanceof LazyWrapper)) {\n if (value instanceof LodashWrapper) {\n return value;\n }\n if (hasOwnProperty.call(value, '__wrapped__')) {\n return wrapperClone(value);\n }\n }\n return new LodashWrapper(value);\n }\n\n /**\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 */\n var 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\n /**\n * The function whose prototype chain sequence wrappers inherit from.\n *\n * @private\n */\n function baseLodash() {\n // No operation performed.\n }\n\n /**\n * The base constructor for creating `lodash` wrapper objects.\n *\n * @private\n * @param {*} value The value to wrap.\n * @param {boolean} [chainAll] Enable explicit method chain sequences.\n */\n function LodashWrapper(value, chainAll) {\n this.__wrapped__ = value;\n this.__actions__ = [];\n this.__chain__ = !!chainAll;\n this.__index__ = 0;\n this.__values__ = undefined;\n }\n\n /**\n * By default, the template delimiters used by lodash are like those in\n * embedded Ruby (ERB) as well as ES2015 template strings. Change the\n * following template settings to use alternative delimiters.\n *\n * @static\n * @memberOf _\n * @type {Object}\n */\n lodash.templateSettings = {\n\n /**\n * Used to detect `data` property values to be HTML-escaped.\n *\n * @memberOf _.templateSettings\n * @type {RegExp}\n */\n 'escape': reEscape,\n\n /**\n * Used to detect code to be evaluated.\n *\n * @memberOf _.templateSettings\n * @type {RegExp}\n */\n 'evaluate': reEvaluate,\n\n /**\n * Used to detect `data` property values to inject.\n *\n * @memberOf _.templateSettings\n * @type {RegExp}\n */\n 'interpolate': reInterpolate,\n\n /**\n * Used to reference the data object in the template text.\n *\n * @memberOf _.templateSettings\n * @type {string}\n */\n 'variable': '',\n\n /**\n * Used to import variables into the compiled template.\n *\n * @memberOf _.templateSettings\n * @type {Object}\n */\n 'imports': {\n\n /**\n * A reference to the `lodash` function.\n *\n * @memberOf _.templateSettings.imports\n * @type {Function}\n */\n '_': lodash\n }\n };\n\n // Ensure wrappers are instances of `baseLodash`.\n lodash.prototype = baseLodash.prototype;\n lodash.prototype.constructor = lodash;\n\n LodashWrapper.prototype = baseCreate(baseLodash.prototype);\n LodashWrapper.prototype.constructor = LodashWrapper;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation.\n *\n * @private\n * @constructor\n * @param {*} value The value to wrap.\n */\n function LazyWrapper(value) {\n this.__wrapped__ = value;\n this.__actions__ = [];\n this.__dir__ = 1;\n this.__filtered__ = false;\n this.__iteratees__ = [];\n this.__takeCount__ = MAX_ARRAY_LENGTH;\n this.__views__ = [];\n }\n\n /**\n * Creates a clone of the lazy wrapper object.\n *\n * @private\n * @name clone\n * @memberOf LazyWrapper\n * @returns {Object} Returns the cloned `LazyWrapper` object.\n */\n function lazyClone() {\n var result = new LazyWrapper(this.__wrapped__);\n result.__actions__ = copyArray(this.__actions__);\n result.__dir__ = this.__dir__;\n result.__filtered__ = this.__filtered__;\n result.__iteratees__ = copyArray(this.__iteratees__);\n result.__takeCount__ = this.__takeCount__;\n result.__views__ = copyArray(this.__views__);\n return result;\n }\n\n /**\n * Reverses the direction of lazy iteration.\n *\n * @private\n * @name reverse\n * @memberOf LazyWrapper\n * @returns {Object} Returns the new reversed `LazyWrapper` object.\n */\n function lazyReverse() {\n if (this.__filtered__) {\n var result = new LazyWrapper(this);\n result.__dir__ = -1;\n result.__filtered__ = true;\n } else {\n result = this.clone();\n result.__dir__ *= -1;\n }\n return result;\n }\n\n /**\n * Extracts the unwrapped value from its lazy wrapper.\n *\n * @private\n * @name value\n * @memberOf LazyWrapper\n * @returns {*} Returns the unwrapped value.\n */\n function lazyValue() {\n var array = this.__wrapped__.value(),\n dir = this.__dir__,\n isArr = isArray(array),\n isRight = dir < 0,\n arrLength = isArr ? array.length : 0,\n view = getView(0, arrLength, this.__views__),\n start = view.start,\n end = view.end,\n length = end - start,\n index = isRight ? end : (start - 1),\n iteratees = this.__iteratees__,\n iterLength = iteratees.length,\n resIndex = 0,\n takeCount = nativeMin(length, this.__takeCount__);\n\n if (!isArr || (!isRight && arrLength == length && takeCount == length)) {\n return baseWrapperValue(array, this.__actions__);\n }\n var result = [];\n\n outer:\n while (length-- && resIndex < takeCount) {\n index += dir;\n\n var iterIndex = -1,\n value = array[index];\n\n while (++iterIndex < iterLength) {\n var data = iteratees[iterIndex],\n iteratee = data.iteratee,\n type = data.type,\n computed = iteratee(value);\n\n if (type == LAZY_MAP_FLAG) {\n value = computed;\n } else if (!computed) {\n if (type == LAZY_FILTER_FLAG) {\n continue outer;\n } else {\n break outer;\n }\n }\n }\n result[resIndex++] = value;\n }\n return result;\n }\n\n // Ensure `LazyWrapper` is an instance of `baseLodash`.\n LazyWrapper.prototype = baseCreate(baseLodash.prototype);\n LazyWrapper.prototype.constructor = LazyWrapper;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function 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 /**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\n function hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n }\n\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 */\n function hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n }\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 */\n function 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\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 */\n function hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n }\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 */\n function 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\n // Add methods to `Hash`.\n Hash.prototype.clear = hashClear;\n Hash.prototype['delete'] = hashDelete;\n Hash.prototype.get = hashGet;\n Hash.prototype.has = hashHas;\n Hash.prototype.set = hashSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function 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 /**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\n function listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n }\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 */\n function 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\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 */\n function listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n }\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 */\n function listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n }\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 */\n function 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\n // Add methods to `ListCache`.\n ListCache.prototype.clear = listCacheClear;\n ListCache.prototype['delete'] = listCacheDelete;\n ListCache.prototype.get = listCacheGet;\n ListCache.prototype.has = listCacheHas;\n ListCache.prototype.set = listCacheSet;\n\n /*------------------------------------------------------------------------*/\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 */\n function 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 /**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\n function mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n }\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 */\n function mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n }\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 */\n function mapCacheGet(key) {\n return getMapData(this, key).get(key);\n }\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 */\n function mapCacheHas(key) {\n return getMapData(this, key).has(key);\n }\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 */\n function 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\n // Add methods to `MapCache`.\n MapCache.prototype.clear = mapCacheClear;\n MapCache.prototype['delete'] = mapCacheDelete;\n MapCache.prototype.get = mapCacheGet;\n MapCache.prototype.has = mapCacheHas;\n MapCache.prototype.set = mapCacheSet;\n\n /*------------------------------------------------------------------------*/\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 */\n function 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 /**\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 */\n function setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n }\n\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 */\n function setCacheHas(value) {\n return this.__data__.has(value);\n }\n\n // Add methods to `SetCache`.\n SetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\n SetCache.prototype.has = setCacheHas;\n\n /*------------------------------------------------------------------------*/\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 */\n function Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n }\n\n /**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\n function stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n }\n\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 */\n function stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n }\n\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 */\n function stackGet(key) {\n return this.__data__.get(key);\n }\n\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 */\n function stackHas(key) {\n return this.__data__.has(key);\n }\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 */\n function 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\n // Add methods to `Stack`.\n Stack.prototype.clear = stackClear;\n Stack.prototype['delete'] = stackDelete;\n Stack.prototype.get = stackGet;\n Stack.prototype.has = stackHas;\n Stack.prototype.set = stackSet;\n\n /*------------------------------------------------------------------------*/\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 */\n function 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\n /**\n * A specialized version of `_.sample` for arrays.\n *\n * @private\n * @param {Array} array The array to sample.\n * @returns {*} Returns the random element.\n */\n function arraySample(array) {\n var length = array.length;\n return length ? array[baseRandom(0, length - 1)] : undefined;\n }\n\n /**\n * A specialized version of `_.sampleSize` for arrays.\n *\n * @private\n * @param {Array} array The array to sample.\n * @param {number} n The number of elements to sample.\n * @returns {Array} Returns the random elements.\n */\n function arraySampleSize(array, n) {\n return shuffleSelf(copyArray(array), baseClamp(n, 0, array.length));\n }\n\n /**\n * A specialized version of `_.shuffle` for arrays.\n *\n * @private\n * @param {Array} array The array to shuffle.\n * @returns {Array} Returns the new shuffled array.\n */\n function arrayShuffle(array) {\n return shuffleSelf(copyArray(array));\n }\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 */\n function 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\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 */\n function 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\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 */\n function 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\n /**\n * Aggregates elements of `collection` on `accumulator` with keys transformed\n * by `iteratee` and values set by `setter`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\n function baseAggregator(collection, setter, iteratee, accumulator) {\n baseEach(collection, function(value, key, collection) {\n setter(accumulator, value, iteratee(value), collection);\n });\n return accumulator;\n }\n\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 */\n function baseAssign(object, source) {\n return object && copyObject(source, keys(source), object);\n }\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 */\n function baseAssignIn(object, source) {\n return object && copyObject(source, keysIn(source), object);\n }\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 */\n function 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\n /**\n * The base implementation of `_.at` without support for individual paths.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {string[]} paths The property paths to pick.\n * @returns {Array} Returns the picked elements.\n */\n function baseAt(object, paths) {\n var index = -1,\n length = paths.length,\n result = Array(length),\n skip = object == null;\n\n while (++index < length) {\n result[index] = skip ? undefined : get(object, paths[index]);\n }\n return result;\n }\n\n /**\n * The base implementation of `_.clamp` which doesn't coerce arguments.\n *\n * @private\n * @param {number} number The number to clamp.\n * @param {number} [lower] The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the clamped number.\n */\n function baseClamp(number, lower, upper) {\n if (number === number) {\n if (upper !== undefined) {\n number = number <= upper ? number : upper;\n }\n if (lower !== undefined) {\n number = number >= lower ? number : lower;\n }\n }\n return number;\n }\n\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 */\n function 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\n /**\n * The base implementation of `_.conforms` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property predicates to conform to.\n * @returns {Function} Returns the new spec function.\n */\n function baseConforms(source) {\n var props = keys(source);\n return function(object) {\n return baseConformsTo(object, source, props);\n };\n }\n\n /**\n * The base implementation of `_.conformsTo` which accepts `props` to check.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property predicates to conform to.\n * @returns {boolean} Returns `true` if `object` conforms, else `false`.\n */\n function baseConformsTo(object, source, props) {\n var length = props.length;\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (length--) {\n var key = props[length],\n predicate = source[key],\n value = object[key];\n\n if ((value === undefined && !(key in object)) || !predicate(value)) {\n return false;\n }\n }\n return true;\n }\n\n /**\n * The base implementation of `_.delay` and `_.defer` which accepts `args`\n * to provide to `func`.\n *\n * @private\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @param {Array} args The arguments to provide to `func`.\n * @returns {number|Object} Returns the timer id or timeout object.\n */\n function baseDelay(func, wait, args) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n return setTimeout(function() { func.apply(undefined, args); }, wait);\n }\n\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 */\n function 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\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 */\n var baseEach = createBaseEach(baseForOwn);\n\n /**\n * The base implementation of `_.forEachRight` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\n var baseEachRight = createBaseEach(baseForOwnRight, true);\n\n /**\n * The base implementation of `_.every` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n * else `false`\n */\n function baseEvery(collection, predicate) {\n var result = true;\n baseEach(collection, function(value, index, collection) {\n result = !!predicate(value, index, collection);\n return result;\n });\n return result;\n }\n\n /**\n * The base implementation of methods like `_.max` and `_.min` which accepts a\n * `comparator` to determine the extremum value.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The iteratee invoked per iteration.\n * @param {Function} comparator The comparator used to compare values.\n * @returns {*} Returns the extremum value.\n */\n function baseExtremum(array, iteratee, comparator) {\n var index = -1,\n length = array.length;\n\n while (++index < length) {\n var value = array[index],\n current = iteratee(value);\n\n if (current != null && (computed === undefined\n ? (current === current && !isSymbol(current))\n : comparator(current, computed)\n )) {\n var computed = current,\n result = value;\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.fill` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n */\n function baseFill(array, value, start, end) {\n var length = array.length;\n\n start = toInteger(start);\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = (end === undefined || end > length) ? length : toInteger(end);\n if (end < 0) {\n end += length;\n }\n end = start > end ? 0 : toLength(end);\n while (start < end) {\n array[start++] = value;\n }\n return array;\n }\n\n /**\n * The base implementation of `_.filter` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\n function baseFilter(collection, predicate) {\n var result = [];\n baseEach(collection, function(value, index, collection) {\n if (predicate(value, index, collection)) {\n result.push(value);\n }\n });\n return result;\n }\n\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 */\n function 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\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 */\n var baseFor = createBaseFor();\n\n /**\n * This function is like `baseFor` except that it iterates over properties\n * in the opposite order.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\n var baseForRight = createBaseFor(true);\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 */\n function baseForOwn(object, iteratee) {\n return object && baseFor(object, iteratee, keys);\n }\n\n /**\n * The base implementation of `_.forOwnRight` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\n function baseForOwnRight(object, iteratee) {\n return object && baseForRight(object, iteratee, keys);\n }\n\n /**\n * The base implementation of `_.functions` which creates an array of\n * `object` function property names filtered from `props`.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Array} props The property names to filter.\n * @returns {Array} Returns the function names.\n */\n function baseFunctions(object, props) {\n return arrayFilter(props, function(key) {\n return isFunction(object[key]);\n });\n }\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 */\n function 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\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 */\n function baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n }\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 */\n function 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\n /**\n * The base implementation of `_.gt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\n * else `false`.\n */\n function baseGt(value, other) {\n return value > other;\n }\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 */\n function baseHas(object, key) {\n return object != null && hasOwnProperty.call(object, key);\n }\n\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 */\n function baseHasIn(object, key) {\n return object != null && key in Object(object);\n }\n\n /**\n * The base implementation of `_.inRange` which doesn't coerce arguments.\n *\n * @private\n * @param {number} number The number to check.\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @returns {boolean} Returns `true` if `number` is in the range, else `false`.\n */\n function baseInRange(number, start, end) {\n return number >= nativeMin(start, end) && number < nativeMax(start, end);\n }\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 */\n function 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\n /**\n * The base implementation of `_.invert` and `_.invertBy` which inverts\n * `object` with values transformed by `iteratee` and set by `setter`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform values.\n * @param {Object} accumulator The initial inverted object.\n * @returns {Function} Returns `accumulator`.\n */\n function baseInverter(object, setter, iteratee, accumulator) {\n baseForOwn(object, function(value, key, object) {\n setter(accumulator, iteratee(value), key, object);\n });\n return accumulator;\n }\n\n /**\n * The base implementation of `_.invoke` without support for individual\n * method arguments.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the method to invoke.\n * @param {Array} args The arguments to invoke the method with.\n * @returns {*} Returns the result of the invoked method.\n */\n function baseInvoke(object, path, args) {\n path = castPath(path, object);\n object = parent(object, path);\n var func = object == null ? object : object[toKey(last(path))];\n return func == null ? undefined : apply(func, object, args);\n }\n\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 */\n function baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n }\n\n /**\n * The base implementation of `_.isArrayBuffer` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`.\n */\n function baseIsArrayBuffer(value) {\n return isObjectLike(value) && baseGetTag(value) == arrayBufferTag;\n }\n\n /**\n * The base implementation of `_.isDate` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\n */\n function baseIsDate(value) {\n return isObjectLike(value) && baseGetTag(value) == dateTag;\n }\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 */\n function 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\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 */\n function 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\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 */\n function baseIsMap(value) {\n return isObjectLike(value) && getTag(value) == mapTag;\n }\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 */\n function 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\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 */\n function 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\n /**\n * The base implementation of `_.isRegExp` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\n */\n function baseIsRegExp(value) {\n return isObjectLike(value) && baseGetTag(value) == regexpTag;\n }\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 */\n function baseIsSet(value) {\n return isObjectLike(value) && getTag(value) == setTag;\n }\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 */\n function baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n }\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 */\n function 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\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 */\n function 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\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 */\n function 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\n /**\n * The base implementation of `_.lt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than `other`,\n * else `false`.\n */\n function baseLt(value, other) {\n return value < other;\n }\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 */\n function 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\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 */\n function 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\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 */\n function 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\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 */\n function 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\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 */\n function 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\n /**\n * The base implementation of `_.nth` which doesn't coerce arguments.\n *\n * @private\n * @param {Array} array The array to query.\n * @param {number} n The index of the element to return.\n * @returns {*} Returns the nth element of `array`.\n */\n function baseNth(array, n) {\n var length = array.length;\n if (!length) {\n return;\n }\n n += n < 0 ? length : 0;\n return isIndex(n, length) ? array[n] : undefined;\n }\n\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 */\n function 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(getIteratee()));\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\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 */\n function basePick(object, paths) {\n return basePickBy(object, paths, function(value, path) {\n return hasIn(object, path);\n });\n }\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 */\n function 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\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 */\n function basePropertyDeep(path) {\n return function(object) {\n return baseGet(object, path);\n };\n }\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 */\n function 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\n /**\n * The base implementation of `_.pullAt` without support for individual\n * indexes or capturing the removed elements.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {number[]} indexes The indexes of elements to remove.\n * @returns {Array} Returns `array`.\n */\n function basePullAt(array, indexes) {\n var length = array ? indexes.length : 0,\n lastIndex = length - 1;\n\n while (length--) {\n var index = indexes[length];\n if (length == lastIndex || index !== previous) {\n var previous = index;\n if (isIndex(index)) {\n splice.call(array, index, 1);\n } else {\n baseUnset(array, index);\n }\n }\n }\n return array;\n }\n\n /**\n * The base implementation of `_.random` without support for returning\n * floating-point numbers.\n *\n * @private\n * @param {number} lower The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the random number.\n */\n function baseRandom(lower, upper) {\n return lower + nativeFloor(nativeRandom() * (upper - lower + 1));\n }\n\n /**\n * The base implementation of `_.range` and `_.rangeRight` which doesn't\n * coerce arguments.\n *\n * @private\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @param {number} step The value to increment or decrement by.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the range of numbers.\n */\n function baseRange(start, end, step, fromRight) {\n var index = -1,\n length = nativeMax(nativeCeil((end - start) / (step || 1)), 0),\n result = Array(length);\n\n while (length--) {\n result[fromRight ? length : ++index] = start;\n start += step;\n }\n return result;\n }\n\n /**\n * The base implementation of `_.repeat` which doesn't coerce arguments.\n *\n * @private\n * @param {string} string The string to repeat.\n * @param {number} n The number of times to repeat the string.\n * @returns {string} Returns the repeated string.\n */\n function baseRepeat(string, n) {\n var result = '';\n if (!string || n < 1 || n > MAX_SAFE_INTEGER) {\n return result;\n }\n // Leverage the exponentiation by squaring algorithm for a faster repeat.\n // See https://en.wikipedia.org/wiki/Exponentiation_by_squaring for more details.\n do {\n if (n % 2) {\n result += string;\n }\n n = nativeFloor(n / 2);\n if (n) {\n string += string;\n }\n } while (n);\n\n return result;\n }\n\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 */\n function baseRest(func, start) {\n return setToString(overRest(func, start, identity), func + '');\n }\n\n /**\n * The base implementation of `_.sample`.\n *\n * @private\n * @param {Array|Object} collection The collection to sample.\n * @returns {*} Returns the random element.\n */\n function baseSample(collection) {\n return arraySample(values(collection));\n }\n\n /**\n * The base implementation of `_.sampleSize` without param guards.\n *\n * @private\n * @param {Array|Object} collection The collection to sample.\n * @param {number} n The number of elements to sample.\n * @returns {Array} Returns the random elements.\n */\n function baseSampleSize(collection, n) {\n var array = values(collection);\n return shuffleSelf(array, baseClamp(n, 0, array.length));\n }\n\n /**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\n function baseSet(object, path, value, customizer) {\n if (!isObject(object)) {\n return object;\n }\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n lastIndex = length - 1,\n nested = object;\n\n while (nested != null && ++index < length) {\n var key = toKey(path[index]),\n newValue = value;\n\n if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n return object;\n }\n\n if (index != lastIndex) {\n var objValue = nested[key];\n newValue = customizer ? customizer(objValue, key, nested) : undefined;\n if (newValue === undefined) {\n newValue = isObject(objValue)\n ? objValue\n : (isIndex(path[index + 1]) ? [] : {});\n }\n }\n assignValue(nested, key, newValue);\n nested = nested[key];\n }\n return object;\n }\n\n /**\n * The base implementation of `setData` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\n var baseSetData = !metaMap ? identity : function(func, data) {\n metaMap.set(func, data);\n return func;\n };\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 */\n var 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\n /**\n * The base implementation of `_.shuffle`.\n *\n * @private\n * @param {Array|Object} collection The collection to shuffle.\n * @returns {Array} Returns the new shuffled array.\n */\n function baseShuffle(collection) {\n return shuffleSelf(values(collection));\n }\n\n /**\n * The base implementation of `_.slice` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\n function baseSlice(array, start, end) {\n var index = -1,\n length = array.length;\n\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = end > length ? length : end;\n if (end < 0) {\n end += length;\n }\n length = start > end ? 0 : ((end - start) >>> 0);\n start >>>= 0;\n\n var result = Array(length);\n while (++index < length) {\n result[index] = array[index + start];\n }\n return result;\n }\n\n /**\n * The base implementation of `_.some` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\n function baseSome(collection, predicate) {\n var result;\n\n baseEach(collection, function(value, index, collection) {\n result = predicate(value, index, collection);\n return !result;\n });\n return !!result;\n }\n\n /**\n * The base implementation of `_.sortedIndex` and `_.sortedLastIndex` which\n * performs a binary search of `array` to determine the index at which `value`\n * should be inserted into `array` in order to maintain its sort order.\n *\n * @private\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {boolean} [retHighest] Specify returning the highest qualified index.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n */\n function baseSortedIndex(array, value, retHighest) {\n var low = 0,\n high = array == null ? low : array.length;\n\n if (typeof value == 'number' && value === value && high <= HALF_MAX_ARRAY_LENGTH) {\n while (low < high) {\n var mid = (low + high) >>> 1,\n computed = array[mid];\n\n if (computed !== null && !isSymbol(computed) &&\n (retHighest ? (computed <= value) : (computed < value))) {\n low = mid + 1;\n } else {\n high = mid;\n }\n }\n return high;\n }\n return baseSortedIndexBy(array, value, identity, retHighest);\n }\n\n /**\n * The base implementation of `_.sortedIndexBy` and `_.sortedLastIndexBy`\n * which invokes `iteratee` for `value` and each element of `array` to compute\n * their sort ranking. The iteratee is invoked with one argument; (value).\n *\n * @private\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} iteratee The iteratee invoked per element.\n * @param {boolean} [retHighest] Specify returning the highest qualified index.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n */\n function baseSortedIndexBy(array, value, iteratee, retHighest) {\n var low = 0,\n high = array == null ? 0 : array.length;\n if (high === 0) {\n return 0;\n }\n\n value = iteratee(value);\n var valIsNaN = value !== value,\n valIsNull = value === null,\n valIsSymbol = isSymbol(value),\n valIsUndefined = value === undefined;\n\n while (low < high) {\n var mid = nativeFloor((low + high) / 2),\n computed = iteratee(array[mid]),\n othIsDefined = computed !== undefined,\n othIsNull = computed === null,\n othIsReflexive = computed === computed,\n othIsSymbol = isSymbol(computed);\n\n if (valIsNaN) {\n var setLow = retHighest || othIsReflexive;\n } else if (valIsUndefined) {\n setLow = othIsReflexive && (retHighest || othIsDefined);\n } else if (valIsNull) {\n setLow = othIsReflexive && othIsDefined && (retHighest || !othIsNull);\n } else if (valIsSymbol) {\n setLow = othIsReflexive && othIsDefined && !othIsNull && (retHighest || !othIsSymbol);\n } else if (othIsNull || othIsSymbol) {\n setLow = false;\n } else {\n setLow = retHighest ? (computed <= value) : (computed < value);\n }\n if (setLow) {\n low = mid + 1;\n } else {\n high = mid;\n }\n }\n return nativeMin(high, MAX_ARRAY_INDEX);\n }\n\n /**\n * The base implementation of `_.sortedUniq` and `_.sortedUniqBy` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n */\n function baseSortedUniq(array, iteratee) {\n var index = -1,\n length = array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n if (!index || !eq(computed, seen)) {\n var seen = computed;\n result[resIndex++] = value === 0 ? 0 : value;\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.toNumber` which doesn't ensure correct\n * conversions of binary, hexadecimal, or octal string values.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n */\n function baseToNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n return +value;\n }\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 */\n function 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\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 */\n function 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\n /**\n * The base implementation of `_.unset`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The property path to unset.\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\n */\n function baseUnset(object, path) {\n path = castPath(path, object);\n object = parent(object, path);\n return object == null || delete object[toKey(last(path))];\n }\n\n /**\n * The base implementation of `_.update`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to update.\n * @param {Function} updater The function to produce the updated value.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\n function baseUpdate(object, path, updater, customizer) {\n return baseSet(object, path, updater(baseGet(object, path)), customizer);\n }\n\n /**\n * The base implementation of methods like `_.dropWhile` and `_.takeWhile`\n * without support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to query.\n * @param {Function} predicate The function invoked per iteration.\n * @param {boolean} [isDrop] Specify dropping elements instead of taking them.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the slice of `array`.\n */\n function baseWhile(array, predicate, isDrop, fromRight) {\n var length = array.length,\n index = fromRight ? length : -1;\n\n while ((fromRight ? index-- : ++index < length) &&\n predicate(array[index], index, array)) {}\n\n return isDrop\n ? baseSlice(array, (fromRight ? 0 : index), (fromRight ? index + 1 : length))\n : baseSlice(array, (fromRight ? index + 1 : 0), (fromRight ? length : index));\n }\n\n /**\n * The base implementation of `wrapperValue` which returns the result of\n * performing a sequence of actions on the unwrapped `value`, where each\n * successive action is supplied the return value of the previous.\n *\n * @private\n * @param {*} value The unwrapped value.\n * @param {Array} actions Actions to perform to resolve the unwrapped value.\n * @returns {*} Returns the resolved value.\n */\n function baseWrapperValue(value, actions) {\n var result = value;\n if (result instanceof LazyWrapper) {\n result = result.value();\n }\n return arrayReduce(actions, function(result, action) {\n return action.func.apply(action.thisArg, arrayPush([result], action.args));\n }, result);\n }\n\n /**\n * The base implementation of methods like `_.xor`, without support for\n * iteratee shorthands, that accepts an array of arrays to inspect.\n *\n * @private\n * @param {Array} arrays The arrays to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of values.\n */\n function baseXor(arrays, iteratee, comparator) {\n var length = arrays.length;\n if (length < 2) {\n return length ? baseUniq(arrays[0]) : [];\n }\n var index = -1,\n result = Array(length);\n\n while (++index < length) {\n var array = arrays[index],\n othIndex = -1;\n\n while (++othIndex < length) {\n if (othIndex != index) {\n result[index] = baseDifference(result[index] || array, arrays[othIndex], iteratee, comparator);\n }\n }\n }\n return baseUniq(baseFlatten(result, 1), iteratee, comparator);\n }\n\n /**\n * This base implementation of `_.zipObject` which assigns values using `assignFunc`.\n *\n * @private\n * @param {Array} props The property identifiers.\n * @param {Array} values The property values.\n * @param {Function} assignFunc The function to assign values.\n * @returns {Object} Returns the new object.\n */\n function baseZipObject(props, values, assignFunc) {\n var index = -1,\n length = props.length,\n valsLength = values.length,\n result = {};\n\n while (++index < length) {\n var value = index < valsLength ? values[index] : undefined;\n assignFunc(result, props[index], value);\n }\n return result;\n }\n\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 */\n function castArrayLikeObject(value) {\n return isArrayLikeObject(value) ? value : [];\n }\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 */\n function castFunction(value) {\n return typeof value == 'function' ? value : identity;\n }\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 */\n function castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n }\n\n /**\n * A `baseRest` alias which can be replaced with `identity` by module\n * replacement plugins.\n *\n * @private\n * @type {Function}\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\n var castRest = baseRest;\n\n /**\n * Casts `array` to a slice if it's needed.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {number} start The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the cast slice.\n */\n function castSlice(array, start, end) {\n var length = array.length;\n end = end === undefined ? length : end;\n return (!start && end >= length) ? array : baseSlice(array, start, end);\n }\n\n /**\n * A simple wrapper around the global [`clearTimeout`](https://mdn.io/clearTimeout).\n *\n * @private\n * @param {number|Object} id The timer id or timeout object of the timer to clear.\n */\n var clearTimeout = ctxClearTimeout || function(id) {\n return root.clearTimeout(id);\n };\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 */\n function 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\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 */\n function cloneArrayBuffer(arrayBuffer) {\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n return result;\n }\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 */\n function cloneDataView(dataView, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n }\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 */\n function cloneRegExp(regexp) {\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n result.lastIndex = regexp.lastIndex;\n return result;\n }\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 */\n function cloneSymbol(symbol) {\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n }\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 */\n function cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n }\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 */\n function 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\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 */\n function 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\n /**\n * Creates an array that is the composition of partially applied arguments,\n * placeholders, and provided arguments into a single array of arguments.\n *\n * @private\n * @param {Array} args The provided arguments.\n * @param {Array} partials The arguments to prepend to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @params {boolean} [isCurried] Specify composing for a curried function.\n * @returns {Array} Returns the new array of composed arguments.\n */\n function composeArgs(args, partials, holders, isCurried) {\n var argsIndex = -1,\n argsLength = args.length,\n holdersLength = holders.length,\n leftIndex = -1,\n leftLength = partials.length,\n rangeLength = nativeMax(argsLength - holdersLength, 0),\n result = Array(leftLength + rangeLength),\n isUncurried = !isCurried;\n\n while (++leftIndex < leftLength) {\n result[leftIndex] = partials[leftIndex];\n }\n while (++argsIndex < holdersLength) {\n if (isUncurried || argsIndex < argsLength) {\n result[holders[argsIndex]] = args[argsIndex];\n }\n }\n while (rangeLength--) {\n result[leftIndex++] = args[argsIndex++];\n }\n return result;\n }\n\n /**\n * This function is like `composeArgs` except that the arguments composition\n * is tailored for `_.partialRight`.\n *\n * @private\n * @param {Array} args The provided arguments.\n * @param {Array} partials The arguments to append to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @params {boolean} [isCurried] Specify composing for a curried function.\n * @returns {Array} Returns the new array of composed arguments.\n */\n function composeArgsRight(args, partials, holders, isCurried) {\n var argsIndex = -1,\n argsLength = args.length,\n holdersIndex = -1,\n holdersLength = holders.length,\n rightIndex = -1,\n rightLength = partials.length,\n rangeLength = nativeMax(argsLength - holdersLength, 0),\n result = Array(rangeLength + rightLength),\n isUncurried = !isCurried;\n\n while (++argsIndex < rangeLength) {\n result[argsIndex] = args[argsIndex];\n }\n var offset = argsIndex;\n while (++rightIndex < rightLength) {\n result[offset + rightIndex] = partials[rightIndex];\n }\n while (++holdersIndex < holdersLength) {\n if (isUncurried || argsIndex < argsLength) {\n result[offset + holders[holdersIndex]] = args[argsIndex++];\n }\n }\n return result;\n }\n\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 */\n function 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\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 */\n function 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\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 */\n function copySymbols(source, object) {\n return copyObject(source, getSymbols(source), object);\n }\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 */\n function copySymbolsIn(source, object) {\n return copyObject(source, getSymbolsIn(source), object);\n }\n\n /**\n * Creates a function like `_.groupBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} [initializer] The accumulator object initializer.\n * @returns {Function} Returns the new aggregator function.\n */\n function createAggregator(setter, initializer) {\n return function(collection, iteratee) {\n var func = isArray(collection) ? arrayAggregator : baseAggregator,\n accumulator = initializer ? initializer() : {};\n\n return func(collection, setter, getIteratee(iteratee, 2), accumulator);\n };\n }\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 */\n function 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\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 */\n function 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\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 */\n function 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\n /**\n * Creates a function that wraps `func` to invoke it with the optional `this`\n * binding of `thisArg`.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createBind(func, bitmask, thisArg) {\n var isBind = bitmask & WRAP_BIND_FLAG,\n Ctor = createCtor(func);\n\n function wrapper() {\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n return fn.apply(isBind ? thisArg : this, arguments);\n }\n return wrapper;\n }\n\n /**\n * Creates a function like `_.lowerFirst`.\n *\n * @private\n * @param {string} methodName The name of the `String` case method to use.\n * @returns {Function} Returns the new case function.\n */\n function createCaseFirst(methodName) {\n return function(string) {\n string = toString(string);\n\n var strSymbols = hasUnicode(string)\n ? stringToArray(string)\n : undefined;\n\n var chr = strSymbols\n ? strSymbols[0]\n : string.charAt(0);\n\n var trailing = strSymbols\n ? castSlice(strSymbols, 1).join('')\n : string.slice(1);\n\n return chr[methodName]() + trailing;\n };\n }\n\n /**\n * Creates a function like `_.camelCase`.\n *\n * @private\n * @param {Function} callback The function to combine each word.\n * @returns {Function} Returns the new compounder function.\n */\n function createCompounder(callback) {\n return function(string) {\n return arrayReduce(words(deburr(string).replace(reApos, '')), callback, '');\n };\n }\n\n /**\n * Creates a function that produces an instance of `Ctor` regardless of\n * whether it was invoked as part of a `new` expression or by `call` or `apply`.\n *\n * @private\n * @param {Function} Ctor The constructor to wrap.\n * @returns {Function} Returns the new wrapped function.\n */\n function createCtor(Ctor) {\n return function() {\n // Use a `switch` statement to work with class constructors. See\n // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist\n // for more details.\n var args = arguments;\n switch (args.length) {\n case 0: return new Ctor;\n case 1: return new Ctor(args[0]);\n case 2: return new Ctor(args[0], args[1]);\n case 3: return new Ctor(args[0], args[1], args[2]);\n case 4: return new Ctor(args[0], args[1], args[2], args[3]);\n case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]);\n case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]);\n case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]);\n }\n var thisBinding = baseCreate(Ctor.prototype),\n result = Ctor.apply(thisBinding, args);\n\n // Mimic the constructor's `return` behavior.\n // See https://es5.github.io/#x13.2.2 for more details.\n return isObject(result) ? result : thisBinding;\n };\n }\n\n /**\n * Creates a function that wraps `func` to enable currying.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {number} arity The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createCurry(func, bitmask, arity) {\n var Ctor = createCtor(func);\n\n function wrapper() {\n var length = arguments.length,\n args = Array(length),\n index = length,\n placeholder = getHolder(wrapper);\n\n while (index--) {\n args[index] = arguments[index];\n }\n var holders = (length < 3 && args[0] !== placeholder && args[length - 1] !== placeholder)\n ? []\n : replaceHolders(args, placeholder);\n\n length -= holders.length;\n if (length < arity) {\n return createRecurry(\n func, bitmask, createHybrid, wrapper.placeholder, undefined,\n args, holders, undefined, undefined, arity - length);\n }\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n return apply(fn, this, args);\n }\n return wrapper;\n }\n\n /**\n * Creates a `_.find` or `_.findLast` function.\n *\n * @private\n * @param {Function} findIndexFunc The function to find the collection index.\n * @returns {Function} Returns the new find function.\n */\n function createFind(findIndexFunc) {\n return function(collection, predicate, fromIndex) {\n var iterable = Object(collection);\n if (!isArrayLike(collection)) {\n var iteratee = getIteratee(predicate, 3);\n collection = keys(collection);\n predicate = function(key) { return iteratee(iterable[key], key, iterable); };\n }\n var index = findIndexFunc(collection, predicate, fromIndex);\n return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined;\n };\n }\n\n /**\n * Creates a `_.flow` or `_.flowRight` function.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new flow function.\n */\n function createFlow(fromRight) {\n return flatRest(function(funcs) {\n var length = funcs.length,\n index = length,\n prereq = LodashWrapper.prototype.thru;\n\n if (fromRight) {\n funcs.reverse();\n }\n while (index--) {\n var func = funcs[index];\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (prereq && !wrapper && getFuncName(func) == 'wrapper') {\n var wrapper = new LodashWrapper([], true);\n }\n }\n index = wrapper ? index : length;\n while (++index < length) {\n func = funcs[index];\n\n var funcName = getFuncName(func),\n data = funcName == 'wrapper' ? getData(func) : undefined;\n\n if (data && isLaziable(data[0]) &&\n data[1] == (WRAP_ARY_FLAG | WRAP_CURRY_FLAG | WRAP_PARTIAL_FLAG | WRAP_REARG_FLAG) &&\n !data[4].length && data[9] == 1\n ) {\n wrapper = wrapper[getFuncName(data[0])].apply(wrapper, data[3]);\n } else {\n wrapper = (func.length == 1 && isLaziable(func))\n ? wrapper[funcName]()\n : wrapper.thru(func);\n }\n }\n return function() {\n var args = arguments,\n value = args[0];\n\n if (wrapper && args.length == 1 && isArray(value)) {\n return wrapper.plant(value).value();\n }\n var index = 0,\n result = length ? funcs[index].apply(this, args) : value;\n\n while (++index < length) {\n result = funcs[index].call(this, result);\n }\n return result;\n };\n });\n }\n\n /**\n * Creates a function that wraps `func` to invoke it with optional `this`\n * binding of `thisArg`, partial application, and currying.\n *\n * @private\n * @param {Function|string} func The function or method name to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to\n * the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [partialsRight] The arguments to append to those provided\n * to the new function.\n * @param {Array} [holdersRight] The `partialsRight` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createHybrid(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) {\n var isAry = bitmask & WRAP_ARY_FLAG,\n isBind = bitmask & WRAP_BIND_FLAG,\n isBindKey = bitmask & WRAP_BIND_KEY_FLAG,\n isCurried = bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG),\n isFlip = bitmask & WRAP_FLIP_FLAG,\n Ctor = isBindKey ? undefined : createCtor(func);\n\n function wrapper() {\n var length = arguments.length,\n args = Array(length),\n index = length;\n\n while (index--) {\n args[index] = arguments[index];\n }\n if (isCurried) {\n var placeholder = getHolder(wrapper),\n holdersCount = countHolders(args, placeholder);\n }\n if (partials) {\n args = composeArgs(args, partials, holders, isCurried);\n }\n if (partialsRight) {\n args = composeArgsRight(args, partialsRight, holdersRight, isCurried);\n }\n length -= holdersCount;\n if (isCurried && length < arity) {\n var newHolders = replaceHolders(args, placeholder);\n return createRecurry(\n func, bitmask, createHybrid, wrapper.placeholder, thisArg,\n args, newHolders, argPos, ary, arity - length\n );\n }\n var thisBinding = isBind ? thisArg : this,\n fn = isBindKey ? thisBinding[func] : func;\n\n length = args.length;\n if (argPos) {\n args = reorder(args, argPos);\n } else if (isFlip && length > 1) {\n args.reverse();\n }\n if (isAry && ary < length) {\n args.length = ary;\n }\n if (this && this !== root && this instanceof wrapper) {\n fn = Ctor || createCtor(fn);\n }\n return fn.apply(thisBinding, args);\n }\n return wrapper;\n }\n\n /**\n * Creates a function like `_.invertBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} toIteratee The function to resolve iteratees.\n * @returns {Function} Returns the new inverter function.\n */\n function createInverter(setter, toIteratee) {\n return function(object, iteratee) {\n return baseInverter(object, setter, toIteratee(iteratee), {});\n };\n }\n\n /**\n * Creates a function that performs a mathematical operation on two values.\n *\n * @private\n * @param {Function} operator The function to perform the operation.\n * @param {number} [defaultValue] The value used for `undefined` arguments.\n * @returns {Function} Returns the new mathematical operation function.\n */\n function createMathOperation(operator, defaultValue) {\n return function(value, other) {\n var result;\n if (value === undefined && other === undefined) {\n return defaultValue;\n }\n if (value !== undefined) {\n result = value;\n }\n if (other !== undefined) {\n if (result === undefined) {\n return other;\n }\n if (typeof value == 'string' || typeof other == 'string') {\n value = baseToString(value);\n other = baseToString(other);\n } else {\n value = baseToNumber(value);\n other = baseToNumber(other);\n }\n result = operator(value, other);\n }\n return result;\n };\n }\n\n /**\n * Creates a function like `_.over`.\n *\n * @private\n * @param {Function} arrayFunc The function to iterate over iteratees.\n * @returns {Function} Returns the new over function.\n */\n function createOver(arrayFunc) {\n return flatRest(function(iteratees) {\n iteratees = arrayMap(iteratees, baseUnary(getIteratee()));\n return baseRest(function(args) {\n var thisArg = this;\n return arrayFunc(iteratees, function(iteratee) {\n return apply(iteratee, thisArg, args);\n });\n });\n });\n }\n\n /**\n * Creates the padding for `string` based on `length`. The `chars` string\n * is truncated if the number of characters exceeds `length`.\n *\n * @private\n * @param {number} length The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padding for `string`.\n */\n function createPadding(length, chars) {\n chars = chars === undefined ? ' ' : baseToString(chars);\n\n var charsLength = chars.length;\n if (charsLength < 2) {\n return charsLength ? baseRepeat(chars, length) : chars;\n }\n var result = baseRepeat(chars, nativeCeil(length / stringSize(chars)));\n return hasUnicode(chars)\n ? castSlice(stringToArray(result), 0, length).join('')\n : result.slice(0, length);\n }\n\n /**\n * Creates a function that wraps `func` to invoke it with the `this` binding\n * of `thisArg` and `partials` prepended to the arguments it receives.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} partials The arguments to prepend to those provided to\n * the new function.\n * @returns {Function} Returns the new wrapped function.\n */\n function createPartial(func, bitmask, thisArg, partials) {\n var isBind = bitmask & WRAP_BIND_FLAG,\n Ctor = createCtor(func);\n\n function wrapper() {\n var argsIndex = -1,\n argsLength = arguments.length,\n leftIndex = -1,\n leftLength = partials.length,\n args = Array(leftLength + argsLength),\n fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n\n while (++leftIndex < leftLength) {\n args[leftIndex] = partials[leftIndex];\n }\n while (argsLength--) {\n args[leftIndex++] = arguments[++argsIndex];\n }\n return apply(fn, isBind ? thisArg : this, args);\n }\n return wrapper;\n }\n\n /**\n * Creates a `_.range` or `_.rangeRight` function.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new range function.\n */\n function createRange(fromRight) {\n return function(start, end, step) {\n if (step && typeof step != 'number' && isIterateeCall(start, end, step)) {\n end = step = undefined;\n }\n // Ensure the sign of `-0` is preserved.\n start = toFinite(start);\n if (end === undefined) {\n end = start;\n start = 0;\n } else {\n end = toFinite(end);\n }\n step = step === undefined ? (start < end ? 1 : -1) : toFinite(step);\n return baseRange(start, end, step, fromRight);\n };\n }\n\n /**\n * Creates a function that performs a relational operation on two values.\n *\n * @private\n * @param {Function} operator The function to perform the operation.\n * @returns {Function} Returns the new relational operation function.\n */\n function createRelationalOperation(operator) {\n return function(value, other) {\n if (!(typeof value == 'string' && typeof other == 'string')) {\n value = toNumber(value);\n other = toNumber(other);\n }\n return operator(value, other);\n };\n }\n\n /**\n * Creates a function that wraps `func` to continue currying.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {Function} wrapFunc The function to create the `func` wrapper.\n * @param {*} placeholder The placeholder value.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to\n * the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createRecurry(func, bitmask, wrapFunc, placeholder, thisArg, partials, holders, argPos, ary, arity) {\n var isCurry = bitmask & WRAP_CURRY_FLAG,\n newHolders = isCurry ? holders : undefined,\n newHoldersRight = isCurry ? undefined : holders,\n newPartials = isCurry ? partials : undefined,\n newPartialsRight = isCurry ? undefined : partials;\n\n bitmask |= (isCurry ? WRAP_PARTIAL_FLAG : WRAP_PARTIAL_RIGHT_FLAG);\n bitmask &= ~(isCurry ? WRAP_PARTIAL_RIGHT_FLAG : WRAP_PARTIAL_FLAG);\n\n if (!(bitmask & WRAP_CURRY_BOUND_FLAG)) {\n bitmask &= ~(WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG);\n }\n var newData = [\n func, bitmask, thisArg, newPartials, newHolders, newPartialsRight,\n newHoldersRight, argPos, ary, arity\n ];\n\n var result = wrapFunc.apply(undefined, newData);\n if (isLaziable(func)) {\n setData(result, newData);\n }\n result.placeholder = placeholder;\n return setWrapToString(result, func, bitmask);\n }\n\n /**\n * Creates a function like `_.round`.\n *\n * @private\n * @param {string} methodName The name of the `Math` method to use when rounding.\n * @returns {Function} Returns the new round function.\n */\n function createRound(methodName) {\n var func = Math[methodName];\n return function(number, precision) {\n number = toNumber(number);\n precision = precision == null ? 0 : nativeMin(toInteger(precision), 292);\n if (precision && nativeIsFinite(number)) {\n // Shift with exponential notation to avoid floating-point issues.\n // See [MDN](https://mdn.io/round#Examples) for more details.\n var pair = (toString(number) + 'e').split('e'),\n value = func(pair[0] + 'e' + (+pair[1] + precision));\n\n pair = (toString(value) + 'e').split('e');\n return +(pair[0] + 'e' + (+pair[1] - precision));\n }\n return func(number);\n };\n }\n\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 */\n var createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) {\n return new Set(values);\n };\n\n /**\n * Creates a `_.toPairs` or `_.toPairsIn` function.\n *\n * @private\n * @param {Function} keysFunc The function to get the keys of a given object.\n * @returns {Function} Returns the new pairs function.\n */\n function createToPairs(keysFunc) {\n return function(object) {\n var tag = getTag(object);\n if (tag == mapTag) {\n return mapToArray(object);\n }\n if (tag == setTag) {\n return setToPairs(object);\n }\n return baseToPairs(object, keysFunc(object));\n };\n }\n\n /**\n * Creates a function that either curries or invokes `func` with optional\n * `this` binding and partially applied arguments.\n *\n * @private\n * @param {Function|string} func The function or method name to wrap.\n * @param {number} bitmask The bitmask flags.\n * 1 - `_.bind`\n * 2 - `_.bindKey`\n * 4 - `_.curry` or `_.curryRight` of a bound function\n * 8 - `_.curry`\n * 16 - `_.curryRight`\n * 32 - `_.partial`\n * 64 - `_.partialRight`\n * 128 - `_.rearg`\n * 256 - `_.ary`\n * 512 - `_.flip`\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to be partially applied.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createWrap(func, bitmask, thisArg, partials, holders, argPos, ary, arity) {\n var isBindKey = bitmask & WRAP_BIND_KEY_FLAG;\n if (!isBindKey && typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var length = partials ? partials.length : 0;\n if (!length) {\n bitmask &= ~(WRAP_PARTIAL_FLAG | WRAP_PARTIAL_RIGHT_FLAG);\n partials = holders = undefined;\n }\n ary = ary === undefined ? ary : nativeMax(toInteger(ary), 0);\n arity = arity === undefined ? arity : toInteger(arity);\n length -= holders ? holders.length : 0;\n\n if (bitmask & WRAP_PARTIAL_RIGHT_FLAG) {\n var partialsRight = partials,\n holdersRight = holders;\n\n partials = holders = undefined;\n }\n var data = isBindKey ? undefined : getData(func);\n\n var newData = [\n func, bitmask, thisArg, partials, holders, partialsRight, holdersRight,\n argPos, ary, arity\n ];\n\n if (data) {\n mergeData(newData, data);\n }\n func = newData[0];\n bitmask = newData[1];\n thisArg = newData[2];\n partials = newData[3];\n holders = newData[4];\n arity = newData[9] = newData[9] === undefined\n ? (isBindKey ? 0 : func.length)\n : nativeMax(newData[9] - length, 0);\n\n if (!arity && bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG)) {\n bitmask &= ~(WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG);\n }\n if (!bitmask || bitmask == WRAP_BIND_FLAG) {\n var result = createBind(func, bitmask, thisArg);\n } else if (bitmask == WRAP_CURRY_FLAG || bitmask == WRAP_CURRY_RIGHT_FLAG) {\n result = createCurry(func, bitmask, arity);\n } else if ((bitmask == WRAP_PARTIAL_FLAG || bitmask == (WRAP_BIND_FLAG | WRAP_PARTIAL_FLAG)) && !holders.length) {\n result = createPartial(func, bitmask, thisArg, partials);\n } else {\n result = createHybrid.apply(undefined, newData);\n }\n var setter = data ? baseSetData : setData;\n return setWrapToString(setter(result, newData), func, bitmask);\n }\n\n /**\n * Used by `_.defaults` to customize its `_.assignIn` use to assign properties\n * of source objects to the destination object for all destination properties\n * that resolve to `undefined`.\n *\n * @private\n * @param {*} objValue The destination value.\n * @param {*} srcValue The source value.\n * @param {string} key The key of the property to assign.\n * @param {Object} object The parent object of `objValue`.\n * @returns {*} Returns the value to assign.\n */\n function customDefaultsAssignIn(objValue, srcValue, key, object) {\n if (objValue === undefined ||\n (eq(objValue, objectProto[key]) && !hasOwnProperty.call(object, key))) {\n return srcValue;\n }\n return objValue;\n }\n\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 */\n function 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\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 */\n function customOmitClone(value) {\n return isPlainObject(value) ? undefined : value;\n }\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 */\n function 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\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 */\n function 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\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 */\n function 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\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 */\n function flatRest(func) {\n return setToString(overRest(func, undefined, flatten), func + '');\n }\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 */\n function getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n }\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 */\n function getAllKeysIn(object) {\n return baseGetAllKeys(object, keysIn, getSymbolsIn);\n }\n\n /**\n * Gets metadata for `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {*} Returns the metadata for `func`.\n */\n var getData = !metaMap ? noop : function(func) {\n return metaMap.get(func);\n };\n\n /**\n * Gets the name of `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {string} Returns the function name.\n */\n function getFuncName(func) {\n var result = (func.name + ''),\n array = realNames[result],\n length = hasOwnProperty.call(realNames, result) ? array.length : 0;\n\n while (length--) {\n var data = array[length],\n otherFunc = data.func;\n if (otherFunc == null || otherFunc == func) {\n return data.name;\n }\n }\n return result;\n }\n\n /**\n * Gets the argument placeholder value for `func`.\n *\n * @private\n * @param {Function} func The function to inspect.\n * @returns {*} Returns the placeholder value.\n */\n function getHolder(func) {\n var object = hasOwnProperty.call(lodash, 'placeholder') ? lodash : func;\n return object.placeholder;\n }\n\n /**\n * Gets the appropriate \"iteratee\" function. If `_.iteratee` is customized,\n * this function returns the custom method, otherwise it returns `baseIteratee`.\n * If arguments are provided, the chosen function is invoked with them and\n * its result is returned.\n *\n * @private\n * @param {*} [value] The value to convert to an iteratee.\n * @param {number} [arity] The arity of the created iteratee.\n * @returns {Function} Returns the chosen function or its result.\n */\n function getIteratee() {\n var result = lodash.iteratee || iteratee;\n result = result === iteratee ? baseIteratee : result;\n return arguments.length ? result(arguments[0], arguments[1]) : result;\n }\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 */\n function getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n }\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 */\n function 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\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 */\n function getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n }\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 */\n function 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\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 */\n var 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\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 */\n var 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\n /**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\n var getTag = baseGetTag;\n\n // Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\n if ((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\n /**\n * Gets the view, applying any `transforms` to the `start` and `end` positions.\n *\n * @private\n * @param {number} start The start of the view.\n * @param {number} end The end of the view.\n * @param {Array} transforms The transformations to apply to the view.\n * @returns {Object} Returns an object containing the `start` and `end`\n * positions of the view.\n */\n function getView(start, end, transforms) {\n var index = -1,\n length = transforms.length;\n\n while (++index < length) {\n var data = transforms[index],\n size = data.size;\n\n switch (data.type) {\n case 'drop': start += size; break;\n case 'dropRight': end -= size; break;\n case 'take': end = nativeMin(end, start + size); break;\n case 'takeRight': start = nativeMax(start, end - size); break;\n }\n }\n return { 'start': start, 'end': end };\n }\n\n /**\n * Extracts wrapper details from the `source` body comment.\n *\n * @private\n * @param {string} source The source to inspect.\n * @returns {Array} Returns the wrapper details.\n */\n function getWrapDetails(source) {\n var match = source.match(reWrapDetails);\n return match ? match[1].split(reSplitDetails) : [];\n }\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 */\n function 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\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 */\n function 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\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 */\n function initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n }\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 */\n function 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\n /**\n * Inserts wrapper `details` in a comment at the top of the `source` body.\n *\n * @private\n * @param {string} source The source to modify.\n * @returns {Array} details The details to insert.\n * @returns {string} Returns the modified source.\n */\n function insertWrapDetails(source, details) {\n var length = details.length;\n if (!length) {\n return source;\n }\n var lastIndex = length - 1;\n details[lastIndex] = (length > 1 ? '& ' : '') + details[lastIndex];\n details = details.join(length > 2 ? ', ' : ' ');\n return source.replace(reWrapComment, '{\\n/* [wrapped with ' + details + '] */\\n');\n }\n\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 */\n function isFlattenable(value) {\n return isArray(value) || isArguments(value) ||\n !!(spreadableSymbol && value && value[spreadableSymbol]);\n }\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 */\n function 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\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 */\n function 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\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 */\n function 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\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 */\n function 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\n /**\n * Checks if `func` has a lazy counterpart.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` has a lazy counterpart,\n * else `false`.\n */\n function isLaziable(func) {\n var funcName = getFuncName(func),\n other = lodash[funcName];\n\n if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) {\n return false;\n }\n if (func === other) {\n return true;\n }\n var data = getData(other);\n return !!data && func === data[0];\n }\n\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 */\n function isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n }\n\n /**\n * Checks if `func` is capable of being masked.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `func` is maskable, else `false`.\n */\n var isMaskable = coreJsData ? isFunction : stubFalse;\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 */\n function isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n }\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 */\n function isStrictComparable(value) {\n return value === value && !isObject(value);\n }\n\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 */\n function 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\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 */\n function 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\n /**\n * Merges the function metadata of `source` into `data`.\n *\n * Merging metadata reduces the number of wrappers used to invoke a function.\n * This is possible because methods like `_.bind`, `_.curry`, and `_.partial`\n * may be applied regardless of execution order. Methods like `_.ary` and\n * `_.rearg` modify function arguments, making the order in which they are\n * executed important, preventing the merging of metadata. However, we make\n * an exception for a safe combined case where curried functions have `_.ary`\n * and or `_.rearg` applied.\n *\n * @private\n * @param {Array} data The destination metadata.\n * @param {Array} source The source metadata.\n * @returns {Array} Returns `data`.\n */\n function mergeData(data, source) {\n var bitmask = data[1],\n srcBitmask = source[1],\n newBitmask = bitmask | srcBitmask,\n isCommon = newBitmask < (WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG | WRAP_ARY_FLAG);\n\n var isCombo =\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_CURRY_FLAG)) ||\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_REARG_FLAG) && (data[7].length <= source[8])) ||\n ((srcBitmask == (WRAP_ARY_FLAG | WRAP_REARG_FLAG)) && (source[7].length <= source[8]) && (bitmask == WRAP_CURRY_FLAG));\n\n // Exit early if metadata can't be merged.\n if (!(isCommon || isCombo)) {\n return data;\n }\n // Use source `thisArg` if available.\n if (srcBitmask & WRAP_BIND_FLAG) {\n data[2] = source[2];\n // Set when currying a bound function.\n newBitmask |= bitmask & WRAP_BIND_FLAG ? 0 : WRAP_CURRY_BOUND_FLAG;\n }\n // Compose partial arguments.\n var value = source[3];\n if (value) {\n var partials = data[3];\n data[3] = partials ? composeArgs(partials, value, source[4]) : value;\n data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : source[4];\n }\n // Compose partial right arguments.\n value = source[5];\n if (value) {\n partials = data[5];\n data[5] = partials ? composeArgsRight(partials, value, source[6]) : value;\n data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : source[6];\n }\n // Use source `argPos` if available.\n value = source[7];\n if (value) {\n data[7] = value;\n }\n // Use source `ary` if it's smaller.\n if (srcBitmask & WRAP_ARY_FLAG) {\n data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]);\n }\n // Use source `arity` if one is not provided.\n if (data[9] == null) {\n data[9] = source[9];\n }\n // Use source `func` and merge bitmasks.\n data[0] = source[0];\n data[1] = newBitmask;\n\n return data;\n }\n\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 */\n function 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\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 */\n function objectToString(value) {\n return nativeObjectToString.call(value);\n }\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 */\n function 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\n /**\n * Gets the parent value at `path` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} path The path to get the parent value of.\n * @returns {*} Returns the parent value.\n */\n function parent(object, path) {\n return path.length < 2 ? object : baseGet(object, baseSlice(path, 0, -1));\n }\n\n /**\n * Reorder `array` according to the specified indexes where the element at\n * the first index is assigned as the first element, the element at\n * the second index is assigned as the second element, and so on.\n *\n * @private\n * @param {Array} array The array to reorder.\n * @param {Array} indexes The arranged array indexes.\n * @returns {Array} Returns `array`.\n */\n function reorder(array, indexes) {\n var arrLength = array.length,\n length = nativeMin(indexes.length, arrLength),\n oldArray = copyArray(array);\n\n while (length--) {\n var index = indexes[length];\n array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined;\n }\n return array;\n }\n\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 */\n function 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\n /**\n * Sets metadata for `func`.\n *\n * **Note:** If this function becomes hot, i.e. is invoked a lot in a short\n * period of time, it will trip its breaker and transition to an identity\n * function to avoid garbage collection pauses in V8. See\n * [V8 issue 2070](https://bugs.chromium.org/p/v8/issues/detail?id=2070)\n * for more details.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\n var setData = shortOut(baseSetData);\n\n /**\n * A simple wrapper around the global [`setTimeout`](https://mdn.io/setTimeout).\n *\n * @private\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @returns {number|Object} Returns the timer id or timeout object.\n */\n var setTimeout = ctxSetTimeout || function(func, wait) {\n return root.setTimeout(func, wait);\n };\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 */\n var setToString = shortOut(baseSetToString);\n\n /**\n * Sets the `toString` method of `wrapper` to mimic the source of `reference`\n * with wrapper details in a comment at the top of the source body.\n *\n * @private\n * @param {Function} wrapper The function to modify.\n * @param {Function} reference The reference function.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @returns {Function} Returns `wrapper`.\n */\n function setWrapToString(wrapper, reference, bitmask) {\n var source = (reference + '');\n return setToString(wrapper, insertWrapDetails(source, updateWrapDetails(getWrapDetails(source), bitmask)));\n }\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 */\n function 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\n /**\n * A specialized version of `_.shuffle` which mutates and sets the size of `array`.\n *\n * @private\n * @param {Array} array The array to shuffle.\n * @param {number} [size=array.length] The size of `array`.\n * @returns {Array} Returns `array`.\n */\n function shuffleSelf(array, size) {\n var index = -1,\n length = array.length,\n lastIndex = length - 1;\n\n size = size === undefined ? length : size;\n while (++index < size) {\n var rand = baseRandom(index, lastIndex),\n value = array[rand];\n\n array[rand] = array[index];\n array[index] = value;\n }\n array.length = size;\n return array;\n }\n\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 */\n var 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\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 */\n function 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\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 */\n function 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\n /**\n * Updates wrapper `details` based on `bitmask` flags.\n *\n * @private\n * @returns {Array} details The details to modify.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @returns {Array} Returns `details`.\n */\n function updateWrapDetails(details, bitmask) {\n arrayEach(wrapFlags, function(pair) {\n var value = '_.' + pair[0];\n if ((bitmask & pair[1]) && !arrayIncludes(details, value)) {\n details.push(value);\n }\n });\n return details.sort();\n }\n\n /**\n * Creates a clone of `wrapper`.\n *\n * @private\n * @param {Object} wrapper The wrapper to clone.\n * @returns {Object} Returns the cloned wrapper.\n */\n function wrapperClone(wrapper) {\n if (wrapper instanceof LazyWrapper) {\n return wrapper.clone();\n }\n var result = new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__);\n result.__actions__ = copyArray(wrapper.__actions__);\n result.__index__ = wrapper.__index__;\n result.__values__ = wrapper.__values__;\n return result;\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an array of elements split into groups the length of `size`.\n * If `array` can't be split evenly, the final chunk will be the remaining\n * elements.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to process.\n * @param {number} [size=1] The length of each chunk\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the new array of chunks.\n * @example\n *\n * _.chunk(['a', 'b', 'c', 'd'], 2);\n * // => [['a', 'b'], ['c', 'd']]\n *\n * _.chunk(['a', 'b', 'c', 'd'], 3);\n * // => [['a', 'b', 'c'], ['d']]\n */\n function chunk(array, size, guard) {\n if ((guard ? isIterateeCall(array, size, guard) : size === undefined)) {\n size = 1;\n } else {\n size = nativeMax(toInteger(size), 0);\n }\n var length = array == null ? 0 : array.length;\n if (!length || size < 1) {\n return [];\n }\n var index = 0,\n resIndex = 0,\n result = Array(nativeCeil(length / size));\n\n while (index < length) {\n result[resIndex++] = baseSlice(array, index, (index += size));\n }\n return result;\n }\n\n /**\n * Creates an array with all falsey values removed. The values `false`, `null`,\n * `0`, `\"\"`, `undefined`, and `NaN` are falsey.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to compact.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.compact([0, 1, false, 2, '', 3]);\n * // => [1, 2, 3]\n */\n function compact(array) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (value) {\n result[resIndex++] = value;\n }\n }\n return result;\n }\n\n /**\n * Creates a new array concatenating `array` with any additional arrays\n * and/or values.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to concatenate.\n * @param {...*} [values] The values to concatenate.\n * @returns {Array} Returns the new concatenated array.\n * @example\n *\n * var array = [1];\n * var other = _.concat(array, 2, [3], [[4]]);\n *\n * console.log(other);\n * // => [1, 2, 3, [4]]\n *\n * console.log(array);\n * // => [1]\n */\n function concat() {\n var length = arguments.length;\n if (!length) {\n return [];\n }\n var args = Array(length - 1),\n array = arguments[0],\n index = length;\n\n while (index--) {\n args[index - 1] = arguments[index];\n }\n return arrayPush(isArray(array) ? copyArray(array) : [array], baseFlatten(args, 1));\n }\n\n /**\n * Creates an array of `array` values not included in the other given arrays\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. The order and references of result values are\n * determined by the first array.\n *\n * **Note:** Unlike `_.pullAll`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.without, _.xor\n * @example\n *\n * _.difference([2, 1], [2, 3]);\n * // => [1]\n */\n var difference = baseRest(function(array, values) {\n return isArrayLikeObject(array)\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true))\n : [];\n });\n\n /**\n * This method is like `_.difference` except that it accepts `iteratee` which\n * is invoked for each element of `array` and `values` to generate the criterion\n * by which they're compared. The order and references of result values are\n * determined by the first array. The iteratee is invoked with one argument:\n * (value).\n *\n * **Note:** Unlike `_.pullAllBy`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.differenceBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.differenceBy([{ 'x': 2 }, { 'x': 1 }], [{ 'x': 1 }], 'x');\n * // => [{ 'x': 2 }]\n */\n var differenceBy = baseRest(function(array, values) {\n var iteratee = last(values);\n if (isArrayLikeObject(iteratee)) {\n iteratee = undefined;\n }\n return isArrayLikeObject(array)\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), getIteratee(iteratee, 2))\n : [];\n });\n\n /**\n * This method is like `_.difference` except that it accepts `comparator`\n * which is invoked to compare elements of `array` to `values`. The order and\n * references of result values are determined by the first array. The comparator\n * is invoked with two arguments: (arrVal, othVal).\n *\n * **Note:** Unlike `_.pullAllWith`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n *\n * _.differenceWith(objects, [{ 'x': 1, 'y': 2 }], _.isEqual);\n * // => [{ 'x': 2, 'y': 1 }]\n */\n var differenceWith = baseRest(function(array, values) {\n var comparator = last(values);\n if (isArrayLikeObject(comparator)) {\n comparator = undefined;\n }\n return isArrayLikeObject(array)\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), undefined, comparator)\n : [];\n });\n\n /**\n * Creates a slice of `array` with `n` elements dropped from the beginning.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to drop.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.drop([1, 2, 3]);\n * // => [2, 3]\n *\n * _.drop([1, 2, 3], 2);\n * // => [3]\n *\n * _.drop([1, 2, 3], 5);\n * // => []\n *\n * _.drop([1, 2, 3], 0);\n * // => [1, 2, 3]\n */\n function drop(array, n, guard) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n return baseSlice(array, n < 0 ? 0 : n, length);\n }\n\n /**\n * Creates a slice of `array` with `n` elements dropped from the end.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to drop.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.dropRight([1, 2, 3]);\n * // => [1, 2]\n *\n * _.dropRight([1, 2, 3], 2);\n * // => [1]\n *\n * _.dropRight([1, 2, 3], 5);\n * // => []\n *\n * _.dropRight([1, 2, 3], 0);\n * // => [1, 2, 3]\n */\n function dropRight(array, n, guard) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n n = length - n;\n return baseSlice(array, 0, n < 0 ? 0 : n);\n }\n\n /**\n * Creates a slice of `array` excluding elements dropped from the end.\n * Elements are dropped until `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.dropRightWhile(users, function(o) { return !o.active; });\n * // => objects for ['barney']\n *\n * // The `_.matches` iteratee shorthand.\n * _.dropRightWhile(users, { 'user': 'pebbles', 'active': false });\n * // => objects for ['barney', 'fred']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.dropRightWhile(users, ['active', false]);\n * // => objects for ['barney']\n *\n * // The `_.property` iteratee shorthand.\n * _.dropRightWhile(users, 'active');\n * // => objects for ['barney', 'fred', 'pebbles']\n */\n function dropRightWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3), true, true)\n : [];\n }\n\n /**\n * Creates a slice of `array` excluding elements dropped from the beginning.\n * Elements are dropped until `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.dropWhile(users, function(o) { return !o.active; });\n * // => objects for ['pebbles']\n *\n * // The `_.matches` iteratee shorthand.\n * _.dropWhile(users, { 'user': 'barney', 'active': false });\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.dropWhile(users, ['active', false]);\n * // => objects for ['pebbles']\n *\n * // The `_.property` iteratee shorthand.\n * _.dropWhile(users, 'active');\n * // => objects for ['barney', 'fred', 'pebbles']\n */\n function dropWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3), true)\n : [];\n }\n\n /**\n * Fills elements of `array` with `value` from `start` up to, but not\n * including, `end`.\n *\n * **Note:** This method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Array\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _.fill(array, 'a');\n * console.log(array);\n * // => ['a', 'a', 'a']\n *\n * _.fill(Array(3), 2);\n * // => [2, 2, 2]\n *\n * _.fill([4, 6, 8, 10], '*', 1, 3);\n * // => [4, '*', '*', 10]\n */\n function fill(array, value, start, end) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n if (start && typeof start != 'number' && isIterateeCall(array, value, start)) {\n start = 0;\n end = length;\n }\n return baseFill(array, value, start, end);\n }\n\n /**\n * This method is like `_.find` except that it returns the index of the first\n * element `predicate` returns truthy for instead of the element itself.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.findIndex(users, function(o) { return o.user == 'barney'; });\n * // => 0\n *\n * // The `_.matches` iteratee shorthand.\n * _.findIndex(users, { 'user': 'fred', 'active': false });\n * // => 1\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findIndex(users, ['active', false]);\n * // => 0\n *\n * // The `_.property` iteratee shorthand.\n * _.findIndex(users, 'active');\n * // => 2\n */\n function findIndex(array, predicate, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\n if (index < 0) {\n index = nativeMax(length + index, 0);\n }\n return baseFindIndex(array, getIteratee(predicate, 3), index);\n }\n\n /**\n * This method is like `_.findIndex` except that it iterates over elements\n * of `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=array.length-1] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.findLastIndex(users, function(o) { return o.user == 'pebbles'; });\n * // => 2\n *\n * // The `_.matches` iteratee shorthand.\n * _.findLastIndex(users, { 'user': 'barney', 'active': true });\n * // => 0\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findLastIndex(users, ['active', false]);\n * // => 2\n *\n * // The `_.property` iteratee shorthand.\n * _.findLastIndex(users, 'active');\n * // => 0\n */\n function findLastIndex(array, predicate, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = length - 1;\n if (fromIndex !== undefined) {\n index = toInteger(fromIndex);\n index = fromIndex < 0\n ? nativeMax(length + index, 0)\n : nativeMin(index, length - 1);\n }\n return baseFindIndex(array, getIteratee(predicate, 3), index, true);\n }\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 */\n function flatten(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseFlatten(array, 1) : [];\n }\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 */\n function flattenDeep(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseFlatten(array, INFINITY) : [];\n }\n\n /**\n * Recursively flatten `array` up to `depth` times.\n *\n * @static\n * @memberOf _\n * @since 4.4.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @param {number} [depth=1] The maximum recursion depth.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * var array = [1, [2, [3, [4]], 5]];\n *\n * _.flattenDepth(array, 1);\n * // => [1, 2, [3, [4]], 5]\n *\n * _.flattenDepth(array, 2);\n * // => [1, 2, 3, [4], 5]\n */\n function flattenDepth(array, depth) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n depth = depth === undefined ? 1 : toInteger(depth);\n return baseFlatten(array, depth);\n }\n\n /**\n * The inverse of `_.toPairs`; this method returns an object composed\n * from key-value `pairs`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} pairs The key-value pairs.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.fromPairs([['a', 1], ['b', 2]]);\n * // => { 'a': 1, 'b': 2 }\n */\n function fromPairs(pairs) {\n var index = -1,\n length = pairs == null ? 0 : pairs.length,\n result = {};\n\n while (++index < length) {\n var pair = pairs[index];\n result[pair[0]] = pair[1];\n }\n return result;\n }\n\n /**\n * Gets the first element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @alias first\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the first element of `array`.\n * @example\n *\n * _.head([1, 2, 3]);\n * // => 1\n *\n * _.head([]);\n * // => undefined\n */\n function head(array) {\n return (array && array.length) ? array[0] : undefined;\n }\n\n /**\n * Gets the index at which the first occurrence of `value` is found in `array`\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. If `fromIndex` is negative, it's used as the\n * offset from the end of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.indexOf([1, 2, 1, 2], 2);\n * // => 1\n *\n * // Search from the `fromIndex`.\n * _.indexOf([1, 2, 1, 2], 2, 2);\n * // => 3\n */\n function indexOf(array, value, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\n if (index < 0) {\n index = nativeMax(length + index, 0);\n }\n return baseIndexOf(array, value, index);\n }\n\n /**\n * Gets all but the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.initial([1, 2, 3]);\n * // => [1, 2]\n */\n function initial(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseSlice(array, 0, -1) : [];\n }\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 */\n var intersection = baseRest(function(arrays) {\n var mapped = arrayMap(arrays, castArrayLikeObject);\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped)\n : [];\n });\n\n /**\n * This method is like `_.intersection` except that it accepts `iteratee`\n * which is invoked for each element of each `arrays` to generate the criterion\n * by which they're compared. The order and references of result values are\n * determined by the first array. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * _.intersectionBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [2.1]\n *\n * // The `_.property` iteratee shorthand.\n * _.intersectionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }]\n */\n var intersectionBy = baseRest(function(arrays) {\n var iteratee = last(arrays),\n mapped = arrayMap(arrays, castArrayLikeObject);\n\n if (iteratee === last(mapped)) {\n iteratee = undefined;\n } else {\n mapped.pop();\n }\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped, getIteratee(iteratee, 2))\n : [];\n });\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 */\n var 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\n /**\n * Converts all elements in `array` into a string separated by `separator`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to convert.\n * @param {string} [separator=','] The element separator.\n * @returns {string} Returns the joined string.\n * @example\n *\n * _.join(['a', 'b', 'c'], '~');\n * // => 'a~b~c'\n */\n function join(array, separator) {\n return array == null ? '' : nativeJoin.call(array, separator);\n }\n\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 */\n function last(array) {\n var length = array == null ? 0 : array.length;\n return length ? array[length - 1] : undefined;\n }\n\n /**\n * This method is like `_.indexOf` except that it iterates over elements of\n * `array` from right to left.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=array.length-1] The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.lastIndexOf([1, 2, 1, 2], 2);\n * // => 3\n *\n * // Search from the `fromIndex`.\n * _.lastIndexOf([1, 2, 1, 2], 2, 2);\n * // => 1\n */\n function lastIndexOf(array, value, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = length;\n if (fromIndex !== undefined) {\n index = toInteger(fromIndex);\n index = index < 0 ? nativeMax(length + index, 0) : nativeMin(index, length - 1);\n }\n return value === value\n ? strictLastIndexOf(array, value, index)\n : baseFindIndex(array, baseIsNaN, index, true);\n }\n\n /**\n * Gets the element at index `n` of `array`. If `n` is negative, the nth\n * element from the end is returned.\n *\n * @static\n * @memberOf _\n * @since 4.11.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=0] The index of the element to return.\n * @returns {*} Returns the nth element of `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'd'];\n *\n * _.nth(array, 1);\n * // => 'b'\n *\n * _.nth(array, -2);\n * // => 'c';\n */\n function nth(array, n) {\n return (array && array.length) ? baseNth(array, toInteger(n)) : undefined;\n }\n\n /**\n * Removes all given values from `array` using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * **Note:** Unlike `_.without`, this method mutates `array`. Use `_.remove`\n * to remove elements from an array by predicate.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {...*} [values] The values to remove.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'a', 'b', 'c'];\n *\n * _.pull(array, 'a', 'c');\n * console.log(array);\n * // => ['b', 'b']\n */\n var pull = baseRest(pullAll);\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 */\n function pullAll(array, values) {\n return (array && array.length && values && values.length)\n ? basePullAll(array, values)\n : array;\n }\n\n /**\n * This method is like `_.pullAll` except that it accepts `iteratee` which is\n * invoked for each element of `array` and `values` to generate the criterion\n * by which they're compared. The iteratee is invoked with one argument: (value).\n *\n * **Note:** Unlike `_.differenceBy`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [{ 'x': 1 }, { 'x': 2 }, { 'x': 3 }, { 'x': 1 }];\n *\n * _.pullAllBy(array, [{ 'x': 1 }, { 'x': 3 }], 'x');\n * console.log(array);\n * // => [{ 'x': 2 }]\n */\n function pullAllBy(array, values, iteratee) {\n return (array && array.length && values && values.length)\n ? basePullAll(array, values, getIteratee(iteratee, 2))\n : array;\n }\n\n /**\n * This method is like `_.pullAll` except that it accepts `comparator` which\n * is invoked to compare elements of `array` to `values`. The comparator is\n * invoked with two arguments: (arrVal, othVal).\n *\n * **Note:** Unlike `_.differenceWith`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [{ 'x': 1, 'y': 2 }, { 'x': 3, 'y': 4 }, { 'x': 5, 'y': 6 }];\n *\n * _.pullAllWith(array, [{ 'x': 3, 'y': 4 }], _.isEqual);\n * console.log(array);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 5, 'y': 6 }]\n */\n function pullAllWith(array, values, comparator) {\n return (array && array.length && values && values.length)\n ? basePullAll(array, values, undefined, comparator)\n : array;\n }\n\n /**\n * Removes elements from `array` corresponding to `indexes` and returns an\n * array of removed elements.\n *\n * **Note:** Unlike `_.at`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {...(number|number[])} [indexes] The indexes of elements to remove.\n * @returns {Array} Returns the new array of removed elements.\n * @example\n *\n * var array = ['a', 'b', 'c', 'd'];\n * var pulled = _.pullAt(array, [1, 3]);\n *\n * console.log(array);\n * // => ['a', 'c']\n *\n * console.log(pulled);\n * // => ['b', 'd']\n */\n var pullAt = flatRest(function(array, indexes) {\n var length = array == null ? 0 : array.length,\n result = baseAt(array, indexes);\n\n basePullAt(array, arrayMap(indexes, function(index) {\n return isIndex(index, length) ? +index : index;\n }).sort(compareAscending));\n\n return result;\n });\n\n /**\n * Removes all elements from `array` that `predicate` returns truthy for\n * and returns an array of the removed elements. The predicate is invoked\n * with three arguments: (value, index, array).\n *\n * **Note:** Unlike `_.filter`, this method mutates `array`. Use `_.pull`\n * to pull elements from an array by value.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new array of removed elements.\n * @example\n *\n * var array = [1, 2, 3, 4];\n * var evens = _.remove(array, function(n) {\n * return n % 2 == 0;\n * });\n *\n * console.log(array);\n * // => [1, 3]\n *\n * console.log(evens);\n * // => [2, 4]\n */\n function remove(array, predicate) {\n var result = [];\n if (!(array && array.length)) {\n return result;\n }\n var index = -1,\n indexes = [],\n length = array.length;\n\n predicate = getIteratee(predicate, 3);\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result.push(value);\n indexes.push(index);\n }\n }\n basePullAt(array, indexes);\n return result;\n }\n\n /**\n * Reverses `array` so that the first element becomes the last, the second\n * element becomes the second to last, and so on.\n *\n * **Note:** This method mutates `array` and is based on\n * [`Array#reverse`](https://mdn.io/Array/reverse).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _.reverse(array);\n * // => [3, 2, 1]\n *\n * console.log(array);\n * // => [3, 2, 1]\n */\n function reverse(array) {\n return array == null ? array : nativeReverse.call(array);\n }\n\n /**\n * Creates a slice of `array` from `start` up to, but not including, `end`.\n *\n * **Note:** This method is used instead of\n * [`Array#slice`](https://mdn.io/Array/slice) to ensure dense arrays are\n * returned.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\n function slice(array, start, end) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n if (end && typeof end != 'number' && isIterateeCall(array, start, end)) {\n start = 0;\n end = length;\n }\n else {\n start = start == null ? 0 : toInteger(start);\n end = end === undefined ? length : toInteger(end);\n }\n return baseSlice(array, start, end);\n }\n\n /**\n * Uses a binary search to determine the lowest index at which `value`\n * should be inserted into `array` in order to maintain its sort order.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * _.sortedIndex([30, 50], 40);\n * // => 1\n */\n function sortedIndex(array, value) {\n return baseSortedIndex(array, value);\n }\n\n /**\n * This method is like `_.sortedIndex` except that it accepts `iteratee`\n * which is invoked for `value` and each element of `array` to compute their\n * sort ranking. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * var objects = [{ 'x': 4 }, { 'x': 5 }];\n *\n * _.sortedIndexBy(objects, { 'x': 4 }, function(o) { return o.x; });\n * // => 0\n *\n * // The `_.property` iteratee shorthand.\n * _.sortedIndexBy(objects, { 'x': 4 }, 'x');\n * // => 0\n */\n function sortedIndexBy(array, value, iteratee) {\n return baseSortedIndexBy(array, value, getIteratee(iteratee, 2));\n }\n\n /**\n * This method is like `_.indexOf` except that it performs a binary\n * search on a sorted `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.sortedIndexOf([4, 5, 5, 5, 6], 5);\n * // => 1\n */\n function sortedIndexOf(array, value) {\n var length = array == null ? 0 : array.length;\n if (length) {\n var index = baseSortedIndex(array, value);\n if (index < length && eq(array[index], value)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * This method is like `_.sortedIndex` except that it returns the highest\n * index at which `value` should be inserted into `array` in order to\n * maintain its sort order.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * _.sortedLastIndex([4, 5, 5, 5, 6], 5);\n * // => 4\n */\n function sortedLastIndex(array, value) {\n return baseSortedIndex(array, value, true);\n }\n\n /**\n * This method is like `_.sortedLastIndex` except that it accepts `iteratee`\n * which is invoked for `value` and each element of `array` to compute their\n * sort ranking. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * var objects = [{ 'x': 4 }, { 'x': 5 }];\n *\n * _.sortedLastIndexBy(objects, { 'x': 4 }, function(o) { return o.x; });\n * // => 1\n *\n * // The `_.property` iteratee shorthand.\n * _.sortedLastIndexBy(objects, { 'x': 4 }, 'x');\n * // => 1\n */\n function sortedLastIndexBy(array, value, iteratee) {\n return baseSortedIndexBy(array, value, getIteratee(iteratee, 2), true);\n }\n\n /**\n * This method is like `_.lastIndexOf` except that it performs a binary\n * search on a sorted `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.sortedLastIndexOf([4, 5, 5, 5, 6], 5);\n * // => 3\n */\n function sortedLastIndexOf(array, value) {\n var length = array == null ? 0 : array.length;\n if (length) {\n var index = baseSortedIndex(array, value, true) - 1;\n if (eq(array[index], value)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * This method is like `_.uniq` except that it's designed and optimized\n * for sorted arrays.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.sortedUniq([1, 1, 2]);\n * // => [1, 2]\n */\n function sortedUniq(array) {\n return (array && array.length)\n ? baseSortedUniq(array)\n : [];\n }\n\n /**\n * This method is like `_.uniqBy` except that it's designed and optimized\n * for sorted arrays.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.sortedUniqBy([1.1, 1.2, 2.3, 2.4], Math.floor);\n * // => [1.1, 2.3]\n */\n function sortedUniqBy(array, iteratee) {\n return (array && array.length)\n ? baseSortedUniq(array, getIteratee(iteratee, 2))\n : [];\n }\n\n /**\n * Gets all but the first element of `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.tail([1, 2, 3]);\n * // => [2, 3]\n */\n function tail(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseSlice(array, 1, length) : [];\n }\n\n /**\n * Creates a slice of `array` with `n` elements taken from the beginning.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to take.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.take([1, 2, 3]);\n * // => [1]\n *\n * _.take([1, 2, 3], 2);\n * // => [1, 2]\n *\n * _.take([1, 2, 3], 5);\n * // => [1, 2, 3]\n *\n * _.take([1, 2, 3], 0);\n * // => []\n */\n function take(array, n, guard) {\n if (!(array && array.length)) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n return baseSlice(array, 0, n < 0 ? 0 : n);\n }\n\n /**\n * Creates a slice of `array` with `n` elements taken from the end.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to take.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.takeRight([1, 2, 3]);\n * // => [3]\n *\n * _.takeRight([1, 2, 3], 2);\n * // => [2, 3]\n *\n * _.takeRight([1, 2, 3], 5);\n * // => [1, 2, 3]\n *\n * _.takeRight([1, 2, 3], 0);\n * // => []\n */\n function takeRight(array, n, guard) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n n = length - n;\n return baseSlice(array, n < 0 ? 0 : n, length);\n }\n\n /**\n * Creates a slice of `array` with elements taken from the end. Elements are\n * taken until `predicate` returns falsey. The predicate is invoked with\n * three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.takeRightWhile(users, function(o) { return !o.active; });\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.matches` iteratee shorthand.\n * _.takeRightWhile(users, { 'user': 'pebbles', 'active': false });\n * // => objects for ['pebbles']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.takeRightWhile(users, ['active', false]);\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.property` iteratee shorthand.\n * _.takeRightWhile(users, 'active');\n * // => []\n */\n function takeRightWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3), false, true)\n : [];\n }\n\n /**\n * Creates a slice of `array` with elements taken from the beginning. Elements\n * are taken until `predicate` returns falsey. The predicate is invoked with\n * three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.takeWhile(users, function(o) { return !o.active; });\n * // => objects for ['barney', 'fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.takeWhile(users, { 'user': 'barney', 'active': false });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.takeWhile(users, ['active', false]);\n * // => objects for ['barney', 'fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.takeWhile(users, 'active');\n * // => []\n */\n function takeWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3))\n : [];\n }\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 */\n var union = baseRest(function(arrays) {\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true));\n });\n\n /**\n * This method is like `_.union` except that it accepts `iteratee` which is\n * invoked for each element of each `arrays` to generate the criterion by\n * which uniqueness is computed. Result values are chosen from the first\n * array in which the value occurs. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * _.unionBy([2.1], [1.2, 2.3], Math.floor);\n * // => [2.1, 1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.unionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }, { 'x': 2 }]\n */\n var unionBy = baseRest(function(arrays) {\n var iteratee = last(arrays);\n if (isArrayLikeObject(iteratee)) {\n iteratee = undefined;\n }\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), getIteratee(iteratee, 2));\n });\n\n /**\n * This method is like `_.union` except that it accepts `comparator` which\n * is invoked to compare elements of `arrays`. Result values are chosen from\n * the first array in which the value occurs. The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.unionWith(objects, others, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]\n */\n var unionWith = baseRest(function(arrays) {\n var comparator = last(arrays);\n comparator = typeof comparator == 'function' ? comparator : undefined;\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), undefined, comparator);\n });\n\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 */\n function uniq(array) {\n return (array && array.length) ? baseUniq(array) : [];\n }\n\n /**\n * This method is like `_.uniq` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the criterion by which\n * uniqueness is computed. The order of result values is determined by the\n * order they occur in the array. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.uniqBy([2.1, 1.2, 2.3], Math.floor);\n * // => [2.1, 1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.uniqBy([{ 'x': 1 }, { 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }, { 'x': 2 }]\n */\n function uniqBy(array, iteratee) {\n return (array && array.length) ? baseUniq(array, getIteratee(iteratee, 2)) : [];\n }\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 */\n function uniqWith(array, comparator) {\n comparator = typeof comparator == 'function' ? comparator : undefined;\n return (array && array.length) ? baseUniq(array, undefined, comparator) : [];\n }\n\n /**\n * This method is like `_.zip` except that it accepts an array of grouped\n * elements and creates an array regrouping the elements to their pre-zip\n * configuration.\n *\n * @static\n * @memberOf _\n * @since 1.2.0\n * @category Array\n * @param {Array} array The array of grouped elements to process.\n * @returns {Array} Returns the new array of regrouped elements.\n * @example\n *\n * var zipped = _.zip(['a', 'b'], [1, 2], [true, false]);\n * // => [['a', 1, true], ['b', 2, false]]\n *\n * _.unzip(zipped);\n * // => [['a', 'b'], [1, 2], [true, false]]\n */\n function unzip(array) {\n if (!(array && array.length)) {\n return [];\n }\n var length = 0;\n array = arrayFilter(array, function(group) {\n if (isArrayLikeObject(group)) {\n length = nativeMax(group.length, length);\n return true;\n }\n });\n return baseTimes(length, function(index) {\n return arrayMap(array, baseProperty(index));\n });\n }\n\n /**\n * This method is like `_.unzip` except that it accepts `iteratee` to specify\n * how regrouped values should be combined. The iteratee is invoked with the\n * elements of each group: (...group).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Array\n * @param {Array} array The array of grouped elements to process.\n * @param {Function} [iteratee=_.identity] The function to combine\n * regrouped values.\n * @returns {Array} Returns the new array of regrouped elements.\n * @example\n *\n * var zipped = _.zip([1, 2], [10, 20], [100, 200]);\n * // => [[1, 10, 100], [2, 20, 200]]\n *\n * _.unzipWith(zipped, _.add);\n * // => [3, 30, 300]\n */\n function unzipWith(array, iteratee) {\n if (!(array && array.length)) {\n return [];\n }\n var result = unzip(array);\n if (iteratee == null) {\n return result;\n }\n return arrayMap(result, function(group) {\n return apply(iteratee, undefined, group);\n });\n }\n\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 */\n var without = baseRest(function(array, values) {\n return isArrayLikeObject(array)\n ? baseDifference(array, values)\n : [];\n });\n\n /**\n * Creates an array of unique values that is the\n * [symmetric difference](https://en.wikipedia.org/wiki/Symmetric_difference)\n * of the given arrays. The order of result values is determined by the order\n * they occur in the arrays.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.difference, _.without\n * @example\n *\n * _.xor([2, 1], [2, 3]);\n * // => [1, 3]\n */\n var xor = baseRest(function(arrays) {\n return baseXor(arrayFilter(arrays, isArrayLikeObject));\n });\n\n /**\n * This method is like `_.xor` except that it accepts `iteratee` which is\n * invoked for each element of each `arrays` to generate the criterion by\n * which by which they're compared. The order of result values is determined\n * by the order they occur in the arrays. The iteratee is invoked with one\n * argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.xorBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [1.2, 3.4]\n *\n * // The `_.property` iteratee shorthand.\n * _.xorBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 2 }]\n */\n var xorBy = baseRest(function(arrays) {\n var iteratee = last(arrays);\n if (isArrayLikeObject(iteratee)) {\n iteratee = undefined;\n }\n return baseXor(arrayFilter(arrays, isArrayLikeObject), getIteratee(iteratee, 2));\n });\n\n /**\n * This method is like `_.xor` except that it accepts `comparator` which is\n * invoked to compare elements of `arrays`. The order of result values is\n * determined by the order they occur in the arrays. The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.xorWith(objects, others, _.isEqual);\n * // => [{ 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]\n */\n var xorWith = baseRest(function(arrays) {\n var comparator = last(arrays);\n comparator = typeof comparator == 'function' ? comparator : undefined;\n return baseXor(arrayFilter(arrays, isArrayLikeObject), undefined, comparator);\n });\n\n /**\n * Creates an array of grouped elements, the first of which contains the\n * first elements of the given arrays, the second of which contains the\n * second elements of the given arrays, and so on.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to process.\n * @returns {Array} Returns the new array of grouped elements.\n * @example\n *\n * _.zip(['a', 'b'], [1, 2], [true, false]);\n * // => [['a', 1, true], ['b', 2, false]]\n */\n var zip = baseRest(unzip);\n\n /**\n * This method is like `_.fromPairs` except that it accepts two arrays,\n * one of property identifiers and one of corresponding values.\n *\n * @static\n * @memberOf _\n * @since 0.4.0\n * @category Array\n * @param {Array} [props=[]] The property identifiers.\n * @param {Array} [values=[]] The property values.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.zipObject(['a', 'b'], [1, 2]);\n * // => { 'a': 1, 'b': 2 }\n */\n function zipObject(props, values) {\n return baseZipObject(props || [], values || [], assignValue);\n }\n\n /**\n * This method is like `_.zipObject` except that it supports property paths.\n *\n * @static\n * @memberOf _\n * @since 4.1.0\n * @category Array\n * @param {Array} [props=[]] The property identifiers.\n * @param {Array} [values=[]] The property values.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.zipObjectDeep(['a.b[0].c', 'a.b[1].d'], [1, 2]);\n * // => { 'a': { 'b': [{ 'c': 1 }, { 'd': 2 }] } }\n */\n function zipObjectDeep(props, values) {\n return baseZipObject(props || [], values || [], baseSet);\n }\n\n /**\n * This method is like `_.zip` except that it accepts `iteratee` to specify\n * how grouped values should be combined. The iteratee is invoked with the\n * elements of each group: (...group).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Array\n * @param {...Array} [arrays] The arrays to process.\n * @param {Function} [iteratee=_.identity] The function to combine\n * grouped values.\n * @returns {Array} Returns the new array of grouped elements.\n * @example\n *\n * _.zipWith([1, 2], [10, 20], [100, 200], function(a, b, c) {\n * return a + b + c;\n * });\n * // => [111, 222]\n */\n var zipWith = baseRest(function(arrays) {\n var length = arrays.length,\n iteratee = length > 1 ? arrays[length - 1] : undefined;\n\n iteratee = typeof iteratee == 'function' ? (arrays.pop(), iteratee) : undefined;\n return unzipWith(arrays, iteratee);\n });\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a `lodash` wrapper instance that wraps `value` with explicit method\n * chain sequences enabled. The result of such sequences must be unwrapped\n * with `_#value`.\n *\n * @static\n * @memberOf _\n * @since 1.3.0\n * @category Seq\n * @param {*} value The value to wrap.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 40 },\n * { 'user': 'pebbles', 'age': 1 }\n * ];\n *\n * var youngest = _\n * .chain(users)\n * .sortBy('age')\n * .map(function(o) {\n * return o.user + ' is ' + o.age;\n * })\n * .head()\n * .value();\n * // => 'pebbles is 1'\n */\n function chain(value) {\n var result = lodash(value);\n result.__chain__ = true;\n return result;\n }\n\n /**\n * This method invokes `interceptor` and returns `value`. The interceptor\n * is invoked with one argument; (value). The purpose of this method is to\n * \"tap into\" a method chain sequence in order to modify intermediate results.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @param {*} value The value to provide to `interceptor`.\n * @param {Function} interceptor The function to invoke.\n * @returns {*} Returns `value`.\n * @example\n *\n * _([1, 2, 3])\n * .tap(function(array) {\n * // Mutate input array.\n * array.pop();\n * })\n * .reverse()\n * .value();\n * // => [2, 1]\n */\n function tap(value, interceptor) {\n interceptor(value);\n return value;\n }\n\n /**\n * This method is like `_.tap` except that it returns the result of `interceptor`.\n * The purpose of this method is to \"pass thru\" values replacing intermediate\n * results in a method chain sequence.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Seq\n * @param {*} value The value to provide to `interceptor`.\n * @param {Function} interceptor The function to invoke.\n * @returns {*} Returns the result of `interceptor`.\n * @example\n *\n * _(' abc ')\n * .chain()\n * .trim()\n * .thru(function(value) {\n * return [value];\n * })\n * .value();\n * // => ['abc']\n */\n function thru(value, interceptor) {\n return interceptor(value);\n }\n\n /**\n * This method is the wrapper version of `_.at`.\n *\n * @name at\n * @memberOf _\n * @since 1.0.0\n * @category Seq\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };\n *\n * _(object).at(['a[0].b.c', 'a[1]']).value();\n * // => [3, 4]\n */\n var wrapperAt = flatRest(function(paths) {\n var length = paths.length,\n start = length ? paths[0] : 0,\n value = this.__wrapped__,\n interceptor = function(object) { return baseAt(object, paths); };\n\n if (length > 1 || this.__actions__.length ||\n !(value instanceof LazyWrapper) || !isIndex(start)) {\n return this.thru(interceptor);\n }\n value = value.slice(start, +start + (length ? 1 : 0));\n value.__actions__.push({\n 'func': thru,\n 'args': [interceptor],\n 'thisArg': undefined\n });\n return new LodashWrapper(value, this.__chain__).thru(function(array) {\n if (length && !array.length) {\n array.push(undefined);\n }\n return array;\n });\n });\n\n /**\n * Creates a `lodash` wrapper instance with explicit method chain sequences enabled.\n *\n * @name chain\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 40 }\n * ];\n *\n * // A sequence without explicit chaining.\n * _(users).head();\n * // => { 'user': 'barney', 'age': 36 }\n *\n * // A sequence with explicit chaining.\n * _(users)\n * .chain()\n * .head()\n * .pick('user')\n * .value();\n * // => { 'user': 'barney' }\n */\n function wrapperChain() {\n return chain(this);\n }\n\n /**\n * Executes the chain sequence and returns the wrapped result.\n *\n * @name commit\n * @memberOf _\n * @since 3.2.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var array = [1, 2];\n * var wrapped = _(array).push(3);\n *\n * console.log(array);\n * // => [1, 2]\n *\n * wrapped = wrapped.commit();\n * console.log(array);\n * // => [1, 2, 3]\n *\n * wrapped.last();\n * // => 3\n *\n * console.log(array);\n * // => [1, 2, 3]\n */\n function wrapperCommit() {\n return new LodashWrapper(this.value(), this.__chain__);\n }\n\n /**\n * Gets the next value on a wrapped object following the\n * [iterator protocol](https://mdn.io/iteration_protocols#iterator).\n *\n * @name next\n * @memberOf _\n * @since 4.0.0\n * @category Seq\n * @returns {Object} Returns the next iterator value.\n * @example\n *\n * var wrapped = _([1, 2]);\n *\n * wrapped.next();\n * // => { 'done': false, 'value': 1 }\n *\n * wrapped.next();\n * // => { 'done': false, 'value': 2 }\n *\n * wrapped.next();\n * // => { 'done': true, 'value': undefined }\n */\n function wrapperNext() {\n if (this.__values__ === undefined) {\n this.__values__ = toArray(this.value());\n }\n var done = this.__index__ >= this.__values__.length,\n value = done ? undefined : this.__values__[this.__index__++];\n\n return { 'done': done, 'value': value };\n }\n\n /**\n * Enables the wrapper to be iterable.\n *\n * @name Symbol.iterator\n * @memberOf _\n * @since 4.0.0\n * @category Seq\n * @returns {Object} Returns the wrapper object.\n * @example\n *\n * var wrapped = _([1, 2]);\n *\n * wrapped[Symbol.iterator]() === wrapped;\n * // => true\n *\n * Array.from(wrapped);\n * // => [1, 2]\n */\n function wrapperToIterator() {\n return this;\n }\n\n /**\n * Creates a clone of the chain sequence planting `value` as the wrapped value.\n *\n * @name plant\n * @memberOf _\n * @since 3.2.0\n * @category Seq\n * @param {*} value The value to plant.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var wrapped = _([1, 2]).map(square);\n * var other = wrapped.plant([3, 4]);\n *\n * other.value();\n * // => [9, 16]\n *\n * wrapped.value();\n * // => [1, 4]\n */\n function wrapperPlant(value) {\n var result,\n parent = this;\n\n while (parent instanceof baseLodash) {\n var clone = wrapperClone(parent);\n clone.__index__ = 0;\n clone.__values__ = undefined;\n if (result) {\n previous.__wrapped__ = clone;\n } else {\n result = clone;\n }\n var previous = clone;\n parent = parent.__wrapped__;\n }\n previous.__wrapped__ = value;\n return result;\n }\n\n /**\n * This method is the wrapper version of `_.reverse`.\n *\n * **Note:** This method mutates the wrapped array.\n *\n * @name reverse\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _(array).reverse().value()\n * // => [3, 2, 1]\n *\n * console.log(array);\n * // => [3, 2, 1]\n */\n function wrapperReverse() {\n var value = this.__wrapped__;\n if (value instanceof LazyWrapper) {\n var wrapped = value;\n if (this.__actions__.length) {\n wrapped = new LazyWrapper(this);\n }\n wrapped = wrapped.reverse();\n wrapped.__actions__.push({\n 'func': thru,\n 'args': [reverse],\n 'thisArg': undefined\n });\n return new LodashWrapper(wrapped, this.__chain__);\n }\n return this.thru(reverse);\n }\n\n /**\n * Executes the chain sequence to resolve the unwrapped value.\n *\n * @name value\n * @memberOf _\n * @since 0.1.0\n * @alias toJSON, valueOf\n * @category Seq\n * @returns {*} Returns the resolved unwrapped value.\n * @example\n *\n * _([1, 2, 3]).value();\n * // => [1, 2, 3]\n */\n function wrapperValue() {\n return baseWrapperValue(this.__wrapped__, this.__actions__);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The corresponding value of\n * each key is the number of times the key was returned by `iteratee`. The\n * iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * _.countBy([6.1, 4.2, 6.3], Math.floor);\n * // => { '4': 1, '6': 2 }\n *\n * // The `_.property` iteratee shorthand.\n * _.countBy(['one', 'two', 'three'], 'length');\n * // => { '3': 2, '5': 1 }\n */\n var countBy = createAggregator(function(result, value, key) {\n if (hasOwnProperty.call(result, key)) {\n ++result[key];\n } else {\n baseAssignValue(result, key, 1);\n }\n });\n\n /**\n * Checks if `predicate` returns truthy for **all** elements of `collection`.\n * Iteration is stopped once `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index|key, collection).\n *\n * **Note:** This method returns `true` for\n * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because\n * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of\n * elements of empty collections.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n * else `false`.\n * @example\n *\n * _.every([true, 1, null, 'yes'], Boolean);\n * // => false\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.every(users, { 'user': 'barney', 'active': false });\n * // => false\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.every(users, ['active', false]);\n * // => true\n *\n * // The `_.property` iteratee shorthand.\n * _.every(users, 'active');\n * // => false\n */\n function every(collection, predicate, guard) {\n var func = isArray(collection) ? arrayEvery : baseEvery;\n if (guard && isIterateeCall(collection, predicate, guard)) {\n predicate = undefined;\n }\n return func(collection, getIteratee(predicate, 3));\n }\n\n /**\n * Iterates over elements of `collection`, returning an array of all elements\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * **Note:** Unlike `_.remove`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.reject\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false }\n * ];\n *\n * _.filter(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.filter(users, { 'age': 36, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.filter(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.filter(users, 'active');\n * // => objects for ['barney']\n *\n * // Combining several predicates using `_.overEvery` or `_.overSome`.\n * _.filter(users, _.overSome([{ 'age': 36 }, ['age', 40]]));\n * // => objects for ['fred', 'barney']\n */\n function filter(collection, predicate) {\n var func = isArray(collection) ? arrayFilter : baseFilter;\n return func(collection, getIteratee(predicate, 3));\n }\n\n /**\n * Iterates over elements of `collection`, returning the first element\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false },\n * { 'user': 'pebbles', 'age': 1, 'active': true }\n * ];\n *\n * _.find(users, function(o) { return o.age < 40; });\n * // => object for 'barney'\n *\n * // The `_.matches` iteratee shorthand.\n * _.find(users, { 'age': 1, 'active': true });\n * // => object for 'pebbles'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.find(users, ['active', false]);\n * // => object for 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.find(users, 'active');\n * // => object for 'barney'\n */\n var find = createFind(findIndex);\n\n /**\n * This method is like `_.find` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=collection.length-1] The index to search from.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * _.findLast([1, 2, 3, 4], function(n) {\n * return n % 2 == 1;\n * });\n * // => 3\n */\n var findLast = createFind(findLastIndex);\n\n /**\n * Creates a flattened array of values by running each element in `collection`\n * thru `iteratee` and flattening the mapped results. The iteratee is invoked\n * with three arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n * return [n, n];\n * }\n *\n * _.flatMap([1, 2], duplicate);\n * // => [1, 1, 2, 2]\n */\n function flatMap(collection, iteratee) {\n return baseFlatten(map(collection, iteratee), 1);\n }\n\n /**\n * This method is like `_.flatMap` except that it recursively flattens the\n * mapped results.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n * return [[[n, n]]];\n * }\n *\n * _.flatMapDeep([1, 2], duplicate);\n * // => [1, 1, 2, 2]\n */\n function flatMapDeep(collection, iteratee) {\n return baseFlatten(map(collection, iteratee), INFINITY);\n }\n\n /**\n * This method is like `_.flatMap` except that it recursively flattens the\n * mapped results up to `depth` times.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {number} [depth=1] The maximum recursion depth.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n * return [[[n, n]]];\n * }\n *\n * _.flatMapDepth([1, 2], duplicate, 2);\n * // => [[1, 1], [2, 2]]\n */\n function flatMapDepth(collection, iteratee, depth) {\n depth = depth === undefined ? 1 : toInteger(depth);\n return baseFlatten(map(collection, iteratee), depth);\n }\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 */\n function forEach(collection, iteratee) {\n var func = isArray(collection) ? arrayEach : baseEach;\n return func(collection, getIteratee(iteratee, 3));\n }\n\n /**\n * This method is like `_.forEach` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @alias eachRight\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n * @see _.forEach\n * @example\n *\n * _.forEachRight([1, 2], function(value) {\n * console.log(value);\n * });\n * // => Logs `2` then `1`.\n */\n function forEachRight(collection, iteratee) {\n var func = isArray(collection) ? arrayEachRight : baseEachRight;\n return func(collection, getIteratee(iteratee, 3));\n }\n\n /**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The order of grouped values\n * is determined by the order they occur in `collection`. The corresponding\n * value of each key is an array of elements responsible for generating the\n * key. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * _.groupBy([6.1, 4.2, 6.3], Math.floor);\n * // => { '4': [4.2], '6': [6.1, 6.3] }\n *\n * // The `_.property` iteratee shorthand.\n * _.groupBy(['one', 'two', 'three'], 'length');\n * // => { '3': ['one', 'two'], '5': ['three'] }\n */\n var groupBy = createAggregator(function(result, value, key) {\n if (hasOwnProperty.call(result, key)) {\n result[key].push(value);\n } else {\n baseAssignValue(result, key, [value]);\n }\n });\n\n /**\n * Checks if `value` is in `collection`. If `collection` is a string, it's\n * checked for a substring of `value`, otherwise\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * is used for equality comparisons. If `fromIndex` is negative, it's used as\n * the offset from the end of `collection`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=0] The index to search from.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.\n * @returns {boolean} Returns `true` if `value` is found, else `false`.\n * @example\n *\n * _.includes([1, 2, 3], 1);\n * // => true\n *\n * _.includes([1, 2, 3], 1, 2);\n * // => false\n *\n * _.includes({ 'a': 1, 'b': 2 }, 1);\n * // => true\n *\n * _.includes('abcd', 'bc');\n * // => true\n */\n function includes(collection, value, fromIndex, guard) {\n collection = isArrayLike(collection) ? collection : values(collection);\n fromIndex = (fromIndex && !guard) ? toInteger(fromIndex) : 0;\n\n var length = collection.length;\n if (fromIndex < 0) {\n fromIndex = nativeMax(length + fromIndex, 0);\n }\n return isString(collection)\n ? (fromIndex <= length && collection.indexOf(value, fromIndex) > -1)\n : (!!length && baseIndexOf(collection, value, fromIndex) > -1);\n }\n\n /**\n * Invokes the method at `path` of each element in `collection`, returning\n * an array of the results of each invoked method. Any additional arguments\n * are provided to each invoked method. If `path` is a function, it's invoked\n * for, and `this` bound to, each element in `collection`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Array|Function|string} path The path of the method to invoke or\n * the function invoked per iteration.\n * @param {...*} [args] The arguments to invoke each method with.\n * @returns {Array} Returns the array of results.\n * @example\n *\n * _.invokeMap([[5, 1, 7], [3, 2, 1]], 'sort');\n * // => [[1, 5, 7], [1, 2, 3]]\n *\n * _.invokeMap([123, 456], String.prototype.split, '');\n * // => [['1', '2', '3'], ['4', '5', '6']]\n */\n var invokeMap = baseRest(function(collection, path, args) {\n var index = -1,\n isFunc = typeof path == 'function',\n result = isArrayLike(collection) ? Array(collection.length) : [];\n\n baseEach(collection, function(value) {\n result[++index] = isFunc ? apply(path, value, args) : baseInvoke(value, path, args);\n });\n return result;\n });\n\n /**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The corresponding value of\n * each key is the last element responsible for generating the key. The\n * iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * var array = [\n * { 'dir': 'left', 'code': 97 },\n * { 'dir': 'right', 'code': 100 }\n * ];\n *\n * _.keyBy(array, function(o) {\n * return String.fromCharCode(o.code);\n * });\n * // => { 'a': { 'dir': 'left', 'code': 97 }, 'd': { 'dir': 'right', 'code': 100 } }\n *\n * _.keyBy(array, 'dir');\n * // => { 'left': { 'dir': 'left', 'code': 97 }, 'right': { 'dir': 'right', 'code': 100 } }\n */\n var keyBy = createAggregator(function(result, value, key) {\n baseAssignValue(result, key, value);\n });\n\n /**\n * Creates an array of values by running each element in `collection` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.\n *\n * The guarded methods are:\n * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`,\n * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`,\n * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`,\n * `template`, `trim`, `trimEnd`, `trimStart`, and `words`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * _.map([4, 8], square);\n * // => [16, 64]\n *\n * _.map({ 'a': 4, 'b': 8 }, square);\n * // => [16, 64] (iteration order is not guaranteed)\n *\n * var users = [\n * { 'user': 'barney' },\n * { 'user': 'fred' }\n * ];\n *\n * // The `_.property` iteratee shorthand.\n * _.map(users, 'user');\n * // => ['barney', 'fred']\n */\n function map(collection, iteratee) {\n var func = isArray(collection) ? arrayMap : baseMap;\n return func(collection, getIteratee(iteratee, 3));\n }\n\n /**\n * This method is like `_.sortBy` except that it allows specifying the sort\n * orders of the iteratees to sort by. If `orders` is unspecified, all values\n * are sorted in ascending order. Otherwise, specify an order of \"desc\" for\n * descending or \"asc\" for ascending sort order of corresponding values.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Array[]|Function[]|Object[]|string[]} [iteratees=[_.identity]]\n * The iteratees to sort by.\n * @param {string[]} [orders] The sort orders of `iteratees`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.\n * @returns {Array} Returns the new sorted array.\n * @example\n *\n * var users = [\n * { 'user': 'fred', 'age': 48 },\n * { 'user': 'barney', 'age': 34 },\n * { 'user': 'fred', 'age': 40 },\n * { 'user': 'barney', 'age': 36 }\n * ];\n *\n * // Sort by `user` in ascending order and by `age` in descending order.\n * _.orderBy(users, ['user', 'age'], ['asc', 'desc']);\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]]\n */\n function orderBy(collection, iteratees, orders, guard) {\n if (collection == null) {\n return [];\n }\n if (!isArray(iteratees)) {\n iteratees = iteratees == null ? [] : [iteratees];\n }\n orders = guard ? undefined : orders;\n if (!isArray(orders)) {\n orders = orders == null ? [] : [orders];\n }\n return baseOrderBy(collection, iteratees, orders);\n }\n\n /**\n * Creates an array of elements split into two groups, the first of which\n * contains elements `predicate` returns truthy for, the second of which\n * contains elements `predicate` returns falsey for. The predicate is\n * invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the array of grouped elements.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': true },\n * { 'user': 'pebbles', 'age': 1, 'active': false }\n * ];\n *\n * _.partition(users, function(o) { return o.active; });\n * // => objects for [['fred'], ['barney', 'pebbles']]\n *\n * // The `_.matches` iteratee shorthand.\n * _.partition(users, { 'age': 1, 'active': false });\n * // => objects for [['pebbles'], ['barney', 'fred']]\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.partition(users, ['active', false]);\n * // => objects for [['barney', 'pebbles'], ['fred']]\n *\n * // The `_.property` iteratee shorthand.\n * _.partition(users, 'active');\n * // => objects for [['fred'], ['barney', 'pebbles']]\n */\n var partition = createAggregator(function(result, value, key) {\n result[key ? 0 : 1].push(value);\n }, function() { return [[], []]; });\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 */\n function reduce(collection, iteratee, accumulator) {\n var func = isArray(collection) ? arrayReduce : baseReduce,\n initAccum = arguments.length < 3;\n\n return func(collection, getIteratee(iteratee, 4), accumulator, initAccum, baseEach);\n }\n\n /**\n * This method is like `_.reduce` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @returns {*} Returns the accumulated value.\n * @see _.reduce\n * @example\n *\n * var array = [[0, 1], [2, 3], [4, 5]];\n *\n * _.reduceRight(array, function(flattened, other) {\n * return flattened.concat(other);\n * }, []);\n * // => [4, 5, 2, 3, 0, 1]\n */\n function reduceRight(collection, iteratee, accumulator) {\n var func = isArray(collection) ? arrayReduceRight : baseReduce,\n initAccum = arguments.length < 3;\n\n return func(collection, getIteratee(iteratee, 4), accumulator, initAccum, baseEachRight);\n }\n\n /**\n * The opposite of `_.filter`; this method returns the elements of `collection`\n * that `predicate` does **not** return truthy for.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.filter\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': true }\n * ];\n *\n * _.reject(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.reject(users, { 'age': 40, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.reject(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.reject(users, 'active');\n * // => objects for ['barney']\n */\n function reject(collection, predicate) {\n var func = isArray(collection) ? arrayFilter : baseFilter;\n return func(collection, negate(getIteratee(predicate, 3)));\n }\n\n /**\n * Gets a random element from `collection`.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to sample.\n * @returns {*} Returns the random element.\n * @example\n *\n * _.sample([1, 2, 3, 4]);\n * // => 2\n */\n function sample(collection) {\n var func = isArray(collection) ? arraySample : baseSample;\n return func(collection);\n }\n\n /**\n * Gets `n` random elements at unique keys from `collection` up to the\n * size of `collection`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to sample.\n * @param {number} [n=1] The number of elements to sample.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the random elements.\n * @example\n *\n * _.sampleSize([1, 2, 3], 2);\n * // => [3, 1]\n *\n * _.sampleSize([1, 2, 3], 4);\n * // => [2, 3, 1]\n */\n function sampleSize(collection, n, guard) {\n if ((guard ? isIterateeCall(collection, n, guard) : n === undefined)) {\n n = 1;\n } else {\n n = toInteger(n);\n }\n var func = isArray(collection) ? arraySampleSize : baseSampleSize;\n return func(collection, n);\n }\n\n /**\n * Creates an array of shuffled values, using a version of the\n * [Fisher-Yates shuffle](https://en.wikipedia.org/wiki/Fisher-Yates_shuffle).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to shuffle.\n * @returns {Array} Returns the new shuffled array.\n * @example\n *\n * _.shuffle([1, 2, 3, 4]);\n * // => [4, 1, 3, 2]\n */\n function shuffle(collection) {\n var func = isArray(collection) ? arrayShuffle : baseShuffle;\n return func(collection);\n }\n\n /**\n * Gets the size of `collection` by returning its length for array-like\n * values or the number of own enumerable string keyed properties for objects.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @returns {number} Returns the collection size.\n * @example\n *\n * _.size([1, 2, 3]);\n * // => 3\n *\n * _.size({ 'a': 1, 'b': 2 });\n * // => 2\n *\n * _.size('pebbles');\n * // => 7\n */\n function size(collection) {\n if (collection == null) {\n return 0;\n }\n if (isArrayLike(collection)) {\n return isString(collection) ? stringSize(collection) : collection.length;\n }\n var tag = getTag(collection);\n if (tag == mapTag || tag == setTag) {\n return collection.size;\n }\n return baseKeys(collection).length;\n }\n\n /**\n * Checks if `predicate` returns truthy for **any** element of `collection`.\n * Iteration is stopped once `predicate` returns truthy. The predicate is\n * invoked with three arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n * @example\n *\n * _.some([null, 0, 'yes', false], Boolean);\n * // => true\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.some(users, { 'user': 'barney', 'active': false });\n * // => false\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.some(users, ['active', false]);\n * // => true\n *\n * // The `_.property` iteratee shorthand.\n * _.some(users, 'active');\n * // => true\n */\n function some(collection, predicate, guard) {\n var func = isArray(collection) ? arraySome : baseSome;\n if (guard && isIterateeCall(collection, predicate, guard)) {\n predicate = undefined;\n }\n return func(collection, getIteratee(predicate, 3));\n }\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 */\n var 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\n /*------------------------------------------------------------------------*/\n\n /**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\n var now = ctxNow || function() {\n return root.Date.now();\n };\n\n /*------------------------------------------------------------------------*/\n\n /**\n * The opposite of `_.before`; this method creates a function that invokes\n * `func` once it's called `n` or more times.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {number} n The number of calls before `func` is invoked.\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * var saves = ['profile', 'settings'];\n *\n * var done = _.after(saves.length, function() {\n * console.log('done saving!');\n * });\n *\n * _.forEach(saves, function(type) {\n * asyncSave({ 'type': type, 'complete': done });\n * });\n * // => Logs 'done saving!' after the two async saves have completed.\n */\n function after(n, func) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n n = toInteger(n);\n return function() {\n if (--n < 1) {\n return func.apply(this, arguments);\n }\n };\n }\n\n /**\n * Creates a function that invokes `func`, with up to `n` arguments,\n * ignoring any additional arguments.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to cap arguments for.\n * @param {number} [n=func.length] The arity cap.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new capped function.\n * @example\n *\n * _.map(['6', '8', '10'], _.ary(parseInt, 1));\n * // => [6, 8, 10]\n */\n function ary(func, n, guard) {\n n = guard ? undefined : n;\n n = (func && n == null) ? func.length : n;\n return createWrap(func, WRAP_ARY_FLAG, undefined, undefined, undefined, undefined, n);\n }\n\n /**\n * Creates a function that invokes `func`, with the `this` binding and arguments\n * of the created function, while it's called less than `n` times. Subsequent\n * calls to the created function return the result of the last `func` invocation.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {number} n The number of calls at which `func` is no longer invoked.\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * jQuery(element).on('click', _.before(5, addContactToList));\n * // => Allows adding up to 4 contacts to the list.\n */\n function before(n, func) {\n var result;\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n n = toInteger(n);\n return function() {\n if (--n > 0) {\n result = func.apply(this, arguments);\n }\n if (n <= 1) {\n func = undefined;\n }\n return result;\n };\n }\n\n /**\n * Creates a function that invokes `func` with the `this` binding of `thisArg`\n * and `partials` prepended to the arguments it receives.\n *\n * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds,\n * may be used as a placeholder for partially applied arguments.\n *\n * **Note:** Unlike native `Function#bind`, this method doesn't set the \"length\"\n * property of bound functions.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to bind.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new bound function.\n * @example\n *\n * function greet(greeting, punctuation) {\n * return greeting + ' ' + this.user + punctuation;\n * }\n *\n * var object = { 'user': 'fred' };\n *\n * var bound = _.bind(greet, object, 'hi');\n * bound('!');\n * // => 'hi fred!'\n *\n * // Bound with placeholders.\n * var bound = _.bind(greet, object, _, '!');\n * bound('hi');\n * // => 'hi fred!'\n */\n var bind = baseRest(function(func, thisArg, partials) {\n var bitmask = WRAP_BIND_FLAG;\n if (partials.length) {\n var holders = replaceHolders(partials, getHolder(bind));\n bitmask |= WRAP_PARTIAL_FLAG;\n }\n return createWrap(func, bitmask, thisArg, partials, holders);\n });\n\n /**\n * Creates a function that invokes the method at `object[key]` with `partials`\n * prepended to the arguments it receives.\n *\n * This method differs from `_.bind` by allowing bound functions to reference\n * methods that may be redefined or don't yet exist. See\n * [Peter Michaux's article](http://peter.michaux.ca/articles/lazy-function-definition-pattern)\n * for more details.\n *\n * The `_.bindKey.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * @static\n * @memberOf _\n * @since 0.10.0\n * @category Function\n * @param {Object} object The object to invoke the method on.\n * @param {string} key The key of the method.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new bound function.\n * @example\n *\n * var object = {\n * 'user': 'fred',\n * 'greet': function(greeting, punctuation) {\n * return greeting + ' ' + this.user + punctuation;\n * }\n * };\n *\n * var bound = _.bindKey(object, 'greet', 'hi');\n * bound('!');\n * // => 'hi fred!'\n *\n * object.greet = function(greeting, punctuation) {\n * return greeting + 'ya ' + this.user + punctuation;\n * };\n *\n * bound('!');\n * // => 'hiya fred!'\n *\n * // Bound with placeholders.\n * var bound = _.bindKey(object, 'greet', _, '!');\n * bound('hi');\n * // => 'hiya fred!'\n */\n var bindKey = baseRest(function(object, key, partials) {\n var bitmask = WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG;\n if (partials.length) {\n var holders = replaceHolders(partials, getHolder(bindKey));\n bitmask |= WRAP_PARTIAL_FLAG;\n }\n return createWrap(key, bitmask, object, partials, holders);\n });\n\n /**\n * Creates a function that accepts arguments of `func` and either invokes\n * `func` returning its result, if at least `arity` number of arguments have\n * been provided, or returns a function that accepts the remaining `func`\n * arguments, and so on. The arity of `func` may be specified if `func.length`\n * is not sufficient.\n *\n * The `_.curry.placeholder` value, which defaults to `_` in monolithic builds,\n * may be used as a placeholder for provided arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of curried functions.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Function\n * @param {Function} func The function to curry.\n * @param {number} [arity=func.length] The arity of `func`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new curried function.\n * @example\n *\n * var abc = function(a, b, c) {\n * return [a, b, c];\n * };\n *\n * var curried = _.curry(abc);\n *\n * curried(1)(2)(3);\n * // => [1, 2, 3]\n *\n * curried(1, 2)(3);\n * // => [1, 2, 3]\n *\n * curried(1, 2, 3);\n * // => [1, 2, 3]\n *\n * // Curried with placeholders.\n * curried(1)(_, 3)(2);\n * // => [1, 2, 3]\n */\n function curry(func, arity, guard) {\n arity = guard ? undefined : arity;\n var result = createWrap(func, WRAP_CURRY_FLAG, undefined, undefined, undefined, undefined, undefined, arity);\n result.placeholder = curry.placeholder;\n return result;\n }\n\n /**\n * This method is like `_.curry` except that arguments are applied to `func`\n * in the manner of `_.partialRight` instead of `_.partial`.\n *\n * The `_.curryRight.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for provided arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of curried functions.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to curry.\n * @param {number} [arity=func.length] The arity of `func`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new curried function.\n * @example\n *\n * var abc = function(a, b, c) {\n * return [a, b, c];\n * };\n *\n * var curried = _.curryRight(abc);\n *\n * curried(3)(2)(1);\n * // => [1, 2, 3]\n *\n * curried(2, 3)(1);\n * // => [1, 2, 3]\n *\n * curried(1, 2, 3);\n * // => [1, 2, 3]\n *\n * // Curried with placeholders.\n * curried(3)(1, _)(2);\n * // => [1, 2, 3]\n */\n function curryRight(func, arity, guard) {\n arity = guard ? undefined : arity;\n var result = createWrap(func, WRAP_CURRY_RIGHT_FLAG, undefined, undefined, undefined, undefined, undefined, arity);\n result.placeholder = curryRight.placeholder;\n return result;\n }\n\n /**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\n function debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n timeWaiting = wait - timeSinceLastCall;\n\n return maxing\n ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)\n : timeWaiting;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n clearTimeout(timerId);\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n }\n\n /**\n * Defers invoking the `func` until the current call stack has cleared. Any\n * additional arguments are provided to `func` when it's invoked.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to defer.\n * @param {...*} [args] The arguments to invoke `func` with.\n * @returns {number} Returns the timer id.\n * @example\n *\n * _.defer(function(text) {\n * console.log(text);\n * }, 'deferred');\n * // => Logs 'deferred' after one millisecond.\n */\n var defer = baseRest(function(func, args) {\n return baseDelay(func, 1, args);\n });\n\n /**\n * Invokes `func` after `wait` milliseconds. Any additional arguments are\n * provided to `func` when it's invoked.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @param {...*} [args] The arguments to invoke `func` with.\n * @returns {number} Returns the timer id.\n * @example\n *\n * _.delay(function(text) {\n * console.log(text);\n * }, 1000, 'later');\n * // => Logs 'later' after one second.\n */\n var delay = baseRest(function(func, wait, args) {\n return baseDelay(func, toNumber(wait) || 0, args);\n });\n\n /**\n * Creates a function that invokes `func` with arguments reversed.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to flip arguments for.\n * @returns {Function} Returns the new flipped function.\n * @example\n *\n * var flipped = _.flip(function() {\n * return _.toArray(arguments);\n * });\n *\n * flipped('a', 'b', 'c', 'd');\n * // => ['d', 'c', 'b', 'a']\n */\n function flip(func) {\n return createWrap(func, WRAP_FLIP_FLAG);\n }\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 */\n function 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`.\n memoize.Cache = MapCache;\n\n /**\n * Creates a function that negates the result of the predicate `func`. The\n * `func` predicate is invoked with the `this` binding and arguments of the\n * created function.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} predicate The predicate to negate.\n * @returns {Function} Returns the new negated function.\n * @example\n *\n * function isEven(n) {\n * return n % 2 == 0;\n * }\n *\n * _.filter([1, 2, 3, 4, 5, 6], _.negate(isEven));\n * // => [1, 3, 5]\n */\n function negate(predicate) {\n if (typeof predicate != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n return function() {\n var args = arguments;\n switch (args.length) {\n case 0: return !predicate.call(this);\n case 1: return !predicate.call(this, args[0]);\n case 2: return !predicate.call(this, args[0], args[1]);\n case 3: return !predicate.call(this, args[0], args[1], args[2]);\n }\n return !predicate.apply(this, args);\n };\n }\n\n /**\n * Creates a function that is restricted to invoking `func` once. Repeat calls\n * to the function return the value of the first invocation. The `func` is\n * invoked with the `this` binding and arguments of the created function.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * var initialize = _.once(createApplication);\n * initialize();\n * initialize();\n * // => `createApplication` is invoked once\n */\n function once(func) {\n return before(2, func);\n }\n\n /**\n * Creates a function that invokes `func` with its arguments transformed.\n *\n * @static\n * @since 4.0.0\n * @memberOf _\n * @category Function\n * @param {Function} func The function to wrap.\n * @param {...(Function|Function[])} [transforms=[_.identity]]\n * The argument transforms.\n * @returns {Function} Returns the new function.\n * @example\n *\n * function doubled(n) {\n * return n * 2;\n * }\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var func = _.overArgs(function(x, y) {\n * return [x, y];\n * }, [square, doubled]);\n *\n * func(9, 3);\n * // => [81, 6]\n *\n * func(10, 5);\n * // => [100, 10]\n */\n var overArgs = castRest(function(func, transforms) {\n transforms = (transforms.length == 1 && isArray(transforms[0]))\n ? arrayMap(transforms[0], baseUnary(getIteratee()))\n : arrayMap(baseFlatten(transforms, 1), baseUnary(getIteratee()));\n\n var funcsLength = transforms.length;\n return baseRest(function(args) {\n var index = -1,\n length = nativeMin(args.length, funcsLength);\n\n while (++index < length) {\n args[index] = transforms[index].call(this, args[index]);\n }\n return apply(func, this, args);\n });\n });\n\n /**\n * Creates a function that invokes `func` with `partials` prepended to the\n * arguments it receives. This method is like `_.bind` except it does **not**\n * alter the `this` binding.\n *\n * The `_.partial.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of partially\n * applied functions.\n *\n * @static\n * @memberOf _\n * @since 0.2.0\n * @category Function\n * @param {Function} func The function to partially apply arguments to.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new partially applied function.\n * @example\n *\n * function greet(greeting, name) {\n * return greeting + ' ' + name;\n * }\n *\n * var sayHelloTo = _.partial(greet, 'hello');\n * sayHelloTo('fred');\n * // => 'hello fred'\n *\n * // Partially applied with placeholders.\n * var greetFred = _.partial(greet, _, 'fred');\n * greetFred('hi');\n * // => 'hi fred'\n */\n var partial = baseRest(function(func, partials) {\n var holders = replaceHolders(partials, getHolder(partial));\n return createWrap(func, WRAP_PARTIAL_FLAG, undefined, partials, holders);\n });\n\n /**\n * This method is like `_.partial` except that partially applied arguments\n * are appended to the arguments it receives.\n *\n * The `_.partialRight.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of partially\n * applied functions.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Function\n * @param {Function} func The function to partially apply arguments to.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new partially applied function.\n * @example\n *\n * function greet(greeting, name) {\n * return greeting + ' ' + name;\n * }\n *\n * var greetFred = _.partialRight(greet, 'fred');\n * greetFred('hi');\n * // => 'hi fred'\n *\n * // Partially applied with placeholders.\n * var sayHelloTo = _.partialRight(greet, 'hello', _);\n * sayHelloTo('fred');\n * // => 'hello fred'\n */\n var partialRight = baseRest(function(func, partials) {\n var holders = replaceHolders(partials, getHolder(partialRight));\n return createWrap(func, WRAP_PARTIAL_RIGHT_FLAG, undefined, partials, holders);\n });\n\n /**\n * Creates a function that invokes `func` with arguments arranged according\n * to the specified `indexes` where the argument value at the first index is\n * provided as the first argument, the argument value at the second index is\n * provided as the second argument, and so on.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to rearrange arguments for.\n * @param {...(number|number[])} indexes The arranged argument indexes.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var rearged = _.rearg(function(a, b, c) {\n * return [a, b, c];\n * }, [2, 0, 1]);\n *\n * rearged('b', 'c', 'a')\n * // => ['a', 'b', 'c']\n */\n var rearg = flatRest(function(func, indexes) {\n return createWrap(func, WRAP_REARG_FLAG, undefined, undefined, undefined, indexes);\n });\n\n /**\n * Creates a function that invokes `func` with the `this` binding of the\n * created function and arguments from `start` and beyond provided as\n * an array.\n *\n * **Note:** This method is based on the\n * [rest parameter](https://mdn.io/rest_parameters).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var say = _.rest(function(what, names) {\n * return what + ' ' + _.initial(names).join(', ') +\n * (_.size(names) > 1 ? ', & ' : '') + _.last(names);\n * });\n *\n * say('hello', 'fred', 'barney', 'pebbles');\n * // => 'hello fred, barney, & pebbles'\n */\n function rest(func, start) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n start = start === undefined ? start : toInteger(start);\n return baseRest(func, start);\n }\n\n /**\n * Creates a function that invokes `func` with the `this` binding of the\n * create function and an array of arguments much like\n * [`Function#apply`](http://www.ecma-international.org/ecma-262/7.0/#sec-function.prototype.apply).\n *\n * **Note:** This method is based on the\n * [spread operator](https://mdn.io/spread_operator).\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Function\n * @param {Function} func The function to spread arguments over.\n * @param {number} [start=0] The start position of the spread.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var say = _.spread(function(who, what) {\n * return who + ' says ' + what;\n * });\n *\n * say(['fred', 'hello']);\n * // => 'fred says hello'\n *\n * var numbers = Promise.all([\n * Promise.resolve(40),\n * Promise.resolve(36)\n * ]);\n *\n * numbers.then(_.spread(function(x, y) {\n * return x + y;\n * }));\n * // => a Promise of 76\n */\n function spread(func, start) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n start = start == null ? 0 : nativeMax(toInteger(start), 0);\n return baseRest(function(args) {\n var array = args[start],\n otherArgs = castSlice(args, 0, start);\n\n if (array) {\n arrayPush(otherArgs, array);\n }\n return apply(func, this, otherArgs);\n });\n }\n\n /**\n * Creates a throttled function that only invokes `func` at most once per\n * every `wait` milliseconds. The throttled function comes with a `cancel`\n * method to cancel delayed `func` invocations and a `flush` method to\n * immediately invoke them. Provide `options` to indicate whether `func`\n * should be invoked on the leading and/or trailing edge of the `wait`\n * timeout. The `func` is invoked with the last arguments provided to the\n * throttled function. Subsequent calls to the throttled function return the\n * result of the last `func` invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the throttled function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.throttle` and `_.debounce`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to throttle.\n * @param {number} [wait=0] The number of milliseconds to throttle invocations to.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=true]\n * Specify invoking on the leading edge of the timeout.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new throttled function.\n * @example\n *\n * // Avoid excessively updating the position while scrolling.\n * jQuery(window).on('scroll', _.throttle(updatePosition, 100));\n *\n * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.\n * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });\n * jQuery(element).on('click', throttled);\n *\n * // Cancel the trailing throttled invocation.\n * jQuery(window).on('popstate', throttled.cancel);\n */\n function throttle(func, wait, options) {\n var leading = true,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (isObject(options)) {\n leading = 'leading' in options ? !!options.leading : leading;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n return debounce(func, wait, {\n 'leading': leading,\n 'maxWait': wait,\n 'trailing': trailing\n });\n }\n\n /**\n * Creates a function that accepts up to one argument, ignoring any\n * additional arguments.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n * @example\n *\n * _.map(['6', '8', '10'], _.unary(parseInt));\n * // => [6, 8, 10]\n */\n function unary(func) {\n return ary(func, 1);\n }\n\n /**\n * Creates a function that provides `value` to `wrapper` as its first\n * argument. Any additional arguments provided to the function are appended\n * to those provided to the `wrapper`. The wrapper is invoked with the `this`\n * binding of the created function.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {*} value The value to wrap.\n * @param {Function} [wrapper=identity] The wrapper function.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var p = _.wrap(_.escape, function(func, text) {\n * return '

' + func(text) + '

';\n * });\n *\n * p('fred, barney, & pebbles');\n * // => '

fred, barney, & pebbles

'\n */\n function wrap(value, wrapper) {\n return partial(castFunction(wrapper), value);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Casts `value` as an array if it's not one.\n *\n * @static\n * @memberOf _\n * @since 4.4.0\n * @category Lang\n * @param {*} value The value to inspect.\n * @returns {Array} Returns the cast array.\n * @example\n *\n * _.castArray(1);\n * // => [1]\n *\n * _.castArray({ 'a': 1 });\n * // => [{ 'a': 1 }]\n *\n * _.castArray('abc');\n * // => ['abc']\n *\n * _.castArray(null);\n * // => [null]\n *\n * _.castArray(undefined);\n * // => [undefined]\n *\n * _.castArray();\n * // => []\n *\n * var array = [1, 2, 3];\n * console.log(_.castArray(array) === array);\n * // => true\n */\n function castArray() {\n if (!arguments.length) {\n return [];\n }\n var value = arguments[0];\n return isArray(value) ? value : [value];\n }\n\n /**\n * Creates a shallow clone of `value`.\n *\n * **Note:** This method is loosely based on the\n * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)\n * and supports cloning arrays, array buffers, booleans, date objects, maps,\n * numbers, `Object` objects, regexes, sets, strings, symbols, and typed\n * arrays. The own enumerable properties of `arguments` objects are cloned\n * as plain objects. An empty object is returned for uncloneable values such\n * as error objects, functions, DOM nodes, and WeakMaps.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to clone.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeep\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var shallow = _.clone(objects);\n * console.log(shallow[0] === objects[0]);\n * // => true\n */\n function clone(value) {\n return baseClone(value, CLONE_SYMBOLS_FLAG);\n }\n\n /**\n * This method is like `_.clone` except that it accepts `customizer` which\n * is invoked to produce the cloned value. If `customizer` returns `undefined`,\n * cloning is handled by the method instead. The `customizer` is invoked with\n * up to four arguments; (value [, index|key, object, stack]).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to clone.\n * @param {Function} [customizer] The function to customize cloning.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeepWith\n * @example\n *\n * function customizer(value) {\n * if (_.isElement(value)) {\n * return value.cloneNode(false);\n * }\n * }\n *\n * var el = _.cloneWith(document.body, customizer);\n *\n * console.log(el === document.body);\n * // => false\n * console.log(el.nodeName);\n * // => 'BODY'\n * console.log(el.childNodes.length);\n * // => 0\n */\n function cloneWith(value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseClone(value, CLONE_SYMBOLS_FLAG, customizer);\n }\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 */\n function cloneDeep(value) {\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\n }\n\n /**\n * This method is like `_.cloneWith` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @param {Function} [customizer] The function to customize cloning.\n * @returns {*} Returns the deep cloned value.\n * @see _.cloneWith\n * @example\n *\n * function customizer(value) {\n * if (_.isElement(value)) {\n * return value.cloneNode(true);\n * }\n * }\n *\n * var el = _.cloneDeepWith(document.body, customizer);\n *\n * console.log(el === document.body);\n * // => false\n * console.log(el.nodeName);\n * // => 'BODY'\n * console.log(el.childNodes.length);\n * // => 20\n */\n function cloneDeepWith(value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG, customizer);\n }\n\n /**\n * Checks if `object` conforms to `source` by invoking the predicate\n * properties of `source` with the corresponding property values of `object`.\n *\n * **Note:** This method is equivalent to `_.conforms` when `source` is\n * partially applied.\n *\n * @static\n * @memberOf _\n * @since 4.14.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property predicates to conform to.\n * @returns {boolean} Returns `true` if `object` conforms, else `false`.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n *\n * _.conformsTo(object, { 'b': function(n) { return n > 1; } });\n * // => true\n *\n * _.conformsTo(object, { 'b': function(n) { return n > 2; } });\n * // => false\n */\n function conformsTo(object, source) {\n return source == null || baseConformsTo(object, source, keys(source));\n }\n\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 */\n function eq(value, other) {\n return value === other || (value !== value && other !== other);\n }\n\n /**\n * Checks if `value` is greater than `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\n * else `false`.\n * @see _.lt\n * @example\n *\n * _.gt(3, 1);\n * // => true\n *\n * _.gt(3, 3);\n * // => false\n *\n * _.gt(1, 3);\n * // => false\n */\n var gt = createRelationalOperation(baseGt);\n\n /**\n * Checks if `value` is greater than or equal to `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than or equal to\n * `other`, else `false`.\n * @see _.lte\n * @example\n *\n * _.gte(3, 1);\n * // => true\n *\n * _.gte(3, 3);\n * // => true\n *\n * _.gte(1, 3);\n * // => false\n */\n var gte = createRelationalOperation(function(value, other) {\n return value >= other;\n });\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 */\n var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n };\n\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 */\n var isArray = Array.isArray;\n\n /**\n * Checks if `value` is classified as an `ArrayBuffer` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`.\n * @example\n *\n * _.isArrayBuffer(new ArrayBuffer(2));\n * // => true\n *\n * _.isArrayBuffer(new Array(2));\n * // => false\n */\n var isArrayBuffer = nodeIsArrayBuffer ? baseUnary(nodeIsArrayBuffer) : baseIsArrayBuffer;\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 */\n function isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n }\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 */\n function isArrayLikeObject(value) {\n return isObjectLike(value) && isArrayLike(value);\n }\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 */\n function isBoolean(value) {\n return value === true || value === false ||\n (isObjectLike(value) && baseGetTag(value) == boolTag);\n }\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 */\n var isBuffer = nativeIsBuffer || stubFalse;\n\n /**\n * Checks if `value` is classified as a `Date` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\n * @example\n *\n * _.isDate(new Date);\n * // => true\n *\n * _.isDate('Mon April 23 2012');\n * // => false\n */\n var isDate = nodeIsDate ? baseUnary(nodeIsDate) : baseIsDate;\n\n /**\n * Checks if `value` is likely a DOM element.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a DOM element, else `false`.\n * @example\n *\n * _.isElement(document.body);\n * // => true\n *\n * _.isElement('');\n * // => false\n */\n function isElement(value) {\n return isObjectLike(value) && value.nodeType === 1 && !isPlainObject(value);\n }\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 */\n function 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\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 */\n function isEqual(value, other) {\n return baseIsEqual(value, other);\n }\n\n /**\n * This method is like `_.isEqual` except that it accepts `customizer` which\n * is invoked to compare values. If `customizer` returns `undefined`, comparisons\n * are handled by the method instead. The `customizer` is invoked with up to\n * six arguments: (objValue, othValue [, index|key, object, other, stack]).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * function isGreeting(value) {\n * return /^h(?:i|ello)$/.test(value);\n * }\n *\n * function customizer(objValue, othValue) {\n * if (isGreeting(objValue) && isGreeting(othValue)) {\n * return true;\n * }\n * }\n *\n * var array = ['hello', 'goodbye'];\n * var other = ['hi', 'goodbye'];\n *\n * _.isEqualWith(array, other, customizer);\n * // => true\n */\n function isEqualWith(value, other, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n var result = customizer ? customizer(value, other) : undefined;\n return result === undefined ? baseIsEqual(value, other, undefined, customizer) : !!result;\n }\n\n /**\n * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`,\n * `SyntaxError`, `TypeError`, or `URIError` object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an error object, else `false`.\n * @example\n *\n * _.isError(new Error);\n * // => true\n *\n * _.isError(Error);\n * // => false\n */\n function isError(value) {\n if (!isObjectLike(value)) {\n return false;\n }\n var tag = baseGetTag(value);\n return tag == errorTag || tag == domExcTag ||\n (typeof value.message == 'string' && typeof value.name == 'string' && !isPlainObject(value));\n }\n\n /**\n * Checks if `value` is a finite primitive number.\n *\n * **Note:** This method is based on\n * [`Number.isFinite`](https://mdn.io/Number/isFinite).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a finite number, else `false`.\n * @example\n *\n * _.isFinite(3);\n * // => true\n *\n * _.isFinite(Number.MIN_VALUE);\n * // => true\n *\n * _.isFinite(Infinity);\n * // => false\n *\n * _.isFinite('3');\n * // => false\n */\n function isFinite(value) {\n return typeof value == 'number' && nativeIsFinite(value);\n }\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 */\n function 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\n /**\n * Checks if `value` is an integer.\n *\n * **Note:** This method is based on\n * [`Number.isInteger`](https://mdn.io/Number/isInteger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an integer, else `false`.\n * @example\n *\n * _.isInteger(3);\n * // => true\n *\n * _.isInteger(Number.MIN_VALUE);\n * // => false\n *\n * _.isInteger(Infinity);\n * // => false\n *\n * _.isInteger('3');\n * // => false\n */\n function isInteger(value) {\n return typeof value == 'number' && value == toInteger(value);\n }\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 */\n function isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n }\n\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 */\n function isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n }\n\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 */\n function isObjectLike(value) {\n return value != null && typeof value == 'object';\n }\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 */\n var isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\n /**\n * Performs a partial deep comparison between `object` and `source` to\n * determine if `object` contains equivalent property values.\n *\n * **Note:** This method is equivalent to `_.matches` when `source` is\n * partially applied.\n *\n * Partial comparisons will match empty array and empty object `source`\n * values against any array or object value, respectively. See `_.isEqual`\n * for a list of supported value comparisons.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n *\n * _.isMatch(object, { 'b': 2 });\n * // => true\n *\n * _.isMatch(object, { 'b': 1 });\n * // => false\n */\n function isMatch(object, source) {\n return object === source || baseIsMatch(object, source, getMatchData(source));\n }\n\n /**\n * This method is like `_.isMatch` except that it accepts `customizer` which\n * is invoked to compare values. If `customizer` returns `undefined`, comparisons\n * are handled by the method instead. The `customizer` is invoked with five\n * arguments: (objValue, srcValue, index|key, object, source).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n * @example\n *\n * function isGreeting(value) {\n * return /^h(?:i|ello)$/.test(value);\n * }\n *\n * function customizer(objValue, srcValue) {\n * if (isGreeting(objValue) && isGreeting(srcValue)) {\n * return true;\n * }\n * }\n *\n * var object = { 'greeting': 'hello' };\n * var source = { 'greeting': 'hi' };\n *\n * _.isMatchWith(object, source, customizer);\n * // => true\n */\n function isMatchWith(object, source, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseIsMatch(object, source, getMatchData(source), customizer);\n }\n\n /**\n * Checks if `value` is `NaN`.\n *\n * **Note:** This method is based on\n * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as\n * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for\n * `undefined` and other non-number values.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n * @example\n *\n * _.isNaN(NaN);\n * // => true\n *\n * _.isNaN(new Number(NaN));\n * // => true\n *\n * isNaN(undefined);\n * // => true\n *\n * _.isNaN(undefined);\n * // => false\n */\n function isNaN(value) {\n // An `NaN` primitive is the only value that is not equal to itself.\n // Perform the `toStringTag` check first to avoid errors with some\n // ActiveX objects in IE.\n return isNumber(value) && value != +value;\n }\n\n /**\n * Checks if `value` is a pristine native function.\n *\n * **Note:** This method can't reliably detect native functions in the presence\n * of the core-js package because core-js circumvents this kind of detection.\n * Despite multiple requests, the core-js maintainer has made it clear: any\n * attempt to fix the detection will be obstructed. As a result, we're left\n * with little choice but to throw an error. Unfortunately, this also affects\n * packages, like [babel-polyfill](https://www.npmjs.com/package/babel-polyfill),\n * which rely on core-js.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n * @example\n *\n * _.isNative(Array.prototype.push);\n * // => true\n *\n * _.isNative(_);\n * // => false\n */\n function isNative(value) {\n if (isMaskable(value)) {\n throw new Error(CORE_ERROR_TEXT);\n }\n return baseIsNative(value);\n }\n\n /**\n * Checks if `value` is `null`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `null`, else `false`.\n * @example\n *\n * _.isNull(null);\n * // => true\n *\n * _.isNull(void 0);\n * // => false\n */\n function isNull(value) {\n return value === null;\n }\n\n /**\n * Checks if `value` is `null` or `undefined`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is nullish, else `false`.\n * @example\n *\n * _.isNil(null);\n * // => true\n *\n * _.isNil(void 0);\n * // => true\n *\n * _.isNil(NaN);\n * // => false\n */\n function isNil(value) {\n return value == null;\n }\n\n /**\n * Checks if `value` is classified as a `Number` primitive or object.\n *\n * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are\n * classified as numbers, use the `_.isFinite` method.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a number, else `false`.\n * @example\n *\n * _.isNumber(3);\n * // => true\n *\n * _.isNumber(Number.MIN_VALUE);\n * // => true\n *\n * _.isNumber(Infinity);\n * // => true\n *\n * _.isNumber('3');\n * // => false\n */\n function isNumber(value) {\n return typeof value == 'number' ||\n (isObjectLike(value) && baseGetTag(value) == numberTag);\n }\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 */\n function 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\n /**\n * Checks if `value` is classified as a `RegExp` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\n * @example\n *\n * _.isRegExp(/abc/);\n * // => true\n *\n * _.isRegExp('/abc/');\n * // => false\n */\n var isRegExp = nodeIsRegExp ? baseUnary(nodeIsRegExp) : baseIsRegExp;\n\n /**\n * Checks if `value` is a safe integer. An integer is safe if it's an IEEE-754\n * double precision number which isn't the result of a rounded unsafe integer.\n *\n * **Note:** This method is based on\n * [`Number.isSafeInteger`](https://mdn.io/Number/isSafeInteger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a safe integer, else `false`.\n * @example\n *\n * _.isSafeInteger(3);\n * // => true\n *\n * _.isSafeInteger(Number.MIN_VALUE);\n * // => false\n *\n * _.isSafeInteger(Infinity);\n * // => false\n *\n * _.isSafeInteger('3');\n * // => false\n */\n function isSafeInteger(value) {\n return isInteger(value) && value >= -MAX_SAFE_INTEGER && value <= MAX_SAFE_INTEGER;\n }\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 */\n var isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\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 */\n function isString(value) {\n return typeof value == 'string' ||\n (!isArray(value) && isObjectLike(value) && baseGetTag(value) == stringTag);\n }\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 */\n function isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n }\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 */\n var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n /**\n * Checks if `value` is `undefined`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`.\n * @example\n *\n * _.isUndefined(void 0);\n * // => true\n *\n * _.isUndefined(null);\n * // => false\n */\n function isUndefined(value) {\n return value === undefined;\n }\n\n /**\n * Checks if `value` is classified as a `WeakMap` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a weak map, else `false`.\n * @example\n *\n * _.isWeakMap(new WeakMap);\n * // => true\n *\n * _.isWeakMap(new Map);\n * // => false\n */\n function isWeakMap(value) {\n return isObjectLike(value) && getTag(value) == weakMapTag;\n }\n\n /**\n * Checks if `value` is classified as a `WeakSet` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a weak set, else `false`.\n * @example\n *\n * _.isWeakSet(new WeakSet);\n * // => true\n *\n * _.isWeakSet(new Set);\n * // => false\n */\n function isWeakSet(value) {\n return isObjectLike(value) && baseGetTag(value) == weakSetTag;\n }\n\n /**\n * Checks if `value` is less than `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than `other`,\n * else `false`.\n * @see _.gt\n * @example\n *\n * _.lt(1, 3);\n * // => true\n *\n * _.lt(3, 3);\n * // => false\n *\n * _.lt(3, 1);\n * // => false\n */\n var lt = createRelationalOperation(baseLt);\n\n /**\n * Checks if `value` is less than or equal to `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than or equal to\n * `other`, else `false`.\n * @see _.gte\n * @example\n *\n * _.lte(1, 3);\n * // => true\n *\n * _.lte(3, 3);\n * // => true\n *\n * _.lte(3, 1);\n * // => false\n */\n var lte = createRelationalOperation(function(value, other) {\n return value <= other;\n });\n\n /**\n * Converts `value` to an array.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Array} Returns the converted array.\n * @example\n *\n * _.toArray({ 'a': 1, 'b': 2 });\n * // => [1, 2]\n *\n * _.toArray('abc');\n * // => ['a', 'b', 'c']\n *\n * _.toArray(1);\n * // => []\n *\n * _.toArray(null);\n * // => []\n */\n function toArray(value) {\n if (!value) {\n return [];\n }\n if (isArrayLike(value)) {\n return isString(value) ? stringToArray(value) : copyArray(value);\n }\n if (symIterator && value[symIterator]) {\n return iteratorToArray(value[symIterator]());\n }\n var tag = getTag(value),\n func = tag == mapTag ? mapToArray : (tag == setTag ? setToArray : values);\n\n return func(value);\n }\n\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 */\n function 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\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 */\n function toInteger(value) {\n var result = toFinite(value),\n remainder = result % 1;\n\n return result === result ? (remainder ? result - remainder : result) : 0;\n }\n\n /**\n * Converts `value` to an integer suitable for use as the length of an\n * array-like object.\n *\n * **Note:** This method is based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toLength(3.2);\n * // => 3\n *\n * _.toLength(Number.MIN_VALUE);\n * // => 0\n *\n * _.toLength(Infinity);\n * // => 4294967295\n *\n * _.toLength('3.2');\n * // => 3\n */\n function toLength(value) {\n return value ? baseClamp(toInteger(value), 0, MAX_ARRAY_LENGTH) : 0;\n }\n\n /**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\n function toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n }\n\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 */\n function toPlainObject(value) {\n return copyObject(value, keysIn(value));\n }\n\n /**\n * Converts `value` to a safe integer. A safe integer can be compared and\n * represented correctly.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toSafeInteger(3.2);\n * // => 3\n *\n * _.toSafeInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toSafeInteger(Infinity);\n * // => 9007199254740991\n *\n * _.toSafeInteger('3.2');\n * // => 3\n */\n function toSafeInteger(value) {\n return value\n ? baseClamp(toInteger(value), -MAX_SAFE_INTEGER, MAX_SAFE_INTEGER)\n : (value === 0 ? value : 0);\n }\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 */\n function toString(value) {\n return value == null ? '' : baseToString(value);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Assigns own enumerable string keyed properties of source objects to the\n * destination object. Source objects are applied from left to right.\n * Subsequent sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object` and is loosely based on\n * [`Object.assign`](https://mdn.io/Object/assign).\n *\n * @static\n * @memberOf _\n * @since 0.10.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.assignIn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * function Bar() {\n * this.c = 3;\n * }\n *\n * Foo.prototype.b = 2;\n * Bar.prototype.d = 4;\n *\n * _.assign({ 'a': 0 }, new Foo, new Bar);\n * // => { 'a': 1, 'c': 3 }\n */\n var assign = createAssigner(function(object, source) {\n if (isPrototype(source) || isArrayLike(source)) {\n copyObject(source, keys(source), object);\n return;\n }\n for (var key in source) {\n if (hasOwnProperty.call(source, key)) {\n assignValue(object, key, source[key]);\n }\n }\n });\n\n /**\n * This method is like `_.assign` except that it iterates over own and\n * inherited source properties.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias extend\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.assign\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * function Bar() {\n * this.c = 3;\n * }\n *\n * Foo.prototype.b = 2;\n * Bar.prototype.d = 4;\n *\n * _.assignIn({ 'a': 0 }, new Foo, new Bar);\n * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 }\n */\n var assignIn = createAssigner(function(object, source) {\n copyObject(source, keysIn(source), object);\n });\n\n /**\n * This method is like `_.assignIn` except that it accepts `customizer`\n * which is invoked to produce the assigned values. If `customizer` returns\n * `undefined`, assignment is handled by the method instead. The `customizer`\n * is invoked with five arguments: (objValue, srcValue, key, object, source).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias extendWith\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @see _.assignWith\n * @example\n *\n * function customizer(objValue, srcValue) {\n * return _.isUndefined(objValue) ? srcValue : objValue;\n * }\n *\n * var defaults = _.partialRight(_.assignInWith, customizer);\n *\n * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\n var assignInWith = createAssigner(function(object, source, srcIndex, customizer) {\n copyObject(source, keysIn(source), object, customizer);\n });\n\n /**\n * This method is like `_.assign` except that it accepts `customizer`\n * which is invoked to produce the assigned values. If `customizer` returns\n * `undefined`, assignment is handled by the method instead. The `customizer`\n * is invoked with five arguments: (objValue, srcValue, key, object, source).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @see _.assignInWith\n * @example\n *\n * function customizer(objValue, srcValue) {\n * return _.isUndefined(objValue) ? srcValue : objValue;\n * }\n *\n * var defaults = _.partialRight(_.assignWith, customizer);\n *\n * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\n var assignWith = createAssigner(function(object, source, srcIndex, customizer) {\n copyObject(source, keys(source), object, customizer);\n });\n\n /**\n * Creates an array of values corresponding to `paths` of `object`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Array} Returns the picked values.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };\n *\n * _.at(object, ['a[0].b.c', 'a[1]']);\n * // => [3, 4]\n */\n var at = flatRest(baseAt);\n\n /**\n * Creates an object that inherits from the `prototype` object. If a\n * `properties` object is given, its own enumerable string keyed properties\n * are assigned to the created object.\n *\n * @static\n * @memberOf _\n * @since 2.3.0\n * @category Object\n * @param {Object} prototype The object to inherit from.\n * @param {Object} [properties] The properties to assign to the object.\n * @returns {Object} Returns the new object.\n * @example\n *\n * function Shape() {\n * this.x = 0;\n * this.y = 0;\n * }\n *\n * function Circle() {\n * Shape.call(this);\n * }\n *\n * Circle.prototype = _.create(Shape.prototype, {\n * 'constructor': Circle\n * });\n *\n * var circle = new Circle;\n * circle instanceof Circle;\n * // => true\n *\n * circle instanceof Shape;\n * // => true\n */\n function create(prototype, properties) {\n var result = baseCreate(prototype);\n return properties == null ? result : baseAssign(result, properties);\n }\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 */\n var 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\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 */\n var defaultsDeep = baseRest(function(args) {\n args.push(undefined, customDefaultsMerge);\n return apply(mergeWith, undefined, args);\n });\n\n /**\n * This method is like `_.find` except that it returns the key of the first\n * element `predicate` returns truthy for instead of the element itself.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {string|undefined} Returns the key of the matched element,\n * else `undefined`.\n * @example\n *\n * var users = {\n * 'barney': { 'age': 36, 'active': true },\n * 'fred': { 'age': 40, 'active': false },\n * 'pebbles': { 'age': 1, 'active': true }\n * };\n *\n * _.findKey(users, function(o) { return o.age < 40; });\n * // => 'barney' (iteration order is not guaranteed)\n *\n * // The `_.matches` iteratee shorthand.\n * _.findKey(users, { 'age': 1, 'active': true });\n * // => 'pebbles'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findKey(users, ['active', false]);\n * // => 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.findKey(users, 'active');\n * // => 'barney'\n */\n function findKey(object, predicate) {\n return baseFindKey(object, getIteratee(predicate, 3), baseForOwn);\n }\n\n /**\n * This method is like `_.findKey` except that it iterates over elements of\n * a collection in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {string|undefined} Returns the key of the matched element,\n * else `undefined`.\n * @example\n *\n * var users = {\n * 'barney': { 'age': 36, 'active': true },\n * 'fred': { 'age': 40, 'active': false },\n * 'pebbles': { 'age': 1, 'active': true }\n * };\n *\n * _.findLastKey(users, function(o) { return o.age < 40; });\n * // => returns 'pebbles' assuming `_.findKey` returns 'barney'\n *\n * // The `_.matches` iteratee shorthand.\n * _.findLastKey(users, { 'age': 36, 'active': true });\n * // => 'barney'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findLastKey(users, ['active', false]);\n * // => 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.findLastKey(users, 'active');\n * // => 'pebbles'\n */\n function findLastKey(object, predicate) {\n return baseFindKey(object, getIteratee(predicate, 3), baseForOwnRight);\n }\n\n /**\n * Iterates over own and inherited enumerable string keyed properties of an\n * object and invokes `iteratee` for each property. The iteratee is invoked\n * with three arguments: (value, key, object). Iteratee functions may exit\n * iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forInRight\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forIn(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a', 'b', then 'c' (iteration order is not guaranteed).\n */\n function forIn(object, iteratee) {\n return object == null\n ? object\n : baseFor(object, getIteratee(iteratee, 3), keysIn);\n }\n\n /**\n * This method is like `_.forIn` except that it iterates over properties of\n * `object` in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forIn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forInRight(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'c', 'b', then 'a' assuming `_.forIn` logs 'a', 'b', then 'c'.\n */\n function forInRight(object, iteratee) {\n return object == null\n ? object\n : baseForRight(object, getIteratee(iteratee, 3), keysIn);\n }\n\n /**\n * Iterates over own enumerable string keyed properties of an object and\n * invokes `iteratee` for each property. The iteratee is invoked with three\n * arguments: (value, key, object). Iteratee functions may exit iteration\n * early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forOwnRight\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forOwn(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\n */\n function forOwn(object, iteratee) {\n return object && baseForOwn(object, getIteratee(iteratee, 3));\n }\n\n /**\n * This method is like `_.forOwn` except that it iterates over properties of\n * `object` in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forOwn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forOwnRight(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'b' then 'a' assuming `_.forOwn` logs 'a' then 'b'.\n */\n function forOwnRight(object, iteratee) {\n return object && baseForOwnRight(object, getIteratee(iteratee, 3));\n }\n\n /**\n * Creates an array of function property names from own enumerable properties\n * of `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to inspect.\n * @returns {Array} Returns the function names.\n * @see _.functionsIn\n * @example\n *\n * function Foo() {\n * this.a = _.constant('a');\n * this.b = _.constant('b');\n * }\n *\n * Foo.prototype.c = _.constant('c');\n *\n * _.functions(new Foo);\n * // => ['a', 'b']\n */\n function functions(object) {\n return object == null ? [] : baseFunctions(object, keys(object));\n }\n\n /**\n * Creates an array of function property names from own and inherited\n * enumerable properties of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @returns {Array} Returns the function names.\n * @see _.functions\n * @example\n *\n * function Foo() {\n * this.a = _.constant('a');\n * this.b = _.constant('b');\n * }\n *\n * Foo.prototype.c = _.constant('c');\n *\n * _.functionsIn(new Foo);\n * // => ['a', 'b', 'c']\n */\n function functionsIn(object) {\n return object == null ? [] : baseFunctions(object, keysIn(object));\n }\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 */\n function get(object, path, defaultValue) {\n var result = object == null ? undefined : baseGet(object, path);\n return result === undefined ? defaultValue : result;\n }\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 */\n function has(object, path) {\n return object != null && hasPath(object, path, baseHas);\n }\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 */\n function hasIn(object, path) {\n return object != null && hasPath(object, path, baseHasIn);\n }\n\n /**\n * Creates an object composed of the inverted keys and values of `object`.\n * If `object` contains duplicate values, subsequent values overwrite\n * property assignments of previous values.\n *\n * @static\n * @memberOf _\n * @since 0.7.0\n * @category Object\n * @param {Object} object The object to invert.\n * @returns {Object} Returns the new inverted object.\n * @example\n *\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\n *\n * _.invert(object);\n * // => { '1': 'c', '2': 'b' }\n */\n var invert = createInverter(function(result, value, key) {\n if (value != null &&\n typeof value.toString != 'function') {\n value = nativeObjectToString.call(value);\n }\n\n result[value] = key;\n }, constant(identity));\n\n /**\n * This method is like `_.invert` except that the inverted object is generated\n * from the results of running each element of `object` thru `iteratee`. The\n * corresponding inverted value of each inverted key is an array of keys\n * responsible for generating the inverted value. The iteratee is invoked\n * with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.1.0\n * @category Object\n * @param {Object} object The object to invert.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Object} Returns the new inverted object.\n * @example\n *\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\n *\n * _.invertBy(object);\n * // => { '1': ['a', 'c'], '2': ['b'] }\n *\n * _.invertBy(object, function(value) {\n * return 'group' + value;\n * });\n * // => { 'group1': ['a', 'c'], 'group2': ['b'] }\n */\n var invertBy = createInverter(function(result, value, key) {\n if (value != null &&\n typeof value.toString != 'function') {\n value = nativeObjectToString.call(value);\n }\n\n if (hasOwnProperty.call(result, value)) {\n result[value].push(key);\n } else {\n result[value] = [key];\n }\n }, getIteratee);\n\n /**\n * Invokes the method at `path` of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the method to invoke.\n * @param {...*} [args] The arguments to invoke the method with.\n * @returns {*} Returns the result of the invoked method.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': [1, 2, 3, 4] } }] };\n *\n * _.invoke(object, 'a[0].b.c.slice', 1, 3);\n * // => [2, 3]\n */\n var invoke = baseRest(baseInvoke);\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 */\n function keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n }\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 */\n function keysIn(object) {\n return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n }\n\n /**\n * The opposite of `_.mapValues`; this method creates an object with the\n * same values as `object` and keys generated by running each own enumerable\n * string keyed property of `object` thru `iteratee`. The iteratee is invoked\n * with three arguments: (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapValues\n * @example\n *\n * _.mapKeys({ 'a': 1, 'b': 2 }, function(value, key) {\n * return key + value;\n * });\n * // => { 'a1': 1, 'b2': 2 }\n */\n function mapKeys(object, iteratee) {\n var result = {};\n iteratee = getIteratee(iteratee, 3);\n\n baseForOwn(object, function(value, key, object) {\n baseAssignValue(result, iteratee(value, key, object), value);\n });\n return result;\n }\n\n /**\n * Creates an object with the same keys as `object` and values generated\n * by running each own enumerable string keyed property of `object` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapKeys\n * @example\n *\n * var users = {\n * 'fred': { 'user': 'fred', 'age': 40 },\n * 'pebbles': { 'user': 'pebbles', 'age': 1 }\n * };\n *\n * _.mapValues(users, function(o) { return o.age; });\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n *\n * // The `_.property` iteratee shorthand.\n * _.mapValues(users, 'age');\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n */\n function mapValues(object, iteratee) {\n var result = {};\n iteratee = getIteratee(iteratee, 3);\n\n baseForOwn(object, function(value, key, object) {\n baseAssignValue(result, key, iteratee(value, key, object));\n });\n return result;\n }\n\n /**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable string keyed properties of source objects into the\n * destination object. Source properties that resolve to `undefined` are\n * skipped if a destination value exists. Array and plain object properties\n * are merged recursively. Other objects and value types are overridden by\n * assignment. Source objects are applied from left to right. Subsequent\n * sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {\n * 'a': [{ 'b': 2 }, { 'd': 4 }]\n * };\n *\n * var other = {\n * 'a': [{ 'c': 3 }, { 'e': 5 }]\n * };\n *\n * _.merge(object, other);\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\n */\n var merge = createAssigner(function(object, source, srcIndex) {\n baseMerge(object, source, srcIndex);\n });\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 */\n var mergeWith = createAssigner(function(object, source, srcIndex, customizer) {\n baseMerge(object, source, srcIndex, customizer);\n });\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 */\n var 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\n /**\n * The opposite of `_.pickBy`; this method creates an object composed of\n * the own and inherited enumerable string keyed properties of `object` that\n * `predicate` doesn't return truthy for. The predicate is invoked with two\n * arguments: (value, key).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The source object.\n * @param {Function} [predicate=_.identity] The function invoked per property.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.omitBy(object, _.isNumber);\n * // => { 'b': '2' }\n */\n function omitBy(object, predicate) {\n return pickBy(object, negate(getIteratee(predicate)));\n }\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 */\n var pick = flatRest(function(object, paths) {\n return object == null ? {} : basePick(object, paths);\n });\n\n /**\n * Creates an object composed of the `object` properties `predicate` returns\n * truthy for. The predicate is invoked with two arguments: (value, key).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The source object.\n * @param {Function} [predicate=_.identity] The function invoked per property.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pickBy(object, _.isNumber);\n * // => { 'a': 1, 'c': 3 }\n */\n function pickBy(object, predicate) {\n if (object == null) {\n return {};\n }\n var props = arrayMap(getAllKeysIn(object), function(prop) {\n return [prop];\n });\n predicate = getIteratee(predicate);\n return basePickBy(object, props, function(value, path) {\n return predicate(value, path[0]);\n });\n }\n\n /**\n * This method is like `_.get` except that if the resolved value is a\n * function it's invoked with the `this` binding of its parent object and\n * its result is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to resolve.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c1': 3, 'c2': _.constant(4) } }] };\n *\n * _.result(object, 'a[0].b.c1');\n * // => 3\n *\n * _.result(object, 'a[0].b.c2');\n * // => 4\n *\n * _.result(object, 'a[0].b.c3', 'default');\n * // => 'default'\n *\n * _.result(object, 'a[0].b.c3', _.constant('default'));\n * // => 'default'\n */\n function result(object, path, defaultValue) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length;\n\n // Ensure the loop is entered when path is empty.\n if (!length) {\n length = 1;\n object = undefined;\n }\n while (++index < length) {\n var value = object == null ? undefined : object[toKey(path[index])];\n if (value === undefined) {\n index = length;\n value = defaultValue;\n }\n object = isFunction(value) ? value.call(object) : value;\n }\n return object;\n }\n\n /**\n * Sets the value at `path` of `object`. If a portion of `path` doesn't exist,\n * it's created. Arrays are created for missing index properties while objects\n * are created for all other missing properties. Use `_.setWith` to customize\n * `path` creation.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.set(object, 'a[0].b.c', 4);\n * console.log(object.a[0].b.c);\n * // => 4\n *\n * _.set(object, ['x', '0', 'y', 'z'], 5);\n * console.log(object.x[0].y.z);\n * // => 5\n */\n function set(object, path, value) {\n return object == null ? object : baseSet(object, path, value);\n }\n\n /**\n * This method is like `_.set` except that it accepts `customizer` which is\n * invoked to produce the objects of `path`. If `customizer` returns `undefined`\n * path creation is handled by the method instead. The `customizer` is invoked\n * with three arguments: (nsValue, key, nsObject).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {};\n *\n * _.setWith(object, '[0][1]', 'a', Object);\n * // => { '0': { '1': 'a' } }\n */\n function setWith(object, path, value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return object == null ? object : baseSet(object, path, value, customizer);\n }\n\n /**\n * Creates an array of own enumerable string keyed-value pairs for `object`\n * which can be consumed by `_.fromPairs`. If `object` is a map or set, its\n * entries are returned.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias entries\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the key-value pairs.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.toPairs(new Foo);\n * // => [['a', 1], ['b', 2]] (iteration order is not guaranteed)\n */\n var toPairs = createToPairs(keys);\n\n /**\n * Creates an array of own and inherited enumerable string keyed-value pairs\n * for `object` which can be consumed by `_.fromPairs`. If `object` is a map\n * or set, its entries are returned.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias entriesIn\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the key-value pairs.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.toPairsIn(new Foo);\n * // => [['a', 1], ['b', 2], ['c', 3]] (iteration order is not guaranteed)\n */\n var toPairsIn = createToPairs(keysIn);\n\n /**\n * An alternative to `_.reduce`; this method transforms `object` to a new\n * `accumulator` object which is the result of running each of its own\n * enumerable string keyed properties thru `iteratee`, with each invocation\n * potentially mutating the `accumulator` object. If `accumulator` is not\n * provided, a new object with the same `[[Prototype]]` will be used. The\n * iteratee is invoked with four arguments: (accumulator, value, key, object).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 1.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The custom accumulator value.\n * @returns {*} Returns the accumulated value.\n * @example\n *\n * _.transform([2, 3, 4], function(result, n) {\n * result.push(n *= n);\n * return n % 2 == 0;\n * }, []);\n * // => [4, 9]\n *\n * _.transform({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n * (result[value] || (result[value] = [])).push(key);\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] }\n */\n function transform(object, iteratee, accumulator) {\n var isArr = isArray(object),\n isArrLike = isArr || isBuffer(object) || isTypedArray(object);\n\n iteratee = getIteratee(iteratee, 4);\n if (accumulator == null) {\n var Ctor = object && object.constructor;\n if (isArrLike) {\n accumulator = isArr ? new Ctor : [];\n }\n else if (isObject(object)) {\n accumulator = isFunction(Ctor) ? baseCreate(getPrototype(object)) : {};\n }\n else {\n accumulator = {};\n }\n }\n (isArrLike ? arrayEach : baseForOwn)(object, function(value, index, object) {\n return iteratee(accumulator, value, index, object);\n });\n return accumulator;\n }\n\n /**\n * Removes the property at `path` of `object`.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to unset.\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 7 } }] };\n * _.unset(object, 'a[0].b.c');\n * // => true\n *\n * console.log(object);\n * // => { 'a': [{ 'b': {} }] };\n *\n * _.unset(object, ['a', '0', 'b', 'c']);\n * // => true\n *\n * console.log(object);\n * // => { 'a': [{ 'b': {} }] };\n */\n function unset(object, path) {\n return object == null ? true : baseUnset(object, path);\n }\n\n /**\n * This method is like `_.set` except that accepts `updater` to produce the\n * value to set. Use `_.updateWith` to customize `path` creation. The `updater`\n * is invoked with one argument: (value).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {Function} updater The function to produce the updated value.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.update(object, 'a[0].b.c', function(n) { return n * n; });\n * console.log(object.a[0].b.c);\n * // => 9\n *\n * _.update(object, 'x[0].y.z', function(n) { return n ? n + 1 : 0; });\n * console.log(object.x[0].y.z);\n * // => 0\n */\n function update(object, path, updater) {\n return object == null ? object : baseUpdate(object, path, castFunction(updater));\n }\n\n /**\n * This method is like `_.update` except that it accepts `customizer` which is\n * invoked to produce the objects of `path`. If `customizer` returns `undefined`\n * path creation is handled by the method instead. The `customizer` is invoked\n * with three arguments: (nsValue, key, nsObject).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {Function} updater The function to produce the updated value.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {};\n *\n * _.updateWith(object, '[0][1]', _.constant('a'), Object);\n * // => { '0': { '1': 'a' } }\n */\n function updateWith(object, path, updater, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return object == null ? object : baseUpdate(object, path, castFunction(updater), customizer);\n }\n\n /**\n * Creates an array of the own enumerable string keyed property values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.values(new Foo);\n * // => [1, 2] (iteration order is not guaranteed)\n *\n * _.values('hi');\n * // => ['h', 'i']\n */\n function values(object) {\n return object == null ? [] : baseValues(object, keys(object));\n }\n\n /**\n * Creates an array of the own and inherited enumerable string keyed property\n * values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.valuesIn(new Foo);\n * // => [1, 2, 3] (iteration order is not guaranteed)\n */\n function valuesIn(object) {\n return object == null ? [] : baseValues(object, keysIn(object));\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Clamps `number` within the inclusive `lower` and `upper` bounds.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Number\n * @param {number} number The number to clamp.\n * @param {number} [lower] The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the clamped number.\n * @example\n *\n * _.clamp(-10, -5, 5);\n * // => -5\n *\n * _.clamp(10, -5, 5);\n * // => 5\n */\n function clamp(number, lower, upper) {\n if (upper === undefined) {\n upper = lower;\n lower = undefined;\n }\n if (upper !== undefined) {\n upper = toNumber(upper);\n upper = upper === upper ? upper : 0;\n }\n if (lower !== undefined) {\n lower = toNumber(lower);\n lower = lower === lower ? lower : 0;\n }\n return baseClamp(toNumber(number), lower, upper);\n }\n\n /**\n * Checks if `n` is between `start` and up to, but not including, `end`. If\n * `end` is not specified, it's set to `start` with `start` then set to `0`.\n * If `start` is greater than `end` the params are swapped to support\n * negative ranges.\n *\n * @static\n * @memberOf _\n * @since 3.3.0\n * @category Number\n * @param {number} number The number to check.\n * @param {number} [start=0] The start of the range.\n * @param {number} end The end of the range.\n * @returns {boolean} Returns `true` if `number` is in the range, else `false`.\n * @see _.range, _.rangeRight\n * @example\n *\n * _.inRange(3, 2, 4);\n * // => true\n *\n * _.inRange(4, 8);\n * // => true\n *\n * _.inRange(4, 2);\n * // => false\n *\n * _.inRange(2, 2);\n * // => false\n *\n * _.inRange(1.2, 2);\n * // => true\n *\n * _.inRange(5.2, 4);\n * // => false\n *\n * _.inRange(-3, -2, -6);\n * // => true\n */\n function inRange(number, start, end) {\n start = toFinite(start);\n if (end === undefined) {\n end = start;\n start = 0;\n } else {\n end = toFinite(end);\n }\n number = toNumber(number);\n return baseInRange(number, start, end);\n }\n\n /**\n * Produces a random number between the inclusive `lower` and `upper` bounds.\n * If only one argument is provided a number between `0` and the given number\n * is returned. If `floating` is `true`, or either `lower` or `upper` are\n * floats, a floating-point number is returned instead of an integer.\n *\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\n * floating-point values which can produce unexpected results.\n *\n * @static\n * @memberOf _\n * @since 0.7.0\n * @category Number\n * @param {number} [lower=0] The lower bound.\n * @param {number} [upper=1] The upper bound.\n * @param {boolean} [floating] Specify returning a floating-point number.\n * @returns {number} Returns the random number.\n * @example\n *\n * _.random(0, 5);\n * // => an integer between 0 and 5\n *\n * _.random(5);\n * // => also an integer between 0 and 5\n *\n * _.random(5, true);\n * // => a floating-point number between 0 and 5\n *\n * _.random(1.2, 5.2);\n * // => a floating-point number between 1.2 and 5.2\n */\n function random(lower, upper, floating) {\n if (floating && typeof floating != 'boolean' && isIterateeCall(lower, upper, floating)) {\n upper = floating = undefined;\n }\n if (floating === undefined) {\n if (typeof upper == 'boolean') {\n floating = upper;\n upper = undefined;\n }\n else if (typeof lower == 'boolean') {\n floating = lower;\n lower = undefined;\n }\n }\n if (lower === undefined && upper === undefined) {\n lower = 0;\n upper = 1;\n }\n else {\n lower = toFinite(lower);\n if (upper === undefined) {\n upper = lower;\n lower = 0;\n } else {\n upper = toFinite(upper);\n }\n }\n if (lower > upper) {\n var temp = lower;\n lower = upper;\n upper = temp;\n }\n if (floating || lower % 1 || upper % 1) {\n var rand = nativeRandom();\n return nativeMin(lower + (rand * (upper - lower + freeParseFloat('1e-' + ((rand + '').length - 1)))), upper);\n }\n return baseRandom(lower, upper);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Converts `string` to [camel case](https://en.wikipedia.org/wiki/CamelCase).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the camel cased string.\n * @example\n *\n * _.camelCase('Foo Bar');\n * // => 'fooBar'\n *\n * _.camelCase('--foo-bar--');\n * // => 'fooBar'\n *\n * _.camelCase('__FOO_BAR__');\n * // => 'fooBar'\n */\n var camelCase = createCompounder(function(result, word, index) {\n word = word.toLowerCase();\n return result + (index ? capitalize(word) : word);\n });\n\n /**\n * Converts the first character of `string` to upper case and the remaining\n * to lower case.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to capitalize.\n * @returns {string} Returns the capitalized string.\n * @example\n *\n * _.capitalize('FRED');\n * // => 'Fred'\n */\n function capitalize(string) {\n return upperFirst(toString(string).toLowerCase());\n }\n\n /**\n * Deburrs `string` by converting\n * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table)\n * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A)\n * letters to basic Latin letters and removing\n * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to deburr.\n * @returns {string} Returns the deburred string.\n * @example\n *\n * _.deburr('déjà vu');\n * // => 'deja vu'\n */\n function deburr(string) {\n string = toString(string);\n return string && string.replace(reLatin, deburrLetter).replace(reComboMark, '');\n }\n\n /**\n * Checks if `string` ends with the given target string.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {string} [target] The string to search for.\n * @param {number} [position=string.length] The position to search up to.\n * @returns {boolean} Returns `true` if `string` ends with `target`,\n * else `false`.\n * @example\n *\n * _.endsWith('abc', 'c');\n * // => true\n *\n * _.endsWith('abc', 'b');\n * // => false\n *\n * _.endsWith('abc', 'b', 2);\n * // => true\n */\n function endsWith(string, target, position) {\n string = toString(string);\n target = baseToString(target);\n\n var length = string.length;\n position = position === undefined\n ? length\n : baseClamp(toInteger(position), 0, length);\n\n var end = position;\n position -= target.length;\n return position >= 0 && string.slice(position, end) == target;\n }\n\n /**\n * Converts the characters \"&\", \"<\", \">\", '\"', and \"'\" in `string` to their\n * corresponding HTML entities.\n *\n * **Note:** No other characters are escaped. To escape additional\n * characters use a third-party library like [_he_](https://mths.be/he).\n *\n * Though the \">\" character is escaped for symmetry, characters like\n * \">\" and \"/\" don't need escaping in HTML and have no special meaning\n * unless they're part of a tag or unquoted attribute value. See\n * [Mathias Bynens's article](https://mathiasbynens.be/notes/ambiguous-ampersands)\n * (under \"semi-related fun fact\") for more details.\n *\n * When working with HTML you should always\n * [quote attribute values](http://wonko.com/post/html-escaping) to reduce\n * XSS vectors.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category String\n * @param {string} [string=''] The string to escape.\n * @returns {string} Returns the escaped string.\n * @example\n *\n * _.escape('fred, barney, & pebbles');\n * // => 'fred, barney, & pebbles'\n */\n function escape(string) {\n string = toString(string);\n return (string && reHasUnescapedHtml.test(string))\n ? string.replace(reUnescapedHtml, escapeHtmlChar)\n : string;\n }\n\n /**\n * Escapes the `RegExp` special characters \"^\", \"$\", \"\\\", \".\", \"*\", \"+\",\n * \"?\", \"(\", \")\", \"[\", \"]\", \"{\", \"}\", and \"|\" in `string`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to escape.\n * @returns {string} Returns the escaped string.\n * @example\n *\n * _.escapeRegExp('[lodash](https://lodash.com/)');\n * // => '\\[lodash\\]\\(https://lodash\\.com/\\)'\n */\n function escapeRegExp(string) {\n string = toString(string);\n return (string && reHasRegExpChar.test(string))\n ? string.replace(reRegExpChar, '\\\\$&')\n : string;\n }\n\n /**\n * Converts `string` to\n * [kebab case](https://en.wikipedia.org/wiki/Letter_case#Special_case_styles).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the kebab cased string.\n * @example\n *\n * _.kebabCase('Foo Bar');\n * // => 'foo-bar'\n *\n * _.kebabCase('fooBar');\n * // => 'foo-bar'\n *\n * _.kebabCase('__FOO_BAR__');\n * // => 'foo-bar'\n */\n var kebabCase = createCompounder(function(result, word, index) {\n return result + (index ? '-' : '') + word.toLowerCase();\n });\n\n /**\n * Converts `string`, as space separated words, to lower case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the lower cased string.\n * @example\n *\n * _.lowerCase('--Foo-Bar--');\n * // => 'foo bar'\n *\n * _.lowerCase('fooBar');\n * // => 'foo bar'\n *\n * _.lowerCase('__FOO_BAR__');\n * // => 'foo bar'\n */\n var lowerCase = createCompounder(function(result, word, index) {\n return result + (index ? ' ' : '') + word.toLowerCase();\n });\n\n /**\n * Converts the first character of `string` to lower case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.lowerFirst('Fred');\n * // => 'fred'\n *\n * _.lowerFirst('FRED');\n * // => 'fRED'\n */\n var lowerFirst = createCaseFirst('toLowerCase');\n\n /**\n * Pads `string` on the left and right sides if it's shorter than `length`.\n * Padding characters are truncated if they can't be evenly divided by `length`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.pad('abc', 8);\n * // => ' abc '\n *\n * _.pad('abc', 8, '_-');\n * // => '_-abc_-_'\n *\n * _.pad('abc', 3);\n * // => 'abc'\n */\n function pad(string, length, chars) {\n string = toString(string);\n length = toInteger(length);\n\n var strLength = length ? stringSize(string) : 0;\n if (!length || strLength >= length) {\n return string;\n }\n var mid = (length - strLength) / 2;\n return (\n createPadding(nativeFloor(mid), chars) +\n string +\n createPadding(nativeCeil(mid), chars)\n );\n }\n\n /**\n * Pads `string` on the right side if it's shorter than `length`. Padding\n * characters are truncated if they exceed `length`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.padEnd('abc', 6);\n * // => 'abc '\n *\n * _.padEnd('abc', 6, '_-');\n * // => 'abc_-_'\n *\n * _.padEnd('abc', 3);\n * // => 'abc'\n */\n function padEnd(string, length, chars) {\n string = toString(string);\n length = toInteger(length);\n\n var strLength = length ? stringSize(string) : 0;\n return (length && strLength < length)\n ? (string + createPadding(length - strLength, chars))\n : string;\n }\n\n /**\n * Pads `string` on the left side if it's shorter than `length`. Padding\n * characters are truncated if they exceed `length`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.padStart('abc', 6);\n * // => ' abc'\n *\n * _.padStart('abc', 6, '_-');\n * // => '_-_abc'\n *\n * _.padStart('abc', 3);\n * // => 'abc'\n */\n function padStart(string, length, chars) {\n string = toString(string);\n length = toInteger(length);\n\n var strLength = length ? stringSize(string) : 0;\n return (length && strLength < length)\n ? (createPadding(length - strLength, chars) + string)\n : string;\n }\n\n /**\n * Converts `string` to an integer of the specified radix. If `radix` is\n * `undefined` or `0`, a `radix` of `10` is used unless `value` is a\n * hexadecimal, in which case a `radix` of `16` is used.\n *\n * **Note:** This method aligns with the\n * [ES5 implementation](https://es5.github.io/#x15.1.2.2) of `parseInt`.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category String\n * @param {string} string The string to convert.\n * @param {number} [radix=10] The radix to interpret `value` by.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.parseInt('08');\n * // => 8\n *\n * _.map(['6', '08', '10'], _.parseInt);\n * // => [6, 8, 10]\n */\n function parseInt(string, radix, guard) {\n if (guard || radix == null) {\n radix = 0;\n } else if (radix) {\n radix = +radix;\n }\n return nativeParseInt(toString(string).replace(reTrimStart, ''), radix || 0);\n }\n\n /**\n * Repeats the given string `n` times.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to repeat.\n * @param {number} [n=1] The number of times to repeat the string.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {string} Returns the repeated string.\n * @example\n *\n * _.repeat('*', 3);\n * // => '***'\n *\n * _.repeat('abc', 2);\n * // => 'abcabc'\n *\n * _.repeat('abc', 0);\n * // => ''\n */\n function repeat(string, n, guard) {\n if ((guard ? isIterateeCall(string, n, guard) : n === undefined)) {\n n = 1;\n } else {\n n = toInteger(n);\n }\n return baseRepeat(toString(string), n);\n }\n\n /**\n * Replaces matches for `pattern` in `string` with `replacement`.\n *\n * **Note:** This method is based on\n * [`String#replace`](https://mdn.io/String/replace).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to modify.\n * @param {RegExp|string} pattern The pattern to replace.\n * @param {Function|string} replacement The match replacement.\n * @returns {string} Returns the modified string.\n * @example\n *\n * _.replace('Hi Fred', 'Fred', 'Barney');\n * // => 'Hi Barney'\n */\n function replace() {\n var args = arguments,\n string = toString(args[0]);\n\n return args.length < 3 ? string : string.replace(args[1], args[2]);\n }\n\n /**\n * Converts `string` to\n * [snake case](https://en.wikipedia.org/wiki/Snake_case).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the snake cased string.\n * @example\n *\n * _.snakeCase('Foo Bar');\n * // => 'foo_bar'\n *\n * _.snakeCase('fooBar');\n * // => 'foo_bar'\n *\n * _.snakeCase('--FOO-BAR--');\n * // => 'foo_bar'\n */\n var snakeCase = createCompounder(function(result, word, index) {\n return result + (index ? '_' : '') + word.toLowerCase();\n });\n\n /**\n * Splits `string` by `separator`.\n *\n * **Note:** This method is based on\n * [`String#split`](https://mdn.io/String/split).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to split.\n * @param {RegExp|string} separator The separator pattern to split by.\n * @param {number} [limit] The length to truncate results to.\n * @returns {Array} Returns the string segments.\n * @example\n *\n * _.split('a-b-c', '-', 2);\n * // => ['a', 'b']\n */\n function split(string, separator, limit) {\n if (limit && typeof limit != 'number' && isIterateeCall(string, separator, limit)) {\n separator = limit = undefined;\n }\n limit = limit === undefined ? MAX_ARRAY_LENGTH : limit >>> 0;\n if (!limit) {\n return [];\n }\n string = toString(string);\n if (string && (\n typeof separator == 'string' ||\n (separator != null && !isRegExp(separator))\n )) {\n separator = baseToString(separator);\n if (!separator && hasUnicode(string)) {\n return castSlice(stringToArray(string), 0, limit);\n }\n }\n return string.split(separator, limit);\n }\n\n /**\n * Converts `string` to\n * [start case](https://en.wikipedia.org/wiki/Letter_case#Stylistic_or_specialised_usage).\n *\n * @static\n * @memberOf _\n * @since 3.1.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the start cased string.\n * @example\n *\n * _.startCase('--foo-bar--');\n * // => 'Foo Bar'\n *\n * _.startCase('fooBar');\n * // => 'Foo Bar'\n *\n * _.startCase('__FOO_BAR__');\n * // => 'FOO BAR'\n */\n var startCase = createCompounder(function(result, word, index) {\n return result + (index ? ' ' : '') + upperFirst(word);\n });\n\n /**\n * Checks if `string` starts with the given target string.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {string} [target] The string to search for.\n * @param {number} [position=0] The position to search from.\n * @returns {boolean} Returns `true` if `string` starts with `target`,\n * else `false`.\n * @example\n *\n * _.startsWith('abc', 'a');\n * // => true\n *\n * _.startsWith('abc', 'b');\n * // => false\n *\n * _.startsWith('abc', 'b', 1);\n * // => true\n */\n function startsWith(string, target, position) {\n string = toString(string);\n position = position == null\n ? 0\n : baseClamp(toInteger(position), 0, string.length);\n\n target = baseToString(target);\n return string.slice(position, position + target.length) == target;\n }\n\n /**\n * Creates a compiled template function that can interpolate data properties\n * in \"interpolate\" delimiters, HTML-escape interpolated data properties in\n * \"escape\" delimiters, and execute JavaScript in \"evaluate\" delimiters. Data\n * properties may be accessed as free variables in the template. If a setting\n * object is given, it takes precedence over `_.templateSettings` values.\n *\n * **Note:** In the development build `_.template` utilizes\n * [sourceURLs](http://www.html5rocks.com/en/tutorials/developertools/sourcemaps/#toc-sourceurl)\n * for easier debugging.\n *\n * For more information on precompiling templates see\n * [lodash's custom builds documentation](https://lodash.com/custom-builds).\n *\n * For more information on Chrome extension sandboxes see\n * [Chrome's extensions documentation](https://developer.chrome.com/extensions/sandboxingEval).\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category String\n * @param {string} [string=''] The template string.\n * @param {Object} [options={}] The options object.\n * @param {RegExp} [options.escape=_.templateSettings.escape]\n * The HTML \"escape\" delimiter.\n * @param {RegExp} [options.evaluate=_.templateSettings.evaluate]\n * The \"evaluate\" delimiter.\n * @param {Object} [options.imports=_.templateSettings.imports]\n * An object to import into the template as free variables.\n * @param {RegExp} [options.interpolate=_.templateSettings.interpolate]\n * The \"interpolate\" delimiter.\n * @param {string} [options.sourceURL='lodash.templateSources[n]']\n * The sourceURL of the compiled template.\n * @param {string} [options.variable='obj']\n * The data object variable name.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the compiled template function.\n * @example\n *\n * // Use the \"interpolate\" delimiter to create a compiled template.\n * var compiled = _.template('hello <%= user %>!');\n * compiled({ 'user': 'fred' });\n * // => 'hello fred!'\n *\n * // Use the HTML \"escape\" delimiter to escape data property values.\n * var compiled = _.template('<%- value %>');\n * compiled({ 'value': '